geonetwork-ui 2.4.1-dev.7a0dc5e3f → 2.4.1-dev.9ee0df3df

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 (95) hide show
  1. package/esm2022/libs/api/metadata-converter/src/lib/iso19139/utils/update-frequency.mapper.mjs +6 -62
  2. package/esm2022/libs/api/metadata-converter/src/lib/iso19139/write-parts.mjs +19 -1
  3. package/esm2022/libs/common/domain/src/lib/model/record/metadata.model.mjs +27 -1
  4. package/esm2022/libs/feature/editor/src/lib/components/constraint-card/constraint-card.component.mjs +3 -3
  5. package/esm2022/libs/feature/editor/src/lib/components/generic-keywords/generic-keywords.component.mjs +3 -3
  6. package/esm2022/libs/feature/editor/src/lib/components/import-record/import-record.component.mjs +2 -2
  7. package/esm2022/libs/feature/editor/src/lib/components/online-service-resource-input/online-service-resource-input.component.mjs +45 -9
  8. package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-online-link-resources/form-field-online-link-resources.component.mjs +3 -3
  9. package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-online-resources/form-field-online-resources.component.mjs +12 -3
  10. package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-overviews/form-field-overviews.component.mjs +2 -2
  11. package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-spatial-extent/form-field-spatial-extent.component.mjs +3 -3
  12. package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-update-frequency/form-field-update-frequency.component.mjs +36 -60
  13. package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field.component.mjs +3 -3
  14. package/esm2022/libs/feature/editor/src/lib/components/record-form/record-form.component.mjs +3 -3
  15. package/esm2022/libs/feature/editor/src/lib/fields.config.mjs +11 -15
  16. package/esm2022/libs/ui/elements/src/index.mjs +3 -2
  17. package/esm2022/libs/ui/elements/src/lib/image-input/image-input.component.mjs +213 -0
  18. package/esm2022/libs/ui/elements/src/lib/ui-elements.module.mjs +19 -13
  19. package/esm2022/libs/ui/inputs/src/index.mjs +5 -6
  20. package/esm2022/libs/ui/inputs/src/lib/button/button.component.mjs +2 -1
  21. package/esm2022/libs/ui/inputs/src/lib/file-input/file-input.component.mjs +2 -2
  22. package/esm2022/libs/ui/inputs/src/lib/ui-inputs.module.mjs +19 -25
  23. package/esm2022/libs/ui/inputs/src/lib/url-input/url-input.component.mjs +6 -6
  24. package/esm2022/translations/de.json +23 -11
  25. package/esm2022/translations/en.json +19 -7
  26. package/esm2022/translations/es.json +23 -11
  27. package/esm2022/translations/fr.json +23 -11
  28. package/esm2022/translations/it.json +23 -11
  29. package/esm2022/translations/nl.json +23 -11
  30. package/esm2022/translations/pt.json +23 -11
  31. package/fesm2022/geonetwork-ui.mjs +922 -835
  32. package/fesm2022/geonetwork-ui.mjs.map +1 -1
  33. package/libs/api/metadata-converter/src/lib/iso19139/utils/update-frequency.mapper.d.ts.map +1 -1
  34. package/libs/api/metadata-converter/src/lib/iso19139/write-parts.d.ts.map +1 -1
  35. package/libs/common/domain/src/lib/model/record/metadata.model.d.ts +2 -1
  36. package/libs/common/domain/src/lib/model/record/metadata.model.d.ts.map +1 -1
  37. package/libs/feature/editor/src/lib/components/online-service-resource-input/online-service-resource-input.component.d.ts +11 -2
  38. package/libs/feature/editor/src/lib/components/online-service-resource-input/online-service-resource-input.component.d.ts.map +1 -1
  39. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-online-resources/form-field-online-resources.component.d.ts +4 -0
  40. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-online-resources/form-field-online-resources.component.d.ts.map +1 -1
  41. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-update-frequency/form-field-update-frequency.component.d.ts +1 -1
  42. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-update-frequency/form-field-update-frequency.component.d.ts.map +1 -1
  43. package/libs/feature/editor/src/lib/fields.config.d.ts.map +1 -1
  44. package/libs/ui/elements/src/index.d.ts +2 -1
  45. package/libs/ui/elements/src/index.d.ts.map +1 -1
  46. package/libs/ui/elements/src/lib/image-input/image-input.component.d.ts.map +1 -0
  47. package/libs/ui/elements/src/lib/ui-elements.module.d.ts +2 -1
  48. package/libs/ui/elements/src/lib/ui-elements.module.d.ts.map +1 -1
  49. package/libs/ui/inputs/src/index.d.ts +4 -5
  50. package/libs/ui/inputs/src/index.d.ts.map +1 -1
  51. package/libs/ui/inputs/src/lib/button/button.component.d.ts +1 -1
  52. package/libs/ui/inputs/src/lib/button/button.component.d.ts.map +1 -1
  53. package/libs/ui/inputs/src/lib/ui-inputs.module.d.ts +6 -7
  54. package/libs/ui/inputs/src/lib/ui-inputs.module.d.ts.map +1 -1
  55. package/libs/ui/inputs/src/lib/url-input/url-input.component.d.ts +2 -2
  56. package/libs/ui/inputs/src/lib/url-input/url-input.component.d.ts.map +1 -1
  57. package/package.json +1 -1
  58. package/src/libs/api/metadata-converter/src/lib/iso19139/utils/update-frequency.mapper.ts +9 -62
  59. package/src/libs/api/metadata-converter/src/lib/iso19139/write-parts.ts +18 -0
  60. package/src/libs/common/domain/src/lib/model/record/metadata.model.ts +29 -7
  61. package/src/libs/feature/editor/src/lib/components/constraint-card/constraint-card.component.html +1 -1
  62. package/src/libs/feature/editor/src/lib/components/generic-keywords/generic-keywords.component.html +1 -1
  63. package/src/libs/feature/editor/src/lib/components/online-service-resource-input/online-service-resource-input.component.html +31 -6
  64. package/src/libs/feature/editor/src/lib/components/online-service-resource-input/online-service-resource-input.component.ts +47 -2
  65. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-online-link-resources/form-field-online-link-resources.component.html +1 -1
  66. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-online-resources/form-field-online-resources.component.html +3 -7
  67. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-online-resources/form-field-online-resources.component.ts +10 -0
  68. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-overviews/form-field-overviews.component.ts +1 -1
  69. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-spatial-extent/form-field-spatial-extent.component.html +6 -6
  70. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-update-frequency/form-field-update-frequency.component.ts +46 -74
  71. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field.component.html +1 -1
  72. package/src/libs/feature/editor/src/lib/components/record-form/record-form.component.html +3 -6
  73. package/src/libs/feature/editor/src/lib/fields.config.ts +10 -14
  74. package/src/libs/ui/elements/src/index.ts +2 -1
  75. package/src/libs/ui/{inputs → elements}/src/lib/image-input/image-input.component.html +4 -19
  76. package/src/libs/ui/{inputs → elements}/src/lib/image-input/image-input.component.ts +13 -9
  77. package/src/libs/ui/elements/src/lib/ui-elements.module.ts +13 -10
  78. package/src/libs/ui/inputs/src/index.ts +4 -5
  79. package/src/libs/ui/inputs/src/lib/button/button.component.ts +2 -1
  80. package/src/libs/ui/inputs/src/lib/ui-inputs.module.ts +22 -25
  81. package/src/libs/ui/inputs/src/lib/url-input/url-input.component.html +5 -3
  82. package/src/libs/ui/inputs/src/lib/url-input/url-input.component.ts +1 -1
  83. package/translations/de.json +23 -11
  84. package/translations/en.json +19 -7
  85. package/translations/es.json +23 -11
  86. package/translations/fr.json +23 -11
  87. package/translations/it.json +23 -11
  88. package/translations/nl.json +23 -11
  89. package/translations/pt.json +23 -11
  90. package/translations/sk.json +23 -11
  91. package/esm2022/libs/ui/inputs/src/lib/image-input/image-input.component.mjs +0 -214
  92. package/libs/ui/inputs/src/lib/image-input/image-input.component.d.ts.map +0 -1
  93. package/src/libs/api/metadata-converter/src/lib/dcat-ap/utils/update-frequency.mapper.ts +0 -67
  94. /package/libs/ui/{inputs → elements}/src/lib/image-input/image-input.component.d.ts +0 -0
  95. /package/src/libs/ui/{inputs → elements}/src/lib/image-input/image-input.component.css +0 -0
@@ -1,12 +1,14 @@
1
1
  import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output, } from '@angular/core';
2
+ import { updateFrequencyCodeValues, } from '../../../../../../../../../libs/common/domain/src/lib/model/record';
2
3
  import { CheckToggleComponent, DropdownSelectorComponent, } from '../../../../../../../../../libs/ui/inputs/src';
3
4
  import { TranslateModule, TranslateService } from '@ngx-translate/core';
4
5
  import { firstValueFrom } from 'rxjs';
5
6
  import * as i0 from "@angular/core";
6
7
  import * as i1 from "@ngx-translate/core";
8
+ const initialListValues = updateFrequencyCodeValues.filter((code) => !['unknown', 'notPlanned', 'asNeeded', 'irregular'].includes(code));
7
9
  export class FormFieldUpdateFrequencyComponent {
8
10
  get planned() {
9
- return typeof this.value !== 'string';
11
+ return this.value && this.value !== 'notPlanned' && this.value !== 'unknown';
10
12
  }
11
13
  constructor(translateService) {
12
14
  this.translateService = translateService;
@@ -15,13 +17,26 @@ export class FormFieldUpdateFrequencyComponent {
15
17
  }
16
18
  async ngOnInit() {
17
19
  this.choices = await this.getInitialChoices();
20
+ if (!this.planned) {
21
+ return;
22
+ }
23
+ if (typeof this.value === 'string' &&
24
+ !this.choices.map((choice) => choice.value).includes(this.value)) {
25
+ this.choices = [
26
+ {
27
+ value: this.value,
28
+ label: await firstValueFrom(this.translateService.get(`domain.record.updateFrequency.${this.value}`)),
29
+ },
30
+ ...this.choices,
31
+ ];
32
+ }
18
33
  if (typeof this.value === 'string') {
19
34
  return;
20
35
  }
21
36
  const updatedTimes = this.value.updatedTimes;
22
37
  const per = this.value.per;
23
38
  // the update frequency is not in the list; make it appear there
24
- if (updatedTimes && updatedTimes !== 1 && updatedTimes !== 2) {
39
+ if (updatedTimes) {
25
40
  this.choices = [
26
41
  {
27
42
  value: `${per}.${updatedTimes}`,
@@ -38,73 +53,34 @@ export class FormFieldUpdateFrequencyComponent {
38
53
  this.valueChange.emit('notPlanned');
39
54
  }
40
55
  else {
41
- this.valueChange.emit({ updatedTimes: 1, per: 'day' });
56
+ this.valueChange.emit(this.choices[0].value);
42
57
  }
43
58
  }
44
59
  get selectedFrequency() {
45
- if (!this.value || typeof this.value === 'string')
60
+ if (!this.value)
46
61
  return null;
62
+ if (typeof this.value === 'string')
63
+ return this.value;
47
64
  const { updatedTimes, per } = this.value;
48
65
  return `${per}.${updatedTimes}`;
49
66
  }
50
67
  onSelectFrequencyValue(value) {
51
- const split = value.split('.');
52
- this.valueChange.emit({
53
- updatedTimes: Number(split[1]),
54
- per: split[0],
55
- });
68
+ if (!value.includes('.')) {
69
+ this.valueChange.emit(value);
70
+ }
71
+ else {
72
+ const split = value.split('.');
73
+ this.valueChange.emit({
74
+ updatedTimes: Number(split[1]),
75
+ per: split[0],
76
+ });
77
+ }
56
78
  }
57
79
  async getInitialChoices() {
58
- return [
59
- {
60
- value: 'day.1',
61
- label: await firstValueFrom(this.translateService.get('domain.record.updateFrequency.day', {
62
- count: 1,
63
- })),
64
- },
65
- {
66
- value: 'day.2',
67
- label: await firstValueFrom(this.translateService.get('domain.record.updateFrequency.day', {
68
- count: 2,
69
- })),
70
- },
71
- {
72
- value: 'week.1',
73
- label: await firstValueFrom(this.translateService.get('domain.record.updateFrequency.week', {
74
- count: 1,
75
- })),
76
- },
77
- {
78
- value: 'week.2',
79
- label: await firstValueFrom(this.translateService.get('domain.record.updateFrequency.week', {
80
- count: 2,
81
- })),
82
- },
83
- {
84
- value: 'month.1',
85
- label: await firstValueFrom(this.translateService.get('domain.record.updateFrequency.month', {
86
- count: 1,
87
- })),
88
- },
89
- {
90
- value: 'month.2',
91
- label: await firstValueFrom(this.translateService.get('domain.record.updateFrequency.month', {
92
- count: 2,
93
- })),
94
- },
95
- {
96
- value: 'year.1',
97
- label: await firstValueFrom(this.translateService.get('domain.record.updateFrequency.year', {
98
- count: 1,
99
- })),
100
- },
101
- {
102
- value: 'year.2',
103
- label: await firstValueFrom(this.translateService.get('domain.record.updateFrequency.year', {
104
- count: 2,
105
- })),
106
- },
107
- ];
80
+ return Promise.all(initialListValues.map(async (value) => ({
81
+ value,
82
+ label: await firstValueFrom(this.translateService.get(`domain.record.updateFrequency.${value}`)),
83
+ })));
108
84
  }
109
85
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FormFieldUpdateFrequencyComponent, deps: [{ token: i1.TranslateService }], target: i0.ɵɵFactoryTarget.Component }); }
110
86
  static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: FormFieldUpdateFrequencyComponent, isStandalone: true, selector: "gn-ui-form-field-update-frequency", inputs: { value: "value" }, outputs: { valueChange: "valueChange" }, ngImport: i0, template: "<div class=\"flex flex-col gap-2\">\n <gn-ui-check-toggle\n [label]=\"'editor.record.form.updateFrequency.planned' | translate\"\n [value]=\"planned\"\n (toggled)=\"onPlannedToggled()\"\n ></gn-ui-check-toggle>\n <gn-ui-dropdown-selector\n title=\"updateFrequency\"\n [showTitle]=\"false\"\n [choices]=\"choices\"\n [selected]=\"selectedFrequency\"\n (selectValue)=\"onSelectFrequencyValue($event)\"\n [disabled]=\"!planned\"\n [extraBtnClass]=\"'input-as-button gn-ui-text-input'\"\n >\n </gn-ui-dropdown-selector>\n</div>\n", styles: ["gn-ui-dropdown-selector{max-width:calc(50% - 16px)}\n"], dependencies: [{ kind: "component", type: CheckToggleComponent, selector: "gn-ui-check-toggle", inputs: ["title", "label", "value", "color"], outputs: ["toggled"] }, { kind: "component", type: DropdownSelectorComponent, selector: "gn-ui-dropdown-selector", inputs: ["title", "showTitle", "ariaName", "choices", "selected", "maxRows", "extraBtnClass", "minWidth", "disabled"], outputs: ["selectValue"] }, { kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i1.TranslatePipe, name: "translate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
@@ -117,4 +93,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
117
93
  }], valueChange: [{
118
94
  type: Output
119
95
  }] } });
120
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-field-update-frequency.component.js","sourceRoot":"","sources":["../../../../../../../../../../../libs/feature/editor/src/lib/components/record-form/form-field/form-field-update-frequency/form-field-update-frequency.component.ts","../../../../../../../../../../../libs/feature/editor/src/lib/components/record-form/form-field/form-field-update-frequency/form-field-update-frequency.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  EventEmitter,\n  Input,\n  OnInit,\n  Output,\n} from '@angular/core'\nimport {\n  UpdateFrequency,\n  UpdateFrequencyCustom,\n} from '../../../../../../../../../libs/common/domain/src/lib/model/record'\nimport {\n  CheckToggleComponent,\n  DropdownChoice,\n  DropdownSelectorComponent,\n} from '../../../../../../../../../libs/ui/inputs/src'\nimport { TranslateModule, TranslateService } from '@ngx-translate/core'\nimport { firstValueFrom } from 'rxjs'\n\n@Component({\n  selector: 'gn-ui-form-field-update-frequency',\n  templateUrl: './form-field-update-frequency.component.html',\n  styleUrls: ['./form-field-update-frequency.component.css'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true,\n  imports: [CheckToggleComponent, DropdownSelectorComponent, TranslateModule],\n})\nexport class FormFieldUpdateFrequencyComponent implements OnInit {\n  @Input() value: UpdateFrequency\n  @Output() valueChange: EventEmitter<UpdateFrequency> = new EventEmitter()\n\n  protected choices: DropdownChoice[] = []\n\n  get planned() {\n    return typeof this.value !== 'string'\n  }\n\n  constructor(private translateService: TranslateService) {}\n\n  async ngOnInit() {\n    this.choices = await this.getInitialChoices()\n    if (typeof this.value === 'string') {\n      return\n    }\n    const updatedTimes = this.value.updatedTimes\n    const per = this.value.per\n    // the update frequency is not in the list; make it appear there\n    if (updatedTimes && updatedTimes !== 1 && updatedTimes !== 2) {\n      this.choices = [\n        {\n          value: `${per}.${updatedTimes}`,\n          label: await firstValueFrom(\n            this.translateService.get(`domain.record.updateFrequency.${per}`, {\n              count: updatedTimes,\n            })\n          ),\n        },\n        ...this.choices,\n      ]\n    }\n  }\n\n  onPlannedToggled() {\n    if (this.planned) {\n      this.valueChange.emit('notPlanned')\n    } else {\n      this.valueChange.emit({ updatedTimes: 1, per: 'day' })\n    }\n  }\n\n  get selectedFrequency(): string {\n    if (!this.value || typeof this.value === 'string') return null\n    const { updatedTimes, per } = this.value\n    return `${per}.${updatedTimes}`\n  }\n\n  onSelectFrequencyValue(value: unknown) {\n    const split = (value as string).split('.')\n    this.valueChange.emit({\n      updatedTimes: Number(split[1]),\n      per: split[0] as UpdateFrequencyCustom['per'],\n    })\n  }\n\n  private async getInitialChoices() {\n    return [\n      {\n        value: 'day.1',\n        label: await firstValueFrom(\n          this.translateService.get('domain.record.updateFrequency.day', {\n            count: 1,\n          })\n        ),\n      },\n      {\n        value: 'day.2',\n        label: await firstValueFrom(\n          this.translateService.get('domain.record.updateFrequency.day', {\n            count: 2,\n          })\n        ),\n      },\n      {\n        value: 'week.1',\n        label: await firstValueFrom(\n          this.translateService.get('domain.record.updateFrequency.week', {\n            count: 1,\n          })\n        ),\n      },\n      {\n        value: 'week.2',\n        label: await firstValueFrom(\n          this.translateService.get('domain.record.updateFrequency.week', {\n            count: 2,\n          })\n        ),\n      },\n      {\n        value: 'month.1',\n        label: await firstValueFrom(\n          this.translateService.get('domain.record.updateFrequency.month', {\n            count: 1,\n          })\n        ),\n      },\n      {\n        value: 'month.2',\n        label: await firstValueFrom(\n          this.translateService.get('domain.record.updateFrequency.month', {\n            count: 2,\n          })\n        ),\n      },\n      {\n        value: 'year.1',\n        label: await firstValueFrom(\n          this.translateService.get('domain.record.updateFrequency.year', {\n            count: 1,\n          })\n        ),\n      },\n      {\n        value: 'year.2',\n        label: await firstValueFrom(\n          this.translateService.get('domain.record.updateFrequency.year', {\n            count: 2,\n          })\n        ),\n      },\n    ]\n  }\n}\n","<div class=\"flex flex-col gap-2\">\n  <gn-ui-check-toggle\n    [label]=\"'editor.record.form.updateFrequency.planned' | translate\"\n    [value]=\"planned\"\n    (toggled)=\"onPlannedToggled()\"\n  ></gn-ui-check-toggle>\n  <gn-ui-dropdown-selector\n    title=\"updateFrequency\"\n    [showTitle]=\"false\"\n    [choices]=\"choices\"\n    [selected]=\"selectedFrequency\"\n    (selectValue)=\"onSelectFrequencyValue($event)\"\n    [disabled]=\"!planned\"\n    [extraBtnClass]=\"'input-as-button gn-ui-text-input'\"\n  >\n  </gn-ui-dropdown-selector>\n</div>\n"]}
96
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-field-update-frequency.component.js","sourceRoot":"","sources":["../../../../../../../../../../../libs/feature/editor/src/lib/components/record-form/form-field/form-field-update-frequency/form-field-update-frequency.component.ts","../../../../../../../../../../../libs/feature/editor/src/lib/components/record-form/form-field/form-field-update-frequency/form-field-update-frequency.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  EventEmitter,\n  Input,\n  OnInit,\n  Output,\n} from '@angular/core'\nimport {\n  UpdateFrequency,\n  UpdateFrequencyCode,\n  updateFrequencyCodeValues,\n  UpdateFrequencyCustom,\n} from '../../../../../../../../../libs/common/domain/src/lib/model/record'\nimport {\n  CheckToggleComponent,\n  DropdownChoice,\n  DropdownSelectorComponent,\n} from '../../../../../../../../../libs/ui/inputs/src'\nimport { TranslateModule, TranslateService } from '@ngx-translate/core'\nimport { firstValueFrom } from 'rxjs'\n\nconst initialListValues = updateFrequencyCodeValues.filter(\n  (code) => !['unknown', 'notPlanned', 'asNeeded', 'irregular'].includes(code)\n)\n\n@Component({\n  selector: 'gn-ui-form-field-update-frequency',\n  templateUrl: './form-field-update-frequency.component.html',\n  styleUrls: ['./form-field-update-frequency.component.css'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true,\n  imports: [CheckToggleComponent, DropdownSelectorComponent, TranslateModule],\n})\nexport class FormFieldUpdateFrequencyComponent implements OnInit {\n  @Input() value: UpdateFrequency\n  @Output() valueChange: EventEmitter<UpdateFrequency> = new EventEmitter()\n\n  protected choices: DropdownChoice[] = []\n\n  get planned() {\n    return this.value && this.value !== 'notPlanned' && this.value !== 'unknown'\n  }\n\n  constructor(private translateService: TranslateService) {}\n\n  async ngOnInit() {\n    this.choices = await this.getInitialChoices()\n    if (!this.planned) {\n      return\n    }\n    if (\n      typeof this.value === 'string' &&\n      !this.choices.map((choice) => choice.value).includes(this.value)\n    ) {\n      this.choices = [\n        {\n          value: this.value,\n          label: await firstValueFrom(\n            this.translateService.get(\n              `domain.record.updateFrequency.${this.value}`\n            )\n          ),\n        },\n        ...this.choices,\n      ]\n    }\n    if (typeof this.value === 'string') {\n      return\n    }\n    const updatedTimes = this.value.updatedTimes\n    const per = this.value.per\n    // the update frequency is not in the list; make it appear there\n    if (updatedTimes) {\n      this.choices = [\n        {\n          value: `${per}.${updatedTimes}`,\n          label: await firstValueFrom(\n            this.translateService.get(`domain.record.updateFrequency.${per}`, {\n              count: updatedTimes,\n            })\n          ),\n        },\n        ...this.choices,\n      ]\n    }\n  }\n\n  onPlannedToggled() {\n    if (this.planned) {\n      this.valueChange.emit('notPlanned')\n    } else {\n      this.valueChange.emit(this.choices[0].value as UpdateFrequencyCode)\n    }\n  }\n\n  get selectedFrequency(): string {\n    if (!this.value) return null\n    if (typeof this.value === 'string') return this.value\n    const { updatedTimes, per } = this.value\n    return `${per}.${updatedTimes}`\n  }\n\n  onSelectFrequencyValue(value: string) {\n    if (!value.includes('.')) {\n      this.valueChange.emit(value as UpdateFrequencyCode)\n    } else {\n      const split = (value as string).split('.')\n      this.valueChange.emit({\n        updatedTimes: Number(split[1]),\n        per: split[0] as UpdateFrequencyCustom['per'],\n      })\n    }\n  }\n\n  private async getInitialChoices() {\n    return Promise.all(\n      initialListValues.map(async (value) => ({\n        value,\n        label: await firstValueFrom(\n          this.translateService.get(`domain.record.updateFrequency.${value}`)\n        ),\n      }))\n    )\n  }\n}\n","<div class=\"flex flex-col gap-2\">\n  <gn-ui-check-toggle\n    [label]=\"'editor.record.form.updateFrequency.planned' | translate\"\n    [value]=\"planned\"\n    (toggled)=\"onPlannedToggled()\"\n  ></gn-ui-check-toggle>\n  <gn-ui-dropdown-selector\n    title=\"updateFrequency\"\n    [showTitle]=\"false\"\n    [choices]=\"choices\"\n    [selected]=\"selectedFrequency\"\n    (selectValue)=\"onSelectFrequencyValue($event)\"\n    [disabled]=\"!planned\"\n    [extraBtnClass]=\"'input-as-button gn-ui-text-input'\"\n  >\n  </gn-ui-dropdown-selector>\n</div>\n"]}
@@ -75,7 +75,7 @@ export class FormFieldComponent {
75
75
  return this.value;
76
76
  }
77
77
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FormFieldComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
78
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: FormFieldComponent, isStandalone: true, selector: "gn-ui-form-field", inputs: { uniqueIdentifier: "uniqueIdentifier", model: "model", modelSpecifier: "modelSpecifier", componentName: "componentName", config: "config", value: "value" }, outputs: { valueChange: "valueChange" }, viewQueries: [{ propertyName: "titleInput", first: true, predicate: ["titleInput"], descendants: true }], ngImport: i0, template: "<!-- TEMPORARY - disabling the open data switch -->\n<!-- <ng-container *ngIf=\"model === 'licenses'\">\n <gn-ui-form-field-open-data\n [value]=\"valueAsConstraints\"\n (valueChange)=\"valueChange.emit($event)\"\n (openDataChange)=\"toggleIsOpenData($event)\"\n ></gn-ui-form-field-open-data>\n</ng-container> -->\n<div class=\"flex flex-col h-full\">\n <ng-container *ngIf=\"withoutWrapper; else withGenericWrapper\">\n <ng-container *ngTemplateOutlet=\"fieldContent\"></ng-container>\n </ng-container>\n <ng-template #withGenericWrapper>\n <gn-ui-form-field-wrapper\n [label]=\"config.labelKey! | translate\"\n [hint]=\"config.hintKey! | translate\"\n >\n <ng-container *ngTemplateOutlet=\"fieldContent\"></ng-container>\n </gn-ui-form-field-wrapper>\n </ng-template>\n</div>\n\n<ng-template #fieldContent>\n <ng-container [ngSwitch]=\"model\">\n <ng-container *ngSwitchCase=\"'title'\">\n <div class=\"flex flex-row flex-start items-center gap-3 mb-[12px]\">\n <textarea\n #titleInput\n cdkTextareaAutosize\n #autosize=\"cdkTextareaAutosize\"\n cdkAutosizeMinRows=\"1\"\n data-test=\"recordTitleInput\"\n class=\"grow font-title text-3xl font-normal overflow-hidden\"\n (change)=\"valueChange.emit($event.target.value)\"\n [placeholder]=\"\n 'editor.record.form.field.title.placeholder' | translate\n \"\n >{{ valueAsString }}</textarea\n >\n <div class=\"flex flex-row justify-between self-start mt-0.5\">\n <span\n class=\"material-symbols-outlined gn-ui-icon-small m-2 cursor-pointer\"\n (click)=\"focusTitleInput()\"\n >edit</span\n >\n <span\n *ngIf=\"config.hintKey\"\n class=\"material-symbols-outlined gn-ui-icon-small m-2\"\n [matTooltip]=\"config.hintKey! | translate\"\n matTooltipPosition=\"above\"\n >\n help\n </span>\n </div>\n </div>\n </ng-container>\n <ng-container *ngSwitchCase=\"'abstract'\">\n <gn-ui-form-field-rich\n [label]=\"config.labelKey! | translate\"\n [hint]=\"config.hintKey! | translate\"\n [value]=\"valueAsString\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-rich>\n </ng-container>\n <ng-container *ngSwitchCase=\"'overviews'\">\n <gn-ui-form-field-overviews\n [metadataUuid]=\"uniqueIdentifier\"\n [value]=\"valueAsOverviews\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-overviews>\n </ng-container>\n <ng-container *ngSwitchCase=\"'resourceIdentifier'\">\n <gn-ui-form-field-simple\n [type]=\"'text'\"\n [value]=\"valueAsString\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-simple>\n </ng-container>\n <ng-container *ngSwitchCase=\"'resourceCreated'\">\n <gn-ui-form-field-date\n [value]=\"valueAsDate\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-date>\n </ng-container>\n <ng-container *ngSwitchCase=\"'resourceUpdated'\">\n <gn-ui-form-field-date\n [value]=\"valueAsDate\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-date>\n </ng-container>\n <ng-container *ngSwitchCase=\"'updateFrequency'\">\n <gn-ui-form-field-update-frequency\n [value]=\"valueAsUpdateFrequency\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-update-frequency>\n </ng-container>\n <ng-container *ngSwitchCase=\"'temporalExtents'\">\n <gn-ui-form-field-temporal-extents\n [value]=\"valueAsTemporalExtents\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-temporal-extents>\n </ng-container>\n <ng-container *ngSwitchCase=\"'spatialExtents'\">\n <gn-ui-form-field-spatial-extent></gn-ui-form-field-spatial-extent>\n </ng-container>\n <ng-container *ngSwitchCase=\"'keywords'\">\n <gn-ui-form-field-keywords\n [value]=\"valueAsKeywords\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-keywords>\n </ng-container>\n <ng-container *ngSwitchCase=\"'licenses'\">\n <gn-ui-form-field-license\n [label]=\"config.labelKey! | translate\"\n [recordConstraints]=\"valueAsConstraints\"\n (recordConstraintsChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-license>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'legalConstraints'\">\n <ng-container *ngTemplateOutlet=\"formFieldConstraints\"></ng-container>\n </ng-container>\n <ng-container *ngSwitchCase=\"'securityConstraints'\">\n <ng-container *ngTemplateOutlet=\"formFieldConstraints\"></ng-container>\n </ng-container>\n <ng-container *ngSwitchCase=\"'otherConstraints'\">\n <ng-container *ngTemplateOutlet=\"formFieldConstraints\"></ng-container\n ></ng-container>\n <ng-template #formFieldConstraints>\n <gn-ui-form-field-constraints\n [label]=\"config.labelKey\"\n [value]=\"valueAsConstraints\"\n [constraintType]=\"model\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-constraints\n ></ng-template>\n\n <ng-container *ngSwitchCase=\"'contactsForResource'\">\n <gn-ui-form-field-contacts-for-resource\n [value]=\"valueAsIndividuals\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-contacts-for-resource>\n </ng-container>\n <ng-container *ngSwitchCase=\"'contacts'\">\n <gn-ui-form-field-contacts\n [value]=\"valueAsIndividuals\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-contacts>\n </ng-container>\n <ng-container *ngSwitchCase=\"'onlineResources'\">\n <gn-ui-form-field-online-resources\n *ngIf=\"modelSpecifier === 'onlineResourceType:!link'\"\n [metadataUuid]=\"uniqueIdentifier\"\n [value]=\"valueAsOnlineResources\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-online-resources>\n </ng-container>\n <ng-container *ngSwitchCase=\"'onlineResources'\">\n <gn-ui-form-field-online-link-resources\n *ngIf=\"modelSpecifier === 'onlineResourceType:link'\"\n [metadataUuid]=\"uniqueIdentifier\"\n [value]=\"valueAsOnlineResources\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-online-link-resources>\n </ng-container>\n </ng-container>\n\n <ng-container *ngIf=\"!model\">\n <ng-container [ngSwitch]=\"componentName\">\n <ng-container *ngSwitchCase=\"'form-field-constraints-shortcuts'\">\n <gn-ui-form-field-constraints-shortcuts></gn-ui-form-field-constraints-shortcuts>\n </ng-container>\n <ng-container *ngSwitchCase=\"'form-field-spatial-toggle'\">\n <gn-ui-form-field-spatial-toggle></gn-ui-form-field-spatial-toggle>\n </ng-container>\n </ng-container>\n </ng-container>\n</ng-template>\n", styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i1.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i1.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i2.TranslatePipe, name: "translate" }, { kind: "ngmodule", type: MatTooltipModule }, { kind: "directive", type: i3.MatTooltip, selector: "[matTooltip]", inputs: ["matTooltipPosition", "matTooltipPositionAtOrigin", "matTooltipDisabled", "matTooltipShowDelay", "matTooltipHideDelay", "matTooltipTouchGestures", "matTooltip", "matTooltipClass"], exportAs: ["matTooltip"] }, { kind: "component", type: FormFieldWrapperComponent, selector: "gn-ui-form-field-wrapper", inputs: ["label", "hint"] }, { kind: "component", type: FormFieldLicenseComponent, selector: "gn-ui-form-field-license", inputs: ["label", "recordConstraints"], outputs: ["recordConstraintsChange"] }, { kind: "component", type: FormFieldDateComponent, selector: "gn-ui-form-field-date", inputs: ["value"], outputs: ["valueChange"] }, { kind: "component", type: FormFieldUpdateFrequencyComponent, selector: "gn-ui-form-field-update-frequency", inputs: ["value"], outputs: ["valueChange"] }, { kind: "component", type: FormFieldTemporalExtentsComponent, selector: "gn-ui-form-field-temporal-extents", inputs: ["value"], outputs: ["valueChange"] }, { kind: "component", type: FormFieldSimpleComponent, selector: "gn-ui-form-field-simple", inputs: ["type", "readonly", "invalid", "placeholder", "value"], outputs: ["valueChange"] }, { kind: "component", type: FormFieldRichComponent, selector: "gn-ui-form-field-rich", inputs: ["label", "hint", "placeholder", "value"], outputs: ["valueChange"] }, { kind: "component", type: FormFieldSpatialExtentComponent, selector: "gn-ui-form-field-spatial-extent" }, { kind: "component", type: FormFieldKeywordsComponent, selector: "gn-ui-form-field-keywords", inputs: ["value"], outputs: ["valueChange"] }, { kind: "component", type: FormFieldOverviewsComponent, selector: "gn-ui-form-field-overviews", inputs: ["metadataUuid", "value"], outputs: ["valueChange"] }, { kind: "component", type: FormFieldContactsForResourceComponent, selector: "gn-ui-form-field-contacts-for-resource", inputs: ["value"], outputs: ["valueChange"] }, { kind: "component", type: FormFieldOnlineResourcesComponent, selector: "gn-ui-form-field-online-resources", inputs: ["metadataUuid", "value"], outputs: ["valueChange"] }, { kind: "component", type: FormFieldOnlineLinkResourcesComponent, selector: "gn-ui-form-field-online-link-resources", inputs: ["metadataUuid", "value"], outputs: ["valueChange"] }, { kind: "component", type: FormFieldContactsComponent, selector: "gn-ui-form-field-contacts", inputs: ["value"], outputs: ["valueChange"] }, { kind: "component", type: FormFieldConstraintsComponent, selector: "gn-ui-form-field-constraints", inputs: ["label", "value", "constraintType"], outputs: ["valueChange"] }, { kind: "component", type: FormFieldConstraintsShortcutsComponent, selector: "gn-ui-form-field-constraints-shortcuts" }, { kind: "component", type: FormFieldSpatialToggleComponent, selector: "gn-ui-form-field-spatial-toggle" }, { kind: "ngmodule", type: TextFieldModule }, { kind: "directive", type: i4.CdkTextareaAutosize, selector: "textarea[cdkTextareaAutosize]", inputs: ["cdkAutosizeMinRows", "cdkAutosizeMaxRows", "cdkTextareaAutosize", "placeholder"], exportAs: ["cdkTextareaAutosize"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
78
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: FormFieldComponent, isStandalone: true, selector: "gn-ui-form-field", inputs: { uniqueIdentifier: "uniqueIdentifier", model: "model", modelSpecifier: "modelSpecifier", componentName: "componentName", config: "config", value: "value" }, outputs: { valueChange: "valueChange" }, viewQueries: [{ propertyName: "titleInput", first: true, predicate: ["titleInput"], descendants: true }], ngImport: i0, template: "<!-- TEMPORARY - disabling the open data switch -->\n<!-- <ng-container *ngIf=\"model === 'licenses'\">\n <gn-ui-form-field-open-data\n [value]=\"valueAsConstraints\"\n (valueChange)=\"valueChange.emit($event)\"\n (openDataChange)=\"toggleIsOpenData($event)\"\n ></gn-ui-form-field-open-data>\n</ng-container> -->\n<div class=\"flex flex-col h-full\">\n <ng-container *ngIf=\"withoutWrapper; else withGenericWrapper\">\n <ng-container *ngTemplateOutlet=\"fieldContent\"></ng-container>\n </ng-container>\n <ng-template #withGenericWrapper>\n <gn-ui-form-field-wrapper\n [label]=\"config.labelKey! | translate\"\n [hint]=\"config.hintKey! | translate\"\n >\n <ng-container *ngTemplateOutlet=\"fieldContent\"></ng-container>\n </gn-ui-form-field-wrapper>\n </ng-template>\n</div>\n\n<ng-template #fieldContent>\n <ng-container [ngSwitch]=\"model\">\n <ng-container *ngSwitchCase=\"'title'\">\n <div class=\"flex flex-row flex-start items-center gap-3 mb-[12px]\">\n <textarea\n #titleInput\n cdkTextareaAutosize\n #autosize=\"cdkTextareaAutosize\"\n cdkAutosizeMinRows=\"1\"\n data-test=\"recordTitleInput\"\n class=\"grow font-title text-3xl font-normal overflow-hidden text-black/80\"\n (change)=\"valueChange.emit($event.target.value)\"\n [placeholder]=\"\n 'editor.record.form.field.title.placeholder' | translate\n \"\n >{{ valueAsString }}</textarea\n >\n <div class=\"flex flex-row justify-between self-start mt-0.5\">\n <span\n class=\"material-symbols-outlined gn-ui-icon-small m-2 cursor-pointer\"\n (click)=\"focusTitleInput()\"\n >edit</span\n >\n <span\n *ngIf=\"config.hintKey\"\n class=\"material-symbols-outlined gn-ui-icon-small m-2\"\n [matTooltip]=\"config.hintKey! | translate\"\n matTooltipPosition=\"above\"\n >\n help\n </span>\n </div>\n </div>\n </ng-container>\n <ng-container *ngSwitchCase=\"'abstract'\">\n <gn-ui-form-field-rich\n [label]=\"config.labelKey! | translate\"\n [hint]=\"config.hintKey! | translate\"\n [value]=\"valueAsString\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-rich>\n </ng-container>\n <ng-container *ngSwitchCase=\"'overviews'\">\n <gn-ui-form-field-overviews\n [metadataUuid]=\"uniqueIdentifier\"\n [value]=\"valueAsOverviews\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-overviews>\n </ng-container>\n <ng-container *ngSwitchCase=\"'resourceIdentifier'\">\n <gn-ui-form-field-simple\n [type]=\"'text'\"\n [value]=\"valueAsString\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-simple>\n </ng-container>\n <ng-container *ngSwitchCase=\"'resourceCreated'\">\n <gn-ui-form-field-date\n [value]=\"valueAsDate\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-date>\n </ng-container>\n <ng-container *ngSwitchCase=\"'resourceUpdated'\">\n <gn-ui-form-field-date\n [value]=\"valueAsDate\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-date>\n </ng-container>\n <ng-container *ngSwitchCase=\"'updateFrequency'\">\n <gn-ui-form-field-update-frequency\n [value]=\"valueAsUpdateFrequency\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-update-frequency>\n </ng-container>\n <ng-container *ngSwitchCase=\"'temporalExtents'\">\n <gn-ui-form-field-temporal-extents\n [value]=\"valueAsTemporalExtents\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-temporal-extents>\n </ng-container>\n <ng-container *ngSwitchCase=\"'spatialExtents'\">\n <gn-ui-form-field-spatial-extent></gn-ui-form-field-spatial-extent>\n </ng-container>\n <ng-container *ngSwitchCase=\"'keywords'\">\n <gn-ui-form-field-keywords\n [value]=\"valueAsKeywords\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-keywords>\n </ng-container>\n <ng-container *ngSwitchCase=\"'licenses'\">\n <gn-ui-form-field-license\n [label]=\"config.labelKey! | translate\"\n [recordConstraints]=\"valueAsConstraints\"\n (recordConstraintsChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-license>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'legalConstraints'\">\n <ng-container *ngTemplateOutlet=\"formFieldConstraints\"></ng-container>\n </ng-container>\n <ng-container *ngSwitchCase=\"'securityConstraints'\">\n <ng-container *ngTemplateOutlet=\"formFieldConstraints\"></ng-container>\n </ng-container>\n <ng-container *ngSwitchCase=\"'otherConstraints'\">\n <ng-container *ngTemplateOutlet=\"formFieldConstraints\"></ng-container\n ></ng-container>\n <ng-template #formFieldConstraints>\n <gn-ui-form-field-constraints\n [label]=\"config.labelKey\"\n [value]=\"valueAsConstraints\"\n [constraintType]=\"model\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-constraints\n ></ng-template>\n\n <ng-container *ngSwitchCase=\"'contactsForResource'\">\n <gn-ui-form-field-contacts-for-resource\n [value]=\"valueAsIndividuals\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-contacts-for-resource>\n </ng-container>\n <ng-container *ngSwitchCase=\"'contacts'\">\n <gn-ui-form-field-contacts\n [value]=\"valueAsIndividuals\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-contacts>\n </ng-container>\n <ng-container *ngSwitchCase=\"'onlineResources'\">\n <gn-ui-form-field-online-resources\n *ngIf=\"modelSpecifier === 'onlineResourceType:!link'\"\n [metadataUuid]=\"uniqueIdentifier\"\n [value]=\"valueAsOnlineResources\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-online-resources>\n </ng-container>\n <ng-container *ngSwitchCase=\"'onlineResources'\">\n <gn-ui-form-field-online-link-resources\n *ngIf=\"modelSpecifier === 'onlineResourceType:link'\"\n [metadataUuid]=\"uniqueIdentifier\"\n [value]=\"valueAsOnlineResources\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-online-link-resources>\n </ng-container>\n </ng-container>\n\n <ng-container *ngIf=\"!model\">\n <ng-container [ngSwitch]=\"componentName\">\n <ng-container *ngSwitchCase=\"'form-field-constraints-shortcuts'\">\n <gn-ui-form-field-constraints-shortcuts></gn-ui-form-field-constraints-shortcuts>\n </ng-container>\n <ng-container *ngSwitchCase=\"'form-field-spatial-toggle'\">\n <gn-ui-form-field-spatial-toggle></gn-ui-form-field-spatial-toggle>\n </ng-container>\n </ng-container>\n </ng-container>\n</ng-template>\n", styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i1.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i1.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i2.TranslatePipe, name: "translate" }, { kind: "ngmodule", type: MatTooltipModule }, { kind: "directive", type: i3.MatTooltip, selector: "[matTooltip]", inputs: ["matTooltipPosition", "matTooltipPositionAtOrigin", "matTooltipDisabled", "matTooltipShowDelay", "matTooltipHideDelay", "matTooltipTouchGestures", "matTooltip", "matTooltipClass"], exportAs: ["matTooltip"] }, { kind: "component", type: FormFieldWrapperComponent, selector: "gn-ui-form-field-wrapper", inputs: ["label", "hint"] }, { kind: "component", type: FormFieldLicenseComponent, selector: "gn-ui-form-field-license", inputs: ["label", "recordConstraints"], outputs: ["recordConstraintsChange"] }, { kind: "component", type: FormFieldDateComponent, selector: "gn-ui-form-field-date", inputs: ["value"], outputs: ["valueChange"] }, { kind: "component", type: FormFieldUpdateFrequencyComponent, selector: "gn-ui-form-field-update-frequency", inputs: ["value"], outputs: ["valueChange"] }, { kind: "component", type: FormFieldTemporalExtentsComponent, selector: "gn-ui-form-field-temporal-extents", inputs: ["value"], outputs: ["valueChange"] }, { kind: "component", type: FormFieldSimpleComponent, selector: "gn-ui-form-field-simple", inputs: ["type", "readonly", "invalid", "placeholder", "value"], outputs: ["valueChange"] }, { kind: "component", type: FormFieldRichComponent, selector: "gn-ui-form-field-rich", inputs: ["label", "hint", "placeholder", "value"], outputs: ["valueChange"] }, { kind: "component", type: FormFieldSpatialExtentComponent, selector: "gn-ui-form-field-spatial-extent" }, { kind: "component", type: FormFieldKeywordsComponent, selector: "gn-ui-form-field-keywords", inputs: ["value"], outputs: ["valueChange"] }, { kind: "component", type: FormFieldOverviewsComponent, selector: "gn-ui-form-field-overviews", inputs: ["metadataUuid", "value"], outputs: ["valueChange"] }, { kind: "component", type: FormFieldContactsForResourceComponent, selector: "gn-ui-form-field-contacts-for-resource", inputs: ["value"], outputs: ["valueChange"] }, { kind: "component", type: FormFieldOnlineResourcesComponent, selector: "gn-ui-form-field-online-resources", inputs: ["metadataUuid", "value"], outputs: ["valueChange"] }, { kind: "component", type: FormFieldOnlineLinkResourcesComponent, selector: "gn-ui-form-field-online-link-resources", inputs: ["metadataUuid", "value"], outputs: ["valueChange"] }, { kind: "component", type: FormFieldContactsComponent, selector: "gn-ui-form-field-contacts", inputs: ["value"], outputs: ["valueChange"] }, { kind: "component", type: FormFieldConstraintsComponent, selector: "gn-ui-form-field-constraints", inputs: ["label", "value", "constraintType"], outputs: ["valueChange"] }, { kind: "component", type: FormFieldConstraintsShortcutsComponent, selector: "gn-ui-form-field-constraints-shortcuts" }, { kind: "component", type: FormFieldSpatialToggleComponent, selector: "gn-ui-form-field-spatial-toggle" }, { kind: "ngmodule", type: TextFieldModule }, { kind: "directive", type: i4.CdkTextareaAutosize, selector: "textarea[cdkTextareaAutosize]", inputs: ["cdkAutosizeMinRows", "cdkAutosizeMaxRows", "cdkTextareaAutosize", "placeholder"], exportAs: ["cdkTextareaAutosize"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
79
79
  }
80
80
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FormFieldComponent, decorators: [{
81
81
  type: Component,
@@ -106,7 +106,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
106
106
  FormFieldConstraintsShortcutsComponent,
107
107
  FormFieldSpatialToggleComponent,
108
108
  TextFieldModule,
109
- ], template: "<!-- TEMPORARY - disabling the open data switch -->\n<!-- <ng-container *ngIf=\"model === 'licenses'\">\n <gn-ui-form-field-open-data\n [value]=\"valueAsConstraints\"\n (valueChange)=\"valueChange.emit($event)\"\n (openDataChange)=\"toggleIsOpenData($event)\"\n ></gn-ui-form-field-open-data>\n</ng-container> -->\n<div class=\"flex flex-col h-full\">\n <ng-container *ngIf=\"withoutWrapper; else withGenericWrapper\">\n <ng-container *ngTemplateOutlet=\"fieldContent\"></ng-container>\n </ng-container>\n <ng-template #withGenericWrapper>\n <gn-ui-form-field-wrapper\n [label]=\"config.labelKey! | translate\"\n [hint]=\"config.hintKey! | translate\"\n >\n <ng-container *ngTemplateOutlet=\"fieldContent\"></ng-container>\n </gn-ui-form-field-wrapper>\n </ng-template>\n</div>\n\n<ng-template #fieldContent>\n <ng-container [ngSwitch]=\"model\">\n <ng-container *ngSwitchCase=\"'title'\">\n <div class=\"flex flex-row flex-start items-center gap-3 mb-[12px]\">\n <textarea\n #titleInput\n cdkTextareaAutosize\n #autosize=\"cdkTextareaAutosize\"\n cdkAutosizeMinRows=\"1\"\n data-test=\"recordTitleInput\"\n class=\"grow font-title text-3xl font-normal overflow-hidden\"\n (change)=\"valueChange.emit($event.target.value)\"\n [placeholder]=\"\n 'editor.record.form.field.title.placeholder' | translate\n \"\n >{{ valueAsString }}</textarea\n >\n <div class=\"flex flex-row justify-between self-start mt-0.5\">\n <span\n class=\"material-symbols-outlined gn-ui-icon-small m-2 cursor-pointer\"\n (click)=\"focusTitleInput()\"\n >edit</span\n >\n <span\n *ngIf=\"config.hintKey\"\n class=\"material-symbols-outlined gn-ui-icon-small m-2\"\n [matTooltip]=\"config.hintKey! | translate\"\n matTooltipPosition=\"above\"\n >\n help\n </span>\n </div>\n </div>\n </ng-container>\n <ng-container *ngSwitchCase=\"'abstract'\">\n <gn-ui-form-field-rich\n [label]=\"config.labelKey! | translate\"\n [hint]=\"config.hintKey! | translate\"\n [value]=\"valueAsString\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-rich>\n </ng-container>\n <ng-container *ngSwitchCase=\"'overviews'\">\n <gn-ui-form-field-overviews\n [metadataUuid]=\"uniqueIdentifier\"\n [value]=\"valueAsOverviews\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-overviews>\n </ng-container>\n <ng-container *ngSwitchCase=\"'resourceIdentifier'\">\n <gn-ui-form-field-simple\n [type]=\"'text'\"\n [value]=\"valueAsString\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-simple>\n </ng-container>\n <ng-container *ngSwitchCase=\"'resourceCreated'\">\n <gn-ui-form-field-date\n [value]=\"valueAsDate\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-date>\n </ng-container>\n <ng-container *ngSwitchCase=\"'resourceUpdated'\">\n <gn-ui-form-field-date\n [value]=\"valueAsDate\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-date>\n </ng-container>\n <ng-container *ngSwitchCase=\"'updateFrequency'\">\n <gn-ui-form-field-update-frequency\n [value]=\"valueAsUpdateFrequency\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-update-frequency>\n </ng-container>\n <ng-container *ngSwitchCase=\"'temporalExtents'\">\n <gn-ui-form-field-temporal-extents\n [value]=\"valueAsTemporalExtents\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-temporal-extents>\n </ng-container>\n <ng-container *ngSwitchCase=\"'spatialExtents'\">\n <gn-ui-form-field-spatial-extent></gn-ui-form-field-spatial-extent>\n </ng-container>\n <ng-container *ngSwitchCase=\"'keywords'\">\n <gn-ui-form-field-keywords\n [value]=\"valueAsKeywords\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-keywords>\n </ng-container>\n <ng-container *ngSwitchCase=\"'licenses'\">\n <gn-ui-form-field-license\n [label]=\"config.labelKey! | translate\"\n [recordConstraints]=\"valueAsConstraints\"\n (recordConstraintsChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-license>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'legalConstraints'\">\n <ng-container *ngTemplateOutlet=\"formFieldConstraints\"></ng-container>\n </ng-container>\n <ng-container *ngSwitchCase=\"'securityConstraints'\">\n <ng-container *ngTemplateOutlet=\"formFieldConstraints\"></ng-container>\n </ng-container>\n <ng-container *ngSwitchCase=\"'otherConstraints'\">\n <ng-container *ngTemplateOutlet=\"formFieldConstraints\"></ng-container\n ></ng-container>\n <ng-template #formFieldConstraints>\n <gn-ui-form-field-constraints\n [label]=\"config.labelKey\"\n [value]=\"valueAsConstraints\"\n [constraintType]=\"model\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-constraints\n ></ng-template>\n\n <ng-container *ngSwitchCase=\"'contactsForResource'\">\n <gn-ui-form-field-contacts-for-resource\n [value]=\"valueAsIndividuals\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-contacts-for-resource>\n </ng-container>\n <ng-container *ngSwitchCase=\"'contacts'\">\n <gn-ui-form-field-contacts\n [value]=\"valueAsIndividuals\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-contacts>\n </ng-container>\n <ng-container *ngSwitchCase=\"'onlineResources'\">\n <gn-ui-form-field-online-resources\n *ngIf=\"modelSpecifier === 'onlineResourceType:!link'\"\n [metadataUuid]=\"uniqueIdentifier\"\n [value]=\"valueAsOnlineResources\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-online-resources>\n </ng-container>\n <ng-container *ngSwitchCase=\"'onlineResources'\">\n <gn-ui-form-field-online-link-resources\n *ngIf=\"modelSpecifier === 'onlineResourceType:link'\"\n [metadataUuid]=\"uniqueIdentifier\"\n [value]=\"valueAsOnlineResources\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-online-link-resources>\n </ng-container>\n </ng-container>\n\n <ng-container *ngIf=\"!model\">\n <ng-container [ngSwitch]=\"componentName\">\n <ng-container *ngSwitchCase=\"'form-field-constraints-shortcuts'\">\n <gn-ui-form-field-constraints-shortcuts></gn-ui-form-field-constraints-shortcuts>\n </ng-container>\n <ng-container *ngSwitchCase=\"'form-field-spatial-toggle'\">\n <gn-ui-form-field-spatial-toggle></gn-ui-form-field-spatial-toggle>\n </ng-container>\n </ng-container>\n </ng-container>\n</ng-template>\n" }]
109
+ ], template: "<!-- TEMPORARY - disabling the open data switch -->\n<!-- <ng-container *ngIf=\"model === 'licenses'\">\n <gn-ui-form-field-open-data\n [value]=\"valueAsConstraints\"\n (valueChange)=\"valueChange.emit($event)\"\n (openDataChange)=\"toggleIsOpenData($event)\"\n ></gn-ui-form-field-open-data>\n</ng-container> -->\n<div class=\"flex flex-col h-full\">\n <ng-container *ngIf=\"withoutWrapper; else withGenericWrapper\">\n <ng-container *ngTemplateOutlet=\"fieldContent\"></ng-container>\n </ng-container>\n <ng-template #withGenericWrapper>\n <gn-ui-form-field-wrapper\n [label]=\"config.labelKey! | translate\"\n [hint]=\"config.hintKey! | translate\"\n >\n <ng-container *ngTemplateOutlet=\"fieldContent\"></ng-container>\n </gn-ui-form-field-wrapper>\n </ng-template>\n</div>\n\n<ng-template #fieldContent>\n <ng-container [ngSwitch]=\"model\">\n <ng-container *ngSwitchCase=\"'title'\">\n <div class=\"flex flex-row flex-start items-center gap-3 mb-[12px]\">\n <textarea\n #titleInput\n cdkTextareaAutosize\n #autosize=\"cdkTextareaAutosize\"\n cdkAutosizeMinRows=\"1\"\n data-test=\"recordTitleInput\"\n class=\"grow font-title text-3xl font-normal overflow-hidden text-black/80\"\n (change)=\"valueChange.emit($event.target.value)\"\n [placeholder]=\"\n 'editor.record.form.field.title.placeholder' | translate\n \"\n >{{ valueAsString }}</textarea\n >\n <div class=\"flex flex-row justify-between self-start mt-0.5\">\n <span\n class=\"material-symbols-outlined gn-ui-icon-small m-2 cursor-pointer\"\n (click)=\"focusTitleInput()\"\n >edit</span\n >\n <span\n *ngIf=\"config.hintKey\"\n class=\"material-symbols-outlined gn-ui-icon-small m-2\"\n [matTooltip]=\"config.hintKey! | translate\"\n matTooltipPosition=\"above\"\n >\n help\n </span>\n </div>\n </div>\n </ng-container>\n <ng-container *ngSwitchCase=\"'abstract'\">\n <gn-ui-form-field-rich\n [label]=\"config.labelKey! | translate\"\n [hint]=\"config.hintKey! | translate\"\n [value]=\"valueAsString\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-rich>\n </ng-container>\n <ng-container *ngSwitchCase=\"'overviews'\">\n <gn-ui-form-field-overviews\n [metadataUuid]=\"uniqueIdentifier\"\n [value]=\"valueAsOverviews\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-overviews>\n </ng-container>\n <ng-container *ngSwitchCase=\"'resourceIdentifier'\">\n <gn-ui-form-field-simple\n [type]=\"'text'\"\n [value]=\"valueAsString\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-simple>\n </ng-container>\n <ng-container *ngSwitchCase=\"'resourceCreated'\">\n <gn-ui-form-field-date\n [value]=\"valueAsDate\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-date>\n </ng-container>\n <ng-container *ngSwitchCase=\"'resourceUpdated'\">\n <gn-ui-form-field-date\n [value]=\"valueAsDate\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-date>\n </ng-container>\n <ng-container *ngSwitchCase=\"'updateFrequency'\">\n <gn-ui-form-field-update-frequency\n [value]=\"valueAsUpdateFrequency\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-update-frequency>\n </ng-container>\n <ng-container *ngSwitchCase=\"'temporalExtents'\">\n <gn-ui-form-field-temporal-extents\n [value]=\"valueAsTemporalExtents\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-temporal-extents>\n </ng-container>\n <ng-container *ngSwitchCase=\"'spatialExtents'\">\n <gn-ui-form-field-spatial-extent></gn-ui-form-field-spatial-extent>\n </ng-container>\n <ng-container *ngSwitchCase=\"'keywords'\">\n <gn-ui-form-field-keywords\n [value]=\"valueAsKeywords\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-keywords>\n </ng-container>\n <ng-container *ngSwitchCase=\"'licenses'\">\n <gn-ui-form-field-license\n [label]=\"config.labelKey! | translate\"\n [recordConstraints]=\"valueAsConstraints\"\n (recordConstraintsChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-license>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'legalConstraints'\">\n <ng-container *ngTemplateOutlet=\"formFieldConstraints\"></ng-container>\n </ng-container>\n <ng-container *ngSwitchCase=\"'securityConstraints'\">\n <ng-container *ngTemplateOutlet=\"formFieldConstraints\"></ng-container>\n </ng-container>\n <ng-container *ngSwitchCase=\"'otherConstraints'\">\n <ng-container *ngTemplateOutlet=\"formFieldConstraints\"></ng-container\n ></ng-container>\n <ng-template #formFieldConstraints>\n <gn-ui-form-field-constraints\n [label]=\"config.labelKey\"\n [value]=\"valueAsConstraints\"\n [constraintType]=\"model\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-constraints\n ></ng-template>\n\n <ng-container *ngSwitchCase=\"'contactsForResource'\">\n <gn-ui-form-field-contacts-for-resource\n [value]=\"valueAsIndividuals\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-contacts-for-resource>\n </ng-container>\n <ng-container *ngSwitchCase=\"'contacts'\">\n <gn-ui-form-field-contacts\n [value]=\"valueAsIndividuals\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-contacts>\n </ng-container>\n <ng-container *ngSwitchCase=\"'onlineResources'\">\n <gn-ui-form-field-online-resources\n *ngIf=\"modelSpecifier === 'onlineResourceType:!link'\"\n [metadataUuid]=\"uniqueIdentifier\"\n [value]=\"valueAsOnlineResources\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-online-resources>\n </ng-container>\n <ng-container *ngSwitchCase=\"'onlineResources'\">\n <gn-ui-form-field-online-link-resources\n *ngIf=\"modelSpecifier === 'onlineResourceType:link'\"\n [metadataUuid]=\"uniqueIdentifier\"\n [value]=\"valueAsOnlineResources\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-online-link-resources>\n </ng-container>\n </ng-container>\n\n <ng-container *ngIf=\"!model\">\n <ng-container [ngSwitch]=\"componentName\">\n <ng-container *ngSwitchCase=\"'form-field-constraints-shortcuts'\">\n <gn-ui-form-field-constraints-shortcuts></gn-ui-form-field-constraints-shortcuts>\n </ng-container>\n <ng-container *ngSwitchCase=\"'form-field-spatial-toggle'\">\n <gn-ui-form-field-spatial-toggle></gn-ui-form-field-spatial-toggle>\n </ng-container>\n </ng-container>\n </ng-container>\n</ng-template>\n" }]
110
110
  }], propDecorators: { uniqueIdentifier: [{
111
111
  type: Input
112
112
  }], model: [{
@@ -125,4 +125,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
125
125
  type: ViewChild,
126
126
  args: ['titleInput']
127
127
  }] } });
128
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-field.component.js","sourceRoot":"","sources":["../../../../../../../../../../libs/feature/editor/src/lib/components/record-form/form-field/form-field.component.ts","../../../../../../../../../../libs/feature/editor/src/lib/components/record-form/form-field/form-field.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common'\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  ElementRef,\n  EventEmitter,\n  Injector,\n  Input,\n  Output,\n  ViewChild,\n  afterNextRender,\n  inject,\n} from '@angular/core'\nimport { MatTooltipModule } from '@angular/material/tooltip'\nimport {\n  CatalogRecordKeys,\n  Constraint,\n  DatasetTemporalExtent,\n  GraphicOverview,\n  Individual,\n  Keyword,\n  OnlineResource,\n  UpdateFrequency,\n} from '../../../../../../../../libs/common/domain/src/lib/model/record'\nimport { EditableLabelDirective } from '../../../../../../../../libs/ui/inputs/src'\nimport { FormFieldWrapperComponent } from '../../../../../../../../libs/ui/layout/src'\nimport { TranslateModule } from '@ngx-translate/core'\nimport {\n  FormFieldDateComponent,\n  FormFieldLicenseComponent,\n  FormFieldTemporalExtentsComponent,\n} from '.'\nimport {\n  FieldModelSpecifier,\n  FormFieldComponentName,\n  FormFieldConfig,\n} from '../../../models'\nimport { FormFieldArrayComponent } from './form-field-array/form-field-array.component'\nimport { FormFieldContactsForResourceComponent } from './form-field-contacts-for-resource/form-field-contacts-for-resource.component'\nimport { FormFieldContactsComponent } from './form-field-contacts/form-field-contacts.component'\nimport { FormFieldFileComponent } from './form-field-file/form-field-file.component'\nimport { FormFieldKeywordsComponent } from './form-field-keywords/form-field-keywords.component'\nimport { FormFieldObjectComponent } from './form-field-object/form-field-object.component'\nimport { FormFieldOnlineLinkResourcesComponent } from './form-field-online-link-resources/form-field-online-link-resources.component'\nimport { FormFieldOnlineResourcesComponent } from './form-field-online-resources/form-field-online-resources.component'\nimport { FormFieldOpenDataComponent } from './form-field-open-data/form-field-open-data.component'\nimport { FormFieldOverviewsComponent } from './form-field-overviews/form-field-overviews.component'\nimport { FormFieldRichComponent } from './form-field-rich/form-field-rich.component'\nimport { FormFieldSimpleComponent } from './form-field-simple/form-field-simple.component'\nimport { FormFieldSpatialExtentComponent } from './form-field-spatial-extent/form-field-spatial-extent.component'\nimport { FormFieldUpdateFrequencyComponent } from './form-field-update-frequency/form-field-update-frequency.component'\nimport { FormFieldConstraintsShortcutsComponent } from './form-field-constraints-shortcuts/form-field-constraints-shortcuts.component'\nimport { FormFieldConstraintsComponent } from './form-field-constraints/form-field-constraints.component'\nimport { TextFieldModule } from '@angular/cdk/text-field'\nimport { FormFieldSpatialToggleComponent } from './form-field-spatial-toggle/form-field-spatial-toggle.component'\n\n@Component({\n  selector: 'gn-ui-form-field',\n  templateUrl: './form-field.component.html',\n  styleUrls: ['./form-field.component.css'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true,\n  imports: [\n    CommonModule,\n    TranslateModule,\n    EditableLabelDirective,\n    MatTooltipModule,\n    FormFieldWrapperComponent,\n    FormFieldLicenseComponent,\n    FormFieldDateComponent,\n    FormFieldUpdateFrequencyComponent,\n    FormFieldTemporalExtentsComponent,\n    FormFieldSimpleComponent,\n    FormFieldRichComponent,\n    FormFieldObjectComponent,\n    FormFieldSpatialExtentComponent,\n    FormFieldFileComponent,\n    FormFieldArrayComponent,\n    FormFieldKeywordsComponent,\n    FormFieldOverviewsComponent,\n    FormFieldContactsForResourceComponent,\n    FormFieldOpenDataComponent,\n    FormFieldOnlineResourcesComponent,\n    FormFieldOnlineLinkResourcesComponent,\n    FormFieldContactsComponent,\n    FormFieldConstraintsComponent,\n    FormFieldConstraintsShortcutsComponent,\n    FormFieldSpatialToggleComponent,\n    TextFieldModule,\n  ],\n})\nexport class FormFieldComponent {\n  @Input() uniqueIdentifier: string\n  @Input() model: CatalogRecordKeys\n  @Input() modelSpecifier: FieldModelSpecifier\n  @Input() componentName: FormFieldComponentName\n\n  @Input() config: FormFieldConfig\n  @Input() value: unknown\n\n  @Output() valueChange: EventEmitter<unknown> = new EventEmitter()\n\n  @ViewChild('titleInput') titleInput: ElementRef\n  isOpenData = false\n\n  toggleIsOpenData(event: boolean) {\n    this.isOpenData = event\n  }\n\n  focusTitleInput() {\n    this.titleInput.nativeElement.focus()\n  }\n\n  get withoutWrapper() {\n    return (\n      this.model === 'title' ||\n      this.model === 'abstract' ||\n      this.model === 'legalConstraints' ||\n      this.model === 'securityConstraints' ||\n      this.model === 'otherConstraints' ||\n      this.componentName === 'form-field-constraints-shortcuts'\n    )\n  }\n\n  get valueAsString() {\n    return this.value as string\n  }\n  get valueAsDate() {\n    return this.value as Date\n  }\n\n  get valueAsOverviews() {\n    return this.value as Array<GraphicOverview>\n  }\n  get valueAsUpdateFrequency() {\n    return this.value as UpdateFrequency\n  }\n  get valueAsTemporalExtents() {\n    return this.value as Array<DatasetTemporalExtent>\n  }\n  get valueAsKeywords() {\n    return this.value as Array<Keyword>\n  }\n  get valueAsConstraints() {\n    return this.value as Array<Constraint>\n  }\n  get valueAsIndividuals() {\n    return this.value as Array<Individual>\n  }\n  get valueAsOnlineResources() {\n    return this.value as Array<OnlineResource>\n  }\n}\n","<!-- TEMPORARY - disabling the open data switch -->\n<!-- <ng-container *ngIf=\"model === 'licenses'\">\n  <gn-ui-form-field-open-data\n    [value]=\"valueAsConstraints\"\n    (valueChange)=\"valueChange.emit($event)\"\n    (openDataChange)=\"toggleIsOpenData($event)\"\n  ></gn-ui-form-field-open-data>\n</ng-container> -->\n<div class=\"flex flex-col h-full\">\n  <ng-container *ngIf=\"withoutWrapper; else withGenericWrapper\">\n    <ng-container *ngTemplateOutlet=\"fieldContent\"></ng-container>\n  </ng-container>\n  <ng-template #withGenericWrapper>\n    <gn-ui-form-field-wrapper\n      [label]=\"config.labelKey! | translate\"\n      [hint]=\"config.hintKey! | translate\"\n    >\n      <ng-container *ngTemplateOutlet=\"fieldContent\"></ng-container>\n    </gn-ui-form-field-wrapper>\n  </ng-template>\n</div>\n\n<ng-template #fieldContent>\n  <ng-container [ngSwitch]=\"model\">\n    <ng-container *ngSwitchCase=\"'title'\">\n      <div class=\"flex flex-row flex-start items-center gap-3 mb-[12px]\">\n        <textarea\n          #titleInput\n          cdkTextareaAutosize\n          #autosize=\"cdkTextareaAutosize\"\n          cdkAutosizeMinRows=\"1\"\n          data-test=\"recordTitleInput\"\n          class=\"grow font-title text-3xl font-normal overflow-hidden\"\n          (change)=\"valueChange.emit($event.target.value)\"\n          [placeholder]=\"\n            'editor.record.form.field.title.placeholder' | translate\n          \"\n          >{{ valueAsString }}</textarea\n        >\n        <div class=\"flex flex-row justify-between self-start mt-0.5\">\n          <span\n            class=\"material-symbols-outlined gn-ui-icon-small m-2 cursor-pointer\"\n            (click)=\"focusTitleInput()\"\n            >edit</span\n          >\n          <span\n            *ngIf=\"config.hintKey\"\n            class=\"material-symbols-outlined gn-ui-icon-small m-2\"\n            [matTooltip]=\"config.hintKey! | translate\"\n            matTooltipPosition=\"above\"\n          >\n            help\n          </span>\n        </div>\n      </div>\n    </ng-container>\n    <ng-container *ngSwitchCase=\"'abstract'\">\n      <gn-ui-form-field-rich\n        [label]=\"config.labelKey! | translate\"\n        [hint]=\"config.hintKey! | translate\"\n        [value]=\"valueAsString\"\n        (valueChange)=\"valueChange.emit($event)\"\n      ></gn-ui-form-field-rich>\n    </ng-container>\n    <ng-container *ngSwitchCase=\"'overviews'\">\n      <gn-ui-form-field-overviews\n        [metadataUuid]=\"uniqueIdentifier\"\n        [value]=\"valueAsOverviews\"\n        (valueChange)=\"valueChange.emit($event)\"\n      ></gn-ui-form-field-overviews>\n    </ng-container>\n    <ng-container *ngSwitchCase=\"'resourceIdentifier'\">\n      <gn-ui-form-field-simple\n        [type]=\"'text'\"\n        [value]=\"valueAsString\"\n        (valueChange)=\"valueChange.emit($event)\"\n      ></gn-ui-form-field-simple>\n    </ng-container>\n    <ng-container *ngSwitchCase=\"'resourceCreated'\">\n      <gn-ui-form-field-date\n        [value]=\"valueAsDate\"\n        (valueChange)=\"valueChange.emit($event)\"\n      ></gn-ui-form-field-date>\n    </ng-container>\n    <ng-container *ngSwitchCase=\"'resourceUpdated'\">\n      <gn-ui-form-field-date\n        [value]=\"valueAsDate\"\n        (valueChange)=\"valueChange.emit($event)\"\n      ></gn-ui-form-field-date>\n    </ng-container>\n    <ng-container *ngSwitchCase=\"'updateFrequency'\">\n      <gn-ui-form-field-update-frequency\n        [value]=\"valueAsUpdateFrequency\"\n        (valueChange)=\"valueChange.emit($event)\"\n      ></gn-ui-form-field-update-frequency>\n    </ng-container>\n    <ng-container *ngSwitchCase=\"'temporalExtents'\">\n      <gn-ui-form-field-temporal-extents\n        [value]=\"valueAsTemporalExtents\"\n        (valueChange)=\"valueChange.emit($event)\"\n      ></gn-ui-form-field-temporal-extents>\n    </ng-container>\n    <ng-container *ngSwitchCase=\"'spatialExtents'\">\n      <gn-ui-form-field-spatial-extent></gn-ui-form-field-spatial-extent>\n    </ng-container>\n    <ng-container *ngSwitchCase=\"'keywords'\">\n      <gn-ui-form-field-keywords\n        [value]=\"valueAsKeywords\"\n        (valueChange)=\"valueChange.emit($event)\"\n      ></gn-ui-form-field-keywords>\n    </ng-container>\n    <ng-container *ngSwitchCase=\"'licenses'\">\n      <gn-ui-form-field-license\n        [label]=\"config.labelKey! | translate\"\n        [recordConstraints]=\"valueAsConstraints\"\n        (recordConstraintsChange)=\"valueChange.emit($event)\"\n      ></gn-ui-form-field-license>\n    </ng-container>\n\n    <ng-container *ngSwitchCase=\"'legalConstraints'\">\n      <ng-container *ngTemplateOutlet=\"formFieldConstraints\"></ng-container>\n    </ng-container>\n    <ng-container *ngSwitchCase=\"'securityConstraints'\">\n      <ng-container *ngTemplateOutlet=\"formFieldConstraints\"></ng-container>\n    </ng-container>\n    <ng-container *ngSwitchCase=\"'otherConstraints'\">\n      <ng-container *ngTemplateOutlet=\"formFieldConstraints\"></ng-container\n    ></ng-container>\n    <ng-template #formFieldConstraints>\n      <gn-ui-form-field-constraints\n        [label]=\"config.labelKey\"\n        [value]=\"valueAsConstraints\"\n        [constraintType]=\"model\"\n        (valueChange)=\"valueChange.emit($event)\"\n      ></gn-ui-form-field-constraints\n    ></ng-template>\n\n    <ng-container *ngSwitchCase=\"'contactsForResource'\">\n      <gn-ui-form-field-contacts-for-resource\n        [value]=\"valueAsIndividuals\"\n        (valueChange)=\"valueChange.emit($event)\"\n      ></gn-ui-form-field-contacts-for-resource>\n    </ng-container>\n    <ng-container *ngSwitchCase=\"'contacts'\">\n      <gn-ui-form-field-contacts\n        [value]=\"valueAsIndividuals\"\n        (valueChange)=\"valueChange.emit($event)\"\n      ></gn-ui-form-field-contacts>\n    </ng-container>\n    <ng-container *ngSwitchCase=\"'onlineResources'\">\n      <gn-ui-form-field-online-resources\n        *ngIf=\"modelSpecifier === 'onlineResourceType:!link'\"\n        [metadataUuid]=\"uniqueIdentifier\"\n        [value]=\"valueAsOnlineResources\"\n        (valueChange)=\"valueChange.emit($event)\"\n      ></gn-ui-form-field-online-resources>\n    </ng-container>\n    <ng-container *ngSwitchCase=\"'onlineResources'\">\n      <gn-ui-form-field-online-link-resources\n        *ngIf=\"modelSpecifier === 'onlineResourceType:link'\"\n        [metadataUuid]=\"uniqueIdentifier\"\n        [value]=\"valueAsOnlineResources\"\n        (valueChange)=\"valueChange.emit($event)\"\n      ></gn-ui-form-field-online-link-resources>\n    </ng-container>\n  </ng-container>\n\n  <ng-container *ngIf=\"!model\">\n    <ng-container [ngSwitch]=\"componentName\">\n      <ng-container *ngSwitchCase=\"'form-field-constraints-shortcuts'\">\n        <gn-ui-form-field-constraints-shortcuts></gn-ui-form-field-constraints-shortcuts>\n      </ng-container>\n      <ng-container *ngSwitchCase=\"'form-field-spatial-toggle'\">\n        <gn-ui-form-field-spatial-toggle></gn-ui-form-field-spatial-toggle>\n      </ng-container>\n    </ng-container>\n  </ng-container>\n</ng-template>\n"]}
128
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-field.component.js","sourceRoot":"","sources":["../../../../../../../../../../libs/feature/editor/src/lib/components/record-form/form-field/form-field.component.ts","../../../../../../../../../../libs/feature/editor/src/lib/components/record-form/form-field/form-field.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common'\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  ElementRef,\n  EventEmitter,\n  Injector,\n  Input,\n  Output,\n  ViewChild,\n  afterNextRender,\n  inject,\n} from '@angular/core'\nimport { MatTooltipModule } from '@angular/material/tooltip'\nimport {\n  CatalogRecordKeys,\n  Constraint,\n  DatasetTemporalExtent,\n  GraphicOverview,\n  Individual,\n  Keyword,\n  OnlineResource,\n  UpdateFrequency,\n} from '../../../../../../../../libs/common/domain/src/lib/model/record'\nimport { EditableLabelDirective } from '../../../../../../../../libs/ui/inputs/src'\nimport { FormFieldWrapperComponent } from '../../../../../../../../libs/ui/layout/src'\nimport { TranslateModule } from '@ngx-translate/core'\nimport {\n  FormFieldDateComponent,\n  FormFieldLicenseComponent,\n  FormFieldTemporalExtentsComponent,\n} from '.'\nimport {\n  FieldModelSpecifier,\n  FormFieldComponentName,\n  FormFieldConfig,\n} from '../../../models'\nimport { FormFieldArrayComponent } from './form-field-array/form-field-array.component'\nimport { FormFieldContactsForResourceComponent } from './form-field-contacts-for-resource/form-field-contacts-for-resource.component'\nimport { FormFieldContactsComponent } from './form-field-contacts/form-field-contacts.component'\nimport { FormFieldFileComponent } from './form-field-file/form-field-file.component'\nimport { FormFieldKeywordsComponent } from './form-field-keywords/form-field-keywords.component'\nimport { FormFieldObjectComponent } from './form-field-object/form-field-object.component'\nimport { FormFieldOnlineLinkResourcesComponent } from './form-field-online-link-resources/form-field-online-link-resources.component'\nimport { FormFieldOnlineResourcesComponent } from './form-field-online-resources/form-field-online-resources.component'\nimport { FormFieldOpenDataComponent } from './form-field-open-data/form-field-open-data.component'\nimport { FormFieldOverviewsComponent } from './form-field-overviews/form-field-overviews.component'\nimport { FormFieldRichComponent } from './form-field-rich/form-field-rich.component'\nimport { FormFieldSimpleComponent } from './form-field-simple/form-field-simple.component'\nimport { FormFieldSpatialExtentComponent } from './form-field-spatial-extent/form-field-spatial-extent.component'\nimport { FormFieldUpdateFrequencyComponent } from './form-field-update-frequency/form-field-update-frequency.component'\nimport { FormFieldConstraintsShortcutsComponent } from './form-field-constraints-shortcuts/form-field-constraints-shortcuts.component'\nimport { FormFieldConstraintsComponent } from './form-field-constraints/form-field-constraints.component'\nimport { TextFieldModule } from '@angular/cdk/text-field'\nimport { FormFieldSpatialToggleComponent } from './form-field-spatial-toggle/form-field-spatial-toggle.component'\n\n@Component({\n  selector: 'gn-ui-form-field',\n  templateUrl: './form-field.component.html',\n  styleUrls: ['./form-field.component.css'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true,\n  imports: [\n    CommonModule,\n    TranslateModule,\n    EditableLabelDirective,\n    MatTooltipModule,\n    FormFieldWrapperComponent,\n    FormFieldLicenseComponent,\n    FormFieldDateComponent,\n    FormFieldUpdateFrequencyComponent,\n    FormFieldTemporalExtentsComponent,\n    FormFieldSimpleComponent,\n    FormFieldRichComponent,\n    FormFieldObjectComponent,\n    FormFieldSpatialExtentComponent,\n    FormFieldFileComponent,\n    FormFieldArrayComponent,\n    FormFieldKeywordsComponent,\n    FormFieldOverviewsComponent,\n    FormFieldContactsForResourceComponent,\n    FormFieldOpenDataComponent,\n    FormFieldOnlineResourcesComponent,\n    FormFieldOnlineLinkResourcesComponent,\n    FormFieldContactsComponent,\n    FormFieldConstraintsComponent,\n    FormFieldConstraintsShortcutsComponent,\n    FormFieldSpatialToggleComponent,\n    TextFieldModule,\n  ],\n})\nexport class FormFieldComponent {\n  @Input() uniqueIdentifier: string\n  @Input() model: CatalogRecordKeys\n  @Input() modelSpecifier: FieldModelSpecifier\n  @Input() componentName: FormFieldComponentName\n\n  @Input() config: FormFieldConfig\n  @Input() value: unknown\n\n  @Output() valueChange: EventEmitter<unknown> = new EventEmitter()\n\n  @ViewChild('titleInput') titleInput: ElementRef\n  isOpenData = false\n\n  toggleIsOpenData(event: boolean) {\n    this.isOpenData = event\n  }\n\n  focusTitleInput() {\n    this.titleInput.nativeElement.focus()\n  }\n\n  get withoutWrapper() {\n    return (\n      this.model === 'title' ||\n      this.model === 'abstract' ||\n      this.model === 'legalConstraints' ||\n      this.model === 'securityConstraints' ||\n      this.model === 'otherConstraints' ||\n      this.componentName === 'form-field-constraints-shortcuts'\n    )\n  }\n\n  get valueAsString() {\n    return this.value as string\n  }\n  get valueAsDate() {\n    return this.value as Date\n  }\n\n  get valueAsOverviews() {\n    return this.value as Array<GraphicOverview>\n  }\n  get valueAsUpdateFrequency() {\n    return this.value as UpdateFrequency\n  }\n  get valueAsTemporalExtents() {\n    return this.value as Array<DatasetTemporalExtent>\n  }\n  get valueAsKeywords() {\n    return this.value as Array<Keyword>\n  }\n  get valueAsConstraints() {\n    return this.value as Array<Constraint>\n  }\n  get valueAsIndividuals() {\n    return this.value as Array<Individual>\n  }\n  get valueAsOnlineResources() {\n    return this.value as Array<OnlineResource>\n  }\n}\n","<!-- TEMPORARY - disabling the open data switch -->\n<!-- <ng-container *ngIf=\"model === 'licenses'\">\n  <gn-ui-form-field-open-data\n    [value]=\"valueAsConstraints\"\n    (valueChange)=\"valueChange.emit($event)\"\n    (openDataChange)=\"toggleIsOpenData($event)\"\n  ></gn-ui-form-field-open-data>\n</ng-container> -->\n<div class=\"flex flex-col h-full\">\n  <ng-container *ngIf=\"withoutWrapper; else withGenericWrapper\">\n    <ng-container *ngTemplateOutlet=\"fieldContent\"></ng-container>\n  </ng-container>\n  <ng-template #withGenericWrapper>\n    <gn-ui-form-field-wrapper\n      [label]=\"config.labelKey! | translate\"\n      [hint]=\"config.hintKey! | translate\"\n    >\n      <ng-container *ngTemplateOutlet=\"fieldContent\"></ng-container>\n    </gn-ui-form-field-wrapper>\n  </ng-template>\n</div>\n\n<ng-template #fieldContent>\n  <ng-container [ngSwitch]=\"model\">\n    <ng-container *ngSwitchCase=\"'title'\">\n      <div class=\"flex flex-row flex-start items-center gap-3 mb-[12px]\">\n        <textarea\n          #titleInput\n          cdkTextareaAutosize\n          #autosize=\"cdkTextareaAutosize\"\n          cdkAutosizeMinRows=\"1\"\n          data-test=\"recordTitleInput\"\n          class=\"grow font-title text-3xl font-normal overflow-hidden text-black/80\"\n          (change)=\"valueChange.emit($event.target.value)\"\n          [placeholder]=\"\n            'editor.record.form.field.title.placeholder' | translate\n          \"\n          >{{ valueAsString }}</textarea\n        >\n        <div class=\"flex flex-row justify-between self-start mt-0.5\">\n          <span\n            class=\"material-symbols-outlined gn-ui-icon-small m-2 cursor-pointer\"\n            (click)=\"focusTitleInput()\"\n            >edit</span\n          >\n          <span\n            *ngIf=\"config.hintKey\"\n            class=\"material-symbols-outlined gn-ui-icon-small m-2\"\n            [matTooltip]=\"config.hintKey! | translate\"\n            matTooltipPosition=\"above\"\n          >\n            help\n          </span>\n        </div>\n      </div>\n    </ng-container>\n    <ng-container *ngSwitchCase=\"'abstract'\">\n      <gn-ui-form-field-rich\n        [label]=\"config.labelKey! | translate\"\n        [hint]=\"config.hintKey! | translate\"\n        [value]=\"valueAsString\"\n        (valueChange)=\"valueChange.emit($event)\"\n      ></gn-ui-form-field-rich>\n    </ng-container>\n    <ng-container *ngSwitchCase=\"'overviews'\">\n      <gn-ui-form-field-overviews\n        [metadataUuid]=\"uniqueIdentifier\"\n        [value]=\"valueAsOverviews\"\n        (valueChange)=\"valueChange.emit($event)\"\n      ></gn-ui-form-field-overviews>\n    </ng-container>\n    <ng-container *ngSwitchCase=\"'resourceIdentifier'\">\n      <gn-ui-form-field-simple\n        [type]=\"'text'\"\n        [value]=\"valueAsString\"\n        (valueChange)=\"valueChange.emit($event)\"\n      ></gn-ui-form-field-simple>\n    </ng-container>\n    <ng-container *ngSwitchCase=\"'resourceCreated'\">\n      <gn-ui-form-field-date\n        [value]=\"valueAsDate\"\n        (valueChange)=\"valueChange.emit($event)\"\n      ></gn-ui-form-field-date>\n    </ng-container>\n    <ng-container *ngSwitchCase=\"'resourceUpdated'\">\n      <gn-ui-form-field-date\n        [value]=\"valueAsDate\"\n        (valueChange)=\"valueChange.emit($event)\"\n      ></gn-ui-form-field-date>\n    </ng-container>\n    <ng-container *ngSwitchCase=\"'updateFrequency'\">\n      <gn-ui-form-field-update-frequency\n        [value]=\"valueAsUpdateFrequency\"\n        (valueChange)=\"valueChange.emit($event)\"\n      ></gn-ui-form-field-update-frequency>\n    </ng-container>\n    <ng-container *ngSwitchCase=\"'temporalExtents'\">\n      <gn-ui-form-field-temporal-extents\n        [value]=\"valueAsTemporalExtents\"\n        (valueChange)=\"valueChange.emit($event)\"\n      ></gn-ui-form-field-temporal-extents>\n    </ng-container>\n    <ng-container *ngSwitchCase=\"'spatialExtents'\">\n      <gn-ui-form-field-spatial-extent></gn-ui-form-field-spatial-extent>\n    </ng-container>\n    <ng-container *ngSwitchCase=\"'keywords'\">\n      <gn-ui-form-field-keywords\n        [value]=\"valueAsKeywords\"\n        (valueChange)=\"valueChange.emit($event)\"\n      ></gn-ui-form-field-keywords>\n    </ng-container>\n    <ng-container *ngSwitchCase=\"'licenses'\">\n      <gn-ui-form-field-license\n        [label]=\"config.labelKey! | translate\"\n        [recordConstraints]=\"valueAsConstraints\"\n        (recordConstraintsChange)=\"valueChange.emit($event)\"\n      ></gn-ui-form-field-license>\n    </ng-container>\n\n    <ng-container *ngSwitchCase=\"'legalConstraints'\">\n      <ng-container *ngTemplateOutlet=\"formFieldConstraints\"></ng-container>\n    </ng-container>\n    <ng-container *ngSwitchCase=\"'securityConstraints'\">\n      <ng-container *ngTemplateOutlet=\"formFieldConstraints\"></ng-container>\n    </ng-container>\n    <ng-container *ngSwitchCase=\"'otherConstraints'\">\n      <ng-container *ngTemplateOutlet=\"formFieldConstraints\"></ng-container\n    ></ng-container>\n    <ng-template #formFieldConstraints>\n      <gn-ui-form-field-constraints\n        [label]=\"config.labelKey\"\n        [value]=\"valueAsConstraints\"\n        [constraintType]=\"model\"\n        (valueChange)=\"valueChange.emit($event)\"\n      ></gn-ui-form-field-constraints\n    ></ng-template>\n\n    <ng-container *ngSwitchCase=\"'contactsForResource'\">\n      <gn-ui-form-field-contacts-for-resource\n        [value]=\"valueAsIndividuals\"\n        (valueChange)=\"valueChange.emit($event)\"\n      ></gn-ui-form-field-contacts-for-resource>\n    </ng-container>\n    <ng-container *ngSwitchCase=\"'contacts'\">\n      <gn-ui-form-field-contacts\n        [value]=\"valueAsIndividuals\"\n        (valueChange)=\"valueChange.emit($event)\"\n      ></gn-ui-form-field-contacts>\n    </ng-container>\n    <ng-container *ngSwitchCase=\"'onlineResources'\">\n      <gn-ui-form-field-online-resources\n        *ngIf=\"modelSpecifier === 'onlineResourceType:!link'\"\n        [metadataUuid]=\"uniqueIdentifier\"\n        [value]=\"valueAsOnlineResources\"\n        (valueChange)=\"valueChange.emit($event)\"\n      ></gn-ui-form-field-online-resources>\n    </ng-container>\n    <ng-container *ngSwitchCase=\"'onlineResources'\">\n      <gn-ui-form-field-online-link-resources\n        *ngIf=\"modelSpecifier === 'onlineResourceType:link'\"\n        [metadataUuid]=\"uniqueIdentifier\"\n        [value]=\"valueAsOnlineResources\"\n        (valueChange)=\"valueChange.emit($event)\"\n      ></gn-ui-form-field-online-link-resources>\n    </ng-container>\n  </ng-container>\n\n  <ng-container *ngIf=\"!model\">\n    <ng-container [ngSwitch]=\"componentName\">\n      <ng-container *ngSwitchCase=\"'form-field-constraints-shortcuts'\">\n        <gn-ui-form-field-constraints-shortcuts></gn-ui-form-field-constraints-shortcuts>\n      </ng-container>\n      <ng-container *ngSwitchCase=\"'form-field-spatial-toggle'\">\n        <gn-ui-form-field-spatial-toggle></gn-ui-form-field-spatial-toggle>\n      </ng-container>\n    </ng-container>\n  </ng-container>\n</ng-template>\n"]}
@@ -26,10 +26,10 @@ export class RecordFormComponent {
26
26
  return section.labelKey;
27
27
  }
28
28
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: RecordFormComponent, deps: [{ token: i1.EditorFacade }], target: i0.ɵɵFactoryTarget.Component }); }
29
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: RecordFormComponent, isStandalone: true, selector: "gn-ui-record-form", ngImport: i0, template: "<div class=\"flex flex-col gap-6\">\n <ng-container\n *ngFor=\"\n let section of facade.currentSections$ | async;\n trackBy: sectionTracker\n \"\n >\n <ng-container *ngIf=\"!section.hidden\">\n <div class=\"flex flex-col gap-8 border p-8 rounded-[8px] shadow\">\n <div\n class=\"flex flex-col gap-2\"\n [ngClass]=\"section.labelKey ? 'mb-4' : 'hidden'\"\n >\n <div\n *ngIf=\"section.labelKey\"\n class=\"text-2xl font-title text-main\"\n translate\n >\n {{ section.labelKey }}\n </div>\n <div\n *ngIf=\"section.descriptionKey\"\n class=\"text-gray-800 text-sm\"\n translate\n >\n {{ section.descriptionKey }}\n </div>\n </div>\n <div class=\"grid auto-rows-auto grid-cols-2 gap-[32px]\">\n <ng-container\n *ngFor=\"\n let field of section.fieldsWithValues;\n trackBy: fieldTracker\n \"\n >\n <ng-container *ngIf=\"!field.config.hidden\">\n <gn-ui-form-field\n [ngClass]=\"\n field.config.gridColumnSpan === 1\n ? 'col-span-1'\n : 'col-span-2'\n \"\n [uniqueIdentifier]=\"recordUniqueIdentifier$ | async\"\n [model]=\"field.config.model!\"\n [modelSpecifier]=\"field.config.modelSpecifier!\"\n [config]=\"field.config.formFieldConfig\"\n [value]=\"field.value\"\n [componentName]=\"field.config.componentName\"\n (valueChange)=\"\n handleFieldValueChange(field.config.model!, $event)\n \"\n ></gn-ui-form-field>\n </ng-container>\n </ng-container>\n </div>\n </div>\n </ng-container>\n </ng-container>\n</div>\n", styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }, { kind: "component", type: FormFieldComponent, selector: "gn-ui-form-field", inputs: ["uniqueIdentifier", "model", "modelSpecifier", "componentName", "config", "value"], outputs: ["valueChange"] }, { kind: "ngmodule", type: TranslateModule }, { kind: "directive", type: i3.TranslateDirective, selector: "[translate],[ngx-translate]", inputs: ["translate", "translateParams"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
29
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: RecordFormComponent, isStandalone: true, selector: "gn-ui-record-form", ngImport: i0, template: "<div class=\"flex flex-col gap-6\">\n <ng-container\n *ngFor=\"\n let section of facade.currentSections$ | async;\n trackBy: sectionTracker\n \"\n >\n <ng-container *ngIf=\"!section.hidden\">\n <div class=\"flex flex-col gap-6 border p-8 rounded-[8px] shadow\">\n <div class=\"flex flex-col gap-2\">\n <div\n *ngIf=\"section.labelKey\"\n class=\"text-2xl font-title text-black\"\n translate\n >\n {{ section.labelKey }}\n </div>\n <div\n *ngIf=\"section.descriptionKey\"\n class=\"text-gray-800 text-sm\"\n translate\n >\n {{ section.descriptionKey }}\n </div>\n </div>\n <div class=\"grid auto-rows-auto grid-cols-2 gap-[32px]\">\n <ng-container\n *ngFor=\"\n let field of section.fieldsWithValues;\n trackBy: fieldTracker\n \"\n >\n <ng-container *ngIf=\"!field.config.hidden\">\n <gn-ui-form-field\n [ngClass]=\"\n field.config.gridColumnSpan === 1\n ? 'col-span-1'\n : 'col-span-2'\n \"\n [uniqueIdentifier]=\"recordUniqueIdentifier$ | async\"\n [model]=\"field.config.model!\"\n [modelSpecifier]=\"field.config.modelSpecifier!\"\n [config]=\"field.config.formFieldConfig\"\n [value]=\"field.value\"\n [componentName]=\"field.config.componentName\"\n (valueChange)=\"\n handleFieldValueChange(field.config.model!, $event)\n \"\n ></gn-ui-form-field>\n </ng-container>\n </ng-container>\n </div>\n </div>\n </ng-container>\n </ng-container>\n</div>\n", styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }, { kind: "component", type: FormFieldComponent, selector: "gn-ui-form-field", inputs: ["uniqueIdentifier", "model", "modelSpecifier", "componentName", "config", "value"], outputs: ["valueChange"] }, { kind: "ngmodule", type: TranslateModule }, { kind: "directive", type: i3.TranslateDirective, selector: "[translate],[ngx-translate]", inputs: ["translate", "translateParams"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
30
30
  }
31
31
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: RecordFormComponent, decorators: [{
32
32
  type: Component,
33
- args: [{ selector: 'gn-ui-record-form', changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, imports: [CommonModule, FormFieldComponent, TranslateModule], template: "<div class=\"flex flex-col gap-6\">\n <ng-container\n *ngFor=\"\n let section of facade.currentSections$ | async;\n trackBy: sectionTracker\n \"\n >\n <ng-container *ngIf=\"!section.hidden\">\n <div class=\"flex flex-col gap-8 border p-8 rounded-[8px] shadow\">\n <div\n class=\"flex flex-col gap-2\"\n [ngClass]=\"section.labelKey ? 'mb-4' : 'hidden'\"\n >\n <div\n *ngIf=\"section.labelKey\"\n class=\"text-2xl font-title text-main\"\n translate\n >\n {{ section.labelKey }}\n </div>\n <div\n *ngIf=\"section.descriptionKey\"\n class=\"text-gray-800 text-sm\"\n translate\n >\n {{ section.descriptionKey }}\n </div>\n </div>\n <div class=\"grid auto-rows-auto grid-cols-2 gap-[32px]\">\n <ng-container\n *ngFor=\"\n let field of section.fieldsWithValues;\n trackBy: fieldTracker\n \"\n >\n <ng-container *ngIf=\"!field.config.hidden\">\n <gn-ui-form-field\n [ngClass]=\"\n field.config.gridColumnSpan === 1\n ? 'col-span-1'\n : 'col-span-2'\n \"\n [uniqueIdentifier]=\"recordUniqueIdentifier$ | async\"\n [model]=\"field.config.model!\"\n [modelSpecifier]=\"field.config.modelSpecifier!\"\n [config]=\"field.config.formFieldConfig\"\n [value]=\"field.value\"\n [componentName]=\"field.config.componentName\"\n (valueChange)=\"\n handleFieldValueChange(field.config.model!, $event)\n \"\n ></gn-ui-form-field>\n </ng-container>\n </ng-container>\n </div>\n </div>\n </ng-container>\n </ng-container>\n</div>\n" }]
33
+ args: [{ selector: 'gn-ui-record-form', changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, imports: [CommonModule, FormFieldComponent, TranslateModule], template: "<div class=\"flex flex-col gap-6\">\n <ng-container\n *ngFor=\"\n let section of facade.currentSections$ | async;\n trackBy: sectionTracker\n \"\n >\n <ng-container *ngIf=\"!section.hidden\">\n <div class=\"flex flex-col gap-6 border p-8 rounded-[8px] shadow\">\n <div class=\"flex flex-col gap-2\">\n <div\n *ngIf=\"section.labelKey\"\n class=\"text-2xl font-title text-black\"\n translate\n >\n {{ section.labelKey }}\n </div>\n <div\n *ngIf=\"section.descriptionKey\"\n class=\"text-gray-800 text-sm\"\n translate\n >\n {{ section.descriptionKey }}\n </div>\n </div>\n <div class=\"grid auto-rows-auto grid-cols-2 gap-[32px]\">\n <ng-container\n *ngFor=\"\n let field of section.fieldsWithValues;\n trackBy: fieldTracker\n \"\n >\n <ng-container *ngIf=\"!field.config.hidden\">\n <gn-ui-form-field\n [ngClass]=\"\n field.config.gridColumnSpan === 1\n ? 'col-span-1'\n : 'col-span-2'\n \"\n [uniqueIdentifier]=\"recordUniqueIdentifier$ | async\"\n [model]=\"field.config.model!\"\n [modelSpecifier]=\"field.config.modelSpecifier!\"\n [config]=\"field.config.formFieldConfig\"\n [value]=\"field.value\"\n [componentName]=\"field.config.componentName\"\n (valueChange)=\"\n handleFieldValueChange(field.config.model!, $event)\n \"\n ></gn-ui-form-field>\n </ng-container>\n </ng-container>\n </div>\n </div>\n </ng-container>\n </ng-container>\n</div>\n" }]
34
34
  }], ctorParameters: () => [{ type: i1.EditorFacade }] });
35
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVjb3JkLWZvcm0uY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9mZWF0dXJlL2VkaXRvci9zcmMvbGliL2NvbXBvbmVudHMvcmVjb3JkLWZvcm0vcmVjb3JkLWZvcm0uY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9mZWF0dXJlL2VkaXRvci9zcmMvbGliL2NvbXBvbmVudHMvcmVjb3JkLWZvcm0vcmVjb3JkLWZvcm0uY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFBO0FBQzlDLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUE7QUFDbEUsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLDRCQUE0QixDQUFBO0FBRXpELE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLGNBQWMsQ0FBQTtBQUNqRCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0scUJBQXFCLENBQUE7QUFLckQsT0FBTyxFQUFFLEdBQUcsRUFBRSxNQUFNLE1BQU0sQ0FBQTs7Ozs7QUFXMUIsTUFBTSxPQUFPLG1CQUFtQjtJQUs5QixZQUFtQixNQUFvQjtRQUFwQixXQUFNLEdBQU4sTUFBTSxDQUFjO1FBSnZDLDRCQUF1QixHQUFHLElBQUksQ0FBQyxNQUFNLENBQUMsT0FBTyxDQUFDLElBQUksQ0FDaEQsR0FBRyxDQUFDLENBQUMsTUFBTSxFQUFFLEVBQUUsQ0FBQyxNQUFNLENBQUMsZ0JBQWdCLENBQUMsQ0FDekMsQ0FBQTtJQUV5QyxDQUFDO0lBRTNDLHNCQUFzQixDQUFDLEtBQXdCLEVBQUUsUUFBMEI7UUFDekUsSUFBSSxDQUFDLEtBQUssRUFBRSxDQUFDO1lBQ1gsT0FBTTtRQUNSLENBQUM7UUFDRCxJQUFJLENBQUMsTUFBTSxDQUFDLGlCQUFpQixDQUFDLEtBQUssRUFBRSxRQUFRLENBQUMsQ0FBQTtJQUNoRCxDQUFDO0lBRUQsWUFBWSxDQUFDLEtBQWEsRUFBRSxLQUEyQjtRQUNyRCxPQUFPLEtBQUssQ0FBQyxNQUFNLENBQUMsS0FBSyxDQUFBO0lBQzNCLENBQUM7SUFFRCxjQUFjLENBQUMsS0FBYSxFQUFFLE9BQWdDO1FBQzVELE9BQU8sT0FBTyxDQUFDLFFBQVEsQ0FBQTtJQUN6QixDQUFDOytHQXBCVSxtQkFBbUI7bUdBQW5CLG1CQUFtQiw2RUNyQmhDLG04REEyREEseUREeENZLFlBQVksbVpBQUUsa0JBQWtCLG1MQUFFLGVBQWU7OzRGQUVoRCxtQkFBbUI7a0JBUi9CLFNBQVM7K0JBQ0UsbUJBQW1CLG1CQUdaLHVCQUF1QixDQUFDLE1BQU0sY0FDbkMsSUFBSSxXQUNQLENBQUMsWUFBWSxFQUFFLGtCQUFrQixFQUFFLGVBQWUsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbidcbmltcG9ydCB7IENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQgfSBmcm9tICdAYW5ndWxhci9jb3JlJ1xuaW1wb3J0IHsgRWRpdG9yRmFjYWRlIH0gZnJvbSAnLi4vLi4vK3N0YXRlL2VkaXRvci5mYWNhZGUnXG5pbXBvcnQgeyBFZGl0b3JGaWVsZFZhbHVlIH0gZnJvbSAnLi4vLi4vbW9kZWxzJ1xuaW1wb3J0IHsgRm9ybUZpZWxkQ29tcG9uZW50IH0gZnJvbSAnLi9mb3JtLWZpZWxkJ1xuaW1wb3J0IHsgVHJhbnNsYXRlTW9kdWxlIH0gZnJvbSAnQG5neC10cmFuc2xhdGUvY29yZSdcbmltcG9ydCB7XG4gIEVkaXRvckZpZWxkV2l0aFZhbHVlLFxuICBFZGl0b3JTZWN0aW9uV2l0aFZhbHVlcyxcbn0gZnJvbSAnLi4vLi4vK3N0YXRlL2VkaXRvci5tb2RlbHMnXG5pbXBvcnQgeyBtYXAgfSBmcm9tICdyeGpzJ1xuaW1wb3J0IHsgQ2F0YWxvZ1JlY29yZEtleXMgfSBmcm9tICcuLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbW1vbi9kb21haW4vc3JjL2xpYi9tb2RlbC9yZWNvcmQnXG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2duLXVpLXJlY29yZC1mb3JtJyxcbiAgdGVtcGxhdGVVcmw6ICcuL3JlY29yZC1mb3JtLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vcmVjb3JkLWZvcm0uY29tcG9uZW50LmNzcyddLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgaW1wb3J0czogW0NvbW1vbk1vZHVsZSwgRm9ybUZpZWxkQ29tcG9uZW50LCBUcmFuc2xhdGVNb2R1bGVdLFxufSlcbmV4cG9ydCBjbGFzcyBSZWNvcmRGb3JtQ29tcG9uZW50IHtcbiAgcmVjb3JkVW5pcXVlSWRlbnRpZmllciQgPSB0aGlzLmZhY2FkZS5yZWNvcmQkLnBpcGUoXG4gICAgbWFwKChyZWNvcmQpID0+IHJlY29yZC51bmlxdWVJZGVudGlmaWVyKVxuICApXG5cbiAgY29uc3RydWN0b3IocHVibGljIGZhY2FkZTogRWRpdG9yRmFjYWRlKSB7fVxuXG4gIGhhbmRsZUZpZWxkVmFsdWVDaGFuZ2UobW9kZWw6IENhdGFsb2dSZWNvcmRLZXlzLCBuZXdWYWx1ZTogRWRpdG9yRmllbGRWYWx1ZSkge1xuICAgIGlmICghbW9kZWwpIHtcbiAgICAgIHJldHVyblxuICAgIH1cbiAgICB0aGlzLmZhY2FkZS51cGRhdGVSZWNvcmRGaWVsZChtb2RlbCwgbmV3VmFsdWUpXG4gIH1cblxuICBmaWVsZFRyYWNrZXIoaW5kZXg6IG51bWJlciwgZmllbGQ6IEVkaXRvckZpZWxkV2l0aFZhbHVlKSB7XG4gICAgcmV0dXJuIGZpZWxkLmNvbmZpZy5tb2RlbFxuICB9XG5cbiAgc2VjdGlvblRyYWNrZXIoaW5kZXg6IG51bWJlciwgc2VjdGlvbjogRWRpdG9yU2VjdGlvbldpdGhWYWx1ZXMpIHtcbiAgICByZXR1cm4gc2VjdGlvbi5sYWJlbEtleVxuICB9XG59XG4iLCI8ZGl2IGNsYXNzPVwiZmxleCBmbGV4LWNvbCBnYXAtNlwiPlxuICA8bmctY29udGFpbmVyXG4gICAgKm5nRm9yPVwiXG4gICAgICBsZXQgc2VjdGlvbiBvZiBmYWNhZGUuY3VycmVudFNlY3Rpb25zJCB8IGFzeW5jO1xuICAgICAgdHJhY2tCeTogc2VjdGlvblRyYWNrZXJcbiAgICBcIlxuICA+XG4gICAgPG5nLWNvbnRhaW5lciAqbmdJZj1cIiFzZWN0aW9uLmhpZGRlblwiPlxuICAgICAgPGRpdiBjbGFzcz1cImZsZXggZmxleC1jb2wgZ2FwLTggYm9yZGVyIHAtOCByb3VuZGVkLVs4cHhdIHNoYWRvd1wiPlxuICAgICAgICA8ZGl2XG4gICAgICAgICAgY2xhc3M9XCJmbGV4IGZsZXgtY29sIGdhcC0yXCJcbiAgICAgICAgICBbbmdDbGFzc109XCJzZWN0aW9uLmxhYmVsS2V5ID8gJ21iLTQnIDogJ2hpZGRlbidcIlxuICAgICAgICA+XG4gICAgICAgICAgPGRpdlxuICAgICAgICAgICAgKm5nSWY9XCJzZWN0aW9uLmxhYmVsS2V5XCJcbiAgICAgICAgICAgIGNsYXNzPVwidGV4dC0yeGwgZm9udC10aXRsZSB0ZXh0LW1haW5cIlxuICAgICAgICAgICAgdHJhbnNsYXRlXG4gICAgICAgICAgPlxuICAgICAgICAgICAge3sgc2VjdGlvbi5sYWJlbEtleSB9fVxuICAgICAgICAgIDwvZGl2PlxuICAgICAgICAgIDxkaXZcbiAgICAgICAgICAgICpuZ0lmPVwic2VjdGlvbi5kZXNjcmlwdGlvbktleVwiXG4gICAgICAgICAgICBjbGFzcz1cInRleHQtZ3JheS04MDAgdGV4dC1zbVwiXG4gICAgICAgICAgICB0cmFuc2xhdGVcbiAgICAgICAgICA+XG4gICAgICAgICAgICB7eyBzZWN0aW9uLmRlc2NyaXB0aW9uS2V5IH19XG4gICAgICAgICAgPC9kaXY+XG4gICAgICAgIDwvZGl2PlxuICAgICAgICA8ZGl2IGNsYXNzPVwiZ3JpZCBhdXRvLXJvd3MtYXV0byBncmlkLWNvbHMtMiBnYXAtWzMycHhdXCI+XG4gICAgICAgICAgPG5nLWNvbnRhaW5lclxuICAgICAgICAgICAgKm5nRm9yPVwiXG4gICAgICAgICAgICAgIGxldCBmaWVsZCBvZiBzZWN0aW9uLmZpZWxkc1dpdGhWYWx1ZXM7XG4gICAgICAgICAgICAgIHRyYWNrQnk6IGZpZWxkVHJhY2tlclxuICAgICAgICAgICAgXCJcbiAgICAgICAgICA+XG4gICAgICAgICAgICA8bmctY29udGFpbmVyICpuZ0lmPVwiIWZpZWxkLmNvbmZpZy5oaWRkZW5cIj5cbiAgICAgICAgICAgICAgPGduLXVpLWZvcm0tZmllbGRcbiAgICAgICAgICAgICAgICBbbmdDbGFzc109XCJcbiAgICAgICAgICAgICAgICAgIGZpZWxkLmNvbmZpZy5ncmlkQ29sdW1uU3BhbiA9PT0gMVxuICAgICAgICAgICAgICAgICAgICA/ICdjb2wtc3Bhbi0xJ1xuICAgICAgICAgICAgICAgICAgICA6ICdjb2wtc3Bhbi0yJ1xuICAgICAgICAgICAgICAgIFwiXG4gICAgICAgICAgICAgICAgW3VuaXF1ZUlkZW50aWZpZXJdPVwicmVjb3JkVW5pcXVlSWRlbnRpZmllciQgfCBhc3luY1wiXG4gICAgICAgICAgICAgICAgW21vZGVsXT1cImZpZWxkLmNvbmZpZy5tb2RlbCFcIlxuICAgICAgICAgICAgICAgIFttb2RlbFNwZWNpZmllcl09XCJmaWVsZC5jb25maWcubW9kZWxTcGVjaWZpZXIhXCJcbiAgICAgICAgICAgICAgICBbY29uZmlnXT1cImZpZWxkLmNvbmZpZy5mb3JtRmllbGRDb25maWdcIlxuICAgICAgICAgICAgICAgIFt2YWx1ZV09XCJmaWVsZC52YWx1ZVwiXG4gICAgICAgICAgICAgICAgW2NvbXBvbmVudE5hbWVdPVwiZmllbGQuY29uZmlnLmNvbXBvbmVudE5hbWVcIlxuICAgICAgICAgICAgICAgICh2YWx1ZUNoYW5nZSk9XCJcbiAgICAgICAgICAgICAgICAgIGhhbmRsZUZpZWxkVmFsdWVDaGFuZ2UoZmllbGQuY29uZmlnLm1vZGVsISwgJGV2ZW50KVxuICAgICAgICAgICAgICAgIFwiXG4gICAgICAgICAgICAgID48L2duLXVpLWZvcm0tZmllbGQ+XG4gICAgICAgICAgICA8L25nLWNvbnRhaW5lcj5cbiAgICAgICAgICA8L25nLWNvbnRhaW5lcj5cbiAgICAgICAgPC9kaXY+XG4gICAgICA8L2Rpdj5cbiAgICA8L25nLWNvbnRhaW5lcj5cbiAgPC9uZy1jb250YWluZXI+XG48L2Rpdj5cbiJdfQ==
35
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVjb3JkLWZvcm0uY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9mZWF0dXJlL2VkaXRvci9zcmMvbGliL2NvbXBvbmVudHMvcmVjb3JkLWZvcm0vcmVjb3JkLWZvcm0uY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9mZWF0dXJlL2VkaXRvci9zcmMvbGliL2NvbXBvbmVudHMvcmVjb3JkLWZvcm0vcmVjb3JkLWZvcm0uY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFBO0FBQzlDLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUE7QUFDbEUsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLDRCQUE0QixDQUFBO0FBRXpELE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLGNBQWMsQ0FBQTtBQUNqRCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0scUJBQXFCLENBQUE7QUFLckQsT0FBTyxFQUFFLEdBQUcsRUFBRSxNQUFNLE1BQU0sQ0FBQTs7Ozs7QUFXMUIsTUFBTSxPQUFPLG1CQUFtQjtJQUs5QixZQUFtQixNQUFvQjtRQUFwQixXQUFNLEdBQU4sTUFBTSxDQUFjO1FBSnZDLDRCQUF1QixHQUFHLElBQUksQ0FBQyxNQUFNLENBQUMsT0FBTyxDQUFDLElBQUksQ0FDaEQsR0FBRyxDQUFDLENBQUMsTUFBTSxFQUFFLEVBQUUsQ0FBQyxNQUFNLENBQUMsZ0JBQWdCLENBQUMsQ0FDekMsQ0FBQTtJQUV5QyxDQUFDO0lBRTNDLHNCQUFzQixDQUFDLEtBQXdCLEVBQUUsUUFBMEI7UUFDekUsSUFBSSxDQUFDLEtBQUssRUFBRSxDQUFDO1lBQ1gsT0FBTTtRQUNSLENBQUM7UUFDRCxJQUFJLENBQUMsTUFBTSxDQUFDLGlCQUFpQixDQUFDLEtBQUssRUFBRSxRQUFRLENBQUMsQ0FBQTtJQUNoRCxDQUFDO0lBRUQsWUFBWSxDQUFDLEtBQWEsRUFBRSxLQUEyQjtRQUNyRCxPQUFPLEtBQUssQ0FBQyxNQUFNLENBQUMsS0FBSyxDQUFBO0lBQzNCLENBQUM7SUFFRCxjQUFjLENBQUMsS0FBYSxFQUFFLE9BQWdDO1FBQzVELE9BQU8sT0FBTyxDQUFDLFFBQVEsQ0FBQTtJQUN6QixDQUFDOytHQXBCVSxtQkFBbUI7bUdBQW5CLG1CQUFtQiw2RUNyQmhDLGkzREF3REEseUREckNZLFlBQVksbVpBQUUsa0JBQWtCLG1MQUFFLGVBQWU7OzRGQUVoRCxtQkFBbUI7a0JBUi9CLFNBQVM7K0JBQ0UsbUJBQW1CLG1CQUdaLHVCQUF1QixDQUFDLE1BQU0sY0FDbkMsSUFBSSxXQUNQLENBQUMsWUFBWSxFQUFFLGtCQUFrQixFQUFFLGVBQWUsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbidcbmltcG9ydCB7IENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQgfSBmcm9tICdAYW5ndWxhci9jb3JlJ1xuaW1wb3J0IHsgRWRpdG9yRmFjYWRlIH0gZnJvbSAnLi4vLi4vK3N0YXRlL2VkaXRvci5mYWNhZGUnXG5pbXBvcnQgeyBFZGl0b3JGaWVsZFZhbHVlIH0gZnJvbSAnLi4vLi4vbW9kZWxzJ1xuaW1wb3J0IHsgRm9ybUZpZWxkQ29tcG9uZW50IH0gZnJvbSAnLi9mb3JtLWZpZWxkJ1xuaW1wb3J0IHsgVHJhbnNsYXRlTW9kdWxlIH0gZnJvbSAnQG5neC10cmFuc2xhdGUvY29yZSdcbmltcG9ydCB7XG4gIEVkaXRvckZpZWxkV2l0aFZhbHVlLFxuICBFZGl0b3JTZWN0aW9uV2l0aFZhbHVlcyxcbn0gZnJvbSAnLi4vLi4vK3N0YXRlL2VkaXRvci5tb2RlbHMnXG5pbXBvcnQgeyBtYXAgfSBmcm9tICdyeGpzJ1xuaW1wb3J0IHsgQ2F0YWxvZ1JlY29yZEtleXMgfSBmcm9tICcuLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbW1vbi9kb21haW4vc3JjL2xpYi9tb2RlbC9yZWNvcmQnXG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2duLXVpLXJlY29yZC1mb3JtJyxcbiAgdGVtcGxhdGVVcmw6ICcuL3JlY29yZC1mb3JtLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vcmVjb3JkLWZvcm0uY29tcG9uZW50LmNzcyddLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgaW1wb3J0czogW0NvbW1vbk1vZHVsZSwgRm9ybUZpZWxkQ29tcG9uZW50LCBUcmFuc2xhdGVNb2R1bGVdLFxufSlcbmV4cG9ydCBjbGFzcyBSZWNvcmRGb3JtQ29tcG9uZW50IHtcbiAgcmVjb3JkVW5pcXVlSWRlbnRpZmllciQgPSB0aGlzLmZhY2FkZS5yZWNvcmQkLnBpcGUoXG4gICAgbWFwKChyZWNvcmQpID0+IHJlY29yZC51bmlxdWVJZGVudGlmaWVyKVxuICApXG5cbiAgY29uc3RydWN0b3IocHVibGljIGZhY2FkZTogRWRpdG9yRmFjYWRlKSB7fVxuXG4gIGhhbmRsZUZpZWxkVmFsdWVDaGFuZ2UobW9kZWw6IENhdGFsb2dSZWNvcmRLZXlzLCBuZXdWYWx1ZTogRWRpdG9yRmllbGRWYWx1ZSkge1xuICAgIGlmICghbW9kZWwpIHtcbiAgICAgIHJldHVyblxuICAgIH1cbiAgICB0aGlzLmZhY2FkZS51cGRhdGVSZWNvcmRGaWVsZChtb2RlbCwgbmV3VmFsdWUpXG4gIH1cblxuICBmaWVsZFRyYWNrZXIoaW5kZXg6IG51bWJlciwgZmllbGQ6IEVkaXRvckZpZWxkV2l0aFZhbHVlKSB7XG4gICAgcmV0dXJuIGZpZWxkLmNvbmZpZy5tb2RlbFxuICB9XG5cbiAgc2VjdGlvblRyYWNrZXIoaW5kZXg6IG51bWJlciwgc2VjdGlvbjogRWRpdG9yU2VjdGlvbldpdGhWYWx1ZXMpIHtcbiAgICByZXR1cm4gc2VjdGlvbi5sYWJlbEtleVxuICB9XG59XG4iLCI8ZGl2IGNsYXNzPVwiZmxleCBmbGV4LWNvbCBnYXAtNlwiPlxuICA8bmctY29udGFpbmVyXG4gICAgKm5nRm9yPVwiXG4gICAgICBsZXQgc2VjdGlvbiBvZiBmYWNhZGUuY3VycmVudFNlY3Rpb25zJCB8IGFzeW5jO1xuICAgICAgdHJhY2tCeTogc2VjdGlvblRyYWNrZXJcbiAgICBcIlxuICA+XG4gICAgPG5nLWNvbnRhaW5lciAqbmdJZj1cIiFzZWN0aW9uLmhpZGRlblwiPlxuICAgICAgPGRpdiBjbGFzcz1cImZsZXggZmxleC1jb2wgZ2FwLTYgYm9yZGVyIHAtOCByb3VuZGVkLVs4cHhdIHNoYWRvd1wiPlxuICAgICAgICA8ZGl2IGNsYXNzPVwiZmxleCBmbGV4LWNvbCBnYXAtMlwiPlxuICAgICAgICAgIDxkaXZcbiAgICAgICAgICAgICpuZ0lmPVwic2VjdGlvbi5sYWJlbEtleVwiXG4gICAgICAgICAgICBjbGFzcz1cInRleHQtMnhsIGZvbnQtdGl0bGUgdGV4dC1ibGFja1wiXG4gICAgICAgICAgICB0cmFuc2xhdGVcbiAgICAgICAgICA+XG4gICAgICAgICAgICB7eyBzZWN0aW9uLmxhYmVsS2V5IH19XG4gICAgICAgICAgPC9kaXY+XG4gICAgICAgICAgPGRpdlxuICAgICAgICAgICAgKm5nSWY9XCJzZWN0aW9uLmRlc2NyaXB0aW9uS2V5XCJcbiAgICAgICAgICAgIGNsYXNzPVwidGV4dC1ncmF5LTgwMCB0ZXh0LXNtXCJcbiAgICAgICAgICAgIHRyYW5zbGF0ZVxuICAgICAgICAgID5cbiAgICAgICAgICAgIHt7IHNlY3Rpb24uZGVzY3JpcHRpb25LZXkgfX1cbiAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgPC9kaXY+XG4gICAgICAgIDxkaXYgY2xhc3M9XCJncmlkIGF1dG8tcm93cy1hdXRvIGdyaWQtY29scy0yIGdhcC1bMzJweF1cIj5cbiAgICAgICAgICA8bmctY29udGFpbmVyXG4gICAgICAgICAgICAqbmdGb3I9XCJcbiAgICAgICAgICAgICAgbGV0IGZpZWxkIG9mIHNlY3Rpb24uZmllbGRzV2l0aFZhbHVlcztcbiAgICAgICAgICAgICAgdHJhY2tCeTogZmllbGRUcmFja2VyXG4gICAgICAgICAgICBcIlxuICAgICAgICAgID5cbiAgICAgICAgICAgIDxuZy1jb250YWluZXIgKm5nSWY9XCIhZmllbGQuY29uZmlnLmhpZGRlblwiPlxuICAgICAgICAgICAgICA8Z24tdWktZm9ybS1maWVsZFxuICAgICAgICAgICAgICAgIFtuZ0NsYXNzXT1cIlxuICAgICAgICAgICAgICAgICAgZmllbGQuY29uZmlnLmdyaWRDb2x1bW5TcGFuID09PSAxXG4gICAgICAgICAgICAgICAgICAgID8gJ2NvbC1zcGFuLTEnXG4gICAgICAgICAgICAgICAgICAgIDogJ2NvbC1zcGFuLTInXG4gICAgICAgICAgICAgICAgXCJcbiAgICAgICAgICAgICAgICBbdW5pcXVlSWRlbnRpZmllcl09XCJyZWNvcmRVbmlxdWVJZGVudGlmaWVyJCB8IGFzeW5jXCJcbiAgICAgICAgICAgICAgICBbbW9kZWxdPVwiZmllbGQuY29uZmlnLm1vZGVsIVwiXG4gICAgICAgICAgICAgICAgW21vZGVsU3BlY2lmaWVyXT1cImZpZWxkLmNvbmZpZy5tb2RlbFNwZWNpZmllciFcIlxuICAgICAgICAgICAgICAgIFtjb25maWddPVwiZmllbGQuY29uZmlnLmZvcm1GaWVsZENvbmZpZ1wiXG4gICAgICAgICAgICAgICAgW3ZhbHVlXT1cImZpZWxkLnZhbHVlXCJcbiAgICAgICAgICAgICAgICBbY29tcG9uZW50TmFtZV09XCJmaWVsZC5jb25maWcuY29tcG9uZW50TmFtZVwiXG4gICAgICAgICAgICAgICAgKHZhbHVlQ2hhbmdlKT1cIlxuICAgICAgICAgICAgICAgICAgaGFuZGxlRmllbGRWYWx1ZUNoYW5nZShmaWVsZC5jb25maWcubW9kZWwhLCAkZXZlbnQpXG4gICAgICAgICAgICAgICAgXCJcbiAgICAgICAgICAgICAgPjwvZ24tdWktZm9ybS1maWVsZD5cbiAgICAgICAgICAgIDwvbmctY29udGFpbmVyPlxuICAgICAgICAgIDwvbmctY29udGFpbmVyPlxuICAgICAgICA8L2Rpdj5cbiAgICAgIDwvZGl2PlxuICAgIDwvbmctY29udGFpbmVyPlxuICA8L25nLWNvbnRhaW5lcj5cbjwvZGl2PlxuIl19