@wertzui/ngx-restworld-client 7.2.0 → 8.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2020/lib/components/restworld-file/restworld-file.component.mjs +57 -0
- package/esm2020/lib/components/restworld-form/restworld-form.component.mjs +188 -0
- package/esm2020/lib/components/restworld-id-navigation/restworld-id-navigation.component.mjs +65 -0
- package/esm2020/lib/components/restworld-image/restworld-image.component.mjs +164 -0
- package/esm2020/lib/components/restworld-inputs/restworld-inputs.mjs +306 -0
- package/esm2020/lib/components/restworld-label/restworld-label.component.mjs +24 -0
- package/esm2020/lib/components/restworld-menu-button/restworld-menu-button.component.mjs +40 -0
- package/esm2020/lib/components/restworld-table/restworld-table.component.mjs +157 -0
- package/esm2020/lib/components/restworld-validation-errors/restworld-validation-errors.component.mjs +21 -0
- package/esm2020/lib/models/o-data.mjs +2 -0
- package/esm2020/lib/models/restworld-image.mjs +2 -0
- package/esm2020/lib/models/restworld-options.mjs +2 -2
- package/esm2020/lib/models/special-properties.mjs +6 -0
- package/esm2020/lib/models/templating.mjs +2 -0
- package/esm2020/lib/restworld-client.module.mjs +83 -25
- package/esm2020/lib/services/o-data.service.mjs +6 -3
- package/esm2020/lib/services/restworld-client-collection.mjs +7 -7
- package/esm2020/lib/services/restworld-client.mjs +40 -29
- package/esm2020/lib/services/settings.service.mjs +5 -5
- package/esm2020/lib/views/restworld-edit-view/restworld-edit-view.component.mjs +24 -255
- package/esm2020/lib/views/restworld-list-view/restworld-list-view.component.mjs +49 -101
- package/esm2020/public-api.mjs +17 -6
- package/fesm2015/wertzui-ngx-restworld-client.mjs +1373 -1017
- package/fesm2015/wertzui-ngx-restworld-client.mjs.map +1 -1
- package/fesm2020/wertzui-ngx-restworld-client.mjs +1322 -978
- package/fesm2020/wertzui-ngx-restworld-client.mjs.map +1 -1
- package/index.d.ts +1 -0
- package/lib/components/restworld-avatar/restworld-avatar.component.d.ts +1 -0
- package/lib/components/restworld-avatar/restworld-avatar.component.d.ts.map +1 -0
- package/lib/{views/restworld-file-view/restworld-file-view.component.d.ts → components/restworld-file/restworld-file.component.d.ts} +4 -3
- package/lib/components/restworld-file/restworld-file.component.d.ts.map +1 -0
- package/lib/components/restworld-form/restworld-form.component.d.ts +53 -0
- package/lib/components/restworld-form/restworld-form.component.d.ts.map +1 -0
- package/lib/components/restworld-id-navigation/restworld-id-navigation.component.d.ts +27 -0
- package/lib/components/restworld-id-navigation/restworld-id-navigation.component.d.ts.map +1 -0
- package/lib/components/restworld-image/restworld-image.component.d.ts +62 -0
- package/lib/components/restworld-image/restworld-image.component.d.ts.map +1 -0
- package/lib/components/restworld-inputs/restworld-inputs.d.ts +146 -0
- package/lib/components/restworld-inputs/restworld-inputs.d.ts.map +1 -0
- package/lib/components/restworld-label/restworld-label.component.d.ts +14 -0
- package/lib/components/restworld-label/restworld-label.component.d.ts.map +1 -0
- package/lib/components/restworld-menu-button/restworld-menu-button.component.d.ts +12 -0
- package/lib/components/restworld-menu-button/restworld-menu-button.component.d.ts.map +1 -0
- package/lib/components/restworld-table/restworld-table.component.d.ts +54 -0
- package/lib/components/restworld-table/restworld-table.component.d.ts.map +1 -0
- package/lib/components/restworld-validation-errors/restworld-validation-errors.component.d.ts +15 -0
- package/lib/components/restworld-validation-errors/restworld-validation-errors.component.d.ts.map +1 -0
- package/lib/constants/link-names.d.ts +1 -0
- package/lib/constants/link-names.d.ts.map +1 -0
- package/lib/models/api-url.d.ts +1 -0
- package/lib/models/api-url.d.ts.map +1 -0
- package/lib/models/client-settings.d.ts +1 -0
- package/lib/models/client-settings.d.ts.map +1 -0
- package/lib/models/o-data.d.ts +7 -0
- package/lib/models/o-data.d.ts.map +1 -0
- package/lib/models/problem-details.d.ts +1 -0
- package/lib/models/problem-details.d.ts.map +1 -0
- package/lib/models/restworld-image.d.ts +28 -0
- package/lib/models/restworld-image.d.ts.map +1 -0
- package/lib/models/restworld-options.d.ts +2 -1
- package/lib/models/restworld-options.d.ts.map +1 -0
- package/lib/models/special-properties.d.ts +9 -0
- package/lib/models/special-properties.d.ts.map +1 -0
- package/lib/models/templating.d.ts +8 -0
- package/lib/models/templating.d.ts.map +1 -0
- package/lib/pipes/as.pipe.d.ts +1 -0
- package/lib/pipes/as.pipe.d.ts.map +1 -0
- package/lib/pipes/safe-url.pipe.d.ts +1 -0
- package/lib/pipes/safe-url.pipe.d.ts.map +1 -0
- package/lib/restworld-client.module.d.ts +45 -37
- package/lib/restworld-client.module.d.ts.map +1 -0
- package/lib/services/avatar-generator.d.ts +1 -0
- package/lib/services/avatar-generator.d.ts.map +1 -0
- package/lib/services/form.service.d.ts +1 -0
- package/lib/services/form.service.d.ts.map +1 -0
- package/lib/services/o-data.service.d.ts +1 -0
- package/lib/services/o-data.service.d.ts.map +1 -0
- package/lib/services/restworld-client-collection.d.ts +9 -8
- package/lib/services/restworld-client-collection.d.ts.map +1 -0
- package/lib/services/restworld-client.d.ts +12 -4
- package/lib/services/restworld-client.d.ts.map +1 -0
- package/lib/services/settings.service.d.ts +3 -2
- package/lib/services/settings.service.d.ts.map +1 -0
- package/lib/views/restworld-edit-view/restworld-edit-view.component.d.ts +16 -68
- package/lib/views/restworld-edit-view/restworld-edit-view.component.d.ts.map +1 -0
- package/lib/views/restworld-list-view/restworld-list-view.component.d.ts +25 -41
- package/lib/views/restworld-list-view/restworld-list-view.component.d.ts.map +1 -0
- package/package.json +6 -6
- package/public-api.d.ts +17 -5
- package/public-api.d.ts.map +1 -0
- package/wertzui-ngx-restworld-client.d.ts.map +1 -0
- package/esm2020/lib/views/restworld-edit-form/restworld-edit-form.component.mjs +0 -233
- package/esm2020/lib/views/restworld-file-view/restworld-file-view.component.mjs +0 -57
- package/esm2020/lib/views/restworld-image-view/restworld-image-view.component.mjs +0 -139
- package/lib/views/restworld-edit-form/restworld-edit-form.component.d.ts +0 -74
- package/lib/views/restworld-image-view/restworld-image-view.component.d.ts +0 -57
|
@@ -0,0 +1,306 @@
|
|
|
1
|
+
import { Component, ContentChild, Input } from '@angular/core';
|
|
2
|
+
import { ControlContainer, FormGroupDirective } from '@angular/forms';
|
|
3
|
+
import { NumberTemplate, PropertyType } from '@wertzui/ngx-hal-client';
|
|
4
|
+
import { ProblemDetails } from '../../models/problem-details';
|
|
5
|
+
import { PropertyWithOptions, PropertyWithImage } from '../../models/special-properties';
|
|
6
|
+
import * as i0 from "@angular/core";
|
|
7
|
+
import * as i1 from "../restworld-label/restworld-label.component";
|
|
8
|
+
import * as i2 from "@angular/common";
|
|
9
|
+
import * as i3 from "../restworld-validation-errors/restworld-validation-errors.component";
|
|
10
|
+
import * as i4 from "../../pipes/as.pipe";
|
|
11
|
+
import * as i5 from "@angular/forms";
|
|
12
|
+
import * as i6 from "../../services/form.service";
|
|
13
|
+
import * as i7 from "primeng/button";
|
|
14
|
+
import * as i8 from "primeng/ripple";
|
|
15
|
+
import * as i9 from "@angular/cdk/drag-drop";
|
|
16
|
+
import * as i10 from "primeng/api";
|
|
17
|
+
import * as i11 from "../../services/restworld-client-collection";
|
|
18
|
+
import * as i12 from "primeng/tooltip";
|
|
19
|
+
import * as i13 from "primeng/dropdown";
|
|
20
|
+
import * as i14 from "primeng/multiselect";
|
|
21
|
+
import * as i15 from "primeng/inputtext";
|
|
22
|
+
import * as i16 from "primeng/inputnumber";
|
|
23
|
+
import * as i17 from "primeng/calendar";
|
|
24
|
+
import * as i18 from "primeng/checkbox";
|
|
25
|
+
import * as i19 from "primeng/tristatecheckbox";
|
|
26
|
+
import * as i20 from "../restworld-image/restworld-image.component";
|
|
27
|
+
import * as i21 from "../restworld-file/restworld-file.component";
|
|
28
|
+
/**
|
|
29
|
+
* A form element with a label that is automatically created from a property in a form template.
|
|
30
|
+
* This may also be a complex object or a collection in which case multiple and nested input elements may be rendered.
|
|
31
|
+
* If you want a form element without a label, use RestWorldFormInput <rw-form-input>.
|
|
32
|
+
*/
|
|
33
|
+
export class RestWorldFormElementComponent {
|
|
34
|
+
}
|
|
35
|
+
RestWorldFormElementComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.0.3", ngImport: i0, type: RestWorldFormElementComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
36
|
+
RestWorldFormElementComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.0.3", type: RestWorldFormElementComponent, selector: "rw-form-element", inputs: { property: "property", apiName: "apiName" }, ngImport: i0, template: "<div class=\"grid field\">\r\n <rw-label [property]=\"property\" class=\"col-12 md:col-2 flex align-items-center\"></rw-label>\r\n <rw-input [apiName]=\"apiName\" [property]=\"property\" class=\"col-12 md:col-10\"></rw-input>\r\n</div>\r\n", styles: [""], dependencies: [{ kind: "component", type: i0.forwardRef(function () { return RestWorldInputComponent; }), selector: "rw-input", inputs: ["property", "apiName"] }, { kind: "component", type: i0.forwardRef(function () { return i1.RestWorldLabelComponent; }), selector: "rw-label", inputs: ["property"] }], viewProviders: [{ provide: ControlContainer, useExisting: FormGroupDirective }] });
|
|
37
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.3", ngImport: i0, type: RestWorldFormElementComponent, decorators: [{
|
|
38
|
+
type: Component,
|
|
39
|
+
args: [{ selector: 'rw-form-element', viewProviders: [{ provide: ControlContainer, useExisting: FormGroupDirective }], template: "<div class=\"grid field\">\r\n <rw-label [property]=\"property\" class=\"col-12 md:col-2 flex align-items-center\"></rw-label>\r\n <rw-input [apiName]=\"apiName\" [property]=\"property\" class=\"col-12 md:col-10\"></rw-input>\r\n</div>\r\n" }]
|
|
40
|
+
}], propDecorators: { property: [{
|
|
41
|
+
type: Input
|
|
42
|
+
}], apiName: [{
|
|
43
|
+
type: Input
|
|
44
|
+
}] } });
|
|
45
|
+
/**
|
|
46
|
+
* A form input element that is automatically created from a property in a form template.
|
|
47
|
+
* This may also be a complex object or a collection in which case multiple and nested input elements may be rendered.
|
|
48
|
+
* If you also want a label, use RestWorldFormElement <rw-form-element>.
|
|
49
|
+
* You can also use one of the different RestWorldInput... <rw-input-...> elements to render a specific input,
|
|
50
|
+
* but it is advised to control the rendered input through the passed in property.
|
|
51
|
+
*/
|
|
52
|
+
export class RestWorldInputComponent {
|
|
53
|
+
get PropertyType() {
|
|
54
|
+
return PropertyType;
|
|
55
|
+
}
|
|
56
|
+
get PropertyWithOptions() {
|
|
57
|
+
return PropertyWithOptions;
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
RestWorldInputComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.0.3", ngImport: i0, type: RestWorldInputComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
61
|
+
RestWorldInputComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.0.3", type: RestWorldInputComponent, selector: "rw-input", inputs: { property: "property", apiName: "apiName" }, ngImport: i0, template: "<rw-input-dropdown *ngIf=\"property.options\" [apiName]=\"apiName\" [property]=\"property | as:PropertyWithOptions\"></rw-input-dropdown>\r\n\r\n<ng-container *ngIf=\"!property.options\">\r\n <ng-container [ngSwitch]=\"property.type\">\r\n <rw-input-object *ngSwitchCase=\"PropertyType.Object\" [apiName]=\"apiName\" [property]=\"property\"></rw-input-object>\r\n <rw-input-collection *ngSwitchCase=\"PropertyType.Collection\" [apiName]=\"apiName\" [property]=\"property\"></rw-input-collection>\r\n <rw-input-simple *ngSwitchDefault [property]=\"property\"></rw-input-simple>\r\n </ng-container>\r\n</ng-container>\r\n\r\n<rw-validation-errors [property]=\"property\"></rw-validation-errors>", styles: [""], dependencies: [{ kind: "directive", type: i0.forwardRef(function () { return i2.NgIf; }), selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i0.forwardRef(function () { return i2.NgSwitch; }), selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i0.forwardRef(function () { return i2.NgSwitchCase; }), selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "directive", type: i0.forwardRef(function () { return i2.NgSwitchDefault; }), selector: "[ngSwitchDefault]" }, { kind: "component", type: i0.forwardRef(function () { return RestWorldInputDropdownComponent; }), selector: "rw-input-dropdown", inputs: ["property", "apiName"] }, { kind: "component", type: i0.forwardRef(function () { return RestWorldInputCollectionComponent; }), selector: "rw-input-collection", inputs: ["property", "apiName"] }, { kind: "component", type: i0.forwardRef(function () { return RestWorldInputObjectComponent; }), selector: "rw-input-object", inputs: ["property", "apiName"] }, { kind: "component", type: i0.forwardRef(function () { return RestWorldInputSimpleComponent; }), selector: "rw-input-simple", inputs: ["property"] }, { kind: "component", type: i0.forwardRef(function () { return i3.RestWorldValidationErrorsComponent; }), selector: "rw-validation-errors", inputs: ["property", "form"] }, { kind: "pipe", type: i0.forwardRef(function () { return i4.AsPipe; }), name: "as" }], viewProviders: [{ provide: ControlContainer, useExisting: FormGroupDirective }] });
|
|
62
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.3", ngImport: i0, type: RestWorldInputComponent, decorators: [{
|
|
63
|
+
type: Component,
|
|
64
|
+
args: [{ selector: 'rw-input', viewProviders: [{ provide: ControlContainer, useExisting: FormGroupDirective }], template: "<rw-input-dropdown *ngIf=\"property.options\" [apiName]=\"apiName\" [property]=\"property | as:PropertyWithOptions\"></rw-input-dropdown>\r\n\r\n<ng-container *ngIf=\"!property.options\">\r\n <ng-container [ngSwitch]=\"property.type\">\r\n <rw-input-object *ngSwitchCase=\"PropertyType.Object\" [apiName]=\"apiName\" [property]=\"property\"></rw-input-object>\r\n <rw-input-collection *ngSwitchCase=\"PropertyType.Collection\" [apiName]=\"apiName\" [property]=\"property\"></rw-input-collection>\r\n <rw-input-simple *ngSwitchDefault [property]=\"property\"></rw-input-simple>\r\n </ng-container>\r\n</ng-container>\r\n\r\n<rw-validation-errors [property]=\"property\"></rw-validation-errors>" }]
|
|
65
|
+
}], propDecorators: { property: [{
|
|
66
|
+
type: Input
|
|
67
|
+
}], apiName: [{
|
|
68
|
+
type: Input
|
|
69
|
+
}] } });
|
|
70
|
+
/**
|
|
71
|
+
* A collection that is automatically created from the given property.
|
|
72
|
+
* The collection supports drag & drop to re order the elements and can also be nested.
|
|
73
|
+
* It is advised to use RestWorldInputComponent <rw-input> and control the rendered inputs with the passed in property
|
|
74
|
+
* instead of using this component directly.
|
|
75
|
+
*/
|
|
76
|
+
export class RestWorldInputCollectionComponent {
|
|
77
|
+
constructor(_controlContainer, _formService, _changeDetectorRef) {
|
|
78
|
+
this._controlContainer = _controlContainer;
|
|
79
|
+
this._formService = _formService;
|
|
80
|
+
this._changeDetectorRef = _changeDetectorRef;
|
|
81
|
+
this._templates = [];
|
|
82
|
+
}
|
|
83
|
+
get templates() {
|
|
84
|
+
return this._templates;
|
|
85
|
+
}
|
|
86
|
+
get defaultTemplate() {
|
|
87
|
+
if (this._defaultTemplate === undefined)
|
|
88
|
+
throw new Error("No default template found.");
|
|
89
|
+
return this._defaultTemplate;
|
|
90
|
+
}
|
|
91
|
+
get innerFormArray() {
|
|
92
|
+
if (this._innerFormArray === undefined)
|
|
93
|
+
throw new Error("formGroup is not set.");
|
|
94
|
+
return this._innerFormArray;
|
|
95
|
+
}
|
|
96
|
+
ngOnInit() {
|
|
97
|
+
const formGroup = this._controlContainer.control;
|
|
98
|
+
this._innerFormArray = formGroup.controls[this.property.name];
|
|
99
|
+
this._templates = RestWorldInputCollectionComponent.getCollectionEntryTemplates(this.property);
|
|
100
|
+
this._defaultTemplate = this.property._templates.default;
|
|
101
|
+
}
|
|
102
|
+
static getCollectionEntryTemplates(property) {
|
|
103
|
+
if (!property)
|
|
104
|
+
return [];
|
|
105
|
+
return Object.entries(property._templates)
|
|
106
|
+
.filter(([key, value]) => Number.isInteger(Number.parseInt(key)) && Number.isInteger(Number.parseInt(value.title ?? "")))
|
|
107
|
+
.map(([, value]) => new NumberTemplate(value));
|
|
108
|
+
}
|
|
109
|
+
addNewItemToCollection() {
|
|
110
|
+
const maxIndex = Math.max(...Object.keys(this.templates)
|
|
111
|
+
.map(key => Number.parseInt(key))
|
|
112
|
+
.filter(key => Number.isSafeInteger(key)));
|
|
113
|
+
const nextIndex = maxIndex < 0 ? 0 : maxIndex + 1;
|
|
114
|
+
const copiedTemplateDto = JSON.parse(JSON.stringify(this.defaultTemplate));
|
|
115
|
+
const copiedTemplate = new NumberTemplate(copiedTemplateDto);
|
|
116
|
+
copiedTemplate.title = nextIndex;
|
|
117
|
+
this.templates[copiedTemplate.title] = copiedTemplate;
|
|
118
|
+
this.innerFormArray.push(this._formService.createFormGroupFromTemplate(this.defaultTemplate));
|
|
119
|
+
}
|
|
120
|
+
deleteItemFromCollection(template) {
|
|
121
|
+
delete this.templates[template.title];
|
|
122
|
+
this.innerFormArray.removeAt(template.title);
|
|
123
|
+
}
|
|
124
|
+
collectionItemDropped($event) {
|
|
125
|
+
const previousIndex = $event.previousIndex;
|
|
126
|
+
const currentIndex = $event.currentIndex;
|
|
127
|
+
const movementDirection = currentIndex > previousIndex ? 1 : -1;
|
|
128
|
+
// Move in FormArray
|
|
129
|
+
// We do not need to move the item in the _templates object
|
|
130
|
+
const movedControl = this.innerFormArray.at(previousIndex);
|
|
131
|
+
for (let i = previousIndex; i * movementDirection < currentIndex * movementDirection; i = i + movementDirection) {
|
|
132
|
+
this.innerFormArray.setControl(i, this.innerFormArray.at(i + movementDirection));
|
|
133
|
+
}
|
|
134
|
+
this.innerFormArray.setControl(currentIndex, movedControl);
|
|
135
|
+
this._changeDetectorRef.markForCheck();
|
|
136
|
+
}
|
|
137
|
+
}
|
|
138
|
+
RestWorldInputCollectionComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.0.3", ngImport: i0, type: RestWorldInputCollectionComponent, deps: [{ token: i5.ControlContainer }, { token: i6.FormService }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
139
|
+
RestWorldInputCollectionComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.0.3", type: RestWorldInputCollectionComponent, selector: "rw-input-collection", inputs: { property: "property", apiName: "apiName" }, queries: [{ propertyName: "inputCollectionRef", first: true, predicate: ["inputCollection"], descendants: true }], ngImport: i0, template: "<div class=\"flex align-items-center\">\n <div class=\"brace\">\n </div>\n <div class=\"w-full\" cdkDropList (cdkDropListDropped)=\"collectionItemDropped($event)\">\n <div *ngFor=\"let template of templates\" class=\"flex align-items-center\" cdkDrag>\n <i class=\"fas fa-grip-lines\" cdkDragHandle></i>\n <div class=\"brace\">\n </div>\n <div class=\"w-full flex justify-content-end\">\n <rw-input-template [formGroup]=\"innerFormArray.controls[template.title]\" [template]=\"defaultTemplate\" [apiName]=\"apiName\" class=\"w-full\"></rw-input-template>\n <button pButton pRipple type=\"button\" icon=\"fas fa-trash\" class=\"p-button-outlined p-button-danger ml-2 mb-3\" (click)=\"deleteItemFromCollection(template)\"></button>\n </div>\n </div>\n <div class=\"flex justify-content-end w-full\">\n <button pButton pRipple type=\"button\" icon=\"fas fa-plus\" class=\"p-button-outlined p-button-info\" (click)=\"addNewItemToCollection()\"></button>\n </div>\n </div>\n</div>", styles: [".cdk-drag-handle{cursor:move}.cdk-drag-preview{background-color:#ffffffd0;border:2px dashed rgb(206,212,218);cursor:move}.cdk-drag-placeholder{border:2px dashed rgb(206,212,218);margin:-2px}.brace{align-self:stretch;margin:.2rem .5rem;border-left:1px solid rgb(206,212,218);border-top:1px solid rgb(206,212,218);border-bottom:1px solid rgb(206,212,218);width:1rem}\n"], dependencies: [{ kind: "directive", type: i0.forwardRef(function () { return i2.NgForOf; }), selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i0.forwardRef(function () { return i5.NgControlStatusGroup; }), selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i0.forwardRef(function () { return i5.FormGroupDirective; }), selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i0.forwardRef(function () { return i7.ButtonDirective; }), selector: "[pButton]", inputs: ["iconPos", "loadingIcon", "label", "icon", "loading"] }, { kind: "directive", type: i0.forwardRef(function () { return i8.Ripple; }), selector: "[pRipple]" }, { kind: "directive", type: i0.forwardRef(function () { return i9.CdkDropList; }), selector: "[cdkDropList], cdk-drop-list", inputs: ["cdkDropListConnectedTo", "cdkDropListData", "cdkDropListOrientation", "id", "cdkDropListLockAxis", "cdkDropListDisabled", "cdkDropListSortingDisabled", "cdkDropListEnterPredicate", "cdkDropListSortPredicate", "cdkDropListAutoScrollDisabled", "cdkDropListAutoScrollStep"], outputs: ["cdkDropListDropped", "cdkDropListEntered", "cdkDropListExited", "cdkDropListSorted"], exportAs: ["cdkDropList"] }, { kind: "directive", type: i0.forwardRef(function () { return i9.CdkDrag; }), selector: "[cdkDrag]", inputs: ["cdkDragData", "cdkDragLockAxis", "cdkDragRootElement", "cdkDragBoundary", "cdkDragStartDelay", "cdkDragFreeDragPosition", "cdkDragDisabled", "cdkDragConstrainPosition", "cdkDragPreviewClass", "cdkDragPreviewContainer"], outputs: ["cdkDragStarted", "cdkDragReleased", "cdkDragEnded", "cdkDragEntered", "cdkDragExited", "cdkDragDropped", "cdkDragMoved"], exportAs: ["cdkDrag"] }, { kind: "directive", type: i0.forwardRef(function () { return i9.CdkDragHandle; }), selector: "[cdkDragHandle]", inputs: ["cdkDragHandleDisabled"] }, { kind: "component", type: i0.forwardRef(function () { return RestWorldInputTemplateComponent; }), selector: "rw-input-template", inputs: ["apiName", "template"] }], viewProviders: [{ provide: ControlContainer, useExisting: FormGroupDirective }] });
|
|
140
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.3", ngImport: i0, type: RestWorldInputCollectionComponent, decorators: [{
|
|
141
|
+
type: Component,
|
|
142
|
+
args: [{ selector: 'rw-input-collection', viewProviders: [{ provide: ControlContainer, useExisting: FormGroupDirective }], template: "<div class=\"flex align-items-center\">\n <div class=\"brace\">\n </div>\n <div class=\"w-full\" cdkDropList (cdkDropListDropped)=\"collectionItemDropped($event)\">\n <div *ngFor=\"let template of templates\" class=\"flex align-items-center\" cdkDrag>\n <i class=\"fas fa-grip-lines\" cdkDragHandle></i>\n <div class=\"brace\">\n </div>\n <div class=\"w-full flex justify-content-end\">\n <rw-input-template [formGroup]=\"innerFormArray.controls[template.title]\" [template]=\"defaultTemplate\" [apiName]=\"apiName\" class=\"w-full\"></rw-input-template>\n <button pButton pRipple type=\"button\" icon=\"fas fa-trash\" class=\"p-button-outlined p-button-danger ml-2 mb-3\" (click)=\"deleteItemFromCollection(template)\"></button>\n </div>\n </div>\n <div class=\"flex justify-content-end w-full\">\n <button pButton pRipple type=\"button\" icon=\"fas fa-plus\" class=\"p-button-outlined p-button-info\" (click)=\"addNewItemToCollection()\"></button>\n </div>\n </div>\n</div>", styles: [".cdk-drag-handle{cursor:move}.cdk-drag-preview{background-color:#ffffffd0;border:2px dashed rgb(206,212,218);cursor:move}.cdk-drag-placeholder{border:2px dashed rgb(206,212,218);margin:-2px}.brace{align-self:stretch;margin:.2rem .5rem;border-left:1px solid rgb(206,212,218);border-top:1px solid rgb(206,212,218);border-bottom:1px solid rgb(206,212,218);width:1rem}\n"] }]
|
|
143
|
+
}], ctorParameters: function () { return [{ type: i5.ControlContainer }, { type: i6.FormService }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { property: [{
|
|
144
|
+
type: Input
|
|
145
|
+
}], apiName: [{
|
|
146
|
+
type: Input
|
|
147
|
+
}], inputCollectionRef: [{
|
|
148
|
+
type: ContentChild,
|
|
149
|
+
args: ['inputCollection', { static: false }]
|
|
150
|
+
}] } });
|
|
151
|
+
/**
|
|
152
|
+
* A dropdown that is automatically created from the given property.
|
|
153
|
+
* The dropdown supports searching through a RESTWorld list endpoint on the backend.
|
|
154
|
+
* It is advised to use RestWorldInputComponent <rw-input> and control the rendered inputs with the passed in property
|
|
155
|
+
* instead of using this component directly.
|
|
156
|
+
*/
|
|
157
|
+
export class RestWorldInputDropdownComponent {
|
|
158
|
+
constructor(_messageService, _clients) {
|
|
159
|
+
this._messageService = _messageService;
|
|
160
|
+
this._clients = _clients;
|
|
161
|
+
}
|
|
162
|
+
getDropdownElementTooltip(resource, keysToExclude) {
|
|
163
|
+
const tooltip = Object.entries(resource)
|
|
164
|
+
.filter(([key]) => !(key.startsWith('_') || ['createdAt', 'createdBy', 'lastChangedAt', 'lastChangedBy', 'timestamp'].includes(key) || keysToExclude?.includes(key)))
|
|
165
|
+
.reduce((prev, [key, value], index) => `${prev}${index === 0 ? '' : '\n'}${key}: ${RestWorldInputDropdownComponent.jsonStringifyWithElipsis(value)}`, '');
|
|
166
|
+
return tooltip;
|
|
167
|
+
}
|
|
168
|
+
async onOptionsFiltered(property, event) {
|
|
169
|
+
const options = property?.options;
|
|
170
|
+
if (!options?.link?.href || !event.filter || event.filter === '')
|
|
171
|
+
return;
|
|
172
|
+
const templatedUri = options.link.href;
|
|
173
|
+
let filter = `contains(${options.promptField}, '${event.filter}')`;
|
|
174
|
+
if (options.valueField?.toLowerCase() === 'id' && !Number.isNaN(Number.parseInt(event.filter)))
|
|
175
|
+
filter = `(${options.valueField} eq ${event.filter}) or (${filter})`;
|
|
176
|
+
const response = await this.getClient().getListByUri(templatedUri, { $filter: filter, $top: 10 });
|
|
177
|
+
if (!response.ok || ProblemDetails.isProblemDetails(response.body) || !response.body) {
|
|
178
|
+
const message = `An error occurred while getting the filtered items.`;
|
|
179
|
+
this._messageService.add({ severity: 'error', summary: 'Error', detail: message, data: response, sticky: true });
|
|
180
|
+
return;
|
|
181
|
+
}
|
|
182
|
+
const items = response.body._embedded.items;
|
|
183
|
+
options.inline = items;
|
|
184
|
+
}
|
|
185
|
+
getClient() {
|
|
186
|
+
if (!this.apiName)
|
|
187
|
+
throw new Error('Cannot get a client, because the apiName is not set.');
|
|
188
|
+
return this._clients.getClient(this.apiName);
|
|
189
|
+
}
|
|
190
|
+
static jsonStringifyWithElipsis(value) {
|
|
191
|
+
const maxLength = 200;
|
|
192
|
+
const end = 10;
|
|
193
|
+
const start = maxLength - end - 2;
|
|
194
|
+
const json = JSON.stringify(value);
|
|
195
|
+
const shortened = json.length > maxLength ? json.substring(0, start) + '…' + json.substring(json.length - end) : json;
|
|
196
|
+
return shortened;
|
|
197
|
+
}
|
|
198
|
+
}
|
|
199
|
+
RestWorldInputDropdownComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.0.3", ngImport: i0, type: RestWorldInputDropdownComponent, deps: [{ token: i10.MessageService }, { token: i11.RestWorldClientCollection }], target: i0.ɵɵFactoryTarget.Component });
|
|
200
|
+
RestWorldInputDropdownComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.0.3", type: RestWorldInputDropdownComponent, selector: "rw-input-dropdown", inputs: { property: "property", apiName: "apiName" }, queries: [{ propertyName: "inputOptionsSingleRef", first: true, predicate: ["inputOptionsSingle"], descendants: true }, { propertyName: "inputOptionsMultipleRef", first: true, predicate: ["inputOptionsMultiple"], descendants: true }], ngImport: i0, template: "<ng-template #defaultInputOptionsSingle let-property=\"property\" let-template=\"template\">\n <p-dropdown \n [formControlName]=\"property.name\" \n [id]=\"property.name\" \n [options]=\"property.options.inline\" \n [filterBy]=\"(property.options.promptField ?? 'prompt') + ',' + (property.options.valueField ?? 'value')\" \n [optionValue]=\"property.options.valueField ?? 'value'\" \n [readonly]=\"property.readOnly\" \n [required]=\"property.required || property.options.minItems > 0\" \n [filter]=\"true\" \n [autoDisplayFirst]=\"false\" \n [showClear]=\"!property.required || property.options.minItems <= 0\" \n (onFilter)=\"onOptionsFiltered(property, $event)\" \n styleClass=\"w-full\" \n [filterPlaceholder]=\"property?.options?.link?.href ? 'search for more results' : ''\">\n <ng-template let-item pTemplate=\"selectedItem\">\n <span [pTooltip]=\"getDropdownElementTooltip(item, [property.options.promptField ?? 'prompt', property.options.valueField ?? 'value'])\">{{item[property.options.promptField ?? 'prompt']}} ({{item[property.options.valueField ?? 'value']}})</span>\n </ng-template>\n <ng-template let-item pTemplate=\"item\">\n <span [pTooltip]=\"getDropdownElementTooltip(item, [property.options.promptField ?? 'prompt', property.options.valueField ?? 'value'])\">{{item[property.options.promptField ?? 'prompt']}} ({{item[property.options.valueField ?? 'value']}})</span>\n </ng-template>\n </p-dropdown>\n</ng-template>\n<ng-container *ngIf=\"!property.options.maxItems || property.options.maxItems == 1\">\n <ng-container *ngTemplateOutlet=\"inputOptionsSingleRef ?? defaultInputOptionsSingle; context: { property: property, apiName: apiName }\"></ng-container>\n</ng-container>\n\n<ng-template #defaultInputOptionsMultiple let-property=\"property\" let-template=\"template\">\n <p-multiSelect \n [formControlName]=\"property.name\" \n [id]=\"property.name\" \n [options]=\"property.options.inline\" \n [optionLabel]=\"property.options.promptField ?? 'prompt'\" \n [optionValue]=\"property.options.valueField ?? 'value'\" \n [readonly]=\"property.readOnly\" \n [selectionLimit]=\"property.options.maxItems\" \n [required]=\"property.required || property.options.minItems > 0\"></p-multiSelect>\n</ng-template>\n<ng-container *ngIf=\"(property.options.maxItems ?? 0) > 1\">\n <ng-container *ngTemplateOutlet=\"inputOptionsMultipleRef ?? defaultInputOptionsMultiple; context: { property: property, apiName: apiName }\"></ng-container>\n</ng-container>", styles: [""], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i5.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i5.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i5.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "directive", type: i10.PrimeTemplate, selector: "[pTemplate]", inputs: ["type", "pTemplate"] }, { kind: "directive", type: i12.Tooltip, selector: "[pTooltip]", inputs: ["tooltipPosition", "tooltipEvent", "appendTo", "positionStyle", "tooltipStyleClass", "tooltipZIndex", "escape", "showDelay", "hideDelay", "life", "positionTop", "positionLeft", "fitContent", "pTooltip", "tooltipDisabled", "tooltipOptions"] }, { kind: "component", type: i13.Dropdown, selector: "p-dropdown", inputs: ["scrollHeight", "filter", "name", "style", "panelStyle", "styleClass", "panelStyleClass", "readonly", "required", "editable", "appendTo", "tabindex", "placeholder", "filterPlaceholder", "filterLocale", "inputId", "selectId", "dataKey", "filterBy", "autofocus", "resetFilterOnHide", "dropdownIcon", "optionLabel", "optionValue", "optionDisabled", "optionGroupLabel", "optionGroupChildren", "autoDisplayFirst", "group", "showClear", "emptyFilterMessage", "emptyMessage", "lazy", "virtualScroll", "virtualScrollItemSize", "virtualScrollOptions", "overlayOptions", "ariaFilterLabel", "ariaLabel", "ariaLabelledBy", "filterMatchMode", "maxlength", "tooltip", "tooltipPosition", "tooltipPositionStyle", "tooltipStyleClass", "autofocusFilter", "overlayDirection", "disabled", "itemSize", "autoZIndex", "baseZIndex", "showTransitionOptions", "hideTransitionOptions", "options", "filterValue"], outputs: ["onChange", "onFilter", "onFocus", "onBlur", "onClick", "onShow", "onHide", "onClear", "onLazyLoad"] }, { kind: "component", type: i14.MultiSelect, selector: "p-multiSelect", inputs: ["style", "styleClass", "panelStyle", "panelStyleClass", "inputId", "disabled", "readonly", "group", "filter", "filterPlaceHolder", "filterLocale", "overlayVisible", "tabindex", "appendTo", "dataKey", "name", "label", "ariaLabelledBy", "displaySelectedLabel", "maxSelectedLabels", "selectionLimit", "selectedItemsLabel", "showToggleAll", "emptyFilterMessage", "emptyMessage", "resetFilterOnHide", "dropdownIcon", "optionLabel", "optionValue", "optionDisabled", "optionGroupLabel", "optionGroupChildren", "showHeader", "filterBy", "scrollHeight", "lazy", "virtualScroll", "virtualScrollItemSize", "virtualScrollOptions", "overlayOptions", "ariaFilterLabel", "filterMatchMode", "tooltip", "tooltipPosition", "tooltipPositionStyle", "tooltipStyleClass", "autofocusFilter", "display", "autocomplete", "showClear", "autoZIndex", "baseZIndex", "showTransitionOptions", "hideTransitionOptions", "defaultLabel", "placeholder", "options", "filterValue", "itemSize"], outputs: ["onChange", "onFilter", "onFocus", "onBlur", "onClick", "onClear", "onPanelShow", "onPanelHide", "onLazyLoad"] }], viewProviders: [{ provide: ControlContainer, useExisting: FormGroupDirective }] });
|
|
201
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.3", ngImport: i0, type: RestWorldInputDropdownComponent, decorators: [{
|
|
202
|
+
type: Component,
|
|
203
|
+
args: [{ selector: 'rw-input-dropdown', viewProviders: [{ provide: ControlContainer, useExisting: FormGroupDirective }], template: "<ng-template #defaultInputOptionsSingle let-property=\"property\" let-template=\"template\">\n <p-dropdown \n [formControlName]=\"property.name\" \n [id]=\"property.name\" \n [options]=\"property.options.inline\" \n [filterBy]=\"(property.options.promptField ?? 'prompt') + ',' + (property.options.valueField ?? 'value')\" \n [optionValue]=\"property.options.valueField ?? 'value'\" \n [readonly]=\"property.readOnly\" \n [required]=\"property.required || property.options.minItems > 0\" \n [filter]=\"true\" \n [autoDisplayFirst]=\"false\" \n [showClear]=\"!property.required || property.options.minItems <= 0\" \n (onFilter)=\"onOptionsFiltered(property, $event)\" \n styleClass=\"w-full\" \n [filterPlaceholder]=\"property?.options?.link?.href ? 'search for more results' : ''\">\n <ng-template let-item pTemplate=\"selectedItem\">\n <span [pTooltip]=\"getDropdownElementTooltip(item, [property.options.promptField ?? 'prompt', property.options.valueField ?? 'value'])\">{{item[property.options.promptField ?? 'prompt']}} ({{item[property.options.valueField ?? 'value']}})</span>\n </ng-template>\n <ng-template let-item pTemplate=\"item\">\n <span [pTooltip]=\"getDropdownElementTooltip(item, [property.options.promptField ?? 'prompt', property.options.valueField ?? 'value'])\">{{item[property.options.promptField ?? 'prompt']}} ({{item[property.options.valueField ?? 'value']}})</span>\n </ng-template>\n </p-dropdown>\n</ng-template>\n<ng-container *ngIf=\"!property.options.maxItems || property.options.maxItems == 1\">\n <ng-container *ngTemplateOutlet=\"inputOptionsSingleRef ?? defaultInputOptionsSingle; context: { property: property, apiName: apiName }\"></ng-container>\n</ng-container>\n\n<ng-template #defaultInputOptionsMultiple let-property=\"property\" let-template=\"template\">\n <p-multiSelect \n [formControlName]=\"property.name\" \n [id]=\"property.name\" \n [options]=\"property.options.inline\" \n [optionLabel]=\"property.options.promptField ?? 'prompt'\" \n [optionValue]=\"property.options.valueField ?? 'value'\" \n [readonly]=\"property.readOnly\" \n [selectionLimit]=\"property.options.maxItems\" \n [required]=\"property.required || property.options.minItems > 0\"></p-multiSelect>\n</ng-template>\n<ng-container *ngIf=\"(property.options.maxItems ?? 0) > 1\">\n <ng-container *ngTemplateOutlet=\"inputOptionsMultipleRef ?? defaultInputOptionsMultiple; context: { property: property, apiName: apiName }\"></ng-container>\n</ng-container>" }]
|
|
204
|
+
}], ctorParameters: function () { return [{ type: i10.MessageService }, { type: i11.RestWorldClientCollection }]; }, propDecorators: { property: [{
|
|
205
|
+
type: Input
|
|
206
|
+
}], apiName: [{
|
|
207
|
+
type: Input
|
|
208
|
+
}], inputOptionsSingleRef: [{
|
|
209
|
+
type: ContentChild,
|
|
210
|
+
args: ['inputOptionsSingle', { static: false }]
|
|
211
|
+
}], inputOptionsMultipleRef: [{
|
|
212
|
+
type: ContentChild,
|
|
213
|
+
args: ['inputOptionsMultiple', { static: false }]
|
|
214
|
+
}] } });
|
|
215
|
+
/**
|
|
216
|
+
* A complex object with multiple properties that is automatically created from the given property.
|
|
217
|
+
* The object can also be nested.
|
|
218
|
+
* It is advised to use RestWorldInputComponent <rw-input> and control the rendered inputs with the passed in property
|
|
219
|
+
* instead of using this component directly.
|
|
220
|
+
*/
|
|
221
|
+
export class RestWorldInputObjectComponent {
|
|
222
|
+
constructor(_controlContainer) {
|
|
223
|
+
this._controlContainer = _controlContainer;
|
|
224
|
+
}
|
|
225
|
+
get innerFormGroup() {
|
|
226
|
+
if (this._innerFormGroup === undefined)
|
|
227
|
+
throw new Error("formGroup is not set.");
|
|
228
|
+
return this._innerFormGroup;
|
|
229
|
+
}
|
|
230
|
+
ngOnInit() {
|
|
231
|
+
const formGroup = this._controlContainer.control;
|
|
232
|
+
this._innerFormGroup = formGroup.controls[this.property.name];
|
|
233
|
+
}
|
|
234
|
+
}
|
|
235
|
+
RestWorldInputObjectComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.0.3", ngImport: i0, type: RestWorldInputObjectComponent, deps: [{ token: i5.ControlContainer }], target: i0.ɵɵFactoryTarget.Component });
|
|
236
|
+
RestWorldInputObjectComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.0.3", type: RestWorldInputObjectComponent, selector: "rw-input-object", inputs: { property: "property", apiName: "apiName" }, queries: [{ propertyName: "inputObjectRef", first: true, predicate: ["inputObject"], descendants: true }], ngImport: i0, template: "<ng-template #defaultInputObject let-property=\"property\" let-template=\"template\">\n <div class=\"flex align-items-center\">\n <div class=\"brace\">\n </div>\n <div class=\"w-full\">\n <rw-input-template [formGroup]=\"innerFormGroup\" [template]=\"property._templates.default\" [apiName]=\"apiName\"></rw-input-template>\n </div>\n </div>\n</ng-template>\n<ng-container>\n <ng-container *ngTemplateOutlet=\"inputObjectRef || defaultInputObject; context: { property: property, innerFormGroup: innerFormGroup, apiName: apiName }\"></ng-container>\n</ng-container>", styles: [".brace{align-self:stretch;margin:.2rem .5rem;border-left:1px solid rgb(206,212,218);border-top:1px solid rgb(206,212,218);border-bottom:1px solid rgb(206,212,218);width:1rem}\n"], dependencies: [{ kind: "directive", type: i0.forwardRef(function () { return i2.NgTemplateOutlet; }), selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i0.forwardRef(function () { return i5.NgControlStatusGroup; }), selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i0.forwardRef(function () { return i5.FormGroupDirective; }), selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "component", type: i0.forwardRef(function () { return RestWorldInputTemplateComponent; }), selector: "rw-input-template", inputs: ["apiName", "template"] }], viewProviders: [{ provide: ControlContainer, useExisting: FormGroupDirective }] });
|
|
237
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.3", ngImport: i0, type: RestWorldInputObjectComponent, decorators: [{
|
|
238
|
+
type: Component,
|
|
239
|
+
args: [{ selector: 'rw-input-object', viewProviders: [{ provide: ControlContainer, useExisting: FormGroupDirective }], template: "<ng-template #defaultInputObject let-property=\"property\" let-template=\"template\">\n <div class=\"flex align-items-center\">\n <div class=\"brace\">\n </div>\n <div class=\"w-full\">\n <rw-input-template [formGroup]=\"innerFormGroup\" [template]=\"property._templates.default\" [apiName]=\"apiName\"></rw-input-template>\n </div>\n </div>\n</ng-template>\n<ng-container>\n <ng-container *ngTemplateOutlet=\"inputObjectRef || defaultInputObject; context: { property: property, innerFormGroup: innerFormGroup, apiName: apiName }\"></ng-container>\n</ng-container>", styles: [".brace{align-self:stretch;margin:.2rem .5rem;border-left:1px solid rgb(206,212,218);border-top:1px solid rgb(206,212,218);border-bottom:1px solid rgb(206,212,218);width:1rem}\n"] }]
|
|
240
|
+
}], ctorParameters: function () { return [{ type: i5.ControlContainer }]; }, propDecorators: { property: [{
|
|
241
|
+
type: Input
|
|
242
|
+
}], apiName: [{
|
|
243
|
+
type: Input
|
|
244
|
+
}], inputObjectRef: [{
|
|
245
|
+
type: ContentChild,
|
|
246
|
+
args: ['inputObject', { static: false }]
|
|
247
|
+
}] } });
|
|
248
|
+
/**
|
|
249
|
+
* A simple input element, like a text, or a number that is automatically created from the given property.
|
|
250
|
+
* It is advised to use RestWorldInputComponent <rw-input> and control the rendered inputs with the passed in property
|
|
251
|
+
* instead of using this component directly.
|
|
252
|
+
*/
|
|
253
|
+
export class RestWorldInputSimpleComponent {
|
|
254
|
+
constructor(_controlContainer) {
|
|
255
|
+
this._controlContainer = _controlContainer;
|
|
256
|
+
}
|
|
257
|
+
get PropertyType() {
|
|
258
|
+
return PropertyType;
|
|
259
|
+
}
|
|
260
|
+
get dateFormat() {
|
|
261
|
+
return new Date(3333, 11, 22)
|
|
262
|
+
.toLocaleDateString()
|
|
263
|
+
.replace("22", "dd")
|
|
264
|
+
.replace("11", "mm")
|
|
265
|
+
.replace("3333", "yy")
|
|
266
|
+
.replace("33", "y");
|
|
267
|
+
}
|
|
268
|
+
get formControl() {
|
|
269
|
+
if (this._formControl === undefined)
|
|
270
|
+
throw new Error("formGroup is not set.");
|
|
271
|
+
return this._formControl;
|
|
272
|
+
}
|
|
273
|
+
get PropertyWithImage() {
|
|
274
|
+
return PropertyWithImage;
|
|
275
|
+
}
|
|
276
|
+
ngOnInit() {
|
|
277
|
+
const formGroup = this._controlContainer.control;
|
|
278
|
+
this._formControl = formGroup.controls[this.property.name];
|
|
279
|
+
}
|
|
280
|
+
}
|
|
281
|
+
RestWorldInputSimpleComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.0.3", ngImport: i0, type: RestWorldInputSimpleComponent, deps: [{ token: i5.ControlContainer }], target: i0.ɵɵFactoryTarget.Component });
|
|
282
|
+
RestWorldInputSimpleComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.0.3", type: RestWorldInputSimpleComponent, selector: "rw-input-simple", inputs: { property: "property" }, ngImport: i0, template: "<div [ngSwitch]=\"property.type\">\n\n <input *ngSwitchCase=\"PropertyType.Hidden\" [formControlName]=\"property.name\" [id]=\"property.name\" type=\"hidden\" [value]=\"property.value\" />\n \n <input *ngSwitchCase=\"PropertyType.Text\" [formControlName]=\"property.name\" [id]=\"property.name\" type=\"text\" pInputText class=\"w-full\" [class.p-disabled]=\"property.readOnly\" />\n \n <textarea *ngSwitchCase=\"PropertyType.Textarea\" [formControlName]=\"property.name\" [id]=\"property.name\" pInputTextarea class=\"w-full p-inputtextarea p-inputtext p-component p-element\" [class.p-disabled]=\"property.readOnly\" [cols]=\"property.cols\" [rows]=\"property.rows\"></textarea>\n \n <input *ngSwitchCase=\"PropertyType.Search\" [formControlName]=\"property.name\" [id]=\"property.name\" type=\"search\" pInputText class=\"w-full\" [class.p-disabled]=\"property.readOnly\" />\n \n <input *ngSwitchCase=\"PropertyType.Tel\" [formControlName]=\"property.name\" [id]=\"property.name\" type=\"tel\" pInputText class=\"w-full\" [class.p-disabled]=\"property.readOnly\" />\n \n <input *ngSwitchCase=\"PropertyType.Url\" [formControlName]=\"property.name\" [id]=\"property.name\" type=\"url\" pInputText class=\"w-full\" [class.p-disabled]=\"property.readOnly\" />\n \n <input *ngSwitchCase=\"PropertyType.Email\" [formControlName]=\"property.name\" [id]=\"property.name\" type=\"email\" pInputText class=\"w-full\" [class.p-disabled]=\"property.readOnly\" />\n \n <input *ngSwitchCase=\"PropertyType.Password\" [formControlName]=\"property.name\" [id]=\"property.name\" type=\"password\" pPassword class=\"w-full\" [class.p-disabled]=\"property.readOnly\" />\n \n <p-calendar *ngSwitchCase=\"PropertyType.Date\" [formControlName]=\"property.name\" [id]=\"property.name\" [dateFormat]=\"dateFormat\" [showWeek]=\"true\" [showIcon]=\"true\" styleClass=\"w-full\" [class.p-disabled]=\"property.readOnly\"></p-calendar>\n \n <p-calendar *ngSwitchCase=\"PropertyType.Month\" [formControlName]=\"property.name\" [id]=\"property.name\" [dateFormat]=\"dateFormat\" [showWeek]=\"false\" view=\"month\" [showIcon]=\"true\" styleClass=\"w-full\" [class.p-disabled]=\"property.readOnly\"></p-calendar>\n \n <input *ngSwitchCase=\"PropertyType.Week\" [formControlName]=\"property.name\" [id]=\"property.name\" type=\"week\" pInputText class=\"w-full\" [class.p-disabled]=\"property.readOnly\" />\n \n <p-calendar *ngSwitchCase=\"PropertyType.Time\" [formControlName]=\"property.name\" [id]=\"property.name\" [dateFormat]=\"dateFormat\" [showTime]=\"true\" [timeOnly]=\"true\" [showWeek]=\"false\" [showIcon]=\"true\" styleClass=\"w-full\" [class.p-disabled]=\"property.readOnly\"></p-calendar>\n \n <p-calendar *ngSwitchCase=\"PropertyType.DatetimeLocal\" [formControlName]=\"property.name\" [id]=\"property.name\" [dateFormat]=\"dateFormat\" [showTime]=\"true\" [showWeek]=\"false\" [showIcon]=\"true\" styleClass=\"w-full\" [class.p-disabled]=\"property.readOnly\"></p-calendar>\n \n <p-inputNumber *ngSwitchCase=\"PropertyType.Number\" [formControlName]=\"property.name\" [id]=\"property.name\" mode=\"decimal\" [showButtons]=\"!property.readOnly\" class=\"w-full\" styleClass=\"w-full\" [class.p-disabled]=\"property.readOnly\"></p-inputNumber>\n \n <input *ngSwitchCase=\"PropertyType.Range\" [formControlName]=\"property.name\" [id]=\"property.name\" type=\"range\" [min]=\"property.min\" [max]=\"property.max\" [step]=\"property.step\" pInputText class=\"w-full\" [class.p-disabled]=\"property.readOnly\" />\n \n <input *ngSwitchCase=\"PropertyType.Color\" [formControlName]=\"property.name\" [id]=\"property.name\" type=\"color\" pInputText class=\"w-full\" [class.p-disabled]=\"property.readOnly\" />\n \n <ng-container *ngSwitchCase=\"PropertyType.Bool\">\n <p-checkbox *ngIf=\"property.required\" [binary]=\"true\" [formControl]=\"formControl\" [id]=\"property.name\" [readonly]=\"property.readOnly!\"></p-checkbox>\n <p-triStateCheckbox *ngIf=\"!property.required\" [formControl]=\"formControl\" [id]=\"property.name\" [readonly]=\"property.readOnly!\"></p-triStateCheckbox>\n </ng-container>\n \n <p-calendar *ngSwitchCase=\"PropertyType.DatetimeOffset\" [formControlName]=\"property.name\" [id]=\"property.name\" [dateFormat]=\"dateFormat\" [showTime]=\"true\" [showWeek]=\"false\" [showIcon]=\"true\" styleClass=\"w-full\" [class.p-disabled]=\"property.readOnly\"></p-calendar>\n \n <p-calendar *ngSwitchCase=\"PropertyType.Duration\" [formControlName]=\"property.name\" [id]=\"property.name\" [dateFormat]=\"dateFormat\" [showTime]=\"true\" [timeOnly]=\"true\" [showWeek]=\"false\" [showIcon]=\"true\" styleClass=\"w-full\" [class.p-disabled]=\"property.readOnly\"></p-calendar>\n\n <rw-image *ngSwitchCase=\"PropertyType.Image\" [formControlName]=\"property.name\" [property]=\"property | as:PropertyWithImage\"></rw-image>\n\n <rw-file *ngSwitchCase=\"PropertyType.File\" [formControlName]=\"property.name\" [fileName]=\"property.name\" [accept]=\"property.placeholder\"></rw-file>\n\n <input *ngSwitchDefault [formControlName]=\"property.name\" [id]=\"property.name\" type=\"text\" pInputText class=\"w-full\" [class.p-disabled]=\"property.readOnly\" />\n</div>", styles: [""], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i2.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "directive", type: i2.NgSwitchDefault, selector: "[ngSwitchDefault]" }, { kind: "directive", type: i5.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i5.RangeValueAccessor, selector: "input[type=range][formControlName],input[type=range][formControl],input[type=range][ngModel]" }, { kind: "directive", type: i5.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i5.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "directive", type: i5.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "directive", type: i15.InputText, selector: "[pInputText]" }, { kind: "component", type: i16.InputNumber, selector: "p-inputNumber", inputs: ["showButtons", "format", "buttonLayout", "inputId", "styleClass", "style", "placeholder", "size", "maxlength", "tabindex", "title", "ariaLabel", "ariaRequired", "name", "required", "autocomplete", "min", "max", "incrementButtonClass", "decrementButtonClass", "incrementButtonIcon", "decrementButtonIcon", "readonly", "step", "allowEmpty", "locale", "localeMatcher", "mode", "currency", "currencyDisplay", "useGrouping", "minFractionDigits", "maxFractionDigits", "prefix", "suffix", "inputStyle", "inputStyleClass", "showClear", "disabled"], outputs: ["onInput", "onFocus", "onBlur", "onKeyDown", "onClear"] }, { kind: "component", type: i17.Calendar, selector: "p-calendar", inputs: ["style", "styleClass", "inputStyle", "inputId", "name", "inputStyleClass", "placeholder", "ariaLabelledBy", "iconAriaLabel", "disabled", "dateFormat", "multipleSeparator", "rangeSeparator", "inline", "showOtherMonths", "selectOtherMonths", "showIcon", "icon", "appendTo", "readonlyInput", "shortYearCutoff", "monthNavigator", "yearNavigator", "hourFormat", "timeOnly", "stepHour", "stepMinute", "stepSecond", "showSeconds", "required", "showOnFocus", "showWeek", "showClear", "dataType", "selectionMode", "maxDateCount", "showButtonBar", "todayButtonStyleClass", "clearButtonStyleClass", "autoZIndex", "baseZIndex", "panelStyleClass", "panelStyle", "keepInvalid", "hideOnDateTimeSelect", "touchUI", "timeSeparator", "focusTrap", "showTransitionOptions", "hideTransitionOptions", "tabindex", "view", "defaultDate", "minDate", "maxDate", "disabledDates", "disabledDays", "yearRange", "showTime", "responsiveOptions", "numberOfMonths", "firstDayOfWeek", "locale"], outputs: ["onFocus", "onBlur", "onClose", "onSelect", "onClear", "onInput", "onTodayClick", "onClearClick", "onMonthChange", "onYearChange", "onClickOutside", "onShow"] }, { kind: "component", type: i18.Checkbox, selector: "p-checkbox", inputs: ["value", "name", "disabled", "binary", "label", "ariaLabelledBy", "ariaLabel", "tabindex", "inputId", "style", "styleClass", "labelStyleClass", "formControl", "checkboxIcon", "readonly", "required", "trueValue", "falseValue"], outputs: ["onChange"] }, { kind: "component", type: i19.TriStateCheckbox, selector: "p-triStateCheckbox", inputs: ["disabled", "name", "ariaLabelledBy", "tabindex", "inputId", "style", "styleClass", "label", "readonly", "checkboxTrueIcon", "checkboxFalseIcon"], outputs: ["onChange"] }, { kind: "component", type: i20.RestWorldImageComponent, selector: "rw-image", inputs: ["property"] }, { kind: "component", type: i21.RestWorldFileComponent, selector: "rw-file", inputs: ["accept", "fileName"] }, { kind: "pipe", type: i4.AsPipe, name: "as" }], viewProviders: [{ provide: ControlContainer, useExisting: FormGroupDirective }] });
|
|
283
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.3", ngImport: i0, type: RestWorldInputSimpleComponent, decorators: [{
|
|
284
|
+
type: Component,
|
|
285
|
+
args: [{ selector: 'rw-input-simple', viewProviders: [{ provide: ControlContainer, useExisting: FormGroupDirective }], template: "<div [ngSwitch]=\"property.type\">\n\n <input *ngSwitchCase=\"PropertyType.Hidden\" [formControlName]=\"property.name\" [id]=\"property.name\" type=\"hidden\" [value]=\"property.value\" />\n \n <input *ngSwitchCase=\"PropertyType.Text\" [formControlName]=\"property.name\" [id]=\"property.name\" type=\"text\" pInputText class=\"w-full\" [class.p-disabled]=\"property.readOnly\" />\n \n <textarea *ngSwitchCase=\"PropertyType.Textarea\" [formControlName]=\"property.name\" [id]=\"property.name\" pInputTextarea class=\"w-full p-inputtextarea p-inputtext p-component p-element\" [class.p-disabled]=\"property.readOnly\" [cols]=\"property.cols\" [rows]=\"property.rows\"></textarea>\n \n <input *ngSwitchCase=\"PropertyType.Search\" [formControlName]=\"property.name\" [id]=\"property.name\" type=\"search\" pInputText class=\"w-full\" [class.p-disabled]=\"property.readOnly\" />\n \n <input *ngSwitchCase=\"PropertyType.Tel\" [formControlName]=\"property.name\" [id]=\"property.name\" type=\"tel\" pInputText class=\"w-full\" [class.p-disabled]=\"property.readOnly\" />\n \n <input *ngSwitchCase=\"PropertyType.Url\" [formControlName]=\"property.name\" [id]=\"property.name\" type=\"url\" pInputText class=\"w-full\" [class.p-disabled]=\"property.readOnly\" />\n \n <input *ngSwitchCase=\"PropertyType.Email\" [formControlName]=\"property.name\" [id]=\"property.name\" type=\"email\" pInputText class=\"w-full\" [class.p-disabled]=\"property.readOnly\" />\n \n <input *ngSwitchCase=\"PropertyType.Password\" [formControlName]=\"property.name\" [id]=\"property.name\" type=\"password\" pPassword class=\"w-full\" [class.p-disabled]=\"property.readOnly\" />\n \n <p-calendar *ngSwitchCase=\"PropertyType.Date\" [formControlName]=\"property.name\" [id]=\"property.name\" [dateFormat]=\"dateFormat\" [showWeek]=\"true\" [showIcon]=\"true\" styleClass=\"w-full\" [class.p-disabled]=\"property.readOnly\"></p-calendar>\n \n <p-calendar *ngSwitchCase=\"PropertyType.Month\" [formControlName]=\"property.name\" [id]=\"property.name\" [dateFormat]=\"dateFormat\" [showWeek]=\"false\" view=\"month\" [showIcon]=\"true\" styleClass=\"w-full\" [class.p-disabled]=\"property.readOnly\"></p-calendar>\n \n <input *ngSwitchCase=\"PropertyType.Week\" [formControlName]=\"property.name\" [id]=\"property.name\" type=\"week\" pInputText class=\"w-full\" [class.p-disabled]=\"property.readOnly\" />\n \n <p-calendar *ngSwitchCase=\"PropertyType.Time\" [formControlName]=\"property.name\" [id]=\"property.name\" [dateFormat]=\"dateFormat\" [showTime]=\"true\" [timeOnly]=\"true\" [showWeek]=\"false\" [showIcon]=\"true\" styleClass=\"w-full\" [class.p-disabled]=\"property.readOnly\"></p-calendar>\n \n <p-calendar *ngSwitchCase=\"PropertyType.DatetimeLocal\" [formControlName]=\"property.name\" [id]=\"property.name\" [dateFormat]=\"dateFormat\" [showTime]=\"true\" [showWeek]=\"false\" [showIcon]=\"true\" styleClass=\"w-full\" [class.p-disabled]=\"property.readOnly\"></p-calendar>\n \n <p-inputNumber *ngSwitchCase=\"PropertyType.Number\" [formControlName]=\"property.name\" [id]=\"property.name\" mode=\"decimal\" [showButtons]=\"!property.readOnly\" class=\"w-full\" styleClass=\"w-full\" [class.p-disabled]=\"property.readOnly\"></p-inputNumber>\n \n <input *ngSwitchCase=\"PropertyType.Range\" [formControlName]=\"property.name\" [id]=\"property.name\" type=\"range\" [min]=\"property.min\" [max]=\"property.max\" [step]=\"property.step\" pInputText class=\"w-full\" [class.p-disabled]=\"property.readOnly\" />\n \n <input *ngSwitchCase=\"PropertyType.Color\" [formControlName]=\"property.name\" [id]=\"property.name\" type=\"color\" pInputText class=\"w-full\" [class.p-disabled]=\"property.readOnly\" />\n \n <ng-container *ngSwitchCase=\"PropertyType.Bool\">\n <p-checkbox *ngIf=\"property.required\" [binary]=\"true\" [formControl]=\"formControl\" [id]=\"property.name\" [readonly]=\"property.readOnly!\"></p-checkbox>\n <p-triStateCheckbox *ngIf=\"!property.required\" [formControl]=\"formControl\" [id]=\"property.name\" [readonly]=\"property.readOnly!\"></p-triStateCheckbox>\n </ng-container>\n \n <p-calendar *ngSwitchCase=\"PropertyType.DatetimeOffset\" [formControlName]=\"property.name\" [id]=\"property.name\" [dateFormat]=\"dateFormat\" [showTime]=\"true\" [showWeek]=\"false\" [showIcon]=\"true\" styleClass=\"w-full\" [class.p-disabled]=\"property.readOnly\"></p-calendar>\n \n <p-calendar *ngSwitchCase=\"PropertyType.Duration\" [formControlName]=\"property.name\" [id]=\"property.name\" [dateFormat]=\"dateFormat\" [showTime]=\"true\" [timeOnly]=\"true\" [showWeek]=\"false\" [showIcon]=\"true\" styleClass=\"w-full\" [class.p-disabled]=\"property.readOnly\"></p-calendar>\n\n <rw-image *ngSwitchCase=\"PropertyType.Image\" [formControlName]=\"property.name\" [property]=\"property | as:PropertyWithImage\"></rw-image>\n\n <rw-file *ngSwitchCase=\"PropertyType.File\" [formControlName]=\"property.name\" [fileName]=\"property.name\" [accept]=\"property.placeholder\"></rw-file>\n\n <input *ngSwitchDefault [formControlName]=\"property.name\" [id]=\"property.name\" type=\"text\" pInputText class=\"w-full\" [class.p-disabled]=\"property.readOnly\" />\n</div>" }]
|
|
286
|
+
}], ctorParameters: function () { return [{ type: i5.ControlContainer }]; }, propDecorators: { property: [{
|
|
287
|
+
type: Input
|
|
288
|
+
}] } });
|
|
289
|
+
/**
|
|
290
|
+
* A collection of rw-form-elemtns automatically created from a template.
|
|
291
|
+
* Does not have any buttons on its own.
|
|
292
|
+
* If you want buttons, use RestWorldForm <rw-form>.
|
|
293
|
+
*/
|
|
294
|
+
export class RestWorldInputTemplateComponent {
|
|
295
|
+
}
|
|
296
|
+
RestWorldInputTemplateComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.0.3", ngImport: i0, type: RestWorldInputTemplateComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
297
|
+
RestWorldInputTemplateComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.0.3", type: RestWorldInputTemplateComponent, selector: "rw-input-template", inputs: { apiName: "apiName", template: "template" }, ngImport: i0, template: "<rw-form-element *ngFor=\"let property of template.properties\" [property]=\"property\" [apiName]=\"apiName\"></rw-form-element>", styles: [""], dependencies: [{ kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "component", type: RestWorldFormElementComponent, selector: "rw-form-element", inputs: ["property", "apiName"] }], viewProviders: [{ provide: ControlContainer, useExisting: FormGroupDirective }] });
|
|
298
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.3", ngImport: i0, type: RestWorldInputTemplateComponent, decorators: [{
|
|
299
|
+
type: Component,
|
|
300
|
+
args: [{ selector: 'rw-input-template', viewProviders: [{ provide: ControlContainer, useExisting: FormGroupDirective }], template: "<rw-form-element *ngFor=\"let property of template.properties\" [property]=\"property\" [apiName]=\"apiName\"></rw-form-element>" }]
|
|
301
|
+
}], propDecorators: { apiName: [{
|
|
302
|
+
type: Input
|
|
303
|
+
}], template: [{
|
|
304
|
+
type: Input
|
|
305
|
+
}] } });
|
|
306
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"restworld-inputs.js","sourceRoot":"","sources":["../../../../../../projects/ngx-restworld-client/src/lib/components/restworld-inputs/restworld-inputs.ts","../../../../../../projects/ngx-restworld-client/src/lib/components/restworld-inputs/restworld-form-element/restworld-form-element.component.html","../../../../../../projects/ngx-restworld-client/src/lib/components/restworld-inputs/restworld-input/restworld-input.component.html","../../../../../../projects/ngx-restworld-client/src/lib/components/restworld-inputs/restworld-input-collection/restworld-input-collection.component.html","../../../../../../projects/ngx-restworld-client/src/lib/components/restworld-inputs/restworld-input-dropdown/restworld-input-dropdown.component.html","../../../../../../projects/ngx-restworld-client/src/lib/components/restworld-inputs/restworld-input-object/restworld-input-object.component.html","../../../../../../projects/ngx-restworld-client/src/lib/components/restworld-inputs/restworld-input-simple/restworld-input-simple.component.html","../../../../../../projects/ngx-restworld-client/src/lib/components/restworld-inputs/restworld-input-template/restworld-input-template.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CdkDragDrop } from '@angular/cdk/drag-drop';\r\nimport { ChangeDetectorRef, Component, ContentChild, Input, OnInit, TemplateRef } from '@angular/core';\r\nimport { AbstractControl, ControlContainer, FormArray, FormControl, FormGroup, FormGroupDirective } from '@angular/forms';\r\nimport { NumberTemplate, Options, Property, PropertyType, Resource, Template, TemplateDto } from '@wertzui/ngx-hal-client';\r\nimport { FormService } from '../../services/form.service';\r\nimport { MessageService } from 'primeng/api';\r\nimport { ProblemDetails } from '../../models/problem-details';\r\nimport { PropertyTemplateContext } from '../../models/templating';\r\nimport { RestWorldClient } from '../../services/restworld-client';\r\nimport { RestWorldClientCollection } from '../../services/restworld-client-collection';\r\nimport { PropertyWithOptions, PropertyWithImage } from '../../models/special-properties'\r\n\r\n/**\r\n * A form element with a label that is automatically created from a property in a form template.\r\n * This may also be a complex object or a collection in which case multiple and nested input elements may be rendered.\r\n * If you want a form element without a label, use RestWorldFormInput <rw-form-input>.\r\n */\r\n@Component({\r\n  selector: 'rw-form-element',\r\n  templateUrl: './restworld-form-element/restworld-form-element.component.html',\r\n  styleUrls: ['./restworld-form-element/restworld-form-element.component.css'],\r\n  viewProviders: [{ provide: ControlContainer, useExisting: FormGroupDirective }]\r\n})\r\nexport class RestWorldFormElementComponent<T extends { [K in keyof T]: AbstractControl<any, any>; }> {\r\n  @Input()\r\n  property!: Property;\r\n\r\n  @Input()\r\n  apiName!: string;\r\n}\r\n\r\n/**\r\n * A form input element that is automatically created from a property in a form template.\r\n * This may also be a complex object or a collection in which case multiple and nested input elements may be rendered.\r\n * If you also want a label, use RestWorldFormElement <rw-form-element>.\r\n * You can also use one of the different RestWorldInput... <rw-input-...> elements to render a specific input,\r\n * but it is advised to control the rendered input through the passed in property.\r\n */\r\n@Component({\r\n  selector: 'rw-input',\r\n  templateUrl: './restworld-input/restworld-input.component.html',\r\n  styleUrls: ['./restworld-input/restworld-input.component.css'],\r\n  viewProviders: [{ provide: ControlContainer, useExisting: FormGroupDirective }]\r\n})\r\nexport class RestWorldInputComponent {\r\n\r\n  @Input()\r\n  property!: Property;\r\n\r\n  @Input()\r\n  apiName!: string;\r\n\r\n  public get PropertyType() {\r\n    return PropertyType;\r\n  }\r\n\r\n  public get PropertyWithOptions() {\r\n    return PropertyWithOptions;\r\n  }\r\n}\r\n\r\n\r\n/**\r\n * A collection that is automatically created from the given property.\r\n * The collection supports drag & drop to re order the elements and can also be nested.\r\n * It is advised to use RestWorldInputComponent <rw-input> and control the rendered inputs with the passed in property\r\n * instead of using this component directly.\r\n */\r\n@Component({\r\n  selector: 'rw-input-collection',\r\n  templateUrl: './restworld-input-collection/restworld-input-collection.component.html',\r\n  styleUrls: ['./restworld-input-collection/restworld-input-collection.component.css'],\r\n  viewProviders: [{ provide: ControlContainer, useExisting: FormGroupDirective }]\r\n})\r\nexport class RestWorldInputCollectionComponent<T extends { [K in keyof T]: AbstractControl<any, any>; }> implements OnInit{\r\n\r\n  @Input()\r\n  property!: Property;\r\n\r\n  @Input()\r\n  apiName!: string;\r\n\r\n  @ContentChild('inputCollection', { static: false })\r\n  inputCollectionRef?: TemplateRef<unknown>;\r\n\r\n\r\n  private _templates: NumberTemplate[] = [];\r\n  public get templates(): NumberTemplate[] {\r\n    return this._templates;\r\n  }\r\n\r\n  private _defaultTemplate?: Template;\r\n  public get defaultTemplate(): Template {\r\n    if(this._defaultTemplate === undefined)\r\n      throw new Error(\"No default template found.\");\r\n\r\n    return this._defaultTemplate;\r\n  }\r\n\r\n  private _innerFormArray?: FormArray<FormGroup<T>>;\r\n  public get innerFormArray() {\r\n    if (this._innerFormArray === undefined)\r\n      throw new Error(\"formGroup is not set.\");\r\n\r\n    return this._innerFormArray;\r\n  }\r\n\r\n  constructor (\r\n    private readonly _controlContainer: ControlContainer,\r\n    private readonly _formService: FormService,\r\n    private readonly _changeDetectorRef: ChangeDetectorRef,\r\n  ) {\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    const formGroup = this._controlContainer.control as FormGroup<any>;\r\n    this._innerFormArray = formGroup.controls[this.property.name] as FormArray<FormGroup<T>>;\r\n    this._templates = RestWorldInputCollectionComponent.getCollectionEntryTemplates(this.property);\r\n    this._defaultTemplate = this.property._templates.default;\r\n  }\r\n\r\n  private static getCollectionEntryTemplates(property?: Property): NumberTemplate[] {\r\n    if (!property)\r\n      return [];\r\n\r\n    return Object.entries(property._templates)\r\n      .filter(([key, value]) => Number.isInteger(Number.parseInt(key)) && Number.isInteger(Number.parseInt(value.title ?? \"\")))\r\n      .map(([, value]) => new NumberTemplate(value));\r\n  }\r\n\r\n  public addNewItemToCollection(): void {\r\n    const maxIndex = Math.max(...Object.keys(this.templates)\r\n      .map(key => Number.parseInt(key))\r\n      .filter(key => Number.isSafeInteger(key)));\r\n    const nextIndex = maxIndex < 0 ? 0 : maxIndex + 1;\r\n\r\n    const copiedTemplateDto = JSON.parse(JSON.stringify(this.defaultTemplate)) as TemplateDto;\r\n    const copiedTemplate = new NumberTemplate(copiedTemplateDto);\r\n    copiedTemplate.title = nextIndex;\r\n\r\n    this.templates[copiedTemplate.title] = copiedTemplate;\r\n    this.innerFormArray.push(this._formService.createFormGroupFromTemplate(this.defaultTemplate));\r\n  }\r\n\r\n  public deleteItemFromCollection(template: NumberTemplate): void {\r\n    delete this.templates[template.title];\r\n    this.innerFormArray.removeAt(template.title);\r\n  }\r\n\r\n  public collectionItemDropped($event: CdkDragDrop<{ }>) {\r\n    const previousIndex = $event.previousIndex;\r\n    const currentIndex = $event.currentIndex;\r\n    const movementDirection = currentIndex > previousIndex ? 1 : -1;\r\n\r\n    // Move in FormArray\r\n    // We do not need to move the item in the _templates object\r\n    const movedControl = this.innerFormArray.at(previousIndex);\r\n    for (let i = previousIndex; i * movementDirection < currentIndex * movementDirection; i = i + movementDirection) {\r\n      this.innerFormArray.setControl(i, this.innerFormArray.at(i + movementDirection));\r\n    }\r\n    this.innerFormArray.setControl(currentIndex, movedControl);\r\n\r\n    this._changeDetectorRef.markForCheck();\r\n  }\r\n}\r\n\r\n/**\r\n * A dropdown that is automatically created from the given property.\r\n * The dropdown supports searching through a RESTWorld list endpoint on the backend.\r\n * It is advised to use RestWorldInputComponent <rw-input> and control the rendered inputs with the passed in property\r\n * instead of using this component directly.\r\n */\r\n@Component({\r\n  selector: 'rw-input-dropdown',\r\n  templateUrl: './restworld-input-dropdown/restworld-input-dropdown.component.html',\r\n  styleUrls: ['./restworld-input-dropdown/restworld-input-dropdown.component.css'],\r\n  viewProviders: [{ provide: ControlContainer, useExisting: FormGroupDirective }]\r\n})\r\nexport class RestWorldInputDropdownComponent {\r\n  @Input()\r\n  property!: Property & { options: Options };\r\n\r\n  @Input()\r\n  apiName!: string;\r\n\r\n  @ContentChild('inputOptionsSingle', { static: false })\r\n  inputOptionsSingleRef?: TemplateRef<PropertyTemplateContext>;\r\n\r\n  @ContentChild('inputOptionsMultiple', { static: false })\r\n  inputOptionsMultipleRef?: TemplateRef<PropertyTemplateContext>;\r\n\r\n  constructor (\r\n    private readonly _messageService: MessageService,\r\n    private readonly _clients: RestWorldClientCollection\r\n  ) {\r\n  }\r\n\r\n  public getDropdownElementTooltip(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}: ${RestWorldInputDropdownComponent.jsonStringifyWithElipsis(value)}`, '');\r\n\r\n    return tooltip;\r\n  }\r\n\r\n  public async onOptionsFiltered(property: Property, event: { originalEvent: unknown; filter: string | null }) {\r\n    const options = property?.options;\r\n\r\n    if (!options?.link?.href || !event.filter || event.filter === '')\r\n      return;\r\n\r\n\r\n    const templatedUri = options.link.href;\r\n    let filter = `contains(${options.promptField}, '${event.filter}')`;\r\n    if (options.valueField?.toLowerCase() === 'id' && !Number.isNaN(Number.parseInt(event.filter)))\r\n      filter = `(${options.valueField} eq ${event.filter})  or (${filter})`;\r\n\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, sticky: true });\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 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  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\r\n/**\r\n * A complex object with multiple properties that is automatically created from the given property.\r\n * The object can also be nested.\r\n * It is advised to use RestWorldInputComponent <rw-input> and control the rendered inputs with the passed in property\r\n * instead of using this component directly.\r\n */\r\n@Component({\r\n  selector: 'rw-input-object',\r\n  templateUrl: './restworld-input-object/restworld-input-object.component.html',\r\n  styleUrls: ['./restworld-input-object/restworld-input-object.component.css'],\r\n  viewProviders: [{ provide: ControlContainer, useExisting: FormGroupDirective }]\r\n})\r\nexport class RestWorldInputObjectComponent<T extends { [K in keyof T]: AbstractControl<any, any>; }> implements OnInit {\r\n\r\n  @Input()\r\n  property!: Property;\r\n\r\n  @Input()\r\n  apiName!: string;\r\n\r\n  @ContentChild('inputObject', { static: false })\r\n  inputObjectRef?: TemplateRef<unknown>;\r\n\r\n  private _innerFormGroup?: FormGroup<T>;\r\n\r\n  public get innerFormGroup() {\r\n    if (this._innerFormGroup === undefined)\r\n      throw new Error(\"formGroup is not set.\");\r\n\r\n    return this._innerFormGroup;\r\n  }\r\n\r\n  constructor (\r\n    private readonly _controlContainer: ControlContainer\r\n  ) {\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    const formGroup = this._controlContainer.control as FormGroup<any>;\r\n    this._innerFormGroup = formGroup.controls[this.property.name] as FormGroup<T>;\r\n  }\r\n}\r\n\r\n/**\r\n * A simple input element, like a text, or a number that is automatically created from the given property.\r\n * It is advised to use RestWorldInputComponent <rw-input> and control the rendered inputs with the passed in property\r\n * instead of using this component directly.\r\n */\r\n@Component({\r\n  selector: 'rw-input-simple',\r\n  templateUrl: './restworld-input-simple/restworld-input-simple.component.html',\r\n  styleUrls: ['./restworld-input-simple/restworld-input-simple.component.css'],\r\n  viewProviders: [{ provide: ControlContainer, useExisting: FormGroupDirective }]\r\n})\r\nexport class RestWorldInputSimpleComponent<T> implements OnInit {\r\n\r\n  @Input()\r\n  property!: Property;\r\n\r\n  public get PropertyType() {\r\n    return PropertyType;\r\n  }\r\n\r\n  public get dateFormat(): string {\r\n    return new Date(3333, 11, 22)\r\n      .toLocaleDateString()\r\n      .replace(\"22\", \"dd\")\r\n      .replace(\"11\", \"mm\")\r\n      .replace(\"3333\", \"yy\")\r\n      .replace(\"33\", \"y\");\r\n  }\r\n\r\n  private _formControl?: FormControl<T>;\r\n\r\n  public get formControl() {\r\n    if (this._formControl === undefined)\r\n      throw new Error(\"formGroup is not set.\");\r\n\r\n    return this._formControl;\r\n  }\r\n\r\n  public get PropertyWithImage() {\r\n    return PropertyWithImage;\r\n  }\r\n\r\n  constructor (\r\n    private readonly _controlContainer: ControlContainer\r\n  ) {\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    const formGroup = this._controlContainer.control as FormGroup<any>;\r\n    this._formControl = formGroup.controls[this.property.name] as FormControl<T>;\r\n  }\r\n}\r\n\r\n/**\r\n * A collection of rw-form-elemtns automatically created from a template.\r\n * Does not have any buttons on its own.\r\n * If you want buttons, use RestWorldForm <rw-form>.\r\n */\r\n@Component({\r\n  selector: 'rw-input-template',\r\n  templateUrl: './restworld-input-template/restworld-input-template.component.html',\r\n  styleUrls: ['./restworld-input-template/restworld-input-template.component.css'],\r\n  viewProviders: [{ provide: ControlContainer, useExisting: FormGroupDirective }]\r\n})\r\nexport class RestWorldInputTemplateComponent<T extends { [K in keyof T]: AbstractControl<any, any>; }> {\r\n  @Input()\r\n  apiName!: string;\r\n\r\n  @Input()\r\n  template!: Template;\r\n}\r\n","<div class=\"grid field\">\r\n    <rw-label [property]=\"property\" class=\"col-12 md:col-2 flex align-items-center\"></rw-label>\r\n    <rw-input [apiName]=\"apiName\" [property]=\"property\" class=\"col-12 md:col-10\"></rw-input>\r\n</div>\r\n","<rw-input-dropdown *ngIf=\"property.options\" [apiName]=\"apiName\" [property]=\"property | as:PropertyWithOptions\"></rw-input-dropdown>\r\n\r\n<ng-container *ngIf=\"!property.options\">\r\n    <ng-container [ngSwitch]=\"property.type\">\r\n        <rw-input-object *ngSwitchCase=\"PropertyType.Object\" [apiName]=\"apiName\" [property]=\"property\"></rw-input-object>\r\n        <rw-input-collection *ngSwitchCase=\"PropertyType.Collection\" [apiName]=\"apiName\" [property]=\"property\"></rw-input-collection>\r\n        <rw-input-simple *ngSwitchDefault [property]=\"property\"></rw-input-simple>\r\n    </ng-container>\r\n</ng-container>\r\n\r\n<rw-validation-errors [property]=\"property\"></rw-validation-errors>","<div class=\"flex align-items-center\">\n    <div class=\"brace\">\n    </div>\n    <div class=\"w-full\" cdkDropList (cdkDropListDropped)=\"collectionItemDropped($event)\">\n        <div *ngFor=\"let template of templates\" class=\"flex align-items-center\" cdkDrag>\n            <i class=\"fas fa-grip-lines\" cdkDragHandle></i>\n            <div class=\"brace\">\n            </div>\n            <div class=\"w-full flex justify-content-end\">\n                <rw-input-template [formGroup]=\"innerFormArray.controls[template.title]\" [template]=\"defaultTemplate\" [apiName]=\"apiName\" class=\"w-full\"></rw-input-template>\n                <button pButton pRipple type=\"button\" icon=\"fas fa-trash\" class=\"p-button-outlined p-button-danger ml-2 mb-3\" (click)=\"deleteItemFromCollection(template)\"></button>\n            </div>\n        </div>\n        <div class=\"flex justify-content-end w-full\">\n            <button pButton pRipple type=\"button\" icon=\"fas fa-plus\" class=\"p-button-outlined p-button-info\" (click)=\"addNewItemToCollection()\"></button>\n        </div>\n    </div>\n</div>","<ng-template #defaultInputOptionsSingle let-property=\"property\" let-template=\"template\">\n    <p-dropdown \n    [formControlName]=\"property.name\" \n    [id]=\"property.name\" \n    [options]=\"property.options.inline\" \n    [filterBy]=\"(property.options.promptField ?? 'prompt') + ',' + (property.options.valueField ?? 'value')\" \n    [optionValue]=\"property.options.valueField ?? 'value'\" \n    [readonly]=\"property.readOnly\" \n    [required]=\"property.required || property.options.minItems > 0\" \n    [filter]=\"true\" \n    [autoDisplayFirst]=\"false\" \n    [showClear]=\"!property.required || property.options.minItems <= 0\" \n    (onFilter)=\"onOptionsFiltered(property, $event)\" \n    styleClass=\"w-full\" \n    [filterPlaceholder]=\"property?.options?.link?.href ? 'search for more results' : ''\">\n        <ng-template let-item pTemplate=\"selectedItem\">\n            <span [pTooltip]=\"getDropdownElementTooltip(item, [property.options.promptField ?? 'prompt', property.options.valueField ?? 'value'])\">{{item[property.options.promptField ?? 'prompt']}} ({{item[property.options.valueField ?? 'value']}})</span>\n        </ng-template>\n        <ng-template let-item pTemplate=\"item\">\n            <span [pTooltip]=\"getDropdownElementTooltip(item, [property.options.promptField ?? 'prompt', property.options.valueField ?? 'value'])\">{{item[property.options.promptField ?? 'prompt']}} ({{item[property.options.valueField ?? 'value']}})</span>\n        </ng-template>\n    </p-dropdown>\n</ng-template>\n<ng-container *ngIf=\"!property.options.maxItems || property.options.maxItems == 1\">\n    <ng-container *ngTemplateOutlet=\"inputOptionsSingleRef ?? defaultInputOptionsSingle; context: { property: property, apiName: apiName }\"></ng-container>\n</ng-container>\n\n<ng-template #defaultInputOptionsMultiple let-property=\"property\" let-template=\"template\">\n    <p-multiSelect \n    [formControlName]=\"property.name\" \n    [id]=\"property.name\" \n    [options]=\"property.options.inline\" \n    [optionLabel]=\"property.options.promptField ?? 'prompt'\" \n    [optionValue]=\"property.options.valueField ?? 'value'\" \n    [readonly]=\"property.readOnly\" \n    [selectionLimit]=\"property.options.maxItems\" \n    [required]=\"property.required || property.options.minItems > 0\"></p-multiSelect>\n</ng-template>\n<ng-container *ngIf=\"(property.options.maxItems ?? 0) > 1\">\n    <ng-container *ngTemplateOutlet=\"inputOptionsMultipleRef ?? defaultInputOptionsMultiple; context: { property: property, apiName: apiName }\"></ng-container>\n</ng-container>","<ng-template #defaultInputObject let-property=\"property\" let-template=\"template\">\n    <div class=\"flex align-items-center\">\n        <div class=\"brace\">\n        </div>\n        <div class=\"w-full\">\n            <rw-input-template [formGroup]=\"innerFormGroup\" [template]=\"property._templates.default\" [apiName]=\"apiName\"></rw-input-template>\n        </div>\n    </div>\n</ng-template>\n<ng-container>\n    <ng-container *ngTemplateOutlet=\"inputObjectRef || defaultInputObject; context: { property: property, innerFormGroup: innerFormGroup, apiName: apiName }\"></ng-container>\n</ng-container>","<div [ngSwitch]=\"property.type\">\n\n    <input *ngSwitchCase=\"PropertyType.Hidden\" [formControlName]=\"property.name\" [id]=\"property.name\" type=\"hidden\" [value]=\"property.value\" />\n  \n    <input *ngSwitchCase=\"PropertyType.Text\" [formControlName]=\"property.name\" [id]=\"property.name\" type=\"text\" pInputText class=\"w-full\" [class.p-disabled]=\"property.readOnly\" />\n   \n    <textarea *ngSwitchCase=\"PropertyType.Textarea\" [formControlName]=\"property.name\" [id]=\"property.name\" pInputTextarea class=\"w-full p-inputtextarea p-inputtext p-component p-element\" [class.p-disabled]=\"property.readOnly\" [cols]=\"property.cols\" [rows]=\"property.rows\"></textarea>\n   \n    <input *ngSwitchCase=\"PropertyType.Search\" [formControlName]=\"property.name\" [id]=\"property.name\" type=\"search\" pInputText class=\"w-full\" [class.p-disabled]=\"property.readOnly\" />\n   \n    <input *ngSwitchCase=\"PropertyType.Tel\" [formControlName]=\"property.name\" [id]=\"property.name\" type=\"tel\" pInputText class=\"w-full\" [class.p-disabled]=\"property.readOnly\" />\n   \n    <input *ngSwitchCase=\"PropertyType.Url\" [formControlName]=\"property.name\" [id]=\"property.name\" type=\"url\" pInputText class=\"w-full\" [class.p-disabled]=\"property.readOnly\" />\n   \n    <input *ngSwitchCase=\"PropertyType.Email\" [formControlName]=\"property.name\" [id]=\"property.name\" type=\"email\" pInputText class=\"w-full\" [class.p-disabled]=\"property.readOnly\" />\n   \n    <input *ngSwitchCase=\"PropertyType.Password\" [formControlName]=\"property.name\" [id]=\"property.name\" type=\"password\" pPassword class=\"w-full\" [class.p-disabled]=\"property.readOnly\" />\n   \n    <p-calendar *ngSwitchCase=\"PropertyType.Date\" [formControlName]=\"property.name\" [id]=\"property.name\" [dateFormat]=\"dateFormat\" [showWeek]=\"true\" [showIcon]=\"true\" styleClass=\"w-full\" [class.p-disabled]=\"property.readOnly\"></p-calendar>\n   \n    <p-calendar *ngSwitchCase=\"PropertyType.Month\" [formControlName]=\"property.name\" [id]=\"property.name\" [dateFormat]=\"dateFormat\" [showWeek]=\"false\" view=\"month\" [showIcon]=\"true\" styleClass=\"w-full\" [class.p-disabled]=\"property.readOnly\"></p-calendar>\n    \n    <input *ngSwitchCase=\"PropertyType.Week\" [formControlName]=\"property.name\" [id]=\"property.name\" type=\"week\" pInputText class=\"w-full\" [class.p-disabled]=\"property.readOnly\" />\n   \n    <p-calendar *ngSwitchCase=\"PropertyType.Time\" [formControlName]=\"property.name\" [id]=\"property.name\" [dateFormat]=\"dateFormat\" [showTime]=\"true\" [timeOnly]=\"true\" [showWeek]=\"false\" [showIcon]=\"true\" styleClass=\"w-full\" [class.p-disabled]=\"property.readOnly\"></p-calendar>\n    \n    <p-calendar *ngSwitchCase=\"PropertyType.DatetimeLocal\" [formControlName]=\"property.name\" [id]=\"property.name\" [dateFormat]=\"dateFormat\" [showTime]=\"true\" [showWeek]=\"false\" [showIcon]=\"true\" styleClass=\"w-full\" [class.p-disabled]=\"property.readOnly\"></p-calendar>\n    \n    <p-inputNumber *ngSwitchCase=\"PropertyType.Number\" [formControlName]=\"property.name\" [id]=\"property.name\" mode=\"decimal\" [showButtons]=\"!property.readOnly\" class=\"w-full\" styleClass=\"w-full\" [class.p-disabled]=\"property.readOnly\"></p-inputNumber>\n    \n    <input *ngSwitchCase=\"PropertyType.Range\" [formControlName]=\"property.name\" [id]=\"property.name\" type=\"range\" [min]=\"property.min\" [max]=\"property.max\" [step]=\"property.step\" pInputText class=\"w-full\" [class.p-disabled]=\"property.readOnly\" />\n    \n    <input *ngSwitchCase=\"PropertyType.Color\" [formControlName]=\"property.name\" [id]=\"property.name\" type=\"color\" pInputText class=\"w-full\" [class.p-disabled]=\"property.readOnly\" />\n   \n    <ng-container *ngSwitchCase=\"PropertyType.Bool\">\n        <p-checkbox *ngIf=\"property.required\" [binary]=\"true\" [formControl]=\"formControl\" [id]=\"property.name\" [readonly]=\"property.readOnly!\"></p-checkbox>\n        <p-triStateCheckbox *ngIf=\"!property.required\" [formControl]=\"formControl\" [id]=\"property.name\" [readonly]=\"property.readOnly!\"></p-triStateCheckbox>\n    </ng-container>\n    \n    <p-calendar *ngSwitchCase=\"PropertyType.DatetimeOffset\" [formControlName]=\"property.name\" [id]=\"property.name\" [dateFormat]=\"dateFormat\" [showTime]=\"true\" [showWeek]=\"false\" [showIcon]=\"true\" styleClass=\"w-full\" [class.p-disabled]=\"property.readOnly\"></p-calendar>\n    \n    <p-calendar *ngSwitchCase=\"PropertyType.Duration\" [formControlName]=\"property.name\" [id]=\"property.name\" [dateFormat]=\"dateFormat\" [showTime]=\"true\" [timeOnly]=\"true\" [showWeek]=\"false\" [showIcon]=\"true\" styleClass=\"w-full\" [class.p-disabled]=\"property.readOnly\"></p-calendar>\n\n    <rw-image *ngSwitchCase=\"PropertyType.Image\" [formControlName]=\"property.name\" [property]=\"property | as:PropertyWithImage\"></rw-image>\n\n    <rw-file *ngSwitchCase=\"PropertyType.File\" [formControlName]=\"property.name\" [fileName]=\"property.name\" [accept]=\"property.placeholder\"></rw-file>\n\n    <input *ngSwitchDefault [formControlName]=\"property.name\" [id]=\"property.name\" type=\"text\" pInputText class=\"w-full\" [class.p-disabled]=\"property.readOnly\" />\n</div>","<rw-form-element *ngFor=\"let property of template.properties\" [property]=\"property\" [apiName]=\"apiName\"></rw-form-element>"]}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import { Component, Input } from '@angular/core';
|
|
2
|
+
import { ControlContainer, FormGroupDirective } from '@angular/forms';
|
|
3
|
+
import { PropertyType } from '@wertzui/ngx-hal-client';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
import * as i1 from "@angular/common";
|
|
6
|
+
/**
|
|
7
|
+
* A label that is generated from the given property.
|
|
8
|
+
* If you also want an input element, you can either use RestWorldFormElement <rw-form-element> to have a label and an input rendered,
|
|
9
|
+
* or use RestWorldInput <rw-input> which will just render the input element, so you can freely place this label.
|
|
10
|
+
*/
|
|
11
|
+
export class RestWorldLabelComponent {
|
|
12
|
+
get PropertyType() {
|
|
13
|
+
return PropertyType;
|
|
14
|
+
}
|
|
15
|
+
}
|
|
16
|
+
RestWorldLabelComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.0.3", ngImport: i0, type: RestWorldLabelComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
17
|
+
RestWorldLabelComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.0.3", type: RestWorldLabelComponent, selector: "rw-label", inputs: { property: "property" }, ngImport: i0, template: "<label \r\n *ngIf=\"property.type !== PropertyType.Hidden\" \r\n [attr.for]=\"property.name\"\r\n [class.p-disabled]=\"property.readOnly\">\r\n {{property.prompt ?? property.name}}\r\n</label>", styles: [".label-hidden{visibility:hidden}.label-collapsed{display:none}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], viewProviders: [{ provide: ControlContainer, useExisting: FormGroupDirective }] });
|
|
18
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.3", ngImport: i0, type: RestWorldLabelComponent, decorators: [{
|
|
19
|
+
type: Component,
|
|
20
|
+
args: [{ selector: 'rw-label', viewProviders: [{ provide: ControlContainer, useExisting: FormGroupDirective }], template: "<label \r\n *ngIf=\"property.type !== PropertyType.Hidden\" \r\n [attr.for]=\"property.name\"\r\n [class.p-disabled]=\"property.readOnly\">\r\n {{property.prompt ?? property.name}}\r\n</label>", styles: [".label-hidden{visibility:hidden}.label-collapsed{display:none}\n"] }]
|
|
21
|
+
}], propDecorators: { property: [{
|
|
22
|
+
type: Input
|
|
23
|
+
}] } });
|
|
24
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVzdHdvcmxkLWxhYmVsLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC1yZXN0d29ybGQtY2xpZW50L3NyYy9saWIvY29tcG9uZW50cy9yZXN0d29ybGQtbGFiZWwvcmVzdHdvcmxkLWxhYmVsLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC1yZXN0d29ybGQtY2xpZW50L3NyYy9saWIvY29tcG9uZW50cy9yZXN0d29ybGQtbGFiZWwvcmVzdHdvcmxkLWxhYmVsLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ2pELE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxrQkFBa0IsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQ3RFLE9BQU8sRUFBWSxZQUFZLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQzs7O0FBRWpFOzs7O0dBSUc7QUFPSCxNQUFNLE9BQU8sdUJBQXVCO0lBSWxDLElBQVcsWUFBWTtRQUNyQixPQUFPLFlBQVksQ0FBQztJQUN0QixDQUFDOztvSEFOVSx1QkFBdUI7d0dBQXZCLHVCQUF1QixrRkNmcEMsOE1BS1EsbU5EUVMsQ0FBQyxFQUFFLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxXQUFXLEVBQUUsa0JBQWtCLEVBQUUsQ0FBQzsyRkFFcEUsdUJBQXVCO2tCQU5uQyxTQUFTOytCQUNFLFVBQVUsaUJBR0wsQ0FBQyxFQUFFLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxXQUFXLEVBQUUsa0JBQWtCLEVBQUUsQ0FBQzs4QkFJL0UsUUFBUTtzQkFEUCxLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBJbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQ29udHJvbENvbnRhaW5lciwgRm9ybUdyb3VwRGlyZWN0aXZlIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xuaW1wb3J0IHsgUHJvcGVydHksIFByb3BlcnR5VHlwZSB9IGZyb20gJ0B3ZXJ0enVpL25neC1oYWwtY2xpZW50JztcblxuLyoqXG4gKiBBIGxhYmVsIHRoYXQgaXMgZ2VuZXJhdGVkIGZyb20gdGhlIGdpdmVuIHByb3BlcnR5LlxuICogSWYgeW91IGFsc28gd2FudCBhbiBpbnB1dCBlbGVtZW50LCB5b3UgY2FuIGVpdGhlciB1c2UgUmVzdFdvcmxkRm9ybUVsZW1lbnQgPHJ3LWZvcm0tZWxlbWVudD4gdG8gaGF2ZSBhIGxhYmVsIGFuZCBhbiBpbnB1dCByZW5kZXJlZCxcbiAqIG9yIHVzZSBSZXN0V29ybGRJbnB1dCA8cnctaW5wdXQ+IHdoaWNoIHdpbGwganVzdCByZW5kZXIgdGhlIGlucHV0IGVsZW1lbnQsIHNvIHlvdSBjYW4gZnJlZWx5IHBsYWNlIHRoaXMgbGFiZWwuXG4gKi9cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ3J3LWxhYmVsJyxcbiAgdGVtcGxhdGVVcmw6ICcuL3Jlc3R3b3JsZC1sYWJlbC5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlVXJsczogWycuL3Jlc3R3b3JsZC1sYWJlbC5jb21wb25lbnQuY3NzJ10sXG4gIHZpZXdQcm92aWRlcnM6IFt7IHByb3ZpZGU6IENvbnRyb2xDb250YWluZXIsIHVzZUV4aXN0aW5nOiBGb3JtR3JvdXBEaXJlY3RpdmUgfV1cbn0pXG5leHBvcnQgY2xhc3MgUmVzdFdvcmxkTGFiZWxDb21wb25lbnQge1xuICBASW5wdXQoKVxuICBwcm9wZXJ0eSE6IFByb3BlcnR5O1xuXG4gIHB1YmxpYyBnZXQgUHJvcGVydHlUeXBlKCkge1xuICAgIHJldHVybiBQcm9wZXJ0eVR5cGU7XG4gIH1cbn1cbiIsIjxsYWJlbCBcclxuICAgICpuZ0lmPVwicHJvcGVydHkudHlwZSAhPT0gUHJvcGVydHlUeXBlLkhpZGRlblwiIFxyXG4gICAgW2F0dHIuZm9yXT1cInByb3BlcnR5Lm5hbWVcIlxyXG4gICAgW2NsYXNzLnAtZGlzYWJsZWRdPVwicHJvcGVydHkucmVhZE9ubHlcIj5cclxuICAgIHt7cHJvcGVydHkucHJvbXB0ID8/IHByb3BlcnR5Lm5hbWV9fVxyXG48L2xhYmVsPiJdfQ==
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
import { Component, Input } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
import * as i1 from "@angular/router";
|
|
4
|
+
import * as i2 from "@angular/common";
|
|
5
|
+
import * as i3 from "primeng/tooltip";
|
|
6
|
+
import * as i4 from "primeng/button";
|
|
7
|
+
import * as i5 from "primeng/splitbutton";
|
|
8
|
+
export class RestWorldMenuButtonComponent {
|
|
9
|
+
constructor(_router) {
|
|
10
|
+
this._router = _router;
|
|
11
|
+
this.items = [];
|
|
12
|
+
}
|
|
13
|
+
onClick(item) {
|
|
14
|
+
if (item.url) {
|
|
15
|
+
window.location.href = item.url;
|
|
16
|
+
}
|
|
17
|
+
else if (item.routerLink) {
|
|
18
|
+
this._router.navigate(item.routerLink, {
|
|
19
|
+
queryParams: item.queryParams,
|
|
20
|
+
fragment: item.fragment,
|
|
21
|
+
queryParamsHandling: item.queryParamsHandling,
|
|
22
|
+
preserveFragment: item.preserveFragment,
|
|
23
|
+
skipLocationChange: item.skipLocationChange,
|
|
24
|
+
replaceUrl: item.replaceUrl
|
|
25
|
+
});
|
|
26
|
+
}
|
|
27
|
+
else if (item.command) {
|
|
28
|
+
item.command();
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
RestWorldMenuButtonComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.0.3", ngImport: i0, type: RestWorldMenuButtonComponent, deps: [{ token: i1.Router }], target: i0.ɵɵFactoryTarget.Component });
|
|
33
|
+
RestWorldMenuButtonComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.0.3", type: RestWorldMenuButtonComponent, selector: "rw-menu-button", inputs: { items: "items" }, ngImport: i0, template: "<ng-container *ngFor=\"let item of items; index as i\">\n <p-button\n *ngIf=\"!item.items\"\n [label]=\"item.label!\"\n [icon]=\"item.icon!\"\n [disabled]=\"item.disabled!\"\n [style]=\"item.style\"\n [styleClass]=\"item.styleClass!\"\n [pTooltip]=\"item.tooltip!\"\n [tooltipPosition]=\"item.tooltipPosition!\"\n (onClick)=\"onClick(item)\"\n [class.ml-2]=\"i > 0\">\n </p-button>\n\n <p-splitButton\n *ngIf=\"item.items\"\n [label]=\"item.label!\"\n [icon]=\"item.icon!\"\n [model]=\"item.items\"\n appendTo=\"body\"\n [disabled]=\"item.disabled!\"\n [style]=\"item.style\"\n [styleClass]=\"item.styleClass!\"\n [pTooltip]=\"item.tooltip!\"\n [tooltipPosition]=\"item.tooltipPosition!\"\n (onClick)=\"onClick(item)\"\n [class.ml-2]=\"i > 0\">\n </p-splitButton>\n</ng-container>\n", styles: [""], dependencies: [{ kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.Tooltip, selector: "[pTooltip]", inputs: ["tooltipPosition", "tooltipEvent", "appendTo", "positionStyle", "tooltipStyleClass", "tooltipZIndex", "escape", "showDelay", "hideDelay", "life", "positionTop", "positionLeft", "fitContent", "pTooltip", "tooltipDisabled", "tooltipOptions"] }, { kind: "component", type: i4.Button, selector: "p-button", inputs: ["type", "iconPos", "icon", "badge", "label", "disabled", "loading", "loadingIcon", "style", "styleClass", "badgeClass", "ariaLabel"], outputs: ["onClick", "onFocus", "onBlur"] }, { kind: "component", type: i5.SplitButton, selector: "p-splitButton", inputs: ["model", "icon", "iconPos", "label", "style", "styleClass", "menuStyle", "menuStyleClass", "disabled", "tabindex", "appendTo", "dir", "expandAriaLabel", "showTransitionOptions", "hideTransitionOptions"], outputs: ["onClick", "onDropdownClick"] }] });
|
|
34
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.3", ngImport: i0, type: RestWorldMenuButtonComponent, decorators: [{
|
|
35
|
+
type: Component,
|
|
36
|
+
args: [{ selector: 'rw-menu-button', template: "<ng-container *ngFor=\"let item of items; index as i\">\n <p-button\n *ngIf=\"!item.items\"\n [label]=\"item.label!\"\n [icon]=\"item.icon!\"\n [disabled]=\"item.disabled!\"\n [style]=\"item.style\"\n [styleClass]=\"item.styleClass!\"\n [pTooltip]=\"item.tooltip!\"\n [tooltipPosition]=\"item.tooltipPosition!\"\n (onClick)=\"onClick(item)\"\n [class.ml-2]=\"i > 0\">\n </p-button>\n\n <p-splitButton\n *ngIf=\"item.items\"\n [label]=\"item.label!\"\n [icon]=\"item.icon!\"\n [model]=\"item.items\"\n appendTo=\"body\"\n [disabled]=\"item.disabled!\"\n [style]=\"item.style\"\n [styleClass]=\"item.styleClass!\"\n [pTooltip]=\"item.tooltip!\"\n [tooltipPosition]=\"item.tooltipPosition!\"\n (onClick)=\"onClick(item)\"\n [class.ml-2]=\"i > 0\">\n </p-splitButton>\n</ng-container>\n" }]
|
|
37
|
+
}], ctorParameters: function () { return [{ type: i1.Router }]; }, propDecorators: { items: [{
|
|
38
|
+
type: Input
|
|
39
|
+
}] } });
|
|
40
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVzdHdvcmxkLW1lbnUtYnV0dG9uLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC1yZXN0d29ybGQtY2xpZW50L3NyYy9saWIvY29tcG9uZW50cy9yZXN0d29ybGQtbWVudS1idXR0b24vcmVzdHdvcmxkLW1lbnUtYnV0dG9uLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC1yZXN0d29ybGQtY2xpZW50L3NyYy9saWIvY29tcG9uZW50cy9yZXN0d29ybGQtbWVudS1idXR0b24vcmVzdHdvcmxkLW1lbnUtYnV0dG9uLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDOzs7Ozs7O0FBU2pELE1BQU0sT0FBTyw0QkFBNEI7SUFJdkMsWUFBNkIsT0FBZTtRQUFmLFlBQU8sR0FBUCxPQUFPLENBQVE7UUFGckMsVUFBSyxHQUFjLEVBQUUsQ0FBQztJQUk3QixDQUFDO0lBRUQsT0FBTyxDQUFDLElBQWM7UUFDcEIsSUFBSSxJQUFJLENBQUMsR0FBRyxFQUFFO1lBQ1osTUFBTSxDQUFDLFFBQVEsQ0FBQyxJQUFJLEdBQUcsSUFBSSxDQUFDLEdBQUcsQ0FBQztTQUNqQzthQUFNLElBQUksSUFBSSxDQUFDLFVBQVUsRUFBRTtZQUMxQixJQUFJLENBQUMsT0FBTyxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsVUFBVSxFQUFFO2dCQUNyQyxXQUFXLEVBQUUsSUFBSSxDQUFDLFdBQVc7Z0JBQzdCLFFBQVEsRUFBRSxJQUFJLENBQUMsUUFBUTtnQkFDdkIsbUJBQW1CLEVBQUUsSUFBSSxDQUFDLG1CQUFtQjtnQkFDN0MsZ0JBQWdCLEVBQUUsSUFBSSxDQUFDLGdCQUFnQjtnQkFDdkMsa0JBQWtCLEVBQUUsSUFBSSxDQUFDLGtCQUFrQjtnQkFDM0MsVUFBVSxFQUFFLElBQUksQ0FBQyxVQUFVO2FBQzVCLENBQUMsQ0FBQztTQUNKO2FBQU0sSUFBSSxJQUFJLENBQUMsT0FBTyxFQUFFO1lBQ3ZCLElBQUksQ0FBQyxPQUFPLEVBQUUsQ0FBQztTQUNoQjtJQUNILENBQUM7O3lIQXZCVSw0QkFBNEI7NkdBQTVCLDRCQUE0QixrRkNUekMsczFCQTZCQTsyRkRwQmEsNEJBQTRCO2tCQUx4QyxTQUFTOytCQUNFLGdCQUFnQjs2RkFNbkIsS0FBSztzQkFEWCxLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBJbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgUm91dGVyIH0gZnJvbSAnQGFuZ3VsYXIvcm91dGVyJztcbmltcG9ydCB7IE1lbnVJdGVtIH0gZnJvbSAncHJpbWVuZy9hcGknO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdydy1tZW51LWJ1dHRvbicsXG4gIHRlbXBsYXRlVXJsOiAnLi9yZXN0d29ybGQtbWVudS1idXR0b24uY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi9yZXN0d29ybGQtbWVudS1idXR0b24uY29tcG9uZW50LmNzcyddXG59KVxuZXhwb3J0IGNsYXNzIFJlc3RXb3JsZE1lbnVCdXR0b25Db21wb25lbnQge1xuICBASW5wdXQoKVxuICBwdWJsaWMgaXRlbXM6IE1lbnVJdGVtW109IFtdO1xuXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgcmVhZG9ubHkgX3JvdXRlcjogUm91dGVyKSB7XG5cbiAgfVxuXG4gIG9uQ2xpY2soaXRlbTogTWVudUl0ZW0pIHtcbiAgICBpZiAoaXRlbS51cmwpIHtcbiAgICAgIHdpbmRvdy5sb2NhdGlvbi5ocmVmID0gaXRlbS51cmw7XG4gICAgfSBlbHNlIGlmIChpdGVtLnJvdXRlckxpbmspIHtcbiAgICAgIHRoaXMuX3JvdXRlci5uYXZpZ2F0ZShpdGVtLnJvdXRlckxpbmssIHtcbiAgICAgICAgcXVlcnlQYXJhbXM6IGl0ZW0ucXVlcnlQYXJhbXMsXG4gICAgICAgIGZyYWdtZW50OiBpdGVtLmZyYWdtZW50LFxuICAgICAgICBxdWVyeVBhcmFtc0hhbmRsaW5nOiBpdGVtLnF1ZXJ5UGFyYW1zSGFuZGxpbmcsXG4gICAgICAgIHByZXNlcnZlRnJhZ21lbnQ6IGl0ZW0ucHJlc2VydmVGcmFnbWVudCxcbiAgICAgICAgc2tpcExvY2F0aW9uQ2hhbmdlOiBpdGVtLnNraXBMb2NhdGlvbkNoYW5nZSxcbiAgICAgICAgcmVwbGFjZVVybDogaXRlbS5yZXBsYWNlVXJsXG4gICAgICB9KTtcbiAgICB9IGVsc2UgaWYgKGl0ZW0uY29tbWFuZCkge1xuICAgICAgaXRlbS5jb21tYW5kKCk7XG4gICAgfVxuICB9XG59XG4iLCI8bmctY29udGFpbmVyICpuZ0Zvcj1cImxldCBpdGVtIG9mIGl0ZW1zOyBpbmRleCBhcyBpXCI+XG4gIDxwLWJ1dHRvblxuICAgICpuZ0lmPVwiIWl0ZW0uaXRlbXNcIlxuICAgIFtsYWJlbF09XCJpdGVtLmxhYmVsIVwiXG4gICAgW2ljb25dPVwiaXRlbS5pY29uIVwiXG4gICAgW2Rpc2FibGVkXT1cIml0ZW0uZGlzYWJsZWQhXCJcbiAgICBbc3R5bGVdPVwiaXRlbS5zdHlsZVwiXG4gICAgW3N0eWxlQ2xhc3NdPVwiaXRlbS5zdHlsZUNsYXNzIVwiXG4gICAgW3BUb29sdGlwXT1cIml0ZW0udG9vbHRpcCFcIlxuICAgIFt0b29sdGlwUG9zaXRpb25dPVwiaXRlbS50b29sdGlwUG9zaXRpb24hXCJcbiAgICAob25DbGljayk9XCJvbkNsaWNrKGl0ZW0pXCJcbiAgICBbY2xhc3MubWwtMl09XCJpID4gMFwiPlxuICA8L3AtYnV0dG9uPlxuXG4gIDxwLXNwbGl0QnV0dG9uXG4gICAgKm5nSWY9XCJpdGVtLml0ZW1zXCJcbiAgICBbbGFiZWxdPVwiaXRlbS5sYWJlbCFcIlxuICAgIFtpY29uXT1cIml0ZW0uaWNvbiFcIlxuICAgIFttb2RlbF09XCJpdGVtLml0ZW1zXCJcbiAgICBhcHBlbmRUbz1cImJvZHlcIlxuICAgIFtkaXNhYmxlZF09XCJpdGVtLmRpc2FibGVkIVwiXG4gICAgW3N0eWxlXT1cIml0ZW0uc3R5bGVcIlxuICAgIFtzdHlsZUNsYXNzXT1cIml0ZW0uc3R5bGVDbGFzcyFcIlxuICAgIFtwVG9vbHRpcF09XCJpdGVtLnRvb2x0aXAhXCJcbiAgICBbdG9vbHRpcFBvc2l0aW9uXT1cIml0ZW0udG9vbHRpcFBvc2l0aW9uIVwiXG4gICAgKG9uQ2xpY2spPVwib25DbGljayhpdGVtKVwiXG4gICAgW2NsYXNzLm1sLTJdPVwiaSA+IDBcIj5cbiAgPC9wLXNwbGl0QnV0dG9uPlxuPC9uZy1jb250YWluZXI+XG4iXX0=
|