@wertzui/ngx-restworld-client 15.3.1 → 15.3.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (68) hide show
  1. package/esm2022/lib/components/restworld-displays/restworld-displays.mjs +87 -9
  2. package/esm2022/lib/components/restworld-file/restworld-file.component.mjs +6 -1
  3. package/esm2022/lib/components/restworld-form/restworld-form.component.mjs +21 -1
  4. package/esm2022/lib/components/restworld-inputs/restworld-inputs.mjs +85 -12
  5. package/esm2022/lib/components/restworld-label/restworld-label.component.mjs +9 -3
  6. package/esm2022/lib/components/restworld-menu-button/restworld-menu-button.component.mjs +3 -1
  7. package/esm2022/lib/components/restworld-table/restworld-table.component.mjs +3 -3
  8. package/esm2022/lib/components/restworld-validation-errors/restworld-validation-errors.component.mjs +6 -1
  9. package/esm2022/lib/constants/link-names.mjs +4 -1
  10. package/esm2022/lib/models/api-url.mjs +1 -1
  11. package/esm2022/lib/models/client-settings.mjs +1 -1
  12. package/esm2022/lib/models/restworld-image.mjs +1 -1
  13. package/esm2022/lib/pipes/as.pipe.mjs +3 -1
  14. package/esm2022/lib/pipes/clr-format.pipe.mjs +4 -4
  15. package/esm2022/lib/pipes/property-type-format.pipe.mjs +4 -2
  16. package/esm2022/lib/pipes/safe-url.pipe.mjs +3 -1
  17. package/esm2022/lib/restworld-client.module.mjs +31 -1
  18. package/esm2022/lib/services/o-data.service.mjs +23 -29
  19. package/esm2022/lib/services/opentelemetry.service.mjs +11 -1
  20. package/esm2022/lib/services/restworld-client.mjs +188 -1
  21. package/esm2022/lib/services/settings.service.mjs +2 -2
  22. package/esm2022/lib/util/debounce.mjs +8 -1
  23. package/esm2022/lib/views/restworld-edit-view/restworld-edit-view.component.mjs +6 -6
  24. package/fesm2022/wertzui-ngx-restworld-client.mjs +487 -61
  25. package/fesm2022/wertzui-ngx-restworld-client.mjs.map +1 -1
  26. package/lib/components/restworld-displays/restworld-displays.d.ts +86 -8
  27. package/lib/components/restworld-displays/restworld-displays.d.ts.map +1 -1
  28. package/lib/components/restworld-file/restworld-file.component.d.ts +5 -0
  29. package/lib/components/restworld-file/restworld-file.component.d.ts.map +1 -1
  30. package/lib/components/restworld-form/restworld-form.component.d.ts +20 -0
  31. package/lib/components/restworld-form/restworld-form.component.d.ts.map +1 -1
  32. package/lib/components/restworld-inputs/restworld-inputs.d.ts +82 -9
  33. package/lib/components/restworld-inputs/restworld-inputs.d.ts.map +1 -1
  34. package/lib/components/restworld-label/restworld-label.component.d.ts +8 -2
  35. package/lib/components/restworld-label/restworld-label.component.d.ts.map +1 -1
  36. package/lib/components/restworld-menu-button/restworld-menu-button.component.d.ts +2 -0
  37. package/lib/components/restworld-menu-button/restworld-menu-button.component.d.ts.map +1 -1
  38. package/lib/components/restworld-validation-errors/restworld-validation-errors.component.d.ts +5 -0
  39. package/lib/components/restworld-validation-errors/restworld-validation-errors.component.d.ts.map +1 -1
  40. package/lib/constants/link-names.d.ts +3 -0
  41. package/lib/constants/link-names.d.ts.map +1 -1
  42. package/lib/models/api-url.d.ts +9 -0
  43. package/lib/models/api-url.d.ts.map +1 -1
  44. package/lib/models/client-settings.d.ts +8 -1
  45. package/lib/models/client-settings.d.ts.map +1 -1
  46. package/lib/models/restworld-image.d.ts +1 -1
  47. package/lib/pipes/as.pipe.d.ts +2 -0
  48. package/lib/pipes/as.pipe.d.ts.map +1 -1
  49. package/lib/pipes/clr-format.pipe.d.ts +0 -1
  50. package/lib/pipes/clr-format.pipe.d.ts.map +1 -1
  51. package/lib/pipes/property-type-format.pipe.d.ts.map +1 -1
  52. package/lib/pipes/safe-url.pipe.d.ts +2 -0
  53. package/lib/pipes/safe-url.pipe.d.ts.map +1 -1
  54. package/lib/restworld-client.module.d.ts +30 -0
  55. package/lib/restworld-client.module.d.ts.map +1 -1
  56. package/lib/services/o-data.service.d.ts +22 -23
  57. package/lib/services/o-data.service.d.ts.map +1 -1
  58. package/lib/services/opentelemetry.service.d.ts +10 -0
  59. package/lib/services/opentelemetry.service.d.ts.map +1 -1
  60. package/lib/services/restworld-client.d.ts +187 -0
  61. package/lib/services/restworld-client.d.ts.map +1 -1
  62. package/lib/services/settings.service.d.ts +1 -1
  63. package/lib/services/settings.service.d.ts.map +1 -1
  64. package/lib/util/debounce.d.ts +7 -0
  65. package/lib/util/debounce.d.ts.map +1 -1
  66. package/lib/views/restworld-edit-view/restworld-edit-view.component.d.ts +17 -0
  67. package/lib/views/restworld-edit-view/restworld-edit-view.component.d.ts.map +1 -1
  68. package/package.json +1 -1
@@ -15,10 +15,21 @@ import * as i10 from "../../pipes/property-type-format.pipe";
15
15
  /**
16
16
  * Display the value of a form element with a label that is automatically created from a property in a form template.
17
17
  * This may also be a complex object or a collection in which case multiple and nested display elements may be rendered.
18
- * If you want to display just the value without a label, use RestWorldDisplayComponent <rw-display>.
18
+ * If you want to display just the value without a label, use {@link RestWorldDisplayComponent} `<rw-display>`.
19
+ * @example
20
+ * <rw-display-element [property]="property" [apiName]="apiName" [value]="value"></rw-display-element>
19
21
  */
20
22
  export class RestWorldDisplayElementComponent {
23
+ /**
24
+ * The property to display.
25
+ * @required
26
+ */
21
27
  property;
28
+ /**
29
+ * The name of the API to use for the property.
30
+ * @required
31
+ * @remarks This is the name of the API as defined in the `RestWorldClientCollection`.
32
+ */
22
33
  apiName;
23
34
  _value;
24
35
  /**
@@ -51,12 +62,23 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.2", ngImpor
51
62
  /**
52
63
  * Displays a value that is automatically created from a property in a form template.
53
64
  * This may also be a complex object or a collection in which case multiple and nested input elements may be rendered.
54
- * If you also want a label, use RestWorldDisplayElementComponent <rw-display-element>.
55
- * You can also use one of the different RestWorldDisplay... <rw-display-...> elements to render a specific property type,
65
+ * If you also want a label, use {@link RestWorldDisplayElementComponent} `<rw-display-element>`.
66
+ * You can also use one of the different RestWorldDisplay... `<rw-display-...>` elements to render a specific property type,
56
67
  * but it is advised to control the rendered element through the passed in property.
68
+ * @example
69
+ * <rw-display [property]="property" [apiName]="apiName" [value]="value"></rw-display>
57
70
  */
58
71
  export class RestWorldDisplayComponent {
72
+ /**
73
+ * The property to display.
74
+ * @required
75
+ */
59
76
  property;
77
+ /**
78
+ * The name of the API to use for the property.
79
+ * @required
80
+ * @remarks This is the name of the API as defined in the `RestWorldClientCollection`.
81
+ */
60
82
  apiName;
61
83
  _value;
62
84
  /**
@@ -92,11 +114,22 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.2", ngImpor
92
114
  /**
93
115
  * Displays the value of a collection that is automatically created from the given property.
94
116
  * The elements and can also be nested.
95
- * @remarks It is advised to use RestWorldDisplayComponent <rw-display> and control the rendered elements with the passed in property
117
+ * @remarks It is advised to use {@link RestWorldDisplayComponent} `<rw-display>` and control the rendered elements with the passed in property
96
118
  * instead of using this component directly.
119
+ * @example
120
+ * <rw-display-collection [property]="property" [apiName]="apiName" [values]="values"></rw-display-collection>
97
121
  */
98
122
  export class RestWorldDisplayCollectionComponent {
123
+ /**
124
+ * The property to display.
125
+ * @required
126
+ */
99
127
  property;
128
+ /**
129
+ * The name of the API to use for the property.
130
+ * @required
131
+ * @remarks This is the name of the API as defined in the `RestWorldClientCollection`.
132
+ */
100
133
  apiName;
101
134
  _values;
102
135
  /**
@@ -154,13 +187,24 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.2", ngImpor
154
187
  /**
155
188
  * Displays the value of a dropdown that is automatically created from the given property.
156
189
  * If set the dropdown will use the `inline` property of the options to render the `selectedValues` Otherwise it will just render the values, but no prompt for them.
157
- * @remarks It is advised to use RestWorldDisplayComponent <rw-display> and control the rendered elements with the passed in property
190
+ * @remarks It is advised to use {@link RestWorldDisplayComponent} `<rw-display>` and control the rendered elements with the passed in property
158
191
  * instead of using this component directly.
192
+ * @example
193
+ * <rw-display-dropdown [property]="property" [apiName]="apiName" [selectedValues]="selectedValues"></rw-display-dropdown>
159
194
  */
160
195
  export class RestWorldDisplayDropdownComponent {
161
196
  _messageService;
162
197
  _clients;
198
+ /**
199
+ * The property to display.
200
+ * @required
201
+ */
163
202
  property;
203
+ /**
204
+ * The name of the API to use for the property.
205
+ * @required
206
+ * @remarks This is the name of the API as defined in the `RestWorldClientCollection`.
207
+ */
164
208
  apiName;
165
209
  _selectedValues;
166
210
  /**
@@ -311,11 +355,22 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.2", ngImpor
311
355
  /**
312
356
  * Displays the value of a complex object with multiple properties that is automatically created from the given property.
313
357
  * The object can also be nested.
314
- * @remarks It is advised to use RestWorldDisplayComponent <rw-display> and control the rendered elements with the passed in property
358
+ * @remarks It is advised to use {@link RestWorldDisplayComponent} `<rw-display>` and control the rendered elements with the passed in property
315
359
  * instead of using this component directly.
360
+ * @example
361
+ * <rw-display-object [property]="property" [apiName]="apiName" [value]="value"></rw-display-object>
316
362
  */
317
363
  export class RestWorldDisplayObjectComponent {
364
+ /**
365
+ * The property to display.
366
+ * @required
367
+ */
318
368
  property;
369
+ /**
370
+ * The name of the API to use for the property.
371
+ * @required
372
+ * @remarks This is the name of the API as defined in the `RestWorldClientCollection`.
373
+ */
319
374
  apiName;
320
375
  _value;
321
376
  /**
@@ -344,11 +399,22 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.2", ngImpor
344
399
  }] } });
345
400
  /**
346
401
  * Displays the value of a simple element, like a string, a number or a Date that is automatically created from the given property.
347
- * @remarks It is advised to use RestWorldDisplayComponent <rw-display> and control the rendered elements with the passed in property
402
+ * @remarks It is advised to use {@link RestWorldDisplayComponent} `<rw-display>` and control the rendered elements with the passed in property
348
403
  * instead of using this component directly.
404
+ * @example
405
+ * <rw-display-simple [property]="property" [apiName]="apiName" [value]="value"></rw-display-simple>
349
406
  */
350
407
  export class RestWorldDisplaySimpleComponent {
408
+ /**
409
+ * The property to display.
410
+ * @required
411
+ */
351
412
  property;
413
+ /**
414
+ * The name of the API to use for the property.
415
+ * @required
416
+ * @remarks This is the name of the API as defined in the `RestWorldClientCollection`.
417
+ */
352
418
  apiName;
353
419
  _value;
354
420
  /**
@@ -399,10 +465,22 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.2", ngImpor
399
465
  type: Input
400
466
  }] } });
401
467
  /**
402
- * Displays the values of a collection of rw-display-elements automatically created from a template.
468
+ * Displays the values of a collection of `<rw-display>` elements automatically created from a template.
469
+ * @example
470
+ * <rw-display-template [template]="template" [apiName]="apiName" [value]="value"></rw-display-template>
403
471
  */
404
472
  export class RestWorldDisplayTemplateComponent {
473
+ /**
474
+ * The template to display.
475
+ * @required
476
+ * @remarks This is the template that defines the properties to display.
477
+ */
405
478
  template;
479
+ /**
480
+ * The name of the API to use for the property.
481
+ * @required
482
+ * @remarks This is the name of the API as defined in the `RestWorldClientCollection`.
483
+ */
406
484
  apiName;
407
485
  _value;
408
486
  /**
@@ -429,4 +507,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.2", ngImpor
429
507
  }], value: [{
430
508
  type: Input
431
509
  }] } });
432
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"restworld-displays.js","sourceRoot":"","sources":["../../../../../../projects/ngx-restworld-client/src/lib/components/restworld-displays/restworld-displays.ts","../../../../../../projects/ngx-restworld-client/src/lib/components/restworld-displays/restworld-display-element/restworld-display-element.component.html","../../../../../../projects/ngx-restworld-client/src/lib/components/restworld-displays/restworld-display/restworld-display.component.html","../../../../../../projects/ngx-restworld-client/src/lib/components/restworld-displays/restworld-display-collection/restworld-display-collection.component.html","../../../../../../projects/ngx-restworld-client/src/lib/components/restworld-displays/restworld-display-dropdown/restworld-display-dropdown.component.html","../../../../../../projects/ngx-restworld-client/src/lib/components/restworld-displays/restworld-display-object/restworld-display-object.component.html","../../../../../../projects/ngx-restworld-client/src/lib/components/restworld-displays/restworld-display-simple/restworld-display-simple.component.html","../../../../../../projects/ngx-restworld-client/src/lib/components/restworld-displays/restworld-display-template/restworld-display-template.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ContentChild, Input, OnInit, TemplateRef } from '@angular/core';\r\nimport { Property, SimpleValue, PropertyType, Template, NumberTemplate, TemplateDto, Options, ExtractGenericOptionsItemType, ExtractValueType, ExtractGenericOptionsSelectedValuesType, ProblemDetails, ResourceOfDto } from '@wertzui/ngx-hal-client';\r\nimport { PropertyWithOptions, PropertyWithImage } from '../../models/special-properties'\r\nimport { PropertyTemplateContext } from '../../models/templating';\r\nimport { MessageService } from 'primeng/api';\r\nimport { RestWorldClientCollection } from '../../services/restworld-client-collection';\r\nimport { RestWorldClient } from '../../services/restworld-client';\r\n\r\n/**\r\n * Display the value of 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 display elements may be rendered.\r\n * If you want to display just the value without a label, use RestWorldDisplayComponent <rw-display>.\r\n */\r\n@Component({\r\n    selector: 'rw-display-element',\r\n    templateUrl: './restworld-display-element/restworld-display-element.component.html',\r\n    styleUrl: './restworld-display-element/restworld-display-element.component.css'\r\n})\r\nexport class RestWorldDisplayElementComponent<TProperty extends Property<SimpleValue, string, string>> {\r\n    @Input({ required: true })\r\n    property!: TProperty;\r\n\r\n    @Input({ required: true })\r\n    apiName!: string;\r\n\r\n    private _value?: ExtractValueType<TProperty> | ExtractGenericOptionsSelectedValuesType<TProperty>[] | ExtractGenericOptionsSelectedValuesType<TProperty> | Record<string, SimpleValue> | Map<number, Record<string, SimpleValue>>;\r\n    /**\r\n     * The value to display. If not set, the value of the property will be used.\r\n    */\r\n    @Input()\r\n    public set value(value: ExtractValueType<TProperty> | ExtractGenericOptionsSelectedValuesType<TProperty>[] | ExtractGenericOptionsSelectedValuesType<TProperty> | Record<string, SimpleValue> | Map<number, Record<string, SimpleValue>>) {\r\n        this._value = value;\r\n    }\r\n    public get value() {\r\n        return this._value ?? this.property.value as ExtractValueType<TProperty>;\r\n    }\r\n\r\n    public get PropertyType() {\r\n        return PropertyType;\r\n    }\r\n}\r\n/**\r\n * Displays a value 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 RestWorldDisplayElementComponent <rw-display-element>.\r\n * You can also use one of the different RestWorldDisplay... <rw-display-...> elements to render a specific  property type,\r\n * but it is advised to control the rendered element through the passed in property.\r\n */\r\n@Component({\r\n    selector: 'rw-display',\r\n    templateUrl: './restworld-display/restworld-display.component.html',\r\n    styleUrl: './restworld-display/restworld-display.component.css'\r\n})\r\nexport class RestWorldDisplayComponent<TProperty extends Property<SimpleValue, string, string>> {\r\n    @Input({ required: true })\r\n    property!: TProperty;\r\n\r\n    @Input({ required: true })\r\n    apiName!: string;\r\n\r\n    private _value?: ExtractValueType<TProperty> | ExtractGenericOptionsSelectedValuesType<TProperty>[] | ExtractGenericOptionsSelectedValuesType<TProperty> | Record<string, SimpleValue> | Map<number, Record<string, SimpleValue>>;\r\n    /**\r\n     * The value to display. If not set, the value of the property will be used.\r\n    */\r\n    @Input()\r\n    public set value(value: ExtractValueType<TProperty> | ExtractGenericOptionsSelectedValuesType<TProperty>[] | ExtractGenericOptionsSelectedValuesType<TProperty> | Record<string, SimpleValue> | Map<number, Record<string, SimpleValue>> | undefined) {\r\n        this._value = value;\r\n    }\r\n    public get value() {\r\n        return this._value ?? this.property.value as ExtractValueType<TProperty>;\r\n    }\r\n\r\n    public get PropertyType() {\r\n        return PropertyType;\r\n    }\r\n\r\n    public get PropertyWithOptions() {\r\n        return PropertyWithOptions<SimpleValue, string, string>;\r\n    }\r\n}\r\n\r\n/**\r\n * Displays the value of a collection that is automatically created from the given property.\r\n * The elements and can also be nested.\r\n * @remarks It is advised to use RestWorldDisplayComponent <rw-display> and control the rendered elements with the passed in property\r\n * instead of using this component directly.\r\n */\r\n@Component({\r\n    selector: 'rw-display-collection',\r\n    templateUrl: './restworld-display-collection/restworld-display-collection.component.html',\r\n    styleUrl: './restworld-display-collection/restworld-display-collection.component.css'\r\n})\r\nexport class RestWorldDisplayCollectionComponent implements OnInit {\r\n    @Input({ required: true })\r\n    property!: Property & { _templates: { default: Template } };\r\n\r\n    @Input({ required: true })\r\n    apiName!: string;\r\n\r\n    private _values?: any[];\r\n    /**\r\n     * The value to display. If not set, the value of the property will be used.\r\n    */\r\n    @Input()\r\n    public set values(values: any[] | Partial<Record<string, any>> | undefined) {\r\n        this._values = RestWorldDisplayCollectionComponent.toArray(values);\r\n    }\r\n    public get values(): any[] | undefined {\r\n        return this._values;\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    ngOnInit(): void {\r\n        this._templates = this._values ?\r\n            Array.from(RestWorldDisplayCollectionComponent.map(this._values.entries(), entry => (new NumberTemplate({ ...(this.property._templates.default as TemplateDto), title: entry[0].toString() })))) :\r\n            RestWorldDisplayCollectionComponent.getCollectionEntryTemplates(this.property);\r\n    }\r\n\r\n    private static * map<T1, T2>(iterable: IterableIterator<T1>, callback: (value: T1) => T2) {\r\n        for (let x of iterable) {\r\n            yield callback(x);\r\n        }\r\n    }\r\n\r\n    private static toArray(arrayOrDictionary: any[] | Partial<Record<string, any>> | undefined): any[] | undefined {\r\n        if (!arrayOrDictionary)\r\n            return undefined;\r\n\r\n        if (Array.isArray(arrayOrDictionary))\r\n            return arrayOrDictionary;\r\n\r\n        return Object.entries(arrayOrDictionary).map(([key, value]) => ({ key, value }));\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 as TemplateDto));\r\n    }\r\n}\r\n\r\n/**\r\n * Displays the value of a dropdown that is automatically created from the given property.\r\n * If set the dropdown will use the `inline` property of the options to render the `selectedValues` Otherwise it will just render the values, but no prompt for them.\r\n * @remarks It is advised to use RestWorldDisplayComponent <rw-display> and control the rendered elements with the passed in property\r\n * instead of using this component directly.\r\n */\r\n@Component({\r\n    selector: 'rw-display-dropdown',\r\n    templateUrl: './restworld-display-dropdown/restworld-display-dropdown.component.html',\r\n    styleUrl: './restworld-display-dropdown/restworld-display-dropdown.component.css'\r\n})\r\nexport class RestWorldDisplayDropdownComponent<TProperty extends Property<SimpleValue, string, string> & { options: Options<SimpleValue, string, string> }, TOptionsItem extends ExtractGenericOptionsItemType<TProperty> = ExtractGenericOptionsItemType<TProperty>> implements OnInit {\r\n    @Input({ required: true })\r\n    property!: TProperty;\r\n\r\n    @Input({ required: true })\r\n    apiName!: string;\r\n\r\n    private _selectedValues?: ExtractGenericOptionsSelectedValuesType<TProperty>[];\r\n    /**\r\n     * The values to display. If not set, the values of the property options will be used.\r\n    */\r\n    @Input()\r\n    public set selectedValues(value: ExtractGenericOptionsSelectedValuesType<TProperty>[] | ExtractGenericOptionsSelectedValuesType<TProperty> | undefined) {\r\n        if (Array.isArray(value))\r\n            this._selectedValues = value as ExtractGenericOptionsSelectedValuesType<TProperty>[];\r\n        else if (value !== undefined && value !== null)\r\n            this._selectedValues = [value];\r\n    }\r\n\r\n    public get selectedValues(): ExtractGenericOptionsSelectedValuesType<TProperty>[] {\r\n        return this._selectedValues ?? (this.property.options.selectedValues as unknown as ExtractGenericOptionsSelectedValuesType<TProperty>[] | undefined) ?? [];\r\n    }\r\n\r\n    private _inline: TOptionsItem[] = [];\r\n\r\n    /**\r\n     * A function that returns the label for the given item.\r\n     * The default returns the prompt and optionally the value in brackets.\r\n     * The value in brackets will only be displayed if the `cols` field of the property is undefined or greater than 1.\r\n     * Overwrite this function to change the label.\r\n     * @param item The item to get the label for.\r\n     */\r\n    @Input()\r\n    getLabel: (item: TOptionsItem) => string = this.getLabelInternal;\r\n\r\n    /**\r\n     * A function that returns the tooltip for the given item.\r\n     * The default returns all properties of the item except the ones that start with an underscore or the ones that are in the list of default properties to exclude.\r\n     * The default properties to exclude are: createdAt, createdBy, lastChangedAt, lastChangedBy, timestamp, promptField, valueField.\r\n     * Overwrite this function to change the tooltip.\r\n     * @param item The item to get the label for.\r\n     */\r\n    @Input()\r\n    getTooltip: (item: TOptionsItem) => string = this.getTooltipInternal;\r\n\r\n    @ContentChild('inputOptions', { static: false })\r\n    inputOptionsRef?: TemplateRef<PropertyTemplateContext>;\r\n\r\n    public get valueField(): string {\r\n        return this.property.options.valueField ?? \"value\";\r\n    }\r\n\r\n    public get promptField(): string {\r\n        return this.property.options.promptField ?? \"prompt\";\r\n    }\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    async ngOnInit(): Promise<void> {\r\n        if (this.property.options?.inline && this.property.options.inline.length > 0)\r\n            this._inline = Array.from(this.property.options.inline) as TOptionsItem[];\r\n\r\n        await this.setInitialSelectedOptionsElementForProperty();\r\n    }\r\n\r\n    public getOptionItem(value: ExtractGenericOptionsSelectedValuesType<TProperty>): TOptionsItem {\r\n        return this._inline.find(o => this.getValue(o as TOptionsItem) === value) as TOptionsItem ?? this.createOptionsItem(value);\r\n    }\r\n\r\n    private createOptionsItem(value: ExtractGenericOptionsSelectedValuesType<TProperty>): TOptionsItem {\r\n        return { [this.valueField]: value, [this.promptField]: \"\" } as TOptionsItem;\r\n    }\r\n\r\n    public getValue(item: TOptionsItem): ExtractGenericOptionsSelectedValuesType<TProperty> {\r\n        if (item === undefined || item === null || !item.hasOwnProperty(this.valueField))\r\n            throw new Error(`The item does not have a property ${this.valueField}.`);\r\n\r\n        return item[this.valueField as keyof TOptionsItem] as ExtractGenericOptionsSelectedValuesType<TProperty>;\r\n    }\r\n\r\n    public getPrompt(item: TOptionsItem): string {\r\n        if (item === undefined || item === null || !item.hasOwnProperty(this.promptField))\r\n            return \"\";\r\n\r\n        return item[this.promptField as keyof TOptionsItem] as string;\r\n    }\r\n\r\n    public getLabelInternal(item: TOptionsItem): string {\r\n        if (item === undefined || item === null)\r\n            return \"\";\r\n\r\n        const prompt = this.getPrompt(item);\r\n        const value = this.getValue(item);\r\n\r\n        let label = prompt;\r\n        if (label === undefined || label === null || label === \"\")\r\n            label = (value?.toString() ?? \"\");\r\n        else if ((this.property.cols === undefined || this.property.cols > 1) && prompt?.toLowerCase() !== value?.toString().toLowerCase())\r\n            label += ` (${value})`;\r\n\r\n        return label;\r\n    }\r\n\r\n    private getTooltipInternal(item: TOptionsItem): string {\r\n        if (item === undefined || item === null)\r\n            return \"\";\r\n\r\n        const tooltip = Object.entries(item)\r\n            .filter(([key]) => !(key.startsWith('_') || ['createdAt', 'createdBy', 'lastChangedAt', 'lastChangedBy', 'timestamp', this.promptField, this.valueField].includes(key)))\r\n            .reduce((prev, [key, value], index) => `${prev}${index === 0 ? '' : '\\n'}${key}: ${RestWorldDisplayDropdownComponent.jsonStringifyWithElipsis(value)}`, '');\r\n\r\n        return tooltip;\r\n    }\r\n\r\n    private async setInitialSelectedOptionsElementForProperty(): Promise<void> {\r\n        const options = this.property.options;\r\n\r\n        if (!options.link?.href || !this.selectedValues || this.selectedValues.length === 0 || this.selectedValues.every(v => this._inline.some(i => this.getValue(i as TOptionsItem) === v) ?? false))\r\n            return;\r\n\r\n        const filter = `${options.valueField} in (${this.selectedValues})`;\r\n        await this.SetInlineOptionsFromFilter(filter);\r\n    }\r\n\r\n    private async SetInlineOptionsFromFilter(filter: string) {\r\n        const options = this.property.options;\r\n        if (!options.link?.href)\r\n            throw new Error('The property does not have a link href.');\r\n\r\n        const templatedUri = options.link.href;\r\n        const response = await this.getClient().getListByUri<TOptionsItem>(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 initial selected items for the property ${this.property.name}.`;\r\n            this._messageService.add({ severity: 'error', summary: 'Error', detail: message, data: response, sticky: true });\r\n        }\r\n\r\n        const items = response.body!._embedded.items as ResourceOfDto<TOptionsItem>[];\r\n        const newItems = this.combineInlineWithSelected(items);\r\n        this._inline = newItems;\r\n    }\r\n\r\n    private combineInlineWithSelected(items: ResourceOfDto<TOptionsItem>[]): TOptionsItem[] {\r\n        const oldInline = this._inline as ResourceOfDto<TOptionsItem>[];\r\n        if (!oldInline || oldInline.length === 0)\r\n            return items;\r\n\r\n        const itemsToKeep = oldInline.filter(i => this.selectedValues.includes(this.getValue(i as TOptionsItem)));\r\n        const newItems = items.concat(itemsToKeep.filter(i => !items.includes(i)));\r\n\r\n        return newItems;\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 * Displays the value of a complex object with multiple properties that is automatically created from the given property.\r\n * The object can also be nested.\r\n * @remarks It is advised to use RestWorldDisplayComponent <rw-display> and control the rendered elements with the passed in property\r\n * instead of using this component directly.\r\n */\r\n@Component({\r\n    selector: 'rw-display-object',\r\n    templateUrl: './restworld-display-object/restworld-display-object.component.html',\r\n    styleUrl: './restworld-display-object/restworld-display-object.component.css'\r\n})\r\nexport class RestWorldDisplayObjectComponent {\r\n    @Input({ required: true })\r\n    property!: Property<null, never, never> & { _templates: { default: Template } };\r\n\r\n    @Input({ required: true })\r\n    apiName!: string;\r\n\r\n    private _value?: Record<string, SimpleValue>;\r\n    /**\r\n     * The value to display. If not set, the value of the template properties will be used.\r\n    */\r\n    @Input()\r\n    public set value(value: Record<string, SimpleValue> | undefined) {\r\n        this._value = value;\r\n    }\r\n    public get value() {\r\n        return this._value;\r\n    }\r\n}\r\n\r\n/**\r\n * Displays the value of a simple element, like a string, a number or a Date that is automatically created from the given property.\r\n * @remarks It is advised to use RestWorldDisplayComponent <rw-display> and control the rendered elements with the passed in property\r\n * instead of using this component directly.\r\n */\r\n@Component({\r\n    selector: 'rw-display-simple',\r\n    templateUrl: './restworld-display-simple/restworld-display-simple.component.html',\r\n    styleUrl: './restworld-display-simple/restworld-display-simple.component.css'\r\n})\r\nexport class RestWorldDisplaySimpleComponent<TProperty extends Property<SimpleValue, string, string>> {\r\n    @Input({ required: true })\r\n    property!: TProperty;\r\n\r\n    @Input({ required: true })\r\n    apiName!: string;\r\n\r\n    private _value?: SimpleValue;\r\n    /**\r\n     * The value to display. If not set, the value of the property will be used.\r\n    */\r\n    @Input()\r\n    public set value(value: SimpleValue) {\r\n        this._value = value;\r\n    }\r\n    public get value() {\r\n        return this._value ?? this.property.value;\r\n    }\r\n\r\n    public get PropertyType() {\r\n        return PropertyType;\r\n    }\r\n\r\n    private static readonly _dateFormat = new Date(3333, 10, 22) // months start at 0 in JS\r\n        .toLocaleDateString()\r\n        .replace(\"22\", \"dd\")\r\n        .replace(\"11\", \"MM\")\r\n        .replace(\"3333\", \"yyyy\")\r\n        .replace(\"33\", \"yy\");\r\n\r\n    public get dateFormat(): string {\r\n        return RestWorldDisplaySimpleComponent._dateFormat;\r\n    }\r\n\r\n    private static readonly _timeFormat = new Date(1, 1, 1, 22, 33, 44)\r\n        .toLocaleTimeString()\r\n        .replace(\"22\", \"hh\")\r\n        .replace(\"33\", \"mm\")\r\n        .replace(\"44\", \"ss\");\r\n\r\n    public get timeFormat() {\r\n        return RestWorldDisplaySimpleComponent._timeFormat;\r\n    }\r\n\r\n    public get PropertyWithImage() {\r\n        return PropertyWithImage;\r\n    }\r\n}\r\n\r\n/**\r\n * Displays the values of a collection of rw-display-elements automatically created from a template.\r\n */\r\n@Component({\r\n    selector: 'rw-display-template',\r\n    templateUrl: './restworld-display-template/restworld-display-template.component.html',\r\n    styleUrl: './restworld-display-template/restworld-display-template.component.css'\r\n})\r\nexport class RestWorldDisplayTemplateComponent {\r\n    @Input({ required: true })\r\n    template!: Template;\r\n\r\n    @Input({ required: true })\r\n    apiName!: string;\r\n\r\n    private _value?: Record<string, any>;\r\n    /**\r\n     * The value to display. If not set, the values of the template properties will be used.\r\n    */\r\n    @Input()\r\n    public set value(value: Record<string, any> | undefined) {\r\n        this._value = value;\r\n    }\r\n    public get value() {\r\n        return this._value;\r\n    }\r\n}\r\n","<div class=\"grid field\" *ngIf=\"property.type !== PropertyType.Hidden\">\r\n    <rw-label [property]=\"property\" class=\"col-12 md:col-2 flex align-items-center\"></rw-label>\r\n    <rw-display [property]=\"property\" [value]=\"value\" [apiName]=\"apiName\" class=\"col-12 md:col-10\"></rw-display>\r\n</div>\r\n","<ng-container *ngIf=\"property.type !== PropertyType.Hidden\">\r\n    <rw-display-dropdown *ngIf=\"property.options\" [property]=\"$any(property)\" [selectedValues]=\"$any(value)\" [apiName]=\"apiName\"></rw-display-dropdown>\r\n\r\n    <ng-container *ngIf=\"!property.options\">\r\n        <ng-container [ngSwitch]=\"property.type\">\r\n            <rw-display-object *ngSwitchCase=\"PropertyType.Object\" [property]=\"$any(property)\" [value]=\"$any(value)\" [apiName]=\"apiName\"></rw-display-object>\r\n            <rw-display-collection *ngSwitchCase=\"PropertyType.Collection\" [property]=\"$any(property)\" [values]=\"$any(value)\" [apiName]=\"apiName\"></rw-display-collection>\r\n            <rw-display-simple *ngSwitchDefault [property]=\"property\" [value]=\"$any(value)\" [apiName]=\"apiName\"></rw-display-simple>\r\n        </ng-container>\r\n    </ng-container>\r\n</ng-container>\r\n","<div class=\"flex align-items-center\">\r\n    <div class=\"brace\">\r\n    </div>\r\n    <div class=\"w-full\">\r\n        <div *ngFor=\"let template of templates\" class=\"flex align-items-center\">\r\n            <div class=\"brace\">\r\n            </div>\r\n            <div class=\"w-full flex justify-content-end\">\r\n                <rw-display-template [template]=\"$any(template)\" [value]=\"values ? values[template.title!] : undefined\" [apiName]=\"apiName\" class=\"w-full\"></rw-display-template>\r\n            </div>\r\n        </div>\r\n    </div>\r\n</div>\r\n","<!-- <ng-template #defaultInputOptions let-property=\"property\" let-selectedValues=\"selectedValues\"> -->\r\n<ng-container *ngFor=\"let value of selectedValues; last as last;\">\r\n    <span [pTooltip]=\"getTooltip(getOptionItem(value))\">{{getLabel(getOptionItem(value))}}</span>{{last ? \"\" : \", \"}}\r\n</ng-container>\r\n<!-- </ng-template>\r\n<ng-container *ngTemplateOutlet=\"inputOptionsRef ?? defaultInputOptions; context: { property: property, selectedValues: selectedValues }\"></ng-container> -->","<div class=\"flex align-items-center\">\r\n    <div class=\"brace\">\r\n    </div>\r\n    <div class=\"w-full\">\r\n        <rw-display-template [template]=\"property._templates.default\" [value]=\"value\" [apiName]=\"apiName\"></rw-display-template>\r\n    </div>\r\n</div>","<ng-container [ngSwitch]=\"property.type\">\r\n    <ng-container *ngSwitchCase=\"PropertyType.Text\">\r\n        <rw-avatar *ngIf=\"property.name === 'createdBy' || property.name === 'lastChangedBy'\" [user]=\"$any(value)\"></rw-avatar>\r\n        <span *ngIf=\"property.name !== 'createdBy' && property.name !== 'lastChangedBy'\" class=\"w-full\">{{value | propertyTypeFormat:property.type}}</span>\r\n    </ng-container>\r\n\r\n    <ng-container *ngSwitchCase=\"PropertyType.Bool\">\r\n        <p-checkbox *ngIf=\"property.required\" [(ngModel)]=\"value\" [binary]=\"true\" [readonly]=\"true\" [disabled]=\"true\"></p-checkbox>\r\n        <p-triStateCheckbox *ngIf=\"!property.required\" [(ngModel)]=\"value\" [readonly]=\"true\" [disabled]=\"true\"></p-triStateCheckbox>\r\n    </ng-container>\r\n\r\n    <span *ngSwitchDefault class=\"w-full\">{{value | propertyTypeFormat:property.type}}</span>\r\n</ng-container>\r\n","<rw-display-element *ngFor=\"let property of template.properties\" [property]=\"property\" [value]=\"value ? value[property.name] : undefined\" [apiName]=\"apiName\"></rw-display-element>"]}
510
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"restworld-displays.js","sourceRoot":"","sources":["../../../../../../projects/ngx-restworld-client/src/lib/components/restworld-displays/restworld-displays.ts","../../../../../../projects/ngx-restworld-client/src/lib/components/restworld-displays/restworld-display-element/restworld-display-element.component.html","../../../../../../projects/ngx-restworld-client/src/lib/components/restworld-displays/restworld-display/restworld-display.component.html","../../../../../../projects/ngx-restworld-client/src/lib/components/restworld-displays/restworld-display-collection/restworld-display-collection.component.html","../../../../../../projects/ngx-restworld-client/src/lib/components/restworld-displays/restworld-display-dropdown/restworld-display-dropdown.component.html","../../../../../../projects/ngx-restworld-client/src/lib/components/restworld-displays/restworld-display-object/restworld-display-object.component.html","../../../../../../projects/ngx-restworld-client/src/lib/components/restworld-displays/restworld-display-simple/restworld-display-simple.component.html","../../../../../../projects/ngx-restworld-client/src/lib/components/restworld-displays/restworld-display-template/restworld-display-template.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ContentChild, Input, OnInit, TemplateRef } from '@angular/core';\r\nimport { Property, SimpleValue, PropertyType, Template, NumberTemplate, TemplateDto, Options, ExtractGenericOptionsItemType, ExtractValueType, ExtractGenericOptionsSelectedValuesType, ProblemDetails, ResourceOfDto } from '@wertzui/ngx-hal-client';\r\nimport { PropertyWithOptions, PropertyWithImage } from '../../models/special-properties'\r\nimport { PropertyTemplateContext } from '../../models/templating';\r\nimport { MessageService } from 'primeng/api';\r\nimport { RestWorldClientCollection } from '../../services/restworld-client-collection';\r\nimport { RestWorldClient } from '../../services/restworld-client';\r\n\r\n/**\r\n * Display the value of 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 display elements may be rendered.\r\n * If you want to display just the value without a label, use {@link RestWorldDisplayComponent} `<rw-display>`.\r\n * @example\r\n * <rw-display-element [property]=\"property\" [apiName]=\"apiName\" [value]=\"value\"></rw-display-element>\r\n */\r\n@Component({\r\n    selector: 'rw-display-element',\r\n    templateUrl: './restworld-display-element/restworld-display-element.component.html',\r\n    styleUrl: './restworld-display-element/restworld-display-element.component.css'\r\n})\r\nexport class RestWorldDisplayElementComponent<TProperty extends Property<SimpleValue, string, string>> {\r\n    /**\r\n     * The property to display.\r\n     * @required\r\n     */\r\n    @Input({ required: true })\r\n    property!: TProperty;\r\n\r\n    /**\r\n     * The name of the API to use for the property.\r\n     * @required\r\n     * @remarks This is the name of the API as defined in the `RestWorldClientCollection`.\r\n     */\r\n    @Input({ required: true })\r\n    apiName!: string;\r\n\r\n    private _value?: ExtractValueType<TProperty> | ExtractGenericOptionsSelectedValuesType<TProperty>[] | ExtractGenericOptionsSelectedValuesType<TProperty> | Record<string, SimpleValue> | Map<number, Record<string, SimpleValue>>;\r\n    /**\r\n     * The value to display. If not set, the value of the property will be used.\r\n    */\r\n    @Input()\r\n    public set value(value: ExtractValueType<TProperty> | ExtractGenericOptionsSelectedValuesType<TProperty>[] | ExtractGenericOptionsSelectedValuesType<TProperty> | Record<string, SimpleValue> | Map<number, Record<string, SimpleValue>>) {\r\n        this._value = value;\r\n    }\r\n    public get value() {\r\n        return this._value ?? this.property.value as ExtractValueType<TProperty>;\r\n    }\r\n\r\n    public get PropertyType() {\r\n        return PropertyType;\r\n    }\r\n}\r\n/**\r\n * Displays a value 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 {@link RestWorldDisplayElementComponent} `<rw-display-element>`.\r\n * You can also use one of the different RestWorldDisplay... `<rw-display-...>` elements to render a specific property type,\r\n * but it is advised to control the rendered element through the passed in property.\r\n * @example\r\n * <rw-display [property]=\"property\" [apiName]=\"apiName\" [value]=\"value\"></rw-display>\r\n */\r\n@Component({\r\n    selector: 'rw-display',\r\n    templateUrl: './restworld-display/restworld-display.component.html',\r\n    styleUrl: './restworld-display/restworld-display.component.css'\r\n})\r\nexport class RestWorldDisplayComponent<TProperty extends Property<SimpleValue, string, string>> {\r\n    /**\r\n     * The property to display.\r\n     * @required\r\n     */\r\n    @Input({ required: true })\r\n    property!: TProperty;\r\n\r\n    /**\r\n     * The name of the API to use for the property.\r\n     * @required\r\n     * @remarks This is the name of the API as defined in the `RestWorldClientCollection`.\r\n     */\r\n    @Input({ required: true })\r\n    apiName!: string;\r\n\r\n    private _value?: ExtractValueType<TProperty> | ExtractGenericOptionsSelectedValuesType<TProperty>[] | ExtractGenericOptionsSelectedValuesType<TProperty> | Record<string, SimpleValue> | Map<number, Record<string, SimpleValue>>;\r\n    /**\r\n     * The value to display. If not set, the value of the property will be used.\r\n    */\r\n    @Input()\r\n    public set value(value: ExtractValueType<TProperty> | ExtractGenericOptionsSelectedValuesType<TProperty>[] | ExtractGenericOptionsSelectedValuesType<TProperty> | Record<string, SimpleValue> | Map<number, Record<string, SimpleValue>> | undefined) {\r\n        this._value = value;\r\n    }\r\n    public get value() {\r\n        return this._value ?? this.property.value as ExtractValueType<TProperty>;\r\n    }\r\n\r\n    public get PropertyType() {\r\n        return PropertyType;\r\n    }\r\n\r\n    public get PropertyWithOptions() {\r\n        return PropertyWithOptions<SimpleValue, string, string>;\r\n    }\r\n}\r\n\r\n/**\r\n * Displays the value of a collection that is automatically created from the given property.\r\n * The elements and can also be nested.\r\n * @remarks It is advised to use {@link RestWorldDisplayComponent} `<rw-display>` and control the rendered elements with the passed in property\r\n * instead of using this component directly.\r\n * @example\r\n * <rw-display-collection [property]=\"property\" [apiName]=\"apiName\" [values]=\"values\"></rw-display-collection>\r\n */\r\n@Component({\r\n    selector: 'rw-display-collection',\r\n    templateUrl: './restworld-display-collection/restworld-display-collection.component.html',\r\n    styleUrl: './restworld-display-collection/restworld-display-collection.component.css'\r\n})\r\nexport class RestWorldDisplayCollectionComponent implements OnInit {\r\n    /**\r\n     * The property to display.\r\n     * @required\r\n     */\r\n    @Input({ required: true })\r\n    property!: Property & { _templates: { default: Template } };\r\n\r\n    /**\r\n     * The name of the API to use for the property.\r\n     * @required\r\n     * @remarks This is the name of the API as defined in the `RestWorldClientCollection`.\r\n     */\r\n    @Input({ required: true })\r\n    apiName!: string;\r\n\r\n    private _values?: any[];\r\n    /**\r\n     * The value to display. If not set, the value of the property will be used.\r\n    */\r\n    @Input()\r\n    public set values(values: any[] | Partial<Record<string, any>> | undefined) {\r\n        this._values = RestWorldDisplayCollectionComponent.toArray(values);\r\n    }\r\n    public get values(): any[] | undefined {\r\n        return this._values;\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    ngOnInit(): void {\r\n        this._templates = this._values ?\r\n            Array.from(RestWorldDisplayCollectionComponent.map(this._values.entries(), entry => (new NumberTemplate({ ...(this.property._templates.default as TemplateDto), title: entry[0].toString() })))) :\r\n            RestWorldDisplayCollectionComponent.getCollectionEntryTemplates(this.property);\r\n    }\r\n\r\n    private static * map<T1, T2>(iterable: IterableIterator<T1>, callback: (value: T1) => T2) {\r\n        for (let x of iterable) {\r\n            yield callback(x);\r\n        }\r\n    }\r\n\r\n    private static toArray(arrayOrDictionary: any[] | Partial<Record<string, any>> | undefined): any[] | undefined {\r\n        if (!arrayOrDictionary)\r\n            return undefined;\r\n\r\n        if (Array.isArray(arrayOrDictionary))\r\n            return arrayOrDictionary;\r\n\r\n        return Object.entries(arrayOrDictionary).map(([key, value]) => ({ key, value }));\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 as TemplateDto));\r\n    }\r\n}\r\n\r\n/**\r\n * Displays the value of a dropdown that is automatically created from the given property.\r\n * If set the dropdown will use the `inline` property of the options to render the `selectedValues` Otherwise it will just render the values, but no prompt for them.\r\n * @remarks It is advised to use {@link RestWorldDisplayComponent} `<rw-display>` and control the rendered elements with the passed in property\r\n * instead of using this component directly.\r\n * @example\r\n * <rw-display-dropdown [property]=\"property\" [apiName]=\"apiName\" [selectedValues]=\"selectedValues\"></rw-display-dropdown>\r\n */\r\n@Component({\r\n    selector: 'rw-display-dropdown',\r\n    templateUrl: './restworld-display-dropdown/restworld-display-dropdown.component.html',\r\n    styleUrl: './restworld-display-dropdown/restworld-display-dropdown.component.css'\r\n})\r\nexport class RestWorldDisplayDropdownComponent<TProperty extends Property<SimpleValue, string, string> & { options: Options<SimpleValue, string, string> }, TOptionsItem extends ExtractGenericOptionsItemType<TProperty> = ExtractGenericOptionsItemType<TProperty>> implements OnInit {\r\n    /**\r\n     * The property to display.\r\n     * @required\r\n     */\r\n    @Input({ required: true })\r\n    property!: TProperty;\r\n\r\n    /**\r\n     * The name of the API to use for the property.\r\n     * @required\r\n     * @remarks This is the name of the API as defined in the `RestWorldClientCollection`.\r\n     */\r\n    @Input({ required: true })\r\n    apiName!: string;\r\n\r\n    private _selectedValues?: ExtractGenericOptionsSelectedValuesType<TProperty>[];\r\n    /**\r\n     * The values to display. If not set, the values of the property options will be used.\r\n    */\r\n    @Input()\r\n    public set selectedValues(value: ExtractGenericOptionsSelectedValuesType<TProperty>[] | ExtractGenericOptionsSelectedValuesType<TProperty> | undefined) {\r\n        if (Array.isArray(value))\r\n            this._selectedValues = value as ExtractGenericOptionsSelectedValuesType<TProperty>[];\r\n        else if (value !== undefined && value !== null)\r\n            this._selectedValues = [value];\r\n    }\r\n\r\n    public get selectedValues(): ExtractGenericOptionsSelectedValuesType<TProperty>[] {\r\n        return this._selectedValues ?? (this.property.options.selectedValues as unknown as ExtractGenericOptionsSelectedValuesType<TProperty>[] | undefined) ?? [];\r\n    }\r\n\r\n    private _inline: TOptionsItem[] = [];\r\n\r\n    /**\r\n     * A function that returns the label for the given item.\r\n     * The default returns the prompt and optionally the value in brackets.\r\n     * The value in brackets will only be displayed if the `cols` field of the property is undefined or greater than 1.\r\n     * Overwrite this function to change the label.\r\n     * @param item The item to get the label for.\r\n     */\r\n    @Input()\r\n    getLabel: (item: TOptionsItem) => string = this.getLabelInternal;\r\n\r\n    /**\r\n     * A function that returns the tooltip for the given item.\r\n     * The default returns all properties of the item except the ones that start with an underscore or the ones that are in the list of default properties to exclude.\r\n     * The default properties to exclude are: createdAt, createdBy, lastChangedAt, lastChangedBy, timestamp, promptField, valueField.\r\n     * Overwrite this function to change the tooltip.\r\n     * @param item The item to get the label for.\r\n     */\r\n    @Input()\r\n    getTooltip: (item: TOptionsItem) => string = this.getTooltipInternal;\r\n\r\n    @ContentChild('inputOptions', { static: false })\r\n    inputOptionsRef?: TemplateRef<PropertyTemplateContext>;\r\n\r\n    public get valueField(): string {\r\n        return this.property.options.valueField ?? \"value\";\r\n    }\r\n\r\n    public get promptField(): string {\r\n        return this.property.options.promptField ?? \"prompt\";\r\n    }\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    async ngOnInit(): Promise<void> {\r\n        if (this.property.options?.inline && this.property.options.inline.length > 0)\r\n            this._inline = Array.from(this.property.options.inline) as TOptionsItem[];\r\n\r\n        await this.setInitialSelectedOptionsElementForProperty();\r\n    }\r\n\r\n    public getOptionItem(value: ExtractGenericOptionsSelectedValuesType<TProperty>): TOptionsItem {\r\n        return this._inline.find(o => this.getValue(o as TOptionsItem) === value) as TOptionsItem ?? this.createOptionsItem(value);\r\n    }\r\n\r\n    private createOptionsItem(value: ExtractGenericOptionsSelectedValuesType<TProperty>): TOptionsItem {\r\n        return { [this.valueField]: value, [this.promptField]: \"\" } as TOptionsItem;\r\n    }\r\n\r\n    public getValue(item: TOptionsItem): ExtractGenericOptionsSelectedValuesType<TProperty> {\r\n        if (item === undefined || item === null || !item.hasOwnProperty(this.valueField))\r\n            throw new Error(`The item does not have a property ${this.valueField}.`);\r\n\r\n        return item[this.valueField as keyof TOptionsItem] as ExtractGenericOptionsSelectedValuesType<TProperty>;\r\n    }\r\n\r\n    public getPrompt(item: TOptionsItem): string {\r\n        if (item === undefined || item === null || !item.hasOwnProperty(this.promptField))\r\n            return \"\";\r\n\r\n        return item[this.promptField as keyof TOptionsItem] as string;\r\n    }\r\n\r\n    public getLabelInternal(item: TOptionsItem): string {\r\n        if (item === undefined || item === null)\r\n            return \"\";\r\n\r\n        const prompt = this.getPrompt(item);\r\n        const value = this.getValue(item);\r\n\r\n        let label = prompt;\r\n        if (label === undefined || label === null || label === \"\")\r\n            label = (value?.toString() ?? \"\");\r\n        else if ((this.property.cols === undefined || this.property.cols > 1) && prompt?.toLowerCase() !== value?.toString().toLowerCase())\r\n            label += ` (${value})`;\r\n\r\n        return label;\r\n    }\r\n\r\n    private getTooltipInternal(item: TOptionsItem): string {\r\n        if (item === undefined || item === null)\r\n            return \"\";\r\n\r\n        const tooltip = Object.entries(item)\r\n            .filter(([key]) => !(key.startsWith('_') || ['createdAt', 'createdBy', 'lastChangedAt', 'lastChangedBy', 'timestamp', this.promptField, this.valueField].includes(key)))\r\n            .reduce((prev, [key, value], index) => `${prev}${index === 0 ? '' : '\\n'}${key}: ${RestWorldDisplayDropdownComponent.jsonStringifyWithElipsis(value)}`, '');\r\n\r\n        return tooltip;\r\n    }\r\n\r\n    private async setInitialSelectedOptionsElementForProperty(): Promise<void> {\r\n        const options = this.property.options;\r\n\r\n        if (!options.link?.href || !this.selectedValues || this.selectedValues.length === 0 || this.selectedValues.every(v => this._inline.some(i => this.getValue(i as TOptionsItem) === v) ?? false))\r\n            return;\r\n\r\n        const filter = `${options.valueField} in (${this.selectedValues})`;\r\n        await this.SetInlineOptionsFromFilter(filter);\r\n    }\r\n\r\n    private async SetInlineOptionsFromFilter(filter: string) {\r\n        const options = this.property.options;\r\n        if (!options.link?.href)\r\n            throw new Error('The property does not have a link href.');\r\n\r\n        const templatedUri = options.link.href;\r\n        const response = await this.getClient().getListByUri<TOptionsItem>(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 initial selected items for the property ${this.property.name}.`;\r\n            this._messageService.add({ severity: 'error', summary: 'Error', detail: message, data: response, sticky: true });\r\n        }\r\n\r\n        const items = response.body!._embedded.items as ResourceOfDto<TOptionsItem>[];\r\n        const newItems = this.combineInlineWithSelected(items);\r\n        this._inline = newItems;\r\n    }\r\n\r\n    private combineInlineWithSelected(items: ResourceOfDto<TOptionsItem>[]): TOptionsItem[] {\r\n        const oldInline = this._inline as ResourceOfDto<TOptionsItem>[];\r\n        if (!oldInline || oldInline.length === 0)\r\n            return items;\r\n\r\n        const itemsToKeep = oldInline.filter(i => this.selectedValues.includes(this.getValue(i as TOptionsItem)));\r\n        const newItems = items.concat(itemsToKeep.filter(i => !items.includes(i)));\r\n\r\n        return newItems;\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 * Displays the value of a complex object with multiple properties that is automatically created from the given property.\r\n * The object can also be nested.\r\n * @remarks It is advised to use {@link RestWorldDisplayComponent} `<rw-display>` and control the rendered elements with the passed in property\r\n * instead of using this component directly.\r\n * @example\r\n * <rw-display-object [property]=\"property\" [apiName]=\"apiName\" [value]=\"value\"></rw-display-object>\r\n */\r\n@Component({\r\n    selector: 'rw-display-object',\r\n    templateUrl: './restworld-display-object/restworld-display-object.component.html',\r\n    styleUrl: './restworld-display-object/restworld-display-object.component.css'\r\n})\r\nexport class RestWorldDisplayObjectComponent {\r\n    /**\r\n     * The property to display.\r\n     * @required\r\n     */\r\n    @Input({ required: true })\r\n    property!: Property<null, never, never> & { _templates: { default: Template } };\r\n\r\n    /**\r\n     * The name of the API to use for the property.\r\n     * @required\r\n     * @remarks This is the name of the API as defined in the `RestWorldClientCollection`.\r\n     */\r\n    @Input({ required: true })\r\n    apiName!: string;\r\n\r\n    private _value?: Record<string, SimpleValue>;\r\n    /**\r\n     * The value to display. If not set, the value of the template properties will be used.\r\n    */\r\n    @Input()\r\n    public set value(value: Record<string, SimpleValue> | undefined) {\r\n        this._value = value;\r\n    }\r\n    public get value() {\r\n        return this._value;\r\n    }\r\n}\r\n\r\n/**\r\n * Displays the value of a simple element, like a string, a number or a Date that is automatically created from the given property.\r\n * @remarks It is advised to use {@link RestWorldDisplayComponent} `<rw-display>` and control the rendered elements with the passed in property\r\n * instead of using this component directly.\r\n * @example\r\n * <rw-display-simple [property]=\"property\" [apiName]=\"apiName\" [value]=\"value\"></rw-display-simple>\r\n */\r\n@Component({\r\n    selector: 'rw-display-simple',\r\n    templateUrl: './restworld-display-simple/restworld-display-simple.component.html',\r\n    styleUrl: './restworld-display-simple/restworld-display-simple.component.css'\r\n})\r\nexport class RestWorldDisplaySimpleComponent<TProperty extends Property<SimpleValue, string, string>> {\r\n    /**\r\n     * The property to display.\r\n     * @required\r\n     */\r\n    @Input({ required: true })\r\n    property!: TProperty;\r\n\r\n    /**\r\n     * The name of the API to use for the property.\r\n     * @required\r\n     * @remarks This is the name of the API as defined in the `RestWorldClientCollection`.\r\n     */\r\n    @Input({ required: true })\r\n    apiName!: string;\r\n\r\n    private _value?: SimpleValue;\r\n    /**\r\n     * The value to display. If not set, the value of the property will be used.\r\n    */\r\n    @Input()\r\n    public set value(value: SimpleValue) {\r\n        this._value = value;\r\n    }\r\n    public get value() {\r\n        return this._value ?? this.property.value;\r\n    }\r\n\r\n    public get PropertyType() {\r\n        return PropertyType;\r\n    }\r\n\r\n    private static readonly _dateFormat = new Date(3333, 10, 22) // months start at 0 in JS\r\n        .toLocaleDateString()\r\n        .replace(\"22\", \"dd\")\r\n        .replace(\"11\", \"MM\")\r\n        .replace(\"3333\", \"yyyy\")\r\n        .replace(\"33\", \"yy\");\r\n\r\n    public get dateFormat(): string {\r\n        return RestWorldDisplaySimpleComponent._dateFormat;\r\n    }\r\n\r\n    private static readonly _timeFormat = new Date(1, 1, 1, 22, 33, 44)\r\n        .toLocaleTimeString()\r\n        .replace(\"22\", \"hh\")\r\n        .replace(\"33\", \"mm\")\r\n        .replace(\"44\", \"ss\");\r\n\r\n    public get timeFormat() {\r\n        return RestWorldDisplaySimpleComponent._timeFormat;\r\n    }\r\n\r\n    public get PropertyWithImage() {\r\n        return PropertyWithImage;\r\n    }\r\n}\r\n\r\n/**\r\n * Displays the values of a collection of `<rw-display>` elements automatically created from a template.\r\n * @example\r\n * <rw-display-template [template]=\"template\" [apiName]=\"apiName\" [value]=\"value\"></rw-display-template>\r\n */\r\n@Component({\r\n    selector: 'rw-display-template',\r\n    templateUrl: './restworld-display-template/restworld-display-template.component.html',\r\n    styleUrl: './restworld-display-template/restworld-display-template.component.css'\r\n})\r\nexport class RestWorldDisplayTemplateComponent {\r\n    /**\r\n     * The template to display.\r\n     * @required\r\n     * @remarks This is the template that defines the properties to display.\r\n     */\r\n    @Input({ required: true })\r\n    template!: Template;\r\n\r\n    /**\r\n     * The name of the API to use for the property.\r\n     * @required\r\n     * @remarks This is the name of the API as defined in the `RestWorldClientCollection`.\r\n     */\r\n    @Input({ required: true })\r\n    apiName!: string;\r\n\r\n    private _value?: Record<string, any>;\r\n    /**\r\n     * The value to display. If not set, the values of the template properties will be used.\r\n    */\r\n    @Input()\r\n    public set value(value: Record<string, any> | undefined) {\r\n        this._value = value;\r\n    }\r\n    public get value() {\r\n        return this._value;\r\n    }\r\n}\r\n","<div class=\"grid field\" *ngIf=\"property.type !== PropertyType.Hidden\">\r\n    <rw-label [property]=\"property\" class=\"col-12 md:col-2 flex align-items-center\"></rw-label>\r\n    <rw-display [property]=\"property\" [value]=\"value\" [apiName]=\"apiName\" class=\"col-12 md:col-10\"></rw-display>\r\n</div>\r\n","<ng-container *ngIf=\"property.type !== PropertyType.Hidden\">\r\n    <rw-display-dropdown *ngIf=\"property.options\" [property]=\"$any(property)\" [selectedValues]=\"$any(value)\" [apiName]=\"apiName\"></rw-display-dropdown>\r\n\r\n    <ng-container *ngIf=\"!property.options\">\r\n        <ng-container [ngSwitch]=\"property.type\">\r\n            <rw-display-object *ngSwitchCase=\"PropertyType.Object\" [property]=\"$any(property)\" [value]=\"$any(value)\" [apiName]=\"apiName\"></rw-display-object>\r\n            <rw-display-collection *ngSwitchCase=\"PropertyType.Collection\" [property]=\"$any(property)\" [values]=\"$any(value)\" [apiName]=\"apiName\"></rw-display-collection>\r\n            <rw-display-simple *ngSwitchDefault [property]=\"property\" [value]=\"$any(value)\" [apiName]=\"apiName\"></rw-display-simple>\r\n        </ng-container>\r\n    </ng-container>\r\n</ng-container>\r\n","<div class=\"flex align-items-center\">\r\n    <div class=\"brace\">\r\n    </div>\r\n    <div class=\"w-full\">\r\n        <div *ngFor=\"let template of templates\" class=\"flex align-items-center\">\r\n            <div class=\"brace\">\r\n            </div>\r\n            <div class=\"w-full flex justify-content-end\">\r\n                <rw-display-template [template]=\"$any(template)\" [value]=\"values ? values[template.title!] : undefined\" [apiName]=\"apiName\" class=\"w-full\"></rw-display-template>\r\n            </div>\r\n        </div>\r\n    </div>\r\n</div>\r\n","<!-- <ng-template #defaultInputOptions let-property=\"property\" let-selectedValues=\"selectedValues\"> -->\r\n<ng-container *ngFor=\"let value of selectedValues; last as last;\">\r\n    <span [pTooltip]=\"getTooltip(getOptionItem(value))\">{{getLabel(getOptionItem(value))}}</span>{{last ? \"\" : \", \"}}\r\n</ng-container>\r\n<!-- </ng-template>\r\n<ng-container *ngTemplateOutlet=\"inputOptionsRef ?? defaultInputOptions; context: { property: property, selectedValues: selectedValues }\"></ng-container> -->","<div class=\"flex align-items-center\">\r\n    <div class=\"brace\">\r\n    </div>\r\n    <div class=\"w-full\">\r\n        <rw-display-template [template]=\"property._templates.default\" [value]=\"value\" [apiName]=\"apiName\"></rw-display-template>\r\n    </div>\r\n</div>","<ng-container [ngSwitch]=\"property.type\">\r\n    <ng-container *ngSwitchCase=\"PropertyType.Text\">\r\n        <rw-avatar *ngIf=\"property.name === 'createdBy' || property.name === 'lastChangedBy'\" [user]=\"$any(value)\"></rw-avatar>\r\n        <span *ngIf=\"property.name !== 'createdBy' && property.name !== 'lastChangedBy'\" class=\"w-full\">{{value | propertyTypeFormat:property.type}}</span>\r\n    </ng-container>\r\n\r\n    <ng-container *ngSwitchCase=\"PropertyType.Bool\">\r\n        <p-checkbox *ngIf=\"property.required\" [(ngModel)]=\"value\" [binary]=\"true\" [readonly]=\"true\" [disabled]=\"true\"></p-checkbox>\r\n        <p-triStateCheckbox *ngIf=\"!property.required\" [(ngModel)]=\"value\" [readonly]=\"true\" [disabled]=\"true\"></p-triStateCheckbox>\r\n    </ng-container>\r\n\r\n    <span *ngSwitchDefault class=\"w-full\">{{value | propertyTypeFormat:property.type}}</span>\r\n</ng-container>\r\n","<rw-display-element *ngFor=\"let property of template.properties\" [property]=\"property\" [value]=\"value ? value[property.name] : undefined\" [apiName]=\"apiName\"></rw-display-element>"]}
@@ -10,6 +10,11 @@ import * as i5 from "../../pipes/safe-url.pipe";
10
10
  /**
11
11
  * Represents a component for uploading files in the RESTworld Angular client.
12
12
  * Implements the ControlValueAccessor interface to enable two-way data binding.
13
+ * @example
14
+ * <rw-file
15
+ * [(ngModel)]="base64EncodedFileUri"
16
+ * accept="file/text">
17
+ * </rw-file>
13
18
  */
14
19
  export class RestWorldFileComponent {
15
20
  onChange;
@@ -64,4 +69,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.2", ngImpor
64
69
  type: ViewChildren,
65
70
  args: [FileUpload]
66
71
  }] } });
67
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVzdHdvcmxkLWZpbGUuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LXJlc3R3b3JsZC1jbGllbnQvc3JjL2xpYi9jb21wb25lbnRzL3Jlc3R3b3JsZC1maWxlL3Jlc3R3b3JsZC1maWxlLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC1yZXN0d29ybGQtY2xpZW50L3NyYy9saWIvY29tcG9uZW50cy9yZXN0d29ybGQtZmlsZS9yZXN0d29ybGQtZmlsZS5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLFVBQVUsRUFBRSxLQUFLLEVBQWEsWUFBWSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3RGLE9BQU8sRUFBd0IsaUJBQWlCLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUN6RSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sb0JBQW9CLENBQUM7Ozs7Ozs7QUFFaEQ7OztHQUdHO0FBV0gsTUFBTSxPQUFPLHNCQUFzQjtJQUN6QixRQUFRLENBQVk7SUFPckIsTUFBTSxDQUFVO0lBTWhCLFFBQVEsQ0FBVTtJQUd6QixXQUFXLENBQXlCO0lBRTdCLFFBQVEsR0FBRyxLQUFLLENBQUM7SUFDeEI7O09BRUc7SUFDSSxHQUFHLENBQVU7SUFFcEIsVUFBVSxDQUFDLEdBQVk7UUFDckIsSUFBSSxDQUFDLEdBQUcsR0FBRyxHQUFHLENBQUM7SUFDakIsQ0FBQztJQUNELGdCQUFnQixDQUFDLEVBQWE7UUFDNUIsSUFBSSxDQUFDLFFBQVEsR0FBRyxFQUFFLENBQUM7SUFDckIsQ0FBQztJQUNELGlCQUFpQjtRQUNmLHVFQUF1RTtJQUN6RSxDQUFDO0lBQ0QsZ0JBQWdCLENBQUUsVUFBbUI7UUFDbkMsSUFBSSxDQUFDLFFBQVEsR0FBRyxVQUFVLENBQUM7SUFDN0IsQ0FBQztJQUVNLFdBQVcsQ0FBQyxLQUF3QjtRQUN6QyxNQUFNLElBQUksR0FBRyxLQUFLLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxDQUFDO1FBQzVCLE1BQU0sTUFBTSxHQUFHLElBQUksVUFBVSxFQUFFLENBQUM7UUFDaEMsTUFBTSxDQUFDLE1BQU0sR0FBRyxHQUFHLEVBQUU7WUFDbkIsSUFBSSxDQUFDLEdBQUcsR0FBRyxNQUFNLENBQUMsTUFBZ0IsQ0FBQztZQUNuQyxJQUFJLENBQUMsUUFBUSxFQUFFLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDO1FBQzVCLENBQUMsQ0FBQztRQUVGLE1BQU0sQ0FBQyxhQUFhLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDN0IsQ0FBQzt1R0EvQ1Usc0JBQXNCOzJGQUF0QixzQkFBc0Isc0ZBTnRCLENBQUM7Z0JBQ1YsT0FBTyxFQUFFLGlCQUFpQjtnQkFDMUIsV0FBVyxFQUFFLFVBQVUsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxzQkFBc0IsQ0FBQztnQkFDckQsS0FBSyxFQUFFLElBQUk7YUFDWixDQUFDLDBEQWtCWSxVQUFVLGdEQ2xDMUIsNmpCQUtBOzsyRkRhYSxzQkFBc0I7a0JBVmxDLFNBQVM7K0JBQ0UsU0FBUyxhQUdSLENBQUM7NEJBQ1YsT0FBTyxFQUFFLGlCQUFpQjs0QkFDMUIsV0FBVyxFQUFFLFVBQVUsQ0FBQyxHQUFHLEVBQUUsdUJBQXVCLENBQUM7NEJBQ3JELEtBQUssRUFBRSxJQUFJO3lCQUNaLENBQUM7OEJBVUssTUFBTTtzQkFOWixLQUFLO2dCQVlDLFFBQVE7c0JBSmQsS0FBSztnQkFPTixXQUFXO3NCQURWLFlBQVk7dUJBQUMsVUFBVSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgZm9yd2FyZFJlZiwgSW5wdXQsIFF1ZXJ5TGlzdCwgVmlld0NoaWxkcmVuIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IENvbnRyb2xWYWx1ZUFjY2Vzc29yLCBOR19WQUxVRV9BQ0NFU1NPUiB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcclxuaW1wb3J0IHsgRmlsZVVwbG9hZCB9IGZyb20gJ3ByaW1lbmcvZmlsZXVwbG9hZCc7XHJcblxyXG4vKipcclxuICogUmVwcmVzZW50cyBhIGNvbXBvbmVudCBmb3IgdXBsb2FkaW5nIGZpbGVzIGluIHRoZSBSRVNUd29ybGQgQW5ndWxhciBjbGllbnQuXHJcbiAqIEltcGxlbWVudHMgdGhlIENvbnRyb2xWYWx1ZUFjY2Vzc29yIGludGVyZmFjZSB0byBlbmFibGUgdHdvLXdheSBkYXRhIGJpbmRpbmcuXHJcbiAqL1xyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogJ3J3LWZpbGUnLFxyXG4gIHRlbXBsYXRlVXJsOiAnLi9yZXN0d29ybGQtZmlsZS5jb21wb25lbnQuaHRtbCcsXHJcbiAgc3R5bGVVcmxzOiBbJy4vcmVzdHdvcmxkLWZpbGUuY29tcG9uZW50LmNzcyddLFxyXG4gIHByb3ZpZGVyczogW3tcclxuICAgIHByb3ZpZGU6IE5HX1ZBTFVFX0FDQ0VTU09SLFxyXG4gICAgdXNlRXhpc3Rpbmc6IGZvcndhcmRSZWYoKCkgPT4gUmVzdFdvcmxkRmlsZUNvbXBvbmVudCksXHJcbiAgICBtdWx0aTogdHJ1ZVxyXG4gIH1dXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBSZXN0V29ybGRGaWxlQ29tcG9uZW50IGltcGxlbWVudHMgQ29udHJvbFZhbHVlQWNjZXNzb3Ige1xyXG4gIHByaXZhdGUgb25DaGFuZ2U/OiBGdW5jdGlvbjtcclxuICBASW5wdXQoKVxyXG4gIC8qKlxyXG4gICAqIFRoZSBmaWxlIHR5cGVzIHRoYXQgdGhlIGNvbXBvbmVudCBzaG91bGQgYWNjZXB0LlxyXG4gICAqIFRoaXMgaXMgYSBjb21tYS1zZXBhcmF0ZWQgbGlzdCBvZiBNSU1FIHR5cGVzIG9yIGZpbGUgZXh0ZW5zaW9ucy5cclxuICAgKiBJZiBub3Qgc3BlY2lmaWVkLCBhbGwgZmlsZSB0eXBlcyBhcmUgYWNjZXB0ZWQuXHJcbiAgICovXHJcbiAgcHVibGljIGFjY2VwdD86IHN0cmluZztcclxuXHJcbiAgQElucHV0KClcclxuICAvKipcclxuICAgKiBUaGUgbmFtZSBvZiB0aGUgZmlsZSB0byBiZSB1cGxvYWRlZC5cclxuICAgKi9cclxuICBwdWJsaWMgZmlsZU5hbWU/OiBzdHJpbmc7XHJcblxyXG4gIEBWaWV3Q2hpbGRyZW4oRmlsZVVwbG9hZClcclxuICBmaWxlVXBsb2Fkcz86IFF1ZXJ5TGlzdDxGaWxlVXBsb2FkPjtcclxuXHJcbiAgcHVibGljIGRpc2FibGVkID0gZmFsc2U7XHJcbiAgLyoqXHJcbiAgICogVGhlIFVSSSBvZiB0aGUgZmlsZS5cclxuICAgKi9cclxuICBwdWJsaWMgdXJpPzogc3RyaW5nO1xyXG5cclxuICB3cml0ZVZhbHVlKG9iaj86IHN0cmluZyk6IHZvaWQge1xyXG4gICAgdGhpcy51cmkgPSBvYmo7XHJcbiAgfVxyXG4gIHJlZ2lzdGVyT25DaGFuZ2UoZm4/OiBGdW5jdGlvbik6IHZvaWQge1xyXG4gICAgdGhpcy5vbkNoYW5nZSA9IGZuO1xyXG4gIH1cclxuICByZWdpc3Rlck9uVG91Y2hlZCgpOiB2b2lkIHtcclxuICAgIC8vIG5vdCBuZWVkZWQgZm9yIHRoaXMgY29tcG9uZW50LCBidXQgbmVlZGVkIHRvIGltcGxlbWVudCB0aGUgaW50ZXJmYWNlXHJcbiAgfVxyXG4gIHNldERpc2FibGVkU3RhdGU/KGlzRGlzYWJsZWQ6IGJvb2xlYW4pOiB2b2lkIHtcclxuICAgIHRoaXMuZGlzYWJsZWQgPSBpc0Rpc2FibGVkO1xyXG4gIH1cclxuXHJcbiAgcHVibGljIGZpbGVDaGFuZ2VkKGV2ZW50OiB7IGZpbGVzOiBGaWxlW10gfSk6IHZvaWQge1xyXG4gICAgY29uc3QgZmlsZSA9IGV2ZW50LmZpbGVzWzBdO1xyXG4gICAgY29uc3QgcmVhZGVyID0gbmV3IEZpbGVSZWFkZXIoKTtcclxuICAgIHJlYWRlci5vbmxvYWQgPSAoKSA9PiB7XHJcbiAgICAgIHRoaXMudXJpID0gcmVhZGVyLnJlc3VsdCBhcyBzdHJpbmc7XHJcbiAgICAgIHRoaXMub25DaGFuZ2U/Lih0aGlzLnVyaSk7XHJcbiAgICB9O1xyXG5cclxuICAgIHJlYWRlci5yZWFkQXNEYXRhVVJMKGZpbGUpO1xyXG4gIH1cclxufVxyXG4iLCI8ZGl2IGNsYXNzPVwiZmxleCBhbGlnbi1pdGVtcy1jZW50ZXJcIj5cclxuICA8cC1idXR0b24gKm5nSWY9XCIhdXJpXCIgW2Rpc2FibGVkXT1cInRydWVcIiBpY29uPVwicGkgcGktZG93bmxvYWRcIiBjbGFzcz1cIm1yLTFcIiBwVG9vbHRpcD1cIk5vIGZpbGUgcHJlc2VudFwiPjwvcC1idXR0b24+XHJcbiAgPGEgKm5nSWY9XCJ1cmlcIiBbaHJlZl09XCJ1cmkgfCBzYWZlVXJsXCIgW2Rvd25sb2FkXT1cImZpbGVOYW1lIHx8ICdkb3dubG9hZCdcIiBjbGFzcz1cIm1yLTFcIiBwQnV0dG9uIHBUb29sdGlwPVwiRG93bmxvYWQgZmlsZVwiIGljb249XCJwaSBwaS1kb3dubG9hZFwiPjwvYT5cclxuICA8cC1maWxlVXBsb2FkIGNob29zZUljb249XCJwaS11cGxvYWQgZmFzIGZhLXVwbG9hZFwiIHBUb29sdGlwPVwiVXBsb2FkIG5ldyBmaWxlXCIgbW9kZT1cImJhc2ljXCIgW2F1dG9dPVwidHJ1ZVwiIFthY2NlcHRdPVwiYWNjZXB0IHx8ICcnXCIgW2N1c3RvbVVwbG9hZF09XCJ0cnVlXCIgKHVwbG9hZEhhbmRsZXIpPVwiZmlsZUNoYW5nZWQoJGV2ZW50KVwiPjwvcC1maWxlVXBsb2FkPlxyXG48L2Rpdj5cclxuIl19
72
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVzdHdvcmxkLWZpbGUuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LXJlc3R3b3JsZC1jbGllbnQvc3JjL2xpYi9jb21wb25lbnRzL3Jlc3R3b3JsZC1maWxlL3Jlc3R3b3JsZC1maWxlLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC1yZXN0d29ybGQtY2xpZW50L3NyYy9saWIvY29tcG9uZW50cy9yZXN0d29ybGQtZmlsZS9yZXN0d29ybGQtZmlsZS5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLFVBQVUsRUFBRSxLQUFLLEVBQWEsWUFBWSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3RGLE9BQU8sRUFBd0IsaUJBQWlCLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUN6RSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sb0JBQW9CLENBQUM7Ozs7Ozs7QUFFaEQ7Ozs7Ozs7O0dBUUc7QUFXSCxNQUFNLE9BQU8sc0JBQXNCO0lBQ3pCLFFBQVEsQ0FBWTtJQU9yQixNQUFNLENBQVU7SUFNaEIsUUFBUSxDQUFVO0lBR3pCLFdBQVcsQ0FBeUI7SUFFN0IsUUFBUSxHQUFHLEtBQUssQ0FBQztJQUN4Qjs7T0FFRztJQUNJLEdBQUcsQ0FBVTtJQUVwQixVQUFVLENBQUMsR0FBWTtRQUNyQixJQUFJLENBQUMsR0FBRyxHQUFHLEdBQUcsQ0FBQztJQUNqQixDQUFDO0lBQ0QsZ0JBQWdCLENBQUMsRUFBYTtRQUM1QixJQUFJLENBQUMsUUFBUSxHQUFHLEVBQUUsQ0FBQztJQUNyQixDQUFDO0lBQ0QsaUJBQWlCO1FBQ2YsdUVBQXVFO0lBQ3pFLENBQUM7SUFDRCxnQkFBZ0IsQ0FBRSxVQUFtQjtRQUNuQyxJQUFJLENBQUMsUUFBUSxHQUFHLFVBQVUsQ0FBQztJQUM3QixDQUFDO0lBRU0sV0FBVyxDQUFDLEtBQXdCO1FBQ3pDLE1BQU0sSUFBSSxHQUFHLEtBQUssQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFDNUIsTUFBTSxNQUFNLEdBQUcsSUFBSSxVQUFVLEVBQUUsQ0FBQztRQUNoQyxNQUFNLENBQUMsTUFBTSxHQUFHLEdBQUcsRUFBRTtZQUNuQixJQUFJLENBQUMsR0FBRyxHQUFHLE1BQU0sQ0FBQyxNQUFnQixDQUFDO1lBQ25DLElBQUksQ0FBQyxRQUFRLEVBQUUsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUM7UUFDNUIsQ0FBQyxDQUFDO1FBRUYsTUFBTSxDQUFDLGFBQWEsQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUM3QixDQUFDO3VHQS9DVSxzQkFBc0I7MkZBQXRCLHNCQUFzQixzRkFOdEIsQ0FBQztnQkFDVixPQUFPLEVBQUUsaUJBQWlCO2dCQUMxQixXQUFXLEVBQUUsVUFBVSxDQUFDLEdBQUcsRUFBRSxDQUFDLHNCQUFzQixDQUFDO2dCQUNyRCxLQUFLLEVBQUUsSUFBSTthQUNaLENBQUMsMERBa0JZLFVBQVUsZ0RDdkMxQiw2akJBS0E7OzJGRGtCYSxzQkFBc0I7a0JBVmxDLFNBQVM7K0JBQ0UsU0FBUyxhQUdSLENBQUM7NEJBQ1YsT0FBTyxFQUFFLGlCQUFpQjs0QkFDMUIsV0FBVyxFQUFFLFVBQVUsQ0FBQyxHQUFHLEVBQUUsdUJBQXVCLENBQUM7NEJBQ3JELEtBQUssRUFBRSxJQUFJO3lCQUNaLENBQUM7OEJBVUssTUFBTTtzQkFOWixLQUFLO2dCQVlDLFFBQVE7c0JBSmQsS0FBSztnQkFPTixXQUFXO3NCQURWLFlBQVk7dUJBQUMsVUFBVSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgZm9yd2FyZFJlZiwgSW5wdXQsIFF1ZXJ5TGlzdCwgVmlld0NoaWxkcmVuIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IENvbnRyb2xWYWx1ZUFjY2Vzc29yLCBOR19WQUxVRV9BQ0NFU1NPUiB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcclxuaW1wb3J0IHsgRmlsZVVwbG9hZCB9IGZyb20gJ3ByaW1lbmcvZmlsZXVwbG9hZCc7XHJcblxyXG4vKipcclxuICogUmVwcmVzZW50cyBhIGNvbXBvbmVudCBmb3IgdXBsb2FkaW5nIGZpbGVzIGluIHRoZSBSRVNUd29ybGQgQW5ndWxhciBjbGllbnQuXHJcbiAqIEltcGxlbWVudHMgdGhlIENvbnRyb2xWYWx1ZUFjY2Vzc29yIGludGVyZmFjZSB0byBlbmFibGUgdHdvLXdheSBkYXRhIGJpbmRpbmcuXHJcbiAqIEBleGFtcGxlXHJcbiAqIDxydy1maWxlXHJcbiAqICBbKG5nTW9kZWwpXT1cImJhc2U2NEVuY29kZWRGaWxlVXJpXCJcclxuICogIGFjY2VwdD1cImZpbGUvdGV4dFwiPlxyXG4gKiA8L3J3LWZpbGU+XHJcbiAqL1xyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogJ3J3LWZpbGUnLFxyXG4gIHRlbXBsYXRlVXJsOiAnLi9yZXN0d29ybGQtZmlsZS5jb21wb25lbnQuaHRtbCcsXHJcbiAgc3R5bGVVcmxzOiBbJy4vcmVzdHdvcmxkLWZpbGUuY29tcG9uZW50LmNzcyddLFxyXG4gIHByb3ZpZGVyczogW3tcclxuICAgIHByb3ZpZGU6IE5HX1ZBTFVFX0FDQ0VTU09SLFxyXG4gICAgdXNlRXhpc3Rpbmc6IGZvcndhcmRSZWYoKCkgPT4gUmVzdFdvcmxkRmlsZUNvbXBvbmVudCksXHJcbiAgICBtdWx0aTogdHJ1ZVxyXG4gIH1dXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBSZXN0V29ybGRGaWxlQ29tcG9uZW50IGltcGxlbWVudHMgQ29udHJvbFZhbHVlQWNjZXNzb3Ige1xyXG4gIHByaXZhdGUgb25DaGFuZ2U/OiBGdW5jdGlvbjtcclxuICBASW5wdXQoKVxyXG4gIC8qKlxyXG4gICAqIFRoZSBmaWxlIHR5cGVzIHRoYXQgdGhlIGNvbXBvbmVudCBzaG91bGQgYWNjZXB0LlxyXG4gICAqIFRoaXMgaXMgYSBjb21tYS1zZXBhcmF0ZWQgbGlzdCBvZiBNSU1FIHR5cGVzIG9yIGZpbGUgZXh0ZW5zaW9ucy5cclxuICAgKiBJZiBub3Qgc3BlY2lmaWVkLCBhbGwgZmlsZSB0eXBlcyBhcmUgYWNjZXB0ZWQuXHJcbiAgICovXHJcbiAgcHVibGljIGFjY2VwdD86IHN0cmluZztcclxuXHJcbiAgQElucHV0KClcclxuICAvKipcclxuICAgKiBUaGUgbmFtZSBvZiB0aGUgZmlsZSB0byBiZSB1cGxvYWRlZC5cclxuICAgKi9cclxuICBwdWJsaWMgZmlsZU5hbWU/OiBzdHJpbmc7XHJcblxyXG4gIEBWaWV3Q2hpbGRyZW4oRmlsZVVwbG9hZClcclxuICBmaWxlVXBsb2Fkcz86IFF1ZXJ5TGlzdDxGaWxlVXBsb2FkPjtcclxuXHJcbiAgcHVibGljIGRpc2FibGVkID0gZmFsc2U7XHJcbiAgLyoqXHJcbiAgICogVGhlIFVSSSBvZiB0aGUgZmlsZS5cclxuICAgKi9cclxuICBwdWJsaWMgdXJpPzogc3RyaW5nO1xyXG5cclxuICB3cml0ZVZhbHVlKG9iaj86IHN0cmluZyk6IHZvaWQge1xyXG4gICAgdGhpcy51cmkgPSBvYmo7XHJcbiAgfVxyXG4gIHJlZ2lzdGVyT25DaGFuZ2UoZm4/OiBGdW5jdGlvbik6IHZvaWQge1xyXG4gICAgdGhpcy5vbkNoYW5nZSA9IGZuO1xyXG4gIH1cclxuICByZWdpc3Rlck9uVG91Y2hlZCgpOiB2b2lkIHtcclxuICAgIC8vIG5vdCBuZWVkZWQgZm9yIHRoaXMgY29tcG9uZW50LCBidXQgbmVlZGVkIHRvIGltcGxlbWVudCB0aGUgaW50ZXJmYWNlXHJcbiAgfVxyXG4gIHNldERpc2FibGVkU3RhdGU/KGlzRGlzYWJsZWQ6IGJvb2xlYW4pOiB2b2lkIHtcclxuICAgIHRoaXMuZGlzYWJsZWQgPSBpc0Rpc2FibGVkO1xyXG4gIH1cclxuXHJcbiAgcHVibGljIGZpbGVDaGFuZ2VkKGV2ZW50OiB7IGZpbGVzOiBGaWxlW10gfSk6IHZvaWQge1xyXG4gICAgY29uc3QgZmlsZSA9IGV2ZW50LmZpbGVzWzBdO1xyXG4gICAgY29uc3QgcmVhZGVyID0gbmV3IEZpbGVSZWFkZXIoKTtcclxuICAgIHJlYWRlci5vbmxvYWQgPSAoKSA9PiB7XHJcbiAgICAgIHRoaXMudXJpID0gcmVhZGVyLnJlc3VsdCBhcyBzdHJpbmc7XHJcbiAgICAgIHRoaXMub25DaGFuZ2U/Lih0aGlzLnVyaSk7XHJcbiAgICB9O1xyXG5cclxuICAgIHJlYWRlci5yZWFkQXNEYXRhVVJMKGZpbGUpO1xyXG4gIH1cclxufVxyXG4iLCI8ZGl2IGNsYXNzPVwiZmxleCBhbGlnbi1pdGVtcy1jZW50ZXJcIj5cclxuICA8cC1idXR0b24gKm5nSWY9XCIhdXJpXCIgW2Rpc2FibGVkXT1cInRydWVcIiBpY29uPVwicGkgcGktZG93bmxvYWRcIiBjbGFzcz1cIm1yLTFcIiBwVG9vbHRpcD1cIk5vIGZpbGUgcHJlc2VudFwiPjwvcC1idXR0b24+XHJcbiAgPGEgKm5nSWY9XCJ1cmlcIiBbaHJlZl09XCJ1cmkgfCBzYWZlVXJsXCIgW2Rvd25sb2FkXT1cImZpbGVOYW1lIHx8ICdkb3dubG9hZCdcIiBjbGFzcz1cIm1yLTFcIiBwQnV0dG9uIHBUb29sdGlwPVwiRG93bmxvYWQgZmlsZVwiIGljb249XCJwaSBwaS1kb3dubG9hZFwiPjwvYT5cclxuICA8cC1maWxlVXBsb2FkIGNob29zZUljb249XCJwaS11cGxvYWQgZmFzIGZhLXVwbG9hZFwiIHBUb29sdGlwPVwiVXBsb2FkIG5ldyBmaWxlXCIgbW9kZT1cImJhc2ljXCIgW2F1dG9dPVwidHJ1ZVwiIFthY2NlcHRdPVwiYWNjZXB0IHx8ICcnXCIgW2N1c3RvbVVwbG9hZF09XCJ0cnVlXCIgKHVwbG9hZEhhbmRsZXIpPVwiZmlsZUNoYW5nZWQoJGV2ZW50KVwiPjwvcC1maWxlVXBsb2FkPlxyXG48L2Rpdj5cclxuIl19
@@ -16,6 +16,26 @@ import * as i10 from "../restworld-validation-errors/restworld-validation-errors
16
16
  * A form with Save, Reload and Delete buttons.
17
17
  * If you do not want buttons, use RestWorldFormTemplateComponent <rw-form-template>.
18
18
  * You can also provide your own buttons by passing in a template.
19
+ * @example
20
+ * <rw-form
21
+ * [template]="template"
22
+ * apiName="apiName"
23
+ * rel="rel"
24
+ * [allowSubmit]="true"
25
+ * [allowDelete]="true"
26
+ * [allowReload]="true"
27
+ * [showSubmit]="true"
28
+ * [showDelete]="true"
29
+ * [showReload]="true">
30
+ * <ng-template #content let-form="form" let-template="template" let-apiName="apiName">
31
+ * <!-- Custom form content here -->
32
+ * <!-- This is optional and will replace the default which renders labels and inputs if present -->
33
+ * </ng-template>
34
+ * <ng-template #buttons let-form="form" let-template="template" let-apiName="apiName">
35
+ * <!-- Custom buttons here -->
36
+ * <!-- This is optional and will replace the default which renders the Save, Reload and Delete buttons if present -->
37
+ * </ng-template>
38
+ * </rw-form>
19
39
  */
20
40
  export class RestWorldFormComponent {
21
41
  _clients;
@@ -272,4 +292,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.2", ngImpor
272
292
  type: ContentChild,
273
293
  args: ['content', { static: false }]
274
294
  }] } });
275
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"restworld-form.component.js","sourceRoot":"","sources":["../../../../../../projects/ngx-restworld-client/src/lib/components/restworld-form/restworld-form.component.ts","../../../../../../projects/ngx-restworld-client/src/lib/components/restworld-form/restworld-form.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ContentChild, ElementRef, EventEmitter, Input, Output, TemplateRef } from '@angular/core';\nimport { AbstractControl, FormGroup, UntypedFormArray, UntypedFormGroup } from '@angular/forms';\nimport { FormService, FormsResource, ProblemDetails, PropertyDto, SimpleValue, Template } from '@wertzui/ngx-hal-client';\nimport { ConfirmationService, MessageService } from 'primeng/api';\nimport { RestWorldClient } from '../../services/restworld-client';\nimport { RestWorldClientCollection } from '../../services/restworld-client-collection';\nimport { AfterSubmitOkEvent, AfterSubmitRedirectEvent } from '../../models/events';\n\n/**\n * A form with Save, Reload and Delete buttons.\n * If you do not want buttons, use RestWorldFormTemplateComponent <rw-form-template>.\n * You can also provide your own buttons by passing in a template.\n */\n@Component({\n  selector: 'rw-form',\n  templateUrl: './restworld-form.component.html',\n  styleUrls: ['./restworld-form.component.css']\n})\nexport class RestWorldFormComponent<TPropertyDtos extends ReadonlyArray<PropertyDto<SimpleValue, string, string>>> {\n  /**\n   * The template used to render the form.\n   */\n  private _template?: Template<TPropertyDtos>;\n  public get template(): Template<TPropertyDtos> | undefined {\n    return this._template;\n  }\n  @Input({ required: true })\n  public set template(value: Template<TPropertyDtos>) {\n    this._template = value;\n    this._formGroup = this._formService.createFormGroupFromTemplate(value);\n  }\n\n  @Input({ required: true })\n  apiName!: string;\n\n  @Input({ required: true })\n  rel!: string;\n\n  /**\n   * Determines whether to enable the submit button.\n  */\n  @Input()\n  allowSubmit = true;\n\n  /**\n   * Determines whether to enable the delete button.\n  */\n  @Input()\n  allowDelete = true;\n\n  /**\n   * Determines whether to enable the reload button.\n  */\n  @Input()\n  allowReload = true;\n\n  /**\n   * Determines whether to show the submit button.\n  */\n  @Input()\n  showSubmit = true;\n\n  /**\n   * Determines whether to show the delete button.\n  */\n  @Input()\n  showDelete = true;\n\n  /**\n   * Determines whether to show the reload button.\n  */\n  @Input()\n  showReload = true;\n\n  @Output()\n  afterDelete = new EventEmitter<void>();\n\n  @Output()\n  afterSubmit = new EventEmitter<AfterSubmitOkEvent | AfterSubmitRedirectEvent>();\n\n  /**\n   * A reference to a template that can be used to render custom buttons for the form.\n  */\n  @ContentChild('buttons', { static: false })\n  buttonsRef?: TemplateRef<unknown>;\n\n  /**\n   * A reference to a template that can be used to render custom content inside the <form> element instead of the default form.\n  */\n  @ContentChild('content', { static: false })\n  contentRef?: TemplateRef<unknown>;\n\n  scrollToFirstValidationError(): void {\n    setTimeout(() => {\n      const validationErrorElements = this._elementRef.nativeElement.querySelectorAll('rw-validation-errors>val-errors>div')\n      const firstError = validationErrorElements[0];\n      firstError.scrollIntoView({ behavior: 'smooth', block: 'center'});\n    },\n    100);\n  }\n\n  private _isLoading = false;\n  public get isLoading(): boolean {\n    return this._isLoading;\n  }\n\n  private _formGroup?: FormGroup<any>;\n  public get formGroup(): FormGroup<any> | undefined {\n    return this._formGroup;\n  }\n\n  public get canSubmit() : boolean {\n    return this.allowSubmit &&\n      this.template !== undefined &&\n      this.template.target !== undefined &&\n      !this.isLoading &&\n      this.formGroup !== undefined &&\n      this.formGroup.valid;\n  }\n\n  public get canDelete(): boolean {\n    return this.allowDelete &&\n      this.template !== undefined &&\n      this.template.target !== undefined &&\n      this.template.method == \"PUT\" &&\n      !this.isLoading;\n  }\n\n  public get canReload(): boolean {\n    return this.allowReload &&\n      this.template !== undefined &&\n      this.template.target !== undefined &&\n      this.template.title !== undefined &&\n      this.template.properties.some(p => p.name === \"id\" && p.value !== undefined && p.value !== null && p.value !== 0) &&\n      !this.isLoading;\n  }\n\n  constructor(\n    private readonly _clients: RestWorldClientCollection,\n    private readonly _confirmationService: ConfirmationService,\n    private readonly _messageService: MessageService,\n    private readonly _formService: FormService,\n    private readonly _elementRef: ElementRef<HTMLElement>) {\n  }\n\n  public async reload(): Promise<void> {\n    if (!this.canReload || this.template === undefined)\n      return;\n\n    this._isLoading = true;\n\n    try\n    {\n      const response = await this.getClient().getForm(this.template.target!);\n      if (!response.ok || ProblemDetails.isProblemDetails(response.body) || !response.body) {\n        this._messageService.add({ severity: 'error', summary: 'Error', detail: 'Error while loading the resource from the API.', data: response, sticky: true });\n      }\n      else {\n        this.template = response.body.getTemplateByTitle(this.template.title!) as Template<TPropertyDtos>;\n        this._formGroup = this._formService.createFormGroupFromTemplate(this.template);\n      }\n    }\n    catch (e: unknown) {\n      this._messageService.add({ severity: 'error', summary: 'Error', detail: `An unknown error occurred. ${JSON.stringify(e)}`, sticky: true });\n      console.log(e);\n    }\n\n    this._isLoading = false;\n  }\n\n  public showDeleteConfirmatioModal() {\n    this._confirmationService.confirm({\n      message: 'Do you really want to delete this resource?',\n      header: 'Confirm delete',\n      icon: 'far fa-trash-alt',\n      accept: () => this.delete()\n    });\n  }\n\n  public async submit() {\n    if(this.formGroup !== undefined)\n    {\n      this.formGroup.markAllAsTouched();\n\n      if (!this.formGroup.valid) {\n        this._messageService.add({\n          severity: 'error',\n          summary: 'Error',\n          detail: 'Please correct the errors before submitting.',\n        });\n\n        this.scrollToFirstValidationError();\n      }\n    }\n\n    if(!this.canSubmit || this.formGroup === undefined || this.template === undefined)\n      return;\n\n    this._isLoading = true;\n\n    try {\n      const response = await this.getClient().submit(this.template, this.formGroup!.value);\n\n      if (!response.ok) {\n        let summary = 'Error';\n        let detail = 'Error while saving the resource.';\n        if (ProblemDetails.isProblemDetails(response.body)) {\n          const problemDetails = response.body as ProblemDetails;\n          summary = problemDetails.title || summary;\n          detail = problemDetails.detail || detail;\n          // display validation errors\n          if (problemDetails['errors'] as {}) {\n            for (const [key, errorsForKey] of Object.entries(problemDetails['errors'] as {})) {\n              const path = key.split(/\\.|\\[/).map(e => e.replace(\"]\", \"\"));\n              // The path might start with a $, indicating the root.\n              if (path.length > 0 && path[0] === '$')\n                path.shift();\n              const formControl = path.reduce<AbstractControl | undefined>(RestWorldFormComponent.getSubControl, this.formGroup);\n              if (formControl) {\n                formControl.setErrors({ ...formControl.errors, ...{ remote: errorsForKey } });\n                formControl.markAsTouched();\n              }\n            }\n          }\n        }\n\n        this._messageService.add({ severity: 'error', summary: summary, detail: detail, data: response, sticky: true });\n      }\n      else if (response.status == 201) {\n        if (!response.headers.has('Location')) {\n          this._messageService.add({ severity: 'error', summary: 'Error', detail: 'The server returned a 201 Created response, but did not return a Location header.', data: response, sticky: true });\n          return;\n        }\n\n        this._messageService.add({ severity: 'success', summary: 'Created', detail: 'The resource has been created.' });\n\n        var createdAtUri = response.headers.get('Location')!;\n        this.afterSubmit.emit({ location: createdAtUri, status: 201 });\n      }\n      else {\n        const templateBeforeSubmit = this.template;\n        const responseResource = (response.body as FormsResource);\n        this.template = responseResource.getTemplateByTitle(this.template.title!) as Template<TPropertyDtos>;\n        this._formGroup = this._formService.createFormGroupFromTemplate(this.template);\n\n        this._messageService.add({ severity: 'success', summary: 'Saved', detail: 'The resource has been saved.' });\n\n        this.afterSubmit.emit({ old: templateBeforeSubmit, new: this.template, status: 200 });\n      }\n    }\n    catch (e: unknown) {\n      this._messageService.add({ severity: 'error', summary: 'Error', detail: `An unknown error occurred. ${JSON.stringify(e)}`, sticky: true });\n      console.log(e);\n    }\n\n    this._isLoading = false;\n  }\n\n  public async delete(): Promise<void> {\n    if (!this.canDelete)\n      return;\n\n    if (this.formGroup === undefined)\n      throw new Error(\"formGroup cannot be undefined.\");\n\n    if (this.template === undefined)\n      throw new Error(\"template cannot be undefined.\");\n\n    await this.getClient().deleteByTemplateAndForm(this.template, this.formGroup);\n    this._messageService.add({ severity: 'success', summary: 'Deleted', detail: 'The resource has been deleted.' })\n\n    this.afterDelete.emit();\n  }\n\n  private static getSubControl(control: AbstractControl | undefined, pathElement: string): AbstractControl | undefined {\n    if (pathElement === \"\")\n      return control;\n\n    if (control instanceof UntypedFormGroup)\n      return control.controls[pathElement];\n\n    if (control instanceof UntypedFormArray) {\n      const index = Number.parseInt(pathElement);\n      if (Number.isInteger(index))\n        return control.controls[index];\n    }\n\n    return control;\n  }\n\n  private getClient(): RestWorldClient {\n    return this._clients.getClient(this.apiName);\n  }\n}\n","<form *ngIf=\"formGroup !== undefined && template !== undefined\" [formGroup]=\"formGroup\" (ngSubmit)=\"submit()\">\n  <div class=\"blockable-container\">\n    <div class=\"blockable-element\">\n      <div class=\"grid field\">\n        <div class=\"col-12 md:col-10 md:col-offset-2\">\n          <rw-validation-errors [form]=\"formGroup\"></rw-validation-errors>\n        </div>\n      </div>\n      <ng-template #defaultContent>\n        <rw-input-template [template]=\"template\" [apiName]=\"apiName\"></rw-input-template>\n      </ng-template>\n      <ng-container *ngTemplateOutlet=\"contentRef ?? defaultContent; context: { form: formGroup, template: template, apiName: apiName }\"></ng-container>\n    </div>\n    <div class=\"blockable-overlay\" *ngIf=\"isLoading\">\n      <p-progressSpinner></p-progressSpinner>\n    </div>\n  </div>\n\n  <div class=\"grid\">\n    <div class=\"col\">\n      <div class=\"flex justify-content-end w-full\">\n        <ng-template #defaultButtons>\n          <button pButton pRipple type=\"submit\" label=\"Save\" icon=\"far fa-save\" class=\"mx-2 p-button-success\"\n            [disabled]=\"!allowSubmit\"></button>\n          <button pButton pRipple type=\"button\" label=\"Reload\" icon=\"fas fa-redo\" class=\"mx-2 p-button-info\"\n            (click)=\"reload()\" [disabled]=\"!canReload\"></button>\n          <button pButton pRipple type=\"button\" label=\"Delete\" icon=\"far fa-trash-alt\" class=\"ml-2 p-button-danger\"\n            (click)=\"showDeleteConfirmatioModal()\" [disabled]=\"!canDelete\"></button>\n        </ng-template>\n        <ng-container *ngTemplateOutlet=\"buttonsRef ?? defaultButtons; context: { form: formGroup, template: template, apiName: apiName }\"></ng-container>\n      </div>\n    </div>\n  </div>\n</form>\n"]}
295
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"restworld-form.component.js","sourceRoot":"","sources":["../../../../../../projects/ngx-restworld-client/src/lib/components/restworld-form/restworld-form.component.ts","../../../../../../projects/ngx-restworld-client/src/lib/components/restworld-form/restworld-form.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ContentChild, ElementRef, EventEmitter, Input, Output, TemplateRef } from '@angular/core';\nimport { AbstractControl, FormGroup, UntypedFormArray, UntypedFormGroup } from '@angular/forms';\nimport { FormService, FormsResource, ProblemDetails, PropertyDto, SimpleValue, Template } from '@wertzui/ngx-hal-client';\nimport { ConfirmationService, MessageService } from 'primeng/api';\nimport { RestWorldClient } from '../../services/restworld-client';\nimport { RestWorldClientCollection } from '../../services/restworld-client-collection';\nimport { AfterSubmitOkEvent, AfterSubmitRedirectEvent } from '../../models/events';\n\n/**\n * A form with Save, Reload and Delete buttons.\n * If you do not want buttons, use RestWorldFormTemplateComponent <rw-form-template>.\n * You can also provide your own buttons by passing in a template.\n * @example\n * <rw-form\n *  [template]=\"template\"\n *  apiName=\"apiName\"\n *  rel=\"rel\"\n *  [allowSubmit]=\"true\"\n *  [allowDelete]=\"true\"\n *  [allowReload]=\"true\"\n *  [showSubmit]=\"true\"\n *  [showDelete]=\"true\"\n *  [showReload]=\"true\">\n *  <ng-template #content let-form=\"form\" let-template=\"template\" let-apiName=\"apiName\">\n *    <!-- Custom form content here -->\n *    <!-- This is optional and will replace the default which renders labels and inputs if present -->\n *  </ng-template>\n *  <ng-template #buttons let-form=\"form\" let-template=\"template\" let-apiName=\"apiName\">\n *    <!-- Custom buttons here -->\n *    <!-- This is optional and will replace the default which renders the Save, Reload and Delete buttons if present -->\n *  </ng-template>\n * </rw-form>\n */\n@Component({\n  selector: 'rw-form',\n  templateUrl: './restworld-form.component.html',\n  styleUrls: ['./restworld-form.component.css']\n})\nexport class RestWorldFormComponent<TPropertyDtos extends ReadonlyArray<PropertyDto<SimpleValue, string, string>>> {\n  /**\n   * The template used to render the form.\n   */\n  private _template?: Template<TPropertyDtos>;\n  public get template(): Template<TPropertyDtos> | undefined {\n    return this._template;\n  }\n  @Input({ required: true })\n  public set template(value: Template<TPropertyDtos>) {\n    this._template = value;\n    this._formGroup = this._formService.createFormGroupFromTemplate(value);\n  }\n\n  @Input({ required: true })\n  apiName!: string;\n\n  @Input({ required: true })\n  rel!: string;\n\n  /**\n   * Determines whether to enable the submit button.\n  */\n  @Input()\n  allowSubmit = true;\n\n  /**\n   * Determines whether to enable the delete button.\n  */\n  @Input()\n  allowDelete = true;\n\n  /**\n   * Determines whether to enable the reload button.\n  */\n  @Input()\n  allowReload = true;\n\n  /**\n   * Determines whether to show the submit button.\n  */\n  @Input()\n  showSubmit = true;\n\n  /**\n   * Determines whether to show the delete button.\n  */\n  @Input()\n  showDelete = true;\n\n  /**\n   * Determines whether to show the reload button.\n  */\n  @Input()\n  showReload = true;\n\n  @Output()\n  afterDelete = new EventEmitter<void>();\n\n  @Output()\n  afterSubmit = new EventEmitter<AfterSubmitOkEvent | AfterSubmitRedirectEvent>();\n\n  /**\n   * A reference to a template that can be used to render custom buttons for the form.\n  */\n  @ContentChild('buttons', { static: false })\n  buttonsRef?: TemplateRef<unknown>;\n\n  /**\n   * A reference to a template that can be used to render custom content inside the <form> element instead of the default form.\n  */\n  @ContentChild('content', { static: false })\n  contentRef?: TemplateRef<unknown>;\n\n  scrollToFirstValidationError(): void {\n    setTimeout(() => {\n      const validationErrorElements = this._elementRef.nativeElement.querySelectorAll('rw-validation-errors>val-errors>div')\n      const firstError = validationErrorElements[0];\n      firstError.scrollIntoView({ behavior: 'smooth', block: 'center'});\n    },\n    100);\n  }\n\n  private _isLoading = false;\n  public get isLoading(): boolean {\n    return this._isLoading;\n  }\n\n  private _formGroup?: FormGroup<any>;\n  public get formGroup(): FormGroup<any> | undefined {\n    return this._formGroup;\n  }\n\n  public get canSubmit() : boolean {\n    return this.allowSubmit &&\n      this.template !== undefined &&\n      this.template.target !== undefined &&\n      !this.isLoading &&\n      this.formGroup !== undefined &&\n      this.formGroup.valid;\n  }\n\n  public get canDelete(): boolean {\n    return this.allowDelete &&\n      this.template !== undefined &&\n      this.template.target !== undefined &&\n      this.template.method == \"PUT\" &&\n      !this.isLoading;\n  }\n\n  public get canReload(): boolean {\n    return this.allowReload &&\n      this.template !== undefined &&\n      this.template.target !== undefined &&\n      this.template.title !== undefined &&\n      this.template.properties.some(p => p.name === \"id\" && p.value !== undefined && p.value !== null && p.value !== 0) &&\n      !this.isLoading;\n  }\n\n  constructor(\n    private readonly _clients: RestWorldClientCollection,\n    private readonly _confirmationService: ConfirmationService,\n    private readonly _messageService: MessageService,\n    private readonly _formService: FormService,\n    private readonly _elementRef: ElementRef<HTMLElement>) {\n  }\n\n  public async reload(): Promise<void> {\n    if (!this.canReload || this.template === undefined)\n      return;\n\n    this._isLoading = true;\n\n    try\n    {\n      const response = await this.getClient().getForm(this.template.target!);\n      if (!response.ok || ProblemDetails.isProblemDetails(response.body) || !response.body) {\n        this._messageService.add({ severity: 'error', summary: 'Error', detail: 'Error while loading the resource from the API.', data: response, sticky: true });\n      }\n      else {\n        this.template = response.body.getTemplateByTitle(this.template.title!) as Template<TPropertyDtos>;\n        this._formGroup = this._formService.createFormGroupFromTemplate(this.template);\n      }\n    }\n    catch (e: unknown) {\n      this._messageService.add({ severity: 'error', summary: 'Error', detail: `An unknown error occurred. ${JSON.stringify(e)}`, sticky: true });\n      console.log(e);\n    }\n\n    this._isLoading = false;\n  }\n\n  public showDeleteConfirmatioModal() {\n    this._confirmationService.confirm({\n      message: 'Do you really want to delete this resource?',\n      header: 'Confirm delete',\n      icon: 'far fa-trash-alt',\n      accept: () => this.delete()\n    });\n  }\n\n  public async submit() {\n    if(this.formGroup !== undefined)\n    {\n      this.formGroup.markAllAsTouched();\n\n      if (!this.formGroup.valid) {\n        this._messageService.add({\n          severity: 'error',\n          summary: 'Error',\n          detail: 'Please correct the errors before submitting.',\n        });\n\n        this.scrollToFirstValidationError();\n      }\n    }\n\n    if(!this.canSubmit || this.formGroup === undefined || this.template === undefined)\n      return;\n\n    this._isLoading = true;\n\n    try {\n      const response = await this.getClient().submit(this.template, this.formGroup!.value);\n\n      if (!response.ok) {\n        let summary = 'Error';\n        let detail = 'Error while saving the resource.';\n        if (ProblemDetails.isProblemDetails(response.body)) {\n          const problemDetails = response.body as ProblemDetails;\n          summary = problemDetails.title || summary;\n          detail = problemDetails.detail || detail;\n          // display validation errors\n          if (problemDetails['errors'] as {}) {\n            for (const [key, errorsForKey] of Object.entries(problemDetails['errors'] as {})) {\n              const path = key.split(/\\.|\\[/).map(e => e.replace(\"]\", \"\"));\n              // The path might start with a $, indicating the root.\n              if (path.length > 0 && path[0] === '$')\n                path.shift();\n              const formControl = path.reduce<AbstractControl | undefined>(RestWorldFormComponent.getSubControl, this.formGroup);\n              if (formControl) {\n                formControl.setErrors({ ...formControl.errors, ...{ remote: errorsForKey } });\n                formControl.markAsTouched();\n              }\n            }\n          }\n        }\n\n        this._messageService.add({ severity: 'error', summary: summary, detail: detail, data: response, sticky: true });\n      }\n      else if (response.status == 201) {\n        if (!response.headers.has('Location')) {\n          this._messageService.add({ severity: 'error', summary: 'Error', detail: 'The server returned a 201 Created response, but did not return a Location header.', data: response, sticky: true });\n          return;\n        }\n\n        this._messageService.add({ severity: 'success', summary: 'Created', detail: 'The resource has been created.' });\n\n        var createdAtUri = response.headers.get('Location')!;\n        this.afterSubmit.emit({ location: createdAtUri, status: 201 });\n      }\n      else {\n        const templateBeforeSubmit = this.template;\n        const responseResource = (response.body as FormsResource);\n        this.template = responseResource.getTemplateByTitle(this.template.title!) as Template<TPropertyDtos>;\n        this._formGroup = this._formService.createFormGroupFromTemplate(this.template);\n\n        this._messageService.add({ severity: 'success', summary: 'Saved', detail: 'The resource has been saved.' });\n\n        this.afterSubmit.emit({ old: templateBeforeSubmit, new: this.template, status: 200 });\n      }\n    }\n    catch (e: unknown) {\n      this._messageService.add({ severity: 'error', summary: 'Error', detail: `An unknown error occurred. ${JSON.stringify(e)}`, sticky: true });\n      console.log(e);\n    }\n\n    this._isLoading = false;\n  }\n\n  public async delete(): Promise<void> {\n    if (!this.canDelete)\n      return;\n\n    if (this.formGroup === undefined)\n      throw new Error(\"formGroup cannot be undefined.\");\n\n    if (this.template === undefined)\n      throw new Error(\"template cannot be undefined.\");\n\n    await this.getClient().deleteByTemplateAndForm(this.template, this.formGroup);\n    this._messageService.add({ severity: 'success', summary: 'Deleted', detail: 'The resource has been deleted.' })\n\n    this.afterDelete.emit();\n  }\n\n  private static getSubControl(control: AbstractControl | undefined, pathElement: string): AbstractControl | undefined {\n    if (pathElement === \"\")\n      return control;\n\n    if (control instanceof UntypedFormGroup)\n      return control.controls[pathElement];\n\n    if (control instanceof UntypedFormArray) {\n      const index = Number.parseInt(pathElement);\n      if (Number.isInteger(index))\n        return control.controls[index];\n    }\n\n    return control;\n  }\n\n  private getClient(): RestWorldClient {\n    return this._clients.getClient(this.apiName);\n  }\n}\n","<form *ngIf=\"formGroup !== undefined && template !== undefined\" [formGroup]=\"formGroup\" (ngSubmit)=\"submit()\">\n  <div class=\"blockable-container\">\n    <div class=\"blockable-element\">\n      <div class=\"grid field\">\n        <div class=\"col-12 md:col-10 md:col-offset-2\">\n          <rw-validation-errors [form]=\"formGroup\"></rw-validation-errors>\n        </div>\n      </div>\n      <ng-template #defaultContent>\n        <rw-input-template [template]=\"template\" [apiName]=\"apiName\"></rw-input-template>\n      </ng-template>\n      <ng-container *ngTemplateOutlet=\"contentRef ?? defaultContent; context: { form: formGroup, template: template, apiName: apiName }\"></ng-container>\n    </div>\n    <div class=\"blockable-overlay\" *ngIf=\"isLoading\">\n      <p-progressSpinner></p-progressSpinner>\n    </div>\n  </div>\n\n  <div class=\"grid\">\n    <div class=\"col\">\n      <div class=\"flex justify-content-end w-full\">\n        <ng-template #defaultButtons>\n          <button pButton pRipple type=\"submit\" label=\"Save\" icon=\"far fa-save\" class=\"mx-2 p-button-success\"\n            [disabled]=\"!allowSubmit\"></button>\n          <button pButton pRipple type=\"button\" label=\"Reload\" icon=\"fas fa-redo\" class=\"mx-2 p-button-info\"\n            (click)=\"reload()\" [disabled]=\"!canReload\"></button>\n          <button pButton pRipple type=\"button\" label=\"Delete\" icon=\"far fa-trash-alt\" class=\"ml-2 p-button-danger\"\n            (click)=\"showDeleteConfirmatioModal()\" [disabled]=\"!canDelete\"></button>\n        </ng-template>\n        <ng-container *ngTemplateOutlet=\"buttonsRef ?? defaultButtons; context: { form: formGroup, template: template, apiName: apiName }\"></ng-container>\n      </div>\n    </div>\n  </div>\n</form>\n"]}