geonetwork-ui 2.3.0-dev.a26c0b88 → 2.3.0-dev.aef43725

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 (130) hide show
  1. package/esm2022/libs/api/metadata-converter/src/lib/iso19139/read-parts.mjs +2 -2
  2. package/esm2022/libs/api/metadata-converter/src/lib/iso19139/write-parts.mjs +2 -2
  3. package/esm2022/libs/api/repository/src/lib/gn4/platform/gn4-platform.service.mjs +9 -7
  4. package/esm2022/libs/feature/dataviz/src/lib/chart-view/chart-view.component.mjs +1 -1
  5. package/esm2022/libs/feature/dataviz/src/lib/service/data.service.mjs +14 -2
  6. package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-license/form-field-license.component.mjs +1 -1
  7. package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-update-frequency/form-field-update-frequency.component.mjs +104 -0
  8. package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field.component.mjs +8 -3
  9. package/esm2022/libs/feature/editor/src/lib/components/wizard-field/wizard-field.component.mjs +1 -1
  10. package/esm2022/libs/feature/editor/src/lib/fields.config.mjs +8 -1
  11. package/esm2022/libs/feature/map/src/lib/add-layer-from-ogc-api/add-layer-from-ogc-api.component.mjs +1 -1
  12. package/esm2022/libs/feature/map/src/lib/map-context/map-context.model.mjs +1 -1
  13. package/esm2022/libs/feature/map/src/lib/map-context/map-context.service.mjs +30 -10
  14. package/esm2022/libs/feature/map/src/lib/utils/map-utils.service.mjs +7 -3
  15. package/esm2022/libs/feature/record/src/lib/data-view/data-view.component.mjs +1 -1
  16. package/esm2022/libs/feature/record/src/lib/map-view/map-view.component.mjs +11 -7
  17. package/esm2022/libs/feature/record/src/lib/state/mdview.facade.mjs +34 -5
  18. package/esm2022/libs/feature/record/src/lib/state/mdview.reducer.mjs +1 -3
  19. package/esm2022/libs/feature/search/src/index.mjs +2 -1
  20. package/esm2022/libs/feature/search/src/lib/results-layout/results-layout.component.mjs +1 -1
  21. package/esm2022/libs/feature/search/src/lib/results-list/results-list.container.component.mjs +4 -4
  22. package/esm2022/libs/feature/search/src/lib/sort-by/sort-by.component.mjs +1 -1
  23. package/esm2022/libs/ui/catalog/src/lib/language-switcher/language-switcher.component.mjs +1 -1
  24. package/esm2022/libs/ui/catalog/src/lib/organisations-filter/organisations-filter.component.mjs +1 -1
  25. package/esm2022/libs/ui/elements/src/index.mjs +2 -2
  26. package/esm2022/libs/ui/elements/src/lib/error/error.component.mjs +30 -0
  27. package/esm2022/libs/ui/elements/src/lib/record-api-form/record-api-form.component.mjs +69 -69
  28. package/esm2022/libs/ui/elements/src/lib/ui-elements.module.mjs +6 -6
  29. package/esm2022/libs/ui/elements/src/lib/user-feedback-item/user-feedback-item.component.mjs +3 -5
  30. package/esm2022/libs/ui/inputs/src/lib/check-toggle/check-toggle.component.mjs +4 -3
  31. package/esm2022/libs/ui/inputs/src/lib/dropdown-selector/dropdown-selector.component.mjs +5 -3
  32. package/esm2022/libs/ui/inputs/src/lib/ui-inputs.module.mjs +6 -5
  33. package/esm2022/libs/util/app-config/src/lib/app-config.mjs +3 -1
  34. package/esm2022/libs/util/app-config/src/lib/fixtures.mjs +2 -1
  35. package/esm2022/libs/util/app-config/src/lib/model.mjs +1 -1
  36. package/esm2022/translations/de.json +3 -0
  37. package/esm2022/translations/en.json +3 -0
  38. package/esm2022/translations/es.json +3 -0
  39. package/esm2022/translations/fr.json +3 -0
  40. package/esm2022/translations/it.json +3 -0
  41. package/esm2022/translations/nl.json +3 -0
  42. package/esm2022/translations/pt.json +3 -0
  43. package/fesm2022/geonetwork-ui.mjs +445 -245
  44. package/fesm2022/geonetwork-ui.mjs.map +1 -1
  45. package/libs/api/metadata-converter/src/lib/iso19139/write-parts.d.ts.map +1 -1
  46. package/libs/api/repository/src/lib/gn4/platform/gn4-platform.service.d.ts.map +1 -1
  47. package/libs/feature/dataviz/src/lib/service/data.service.d.ts +2 -1
  48. package/libs/feature/dataviz/src/lib/service/data.service.d.ts.map +1 -1
  49. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-update-frequency/form-field-update-frequency.component.d.ts +21 -0
  50. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-update-frequency/form-field-update-frequency.component.d.ts.map +1 -0
  51. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field.component.d.ts +1 -0
  52. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field.component.d.ts.map +1 -1
  53. package/libs/feature/editor/src/lib/fields.config.d.ts.map +1 -1
  54. package/libs/feature/map/src/lib/map-context/map-context.model.d.ts +6 -0
  55. package/libs/feature/map/src/lib/map-context/map-context.model.d.ts.map +1 -1
  56. package/libs/feature/map/src/lib/map-context/map-context.service.d.ts +1 -1
  57. package/libs/feature/map/src/lib/map-context/map-context.service.d.ts.map +1 -1
  58. package/libs/feature/map/src/lib/utils/map-utils.service.d.ts.map +1 -1
  59. package/libs/feature/record/src/lib/map-view/map-view.component.d.ts +2 -2
  60. package/libs/feature/record/src/lib/map-view/map-view.component.d.ts.map +1 -1
  61. package/libs/feature/record/src/lib/state/mdview.facade.d.ts +5 -2
  62. package/libs/feature/record/src/lib/state/mdview.facade.d.ts.map +1 -1
  63. package/libs/feature/record/src/lib/state/mdview.reducer.d.ts.map +1 -1
  64. package/libs/feature/search/src/index.d.ts +1 -0
  65. package/libs/feature/search/src/index.d.ts.map +1 -1
  66. package/libs/ui/elements/src/index.d.ts +1 -1
  67. package/libs/ui/elements/src/index.d.ts.map +1 -1
  68. package/libs/ui/elements/src/lib/error/error.component.d.ts +16 -0
  69. package/libs/ui/elements/src/lib/error/error.component.d.ts.map +1 -0
  70. package/libs/ui/elements/src/lib/record-api-form/record-api-form.component.d.ts +14 -3
  71. package/libs/ui/elements/src/lib/record-api-form/record-api-form.component.d.ts.map +1 -1
  72. package/libs/ui/elements/src/lib/ui-elements.module.d.ts +2 -2
  73. package/libs/ui/elements/src/lib/ui-elements.module.d.ts.map +1 -1
  74. package/libs/ui/elements/src/lib/user-feedback-item/user-feedback-item.component.d.ts +1 -2
  75. package/libs/ui/elements/src/lib/user-feedback-item/user-feedback-item.component.d.ts.map +1 -1
  76. package/libs/ui/inputs/src/lib/check-toggle/check-toggle.component.d.ts +1 -1
  77. package/libs/ui/inputs/src/lib/check-toggle/check-toggle.component.d.ts.map +1 -1
  78. package/libs/ui/inputs/src/lib/dropdown-selector/dropdown-selector.component.d.ts +2 -1
  79. package/libs/ui/inputs/src/lib/dropdown-selector/dropdown-selector.component.d.ts.map +1 -1
  80. package/libs/ui/inputs/src/lib/ui-inputs.module.d.ts +27 -27
  81. package/libs/util/app-config/src/lib/app-config.d.ts.map +1 -1
  82. package/libs/util/app-config/src/lib/fixtures.d.ts.map +1 -1
  83. package/libs/util/app-config/src/lib/model.d.ts +1 -0
  84. package/libs/util/app-config/src/lib/model.d.ts.map +1 -1
  85. package/package.json +2 -2
  86. package/src/libs/api/metadata-converter/src/lib/iso19139/read-parts.ts +1 -1
  87. package/src/libs/api/metadata-converter/src/lib/iso19139/write-parts.ts +1 -4
  88. package/src/libs/api/repository/src/lib/gn4/platform/gn4-platform.service.ts +16 -10
  89. package/src/libs/common/fixtures/src/lib/records.fixtures.ts +8 -0
  90. package/src/libs/feature/dataviz/src/lib/service/data.service.ts +15 -1
  91. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-update-frequency/form-field-update-frequency.component.css +0 -0
  92. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-update-frequency/form-field-update-frequency.component.html +14 -0
  93. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-update-frequency/form-field-update-frequency.component.ts +143 -0
  94. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field.component.html +5 -0
  95. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field.component.ts +5 -0
  96. package/src/libs/feature/editor/src/lib/fields.config.ts +7 -0
  97. package/src/libs/feature/map/src/lib/map-context/map-context.model.ts +6 -0
  98. package/src/libs/feature/map/src/lib/map-context/map-context.service.ts +31 -9
  99. package/src/libs/feature/map/src/lib/utils/map-utils.service.ts +6 -2
  100. package/src/libs/feature/record/src/lib/map-view/map-view.component.ts +10 -8
  101. package/src/libs/feature/record/src/lib/state/mdview.facade.ts +40 -3
  102. package/src/libs/feature/record/src/lib/state/mdview.reducer.ts +0 -2
  103. package/src/libs/feature/search/src/index.ts +1 -0
  104. package/src/libs/feature/search/src/lib/results-list/results-list.container.component.html +4 -4
  105. package/src/libs/ui/elements/src/index.ts +1 -1
  106. package/src/libs/ui/elements/src/lib/{search-results-error/search-results-error.component.html → error/error.component.html} +18 -3
  107. package/src/libs/ui/elements/src/lib/{search-results-error/search-results-error.component.ts → error/error.component.ts} +5 -4
  108. package/src/libs/ui/elements/src/lib/record-api-form/record-api-form.component.ts +95 -79
  109. package/src/libs/ui/elements/src/lib/ui-elements.module.ts +3 -4
  110. package/src/libs/ui/elements/src/lib/user-feedback-item/user-feedback-item.component.html +1 -1
  111. package/src/libs/ui/elements/src/lib/user-feedback-item/user-feedback-item.component.ts +0 -1
  112. package/src/libs/ui/inputs/src/lib/check-toggle/check-toggle.component.ts +3 -0
  113. package/src/libs/ui/inputs/src/lib/dropdown-selector/dropdown-selector.component.html +1 -0
  114. package/src/libs/ui/inputs/src/lib/dropdown-selector/dropdown-selector.component.ts +1 -0
  115. package/src/libs/ui/inputs/src/lib/ui-inputs.module.ts +1 -1
  116. package/src/libs/util/app-config/src/lib/app-config.ts +2 -0
  117. package/src/libs/util/app-config/src/lib/fixtures.ts +1 -0
  118. package/src/libs/util/app-config/src/lib/model.ts +1 -0
  119. package/translations/de.json +3 -0
  120. package/translations/en.json +3 -0
  121. package/translations/es.json +3 -0
  122. package/translations/fr.json +3 -0
  123. package/translations/it.json +3 -0
  124. package/translations/nl.json +3 -0
  125. package/translations/pt.json +3 -0
  126. package/translations/sk.json +3 -0
  127. package/esm2022/libs/ui/elements/src/lib/search-results-error/search-results-error.component.mjs +0 -29
  128. package/libs/ui/elements/src/lib/search-results-error/search-results-error.component.d.ts +0 -15
  129. package/libs/ui/elements/src/lib/search-results-error/search-results-error.component.d.ts.map +0 -1
  130. /package/src/libs/ui/elements/src/lib/{search-results-error/search-results-error.component.css → error/error.component.css} +0 -0
@@ -1,7 +1,7 @@
1
1
  import { ChangeDetectionStrategy, Component, Input } from '@angular/core';
2
2
  import { OgcApiEndpoint, WfsEndpoint } from '@camptocamp/ogc-client';
3
3
  import { mimeTypeToFormat } from '../../../../../../libs/util/shared/src';
4
- import { BehaviorSubject, combineLatest, map, switchMap } from 'rxjs';
4
+ import { BehaviorSubject, combineLatest, filter, map, switchMap } from 'rxjs';
5
5
  import * as i0 from "@angular/core";
6
6
  import * as i1 from "@angular/common";
7
7
  import * as i2 from "@angular/material/tooltip";
@@ -16,41 +16,19 @@ const DEFAULT_PARAMS = {
16
16
  };
17
17
  export class RecordApiFormComponent {
18
18
  constructor() {
19
- this.offset$ = new BehaviorSubject('');
20
- this.limit$ = new BehaviorSubject('');
21
- this.format$ = new BehaviorSubject('');
19
+ this.offset$ = new BehaviorSubject(DEFAULT_PARAMS.OFFSET);
20
+ this.limit$ = new BehaviorSubject(DEFAULT_PARAMS.LIMIT);
21
+ this.format$ = new BehaviorSubject(DEFAULT_PARAMS.FORMAT);
22
+ this.endpoint$ = new BehaviorSubject(undefined);
22
23
  this.supportOffset = true;
23
24
  this.outputFormats = [{ value: 'json', label: 'JSON' }];
24
- this.apiQueryUrl$ = combineLatest([this.offset$, this.limit$, this.format$]).pipe(switchMap(async ([offset, limit, format]) => {
25
- let outputUrl;
26
- if (this.apiBaseUrl) {
27
- const url = new URL(this.apiBaseUrl);
28
- const params = { offset: offset, limit: limit, f: format };
29
- for (const [key, value] of Object.entries(params)) {
30
- if (value && value !== '0') {
31
- url.searchParams.set(key, value);
32
- }
33
- else {
34
- url.searchParams.delete(key);
35
- }
36
- }
37
- outputUrl = url.toString();
38
- }
39
- if (this.accessServiceProtocol === 'wfs') {
40
- const wfsEndpoint = new WfsEndpoint(this.apiBaseUrl);
41
- if (await wfsEndpoint.isReady()) {
42
- const options = {
43
- outputFormat: format,
44
- startIndex: Number(offset),
45
- };
46
- if (limit !== '-1') {
47
- options['maxFeatures'] = Number(limit);
48
- }
49
- outputUrl = wfsEndpoint.getFeatureUrl(this.apiFeatureType, options);
50
- }
51
- }
52
- return outputUrl;
53
- }));
25
+ this.apiQueryUrl$ = combineLatest([
26
+ this.offset$,
27
+ this.limit$,
28
+ this.format$,
29
+ // only compute the url if the endpoint was created
30
+ this.endpoint$.pipe(filter((endpoint) => !!endpoint)),
31
+ ]).pipe(switchMap(([offset, limit, format]) => this.generateApiQueryUrl(offset, limit, format)));
54
32
  this.noLimitChecked$ = this.limit$.pipe(map((limit) => limit === '-1' || limit === ''));
55
33
  this.displayLimit$ = this.limit$.pipe(map((limit) => (limit !== '-1' ? limit : '')));
56
34
  }
@@ -60,7 +38,7 @@ export class RecordApiFormComponent {
60
38
  this.apiFeatureType = value ? value.name : undefined;
61
39
  if (value) {
62
40
  this.apiBaseUrl = value.url.href;
63
- this.parseOutputFormats();
41
+ this.createEndpoint().then(() => this.parseOutputFormats());
64
42
  }
65
43
  this.resetUrl();
66
44
  }
@@ -68,8 +46,7 @@ export class RecordApiFormComponent {
68
46
  this.offset$.next(value);
69
47
  }
70
48
  setLimit(value) {
71
- const newLimit = value === '' ? '-1' : value;
72
- this.limit$.next(newLimit);
49
+ this.limit$.next(value === '' ? '-1' : value);
73
50
  }
74
51
  setFormat(value) {
75
52
  this.format$.next(String(value));
@@ -79,50 +56,73 @@ export class RecordApiFormComponent {
79
56
  this.limit$.next(DEFAULT_PARAMS.LIMIT);
80
57
  this.format$.next(DEFAULT_PARAMS.FORMAT);
81
58
  }
82
- parseOutputFormats() {
83
- const apiUrl = this.apiBaseUrl.slice(-1) === '?'
59
+ async parseOutputFormats() {
60
+ if (!this.endpoint)
61
+ return;
62
+ const apiUrl = this.apiBaseUrl.endsWith('?')
84
63
  ? this.apiBaseUrl.slice(0, -1)
85
64
  : this.apiBaseUrl;
86
- this.getOutputFormats(apiUrl, this.accessServiceProtocol).then((outputFormats) => {
87
- let formatsList = [];
88
- if ('itemFormats' in outputFormats) {
89
- formatsList = this.mapFormats(outputFormats.itemFormats);
90
- }
91
- else if ('outputFormats' in outputFormats) {
92
- formatsList = this.mapFormats(outputFormats.outputFormats);
93
- }
94
- this.outputFormats = this.outputFormats.concat(formatsList.filter(Boolean));
95
- this.outputFormats = this.outputFormats
96
- .filter((format, index, self) => index === self.findIndex((t) => t.value === format.value))
97
- .sort((a, b) => a.label.localeCompare(b.label));
98
- });
65
+ const outputFormats = await this.getOutputFormats(apiUrl);
66
+ const formatsList = outputFormats.itemFormats
67
+ ? this.mapFormats(outputFormats.itemFormats)
68
+ : this.mapFormats(outputFormats.outputFormats || []);
69
+ this.outputFormats = this.outputFormats
70
+ .concat(formatsList.filter(Boolean))
71
+ .filter((format, index, self) => index === self.findIndex((t) => t.value === format.value))
72
+ .sort((a, b) => a.label.localeCompare(b.label));
99
73
  }
100
74
  mapFormats(formats) {
101
75
  return formats.map((format) => {
102
76
  const normalizedFormat = mimeTypeToFormat(format);
103
- if (normalizedFormat) {
104
- return {
105
- label: normalizedFormat.toUpperCase(),
106
- value: normalizedFormat,
107
- };
108
- }
109
- return null;
77
+ return normalizedFormat
78
+ ? { label: normalizedFormat.toUpperCase(), value: normalizedFormat }
79
+ : null;
110
80
  });
111
81
  }
112
- async getOutputFormats(url, accessServiceProtocol) {
113
- if (accessServiceProtocol === 'wfs') {
114
- const endpoint = await new WfsEndpoint(url).isReady();
115
- this.supportOffset = endpoint.supportsStartIndex();
116
- return endpoint.getServiceInfo();
82
+ async getOutputFormats(url) {
83
+ if (!this.endpoint)
84
+ return {};
85
+ if (this.endpoint instanceof WfsEndpoint) {
86
+ this.supportOffset = this.endpoint.supportsStartIndex();
87
+ return this.endpoint.getServiceInfo();
88
+ }
89
+ else {
90
+ return (await this.endpoint.getCollectionInfo(this.firstCollection));
91
+ }
92
+ }
93
+ async createEndpoint() {
94
+ if (!this.apiBaseUrl || !this.accessServiceProtocol)
95
+ return;
96
+ if (this.accessServiceProtocol === 'wfs') {
97
+ this.endpoint = new WfsEndpoint(this.apiBaseUrl);
98
+ await this.endpoint.isReady();
99
+ }
100
+ else {
101
+ this.endpoint = new OgcApiEndpoint(this.apiBaseUrl);
102
+ this.firstCollection = (await this.endpoint.allCollections)[0].name;
103
+ }
104
+ this.endpoint$.next(this.endpoint);
105
+ }
106
+ async generateApiQueryUrl(offset, limit, format) {
107
+ if (!this.apiBaseUrl || !this.endpoint || !this.apiFeatureType)
108
+ return '';
109
+ const options = {
110
+ outputFormat: format,
111
+ startIndex: offset ? Number(offset) : undefined,
112
+ maxFeatures: limit !== '-1' ? Number(limit) : undefined,
113
+ limit: limit !== '-1' ? Number(limit) : limit === '-1' ? -1 : undefined,
114
+ offset: offset !== '' ? Number(offset) : undefined,
115
+ };
116
+ if (this.endpoint instanceof WfsEndpoint) {
117
+ options.maxFeatures = limit !== '-1' ? Number(limit) : undefined;
118
+ return this.endpoint.getFeatureUrl(this.apiFeatureType, options);
117
119
  }
118
120
  else {
119
- const endpoint = await new OgcApiEndpoint(url);
120
- const firstCollection = (await endpoint.featureCollections)[0];
121
- return endpoint.getCollectionInfo(firstCollection);
121
+ return await this.endpoint.getCollectionItemsUrl(this.firstCollection, options);
122
122
  }
123
123
  }
124
124
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: RecordApiFormComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
125
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.7", type: RecordApiFormComponent, selector: "gn-ui-record-api-form", inputs: { apiLink: "apiLink" }, ngImport: i0, template: "<div class=\"flex flex-col gap-8\">\n <div class=\"flex flex-col bg-white p-8 ng-star-inserted shadow-xl gap-8\">\n <div class=\"flex flex-row\">\n <div class=\"text-[16px] text-black truncate font-title w-11/12\" translate>\n record.metadata.api.form.create\n </div>\n <button\n (click)=\"resetUrl()\"\n class=\"bg-primary-opacity-50 inline-flex items-center justify-center px-2 py-1 text-13 font-medium leading-none text-white rounded capitalize text-primary-lightest hover:bg-primary transition-colors\"\n >\n <p class=\"text-[13px] uppercase\" translate>\n record.metadata.api.form.reset\n </p>\n </button>\n </div>\n <div class=\"flex flex-row flex-wrap justify-between grow gap-5\">\n <div class=\"flex flex-col gap-3\">\n <p class=\"text-[14px]\" translate>record.metadata.api.form.limit</p>\n <div class=\"flex flex-row items-center gap-2\">\n <gn-ui-text-input\n class=\"mr-2 w-20\"\n (valueChange)=\"setLimit($event)\"\n [value]=\"displayLimit$ | async\"\n hint=\"\"\n >\n </gn-ui-text-input>\n <div class=\"flex items-center\">\n <input\n class=\"mr-2 cursor-pointer\"\n type=\"checkbox\"\n [checked]=\"noLimitChecked$ | async\"\n (change)=\"setLimit('-1')\"\n />\n <span class=\"text-sm\" translate\n >record.metadata.api.form.limit.all</span\n >\n </div>\n </div>\n </div>\n <div class=\"flex flex-col gap-3 relative\">\n <p class=\"text-sm\" [class.text-gray-600]=\"!supportOffset\" translate>\n record.metadata.api.form.offset\n </p>\n <div class=\"flex items-center\">\n <gn-ui-text-input\n class=\"w-20\"\n [value]=\"offset$ | async\"\n [disabled]=\"!supportOffset\"\n (valueChange)=\"supportOffset ? setOffset($event) : null\"\n hint=\"\"\n >\n </gn-ui-text-input>\n <div\n *ngIf=\"!supportOffset\"\n class=\"flex items-center gap-2 text-orange-500 z-10 ml-3\"\n >\n <span\n class=\"material-symbols-outlined\"\n matTooltip=\"Not supported on this service\"\n >\n warning\n </span>\n </div>\n </div>\n </div>\n <div class=\"flex flex-col gap-3\">\n <p class=\"text-sm\" translate>record.metadata.api.form.type</p>\n <gn-ui-dropdown-selector\n #dropdown\n [title]=\"''\"\n extraBtnClass=\"secondary min-w-full !w-40 !text-black\"\n [showTitle]=\"false\"\n class=\"text-black\"\n [choices]=\"outputFormats\"\n (selectValue)=\"setFormat($event)\"\n [selected]=\"format$ | async\"\n ></gn-ui-dropdown-selector>\n </div>\n </div>\n </div>\n <div class=\"flex flex-col gap-3 mb-3\">\n <div class=\"text-sm text-black truncate font-title w-11/12\" translate>\n record.metadata.api.form.customUrl\n </div>\n <div class=\"bg-white rounded-lg\">\n <gn-ui-copy-text-button\n [text]=\"apiQueryUrl$ | async\"\n ></gn-ui-copy-text-button>\n </div>\n </div>\n</div>\n", styles: [":host ::ng-deep input{color:#000;opacity:1}:host ::ng-deep gn-ui-copy-text-button input[type=text]{color:#000;background-color:#fff}:host ::ng-deep gn-ui-copy-text-button button,host ::ng-deep gn-ui-copy-text-button button:hover{background-color:var(--color-secondary)!important}:host ::ng-deep gn-ui-copy-text-button button mat-icon{color:#fff!important;opacity:1!important}:host ::ng-deep gn-ui-copy-text-button button:hover mat-icon{color:#d3d3d3!important}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.MatTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }, { kind: "directive", type: i3.TranslateDirective, selector: "[translate],[ngx-translate]", inputs: ["translate", "translateParams"] }, { kind: "component", type: i4.DropdownSelectorComponent, selector: "gn-ui-dropdown-selector", inputs: ["title", "showTitle", "ariaName", "choices", "selected", "maxRows", "extraBtnClass", "minWidth"], outputs: ["selectValue"] }, { kind: "component", type: i5.TextInputComponent, selector: "gn-ui-text-input", inputs: ["value", "extraClass", "hint", "required", "disabled"], outputs: ["valueChange"] }, { kind: "component", type: i6.CopyTextButtonComponent, selector: "gn-ui-copy-text-button", inputs: ["text", "tooltipText", "displayText", "rows"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
125
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.7", type: RecordApiFormComponent, selector: "gn-ui-record-api-form", inputs: { apiLink: "apiLink" }, ngImport: i0, template: "<div class=\"flex flex-col gap-8\">\n <div class=\"flex flex-col bg-white p-8 ng-star-inserted shadow-xl gap-8\">\n <div class=\"flex flex-row\">\n <div class=\"text-[16px] text-black truncate font-title w-11/12\" translate>\n record.metadata.api.form.create\n </div>\n <button\n (click)=\"resetUrl()\"\n class=\"bg-primary-opacity-50 inline-flex items-center justify-center px-2 py-1 text-13 font-medium leading-none text-white rounded capitalize text-primary-lightest hover:bg-primary transition-colors\"\n >\n <p class=\"text-[13px] uppercase\" translate>\n record.metadata.api.form.reset\n </p>\n </button>\n </div>\n <div class=\"flex flex-row flex-wrap justify-between grow gap-5\">\n <div class=\"flex flex-col gap-3\">\n <p class=\"text-[14px]\" translate>record.metadata.api.form.limit</p>\n <div class=\"flex flex-row items-center gap-2\">\n <gn-ui-text-input\n class=\"mr-2 w-20\"\n (valueChange)=\"setLimit($event)\"\n [value]=\"displayLimit$ | async\"\n hint=\"\"\n >\n </gn-ui-text-input>\n <div class=\"flex items-center\">\n <input\n class=\"mr-2 cursor-pointer\"\n type=\"checkbox\"\n [checked]=\"noLimitChecked$ | async\"\n (change)=\"setLimit('-1')\"\n />\n <span class=\"text-sm\" translate\n >record.metadata.api.form.limit.all</span\n >\n </div>\n </div>\n </div>\n <div class=\"flex flex-col gap-3 relative\">\n <p class=\"text-sm\" [class.text-gray-600]=\"!supportOffset\" translate>\n record.metadata.api.form.offset\n </p>\n <div class=\"flex items-center\">\n <gn-ui-text-input\n class=\"w-20\"\n [value]=\"offset$ | async\"\n [disabled]=\"!supportOffset\"\n (valueChange)=\"supportOffset ? setOffset($event) : null\"\n hint=\"\"\n >\n </gn-ui-text-input>\n <div\n *ngIf=\"!supportOffset\"\n class=\"flex items-center gap-2 text-orange-500 z-10 ml-3\"\n >\n <span\n class=\"material-symbols-outlined\"\n matTooltip=\"Not supported on this service\"\n >\n warning\n </span>\n </div>\n </div>\n </div>\n <div class=\"flex flex-col gap-3\">\n <p class=\"text-sm\" translate>record.metadata.api.form.type</p>\n <gn-ui-dropdown-selector\n #dropdown\n [title]=\"''\"\n extraBtnClass=\"secondary min-w-full !w-40 !text-black\"\n [showTitle]=\"false\"\n class=\"text-black\"\n [choices]=\"outputFormats\"\n (selectValue)=\"setFormat($event)\"\n [selected]=\"format$ | async\"\n ></gn-ui-dropdown-selector>\n </div>\n </div>\n </div>\n <div class=\"flex flex-col gap-3 mb-3\">\n <div class=\"text-sm text-black truncate font-title w-11/12\" translate>\n record.metadata.api.form.customUrl\n </div>\n <div class=\"bg-white rounded-lg\">\n <gn-ui-copy-text-button\n [text]=\"apiQueryUrl$ | async\"\n ></gn-ui-copy-text-button>\n </div>\n </div>\n</div>\n", styles: [":host ::ng-deep input{color:#000;opacity:1}:host ::ng-deep gn-ui-copy-text-button input[type=text]{color:#000;background-color:#fff}:host ::ng-deep gn-ui-copy-text-button button,host ::ng-deep gn-ui-copy-text-button button:hover{background-color:var(--color-secondary)!important}:host ::ng-deep gn-ui-copy-text-button button mat-icon{color:#fff!important;opacity:1!important}:host ::ng-deep gn-ui-copy-text-button button:hover mat-icon{color:#d3d3d3!important}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.MatTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }, { kind: "directive", type: i3.TranslateDirective, selector: "[translate],[ngx-translate]", inputs: ["translate", "translateParams"] }, { kind: "component", type: i4.DropdownSelectorComponent, selector: "gn-ui-dropdown-selector", inputs: ["title", "showTitle", "ariaName", "choices", "selected", "maxRows", "extraBtnClass", "minWidth", "disabled"], outputs: ["selectValue"] }, { kind: "component", type: i5.TextInputComponent, selector: "gn-ui-text-input", inputs: ["value", "extraClass", "hint", "required", "disabled"], outputs: ["valueChange"] }, { kind: "component", type: i6.CopyTextButtonComponent, selector: "gn-ui-copy-text-button", inputs: ["text", "tooltipText", "displayText", "rows"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
126
126
  }
127
127
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: RecordApiFormComponent, decorators: [{
128
128
  type: Component,
@@ -130,4 +130,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.7", ngImpor
130
130
  }], propDecorators: { apiLink: [{
131
131
  type: Input
132
132
  }] } });
133
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"record-api-form.component.js","sourceRoot":"","sources":["../../../../../../../../libs/ui/elements/src/lib/record-api-form/record-api-form.component.ts","../../../../../../../../libs/ui/elements/src/lib/record-api-form/record-api-form.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, Input } from '@angular/core'\nimport { OgcApiEndpoint, WfsEndpoint } from '@camptocamp/ogc-client'\nimport {\n  DatasetServiceDistribution,\n  ServiceProtocol,\n} from '../../../../../../libs/common/domain/src/lib/model/record'\nimport { mimeTypeToFormat } from '../../../../../../libs/util/shared/src'\nimport { BehaviorSubject, combineLatest, map, switchMap } from 'rxjs'\n\nconst DEFAULT_PARAMS = {\n  OFFSET: '',\n  LIMIT: '-1',\n  FORMAT: 'json',\n}\n@Component({\n  selector: 'gn-ui-record-api-form',\n  templateUrl: './record-api-form.component.html',\n  styleUrls: ['./record-api-form.component.css'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class RecordApiFormComponent {\n  @Input() set apiLink(value: DatasetServiceDistribution) {\n    this.outputFormats = [{ value: 'json', label: 'JSON' }]\n    this.accessServiceProtocol = value ? value.accessServiceProtocol : undefined\n    this.apiFeatureType = value ? value.name : undefined\n    if (value) {\n      this.apiBaseUrl = value.url.href\n      this.parseOutputFormats()\n    }\n    this.resetUrl()\n  }\n\n  offset$ = new BehaviorSubject('')\n  limit$ = new BehaviorSubject('')\n  format$ = new BehaviorSubject('')\n  apiBaseUrl: string\n  apiFeatureType: string\n  supportOffset = true\n  accessServiceProtocol: ServiceProtocol | undefined\n  outputFormats = [{ value: 'json', label: 'JSON' }]\n\n  apiQueryUrl$ = combineLatest([this.offset$, this.limit$, this.format$]).pipe(\n    switchMap(async ([offset, limit, format]) => {\n      let outputUrl\n      if (this.apiBaseUrl) {\n        const url = new URL(this.apiBaseUrl)\n        const params = { offset: offset, limit: limit, f: format }\n        for (const [key, value] of Object.entries(params)) {\n          if (value && value !== '0') {\n            url.searchParams.set(key, value)\n          } else {\n            url.searchParams.delete(key)\n          }\n        }\n        outputUrl = url.toString()\n      }\n\n      if (this.accessServiceProtocol === 'wfs') {\n        const wfsEndpoint = new WfsEndpoint(this.apiBaseUrl)\n        if (await wfsEndpoint.isReady()) {\n          const options = {\n            outputFormat: format,\n            startIndex: Number(offset),\n          }\n          if (limit !== '-1') {\n            options['maxFeatures'] = Number(limit)\n          }\n          outputUrl = wfsEndpoint.getFeatureUrl(this.apiFeatureType, options)\n        }\n      }\n      return outputUrl\n    })\n  )\n  noLimitChecked$ = this.limit$.pipe(\n    map((limit) => limit === '-1' || limit === '')\n  )\n\n  displayLimit$ = this.limit$.pipe(\n    map((limit) => (limit !== '-1' ? limit : ''))\n  )\n\n  setOffset(value: string) {\n    this.offset$.next(value)\n  }\n\n  setLimit(value: string) {\n    const newLimit = value === '' ? '-1' : value\n    this.limit$.next(newLimit)\n  }\n\n  setFormat(value: string | unknown) {\n    this.format$.next(String(value))\n  }\n\n  resetUrl() {\n    this.offset$.next(DEFAULT_PARAMS.OFFSET)\n    this.limit$.next(DEFAULT_PARAMS.LIMIT)\n    this.format$.next(DEFAULT_PARAMS.FORMAT)\n  }\n\n  parseOutputFormats() {\n    const apiUrl =\n      this.apiBaseUrl.slice(-1) === '?'\n        ? this.apiBaseUrl.slice(0, -1)\n        : this.apiBaseUrl\n\n    this.getOutputFormats(apiUrl, this.accessServiceProtocol).then(\n      (outputFormats) => {\n        let formatsList = []\n        if ('itemFormats' in outputFormats) {\n          formatsList = this.mapFormats(outputFormats.itemFormats)\n        } else if ('outputFormats' in outputFormats) {\n          formatsList = this.mapFormats(outputFormats.outputFormats)\n        }\n        this.outputFormats = this.outputFormats.concat(\n          formatsList.filter(Boolean)\n        )\n        this.outputFormats = this.outputFormats\n          .filter(\n            (format, index, self) =>\n              index === self.findIndex((t) => t.value === format.value)\n          )\n          .sort((a, b) => a.label.localeCompare(b.label))\n      }\n    )\n  }\n\n  mapFormats(formats: any[]) {\n    return formats.map((format) => {\n      const normalizedFormat = mimeTypeToFormat(format)\n      if (normalizedFormat) {\n        return {\n          label: normalizedFormat.toUpperCase(),\n          value: normalizedFormat,\n        }\n      }\n      return null\n    })\n  }\n\n  async getOutputFormats(url: string, accessServiceProtocol: string) {\n    if (accessServiceProtocol === 'wfs') {\n      const endpoint = await new WfsEndpoint(url).isReady()\n      this.supportOffset = endpoint.supportsStartIndex()\n      return endpoint.getServiceInfo()\n    } else {\n      const endpoint = await new OgcApiEndpoint(url)\n      const firstCollection = (await endpoint.featureCollections)[0]\n      return endpoint.getCollectionInfo(firstCollection)\n    }\n  }\n}\n","<div class=\"flex flex-col gap-8\">\n  <div class=\"flex flex-col bg-white p-8 ng-star-inserted shadow-xl gap-8\">\n    <div class=\"flex flex-row\">\n      <div class=\"text-[16px] text-black truncate font-title w-11/12\" translate>\n        record.metadata.api.form.create\n      </div>\n      <button\n        (click)=\"resetUrl()\"\n        class=\"bg-primary-opacity-50 inline-flex items-center justify-center px-2 py-1 text-13 font-medium leading-none text-white rounded capitalize text-primary-lightest hover:bg-primary transition-colors\"\n      >\n        <p class=\"text-[13px] uppercase\" translate>\n          record.metadata.api.form.reset\n        </p>\n      </button>\n    </div>\n    <div class=\"flex flex-row flex-wrap justify-between grow gap-5\">\n      <div class=\"flex flex-col gap-3\">\n        <p class=\"text-[14px]\" translate>record.metadata.api.form.limit</p>\n        <div class=\"flex flex-row items-center gap-2\">\n          <gn-ui-text-input\n            class=\"mr-2 w-20\"\n            (valueChange)=\"setLimit($event)\"\n            [value]=\"displayLimit$ | async\"\n            hint=\"\"\n          >\n          </gn-ui-text-input>\n          <div class=\"flex items-center\">\n            <input\n              class=\"mr-2 cursor-pointer\"\n              type=\"checkbox\"\n              [checked]=\"noLimitChecked$ | async\"\n              (change)=\"setLimit('-1')\"\n            />\n            <span class=\"text-sm\" translate\n              >record.metadata.api.form.limit.all</span\n            >\n          </div>\n        </div>\n      </div>\n      <div class=\"flex flex-col gap-3 relative\">\n        <p class=\"text-sm\" [class.text-gray-600]=\"!supportOffset\" translate>\n          record.metadata.api.form.offset\n        </p>\n        <div class=\"flex items-center\">\n          <gn-ui-text-input\n            class=\"w-20\"\n            [value]=\"offset$ | async\"\n            [disabled]=\"!supportOffset\"\n            (valueChange)=\"supportOffset ? setOffset($event) : null\"\n            hint=\"\"\n          >\n          </gn-ui-text-input>\n          <div\n            *ngIf=\"!supportOffset\"\n            class=\"flex items-center gap-2 text-orange-500 z-10 ml-3\"\n          >\n            <span\n              class=\"material-symbols-outlined\"\n              matTooltip=\"Not supported on this service\"\n            >\n              warning\n            </span>\n          </div>\n        </div>\n      </div>\n      <div class=\"flex flex-col gap-3\">\n        <p class=\"text-sm\" translate>record.metadata.api.form.type</p>\n        <gn-ui-dropdown-selector\n          #dropdown\n          [title]=\"''\"\n          extraBtnClass=\"secondary min-w-full !w-40 !text-black\"\n          [showTitle]=\"false\"\n          class=\"text-black\"\n          [choices]=\"outputFormats\"\n          (selectValue)=\"setFormat($event)\"\n          [selected]=\"format$ | async\"\n        ></gn-ui-dropdown-selector>\n      </div>\n    </div>\n  </div>\n  <div class=\"flex flex-col gap-3 mb-3\">\n    <div class=\"text-sm text-black truncate font-title w-11/12\" translate>\n      record.metadata.api.form.customUrl\n    </div>\n    <div class=\"bg-white rounded-lg\">\n      <gn-ui-copy-text-button\n        [text]=\"apiQueryUrl$ | async\"\n      ></gn-ui-copy-text-button>\n    </div>\n  </div>\n</div>\n"]}
133
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"record-api-form.component.js","sourceRoot":"","sources":["../../../../../../../../libs/ui/elements/src/lib/record-api-form/record-api-form.component.ts","../../../../../../../../libs/ui/elements/src/lib/record-api-form/record-api-form.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,uBAAuB,EAAE,SAAS,EAAE,KAAK,EAAE,MAAM,eAAe,CAAA;AACzE,OAAO,EAAE,cAAc,EAAE,WAAW,EAAE,MAAM,wBAAwB,CAAA;AAKpE,OAAO,EAAE,gBAAgB,EAAE,MAAM,wCAAwC,CAAA;AACzE,OAAO,EAAE,eAAe,EAAE,aAAa,EAAE,MAAM,EAAE,GAAG,EAAE,SAAS,EAAE,MAAM,MAAM,CAAA;;;;;;;;AAE7E,MAAM,cAAc,GAAG;IACrB,MAAM,EAAE,EAAE;IACV,KAAK,EAAE,IAAI;IACX,MAAM,EAAE,MAAM;CACf,CAAA;AAaD,MAAM,OAAO,sBAAsB;IANnC;QAkBE,YAAO,GAAG,IAAI,eAAe,CAAC,cAAc,CAAC,MAAM,CAAC,CAAA;QACpD,WAAM,GAAG,IAAI,eAAe,CAAC,cAAc,CAAC,KAAK,CAAC,CAAA;QAClD,YAAO,GAAG,IAAI,eAAe,CAAC,cAAc,CAAC,MAAM,CAAC,CAAA;QACpD,cAAS,GAAG,IAAI,eAAe,CAC7B,SAAS,CACV,CAAA;QAGD,kBAAa,GAAG,IAAI,CAAA;QAEpB,kBAAa,GAAG,CAAC,EAAE,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,CAAC,CAAA;QAIlD,iBAAY,GAAG,aAAa,CAAC;YAC3B,IAAI,CAAC,OAAO;YACZ,IAAI,CAAC,MAAM;YACX,IAAI,CAAC,OAAO;YACZ,mDAAmD;YACnD,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,QAAQ,EAAE,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC;SACtD,CAAC,CAAC,IAAI,CACL,SAAS,CAAC,CAAC,CAAC,MAAM,EAAE,KAAK,EAAE,MAAM,CAAC,EAAE,EAAE,CACpC,IAAI,CAAC,mBAAmB,CAAC,MAAM,EAAE,KAAK,EAAE,MAAM,CAAC,CAChD,CACF,CAAA;QAED,oBAAe,GAAG,IAAI,CAAC,MAAM,CAAC,IAAI,CAChC,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,KAAK,IAAI,IAAI,KAAK,KAAK,EAAE,CAAC,CAC/C,CAAA;QACD,kBAAa,GAAG,IAAI,CAAC,MAAM,CAAC,IAAI,CAC9B,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC,KAAK,KAAK,IAAI,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAC9C,CAAA;KAkGF;IA5IC,IAAa,OAAO,CAAC,KAAiC;QACpD,IAAI,CAAC,aAAa,GAAG,CAAC,EAAE,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,CAAC,CAAA;QACvD,IAAI,CAAC,qBAAqB,GAAG,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,qBAAqB,CAAC,CAAC,CAAC,SAAS,CAAA;QAC5E,IAAI,CAAC,cAAc,GAAG,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,SAAS,CAAA;QACpD,IAAI,KAAK,EAAE;YACT,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC,GAAG,CAAC,IAAI,CAAA;YAChC,IAAI,CAAC,cAAc,EAAE,CAAC,IAAI,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,kBAAkB,EAAE,CAAC,CAAA;SAC5D;QACD,IAAI,CAAC,QAAQ,EAAE,CAAA;IACjB,CAAC;IAmCD,SAAS,CAAC,KAAa;QACrB,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,CAAA;IAC1B,CAAC;IAED,QAAQ,CAAC,KAAa;QACpB,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,KAAK,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK,CAAC,CAAA;IAC/C,CAAC;IAED,SAAS,CAAC,KAAuB;QAC/B,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAA;IAClC,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,CAAA;QACxC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,CAAA;QACtC,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,CAAA;IAC1C,CAAC;IAED,KAAK,CAAC,kBAAkB;QACtB,IAAI,CAAC,IAAI,CAAC,QAAQ;YAAE,OAAM;QAC1B,MAAM,MAAM,GAAG,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,GAAG,CAAC;YAC1C,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;YAC9B,CAAC,CAAC,IAAI,CAAC,UAAU,CAAA;QACnB,MAAM,aAAa,GAAG,MAAM,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,CAAA;QAEzD,MAAM,WAAW,GAAG,aAAa,CAAC,WAAW;YAC3C,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,WAAW,CAAC;YAC5C,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,aAAa,IAAI,EAAE,CAAC,CAAA;QAEtD,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,aAAa;aACpC,MAAM,CAAC,WAAW,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;aACnC,MAAM,CACL,CAAC,MAAM,EAAE,KAAK,EAAE,IAAI,EAAE,EAAE,CACtB,KAAK,KAAK,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,KAAK,KAAK,MAAM,CAAC,KAAK,CAAC,CAC5D;aACA,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,aAAa,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAA;IACnD,CAAC;IAED,UAAU,CAAC,OAAc;QACvB,OAAO,OAAO,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,EAAE;YAC5B,MAAM,gBAAgB,GAAG,gBAAgB,CAAC,MAAM,CAAC,CAAA;YACjD,OAAO,gBAAgB;gBACrB,CAAC,CAAC,EAAE,KAAK,EAAE,gBAAgB,CAAC,WAAW,EAAE,EAAE,KAAK,EAAE,gBAAgB,EAAE;gBACpE,CAAC,CAAC,IAAI,CAAA;QACV,CAAC,CAAC,CAAA;IACJ,CAAC;IAED,KAAK,CAAC,gBAAgB,CAAC,GAAW;QAChC,IAAI,CAAC,IAAI,CAAC,QAAQ;YAAE,OAAO,EAAE,CAAA;QAC7B,IAAI,IAAI,CAAC,QAAQ,YAAY,WAAW,EAAE;YACxC,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,QAAQ,CAAC,kBAAkB,EAAE,CAAA;YACvD,OAAO,IAAI,CAAC,QAAQ,CAAC,cAAc,EAAmB,CAAA;SACvD;aAAM;YACL,OAAO,CAAC,MAAM,IAAI,CAAC,QAAQ,CAAC,iBAAiB,CAC3C,IAAI,CAAC,eAAe,CACrB,CAAkB,CAAA;SACpB;IACH,CAAC;IAED,KAAK,CAAC,cAAc;QAClB,IAAI,CAAC,IAAI,CAAC,UAAU,IAAI,CAAC,IAAI,CAAC,qBAAqB;YAAE,OAAM;QAC3D,IAAI,IAAI,CAAC,qBAAqB,KAAK,KAAK,EAAE;YACxC,IAAI,CAAC,QAAQ,GAAG,IAAI,WAAW,CAAC,IAAI,CAAC,UAAU,CAAC,CAAA;YAChD,MAAO,IAAI,CAAC,QAAwB,CAAC,OAAO,EAAE,CAAA;SAC/C;aAAM;YACL,IAAI,CAAC,QAAQ,GAAG,IAAI,cAAc,CAAC,IAAI,CAAC,UAAU,CAAC,CAAA;YACnD,IAAI,CAAC,eAAe,GAAG,CAAC,MAAM,IAAI,CAAC,QAAQ,CAAC,cAAc,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAA;SACpE;QACD,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAA;IACpC,CAAC;IAED,KAAK,CAAC,mBAAmB,CACvB,MAAc,EACd,KAAa,EACb,MAAc;QAEd,IAAI,CAAC,IAAI,CAAC,UAAU,IAAI,CAAC,IAAI,CAAC,QAAQ,IAAI,CAAC,IAAI,CAAC,cAAc;YAAE,OAAO,EAAE,CAAA;QAEzE,MAAM,OAAO,GAAG;YACd,YAAY,EAAE,MAAM;YACpB,UAAU,EAAE,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,SAAS;YAC/C,WAAW,EAAE,KAAK,KAAK,IAAI,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,SAAS;YACvD,KAAK,EAAE,KAAK,KAAK,IAAI,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,KAAK,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS;YACvE,MAAM,EAAE,MAAM,KAAK,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,SAAS;SACnD,CAAA;QAED,IAAI,IAAI,CAAC,QAAQ,YAAY,WAAW,EAAE;YACxC,OAAO,CAAC,WAAW,GAAG,KAAK,KAAK,IAAI,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,SAAS,CAAA;YAChE,OAAO,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC,IAAI,CAAC,cAAc,EAAE,OAAO,CAAC,CAAA;SACjE;aAAM;YACL,OAAO,MAAM,IAAI,CAAC,QAAQ,CAAC,qBAAqB,CAC9C,IAAI,CAAC,eAAe,EACpB,OAAO,CACR,CAAA;SACF;IACH,CAAC;8GA5IU,sBAAsB;kGAAtB,sBAAsB,6FC1BnC,6yGA2FA;;2FDjEa,sBAAsB;kBANlC,SAAS;+BACE,uBAAuB,mBAGhB,uBAAuB,CAAC,MAAM;8BAGlC,OAAO;sBAAnB,KAAK","sourcesContent":["import { ChangeDetectionStrategy, Component, Input } from '@angular/core'\nimport { OgcApiEndpoint, WfsEndpoint } from '@camptocamp/ogc-client'\nimport {\n  DatasetServiceDistribution,\n  ServiceProtocol,\n} from '../../../../../../libs/common/domain/src/lib/model/record'\nimport { mimeTypeToFormat } from '../../../../../../libs/util/shared/src'\nimport { BehaviorSubject, combineLatest, filter, map, switchMap } from 'rxjs'\n\nconst DEFAULT_PARAMS = {\n  OFFSET: '',\n  LIMIT: '-1',\n  FORMAT: 'json',\n}\n\ninterface OutputFormats {\n  itemFormats?: any[]\n  outputFormats?: any[]\n}\n\n@Component({\n  selector: 'gn-ui-record-api-form',\n  templateUrl: './record-api-form.component.html',\n  styleUrls: ['./record-api-form.component.css'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class RecordApiFormComponent {\n  @Input() set apiLink(value: DatasetServiceDistribution) {\n    this.outputFormats = [{ value: 'json', label: 'JSON' }]\n    this.accessServiceProtocol = value ? value.accessServiceProtocol : undefined\n    this.apiFeatureType = value ? value.name : undefined\n    if (value) {\n      this.apiBaseUrl = value.url.href\n      this.createEndpoint().then(() => this.parseOutputFormats())\n    }\n    this.resetUrl()\n  }\n\n  offset$ = new BehaviorSubject(DEFAULT_PARAMS.OFFSET)\n  limit$ = new BehaviorSubject(DEFAULT_PARAMS.LIMIT)\n  format$ = new BehaviorSubject(DEFAULT_PARAMS.FORMAT)\n  endpoint$ = new BehaviorSubject<WfsEndpoint | OgcApiEndpoint | undefined>(\n    undefined\n  )\n  apiBaseUrl: string\n  apiFeatureType: string\n  supportOffset = true\n  accessServiceProtocol: ServiceProtocol | undefined\n  outputFormats = [{ value: 'json', label: 'JSON' }]\n  endpoint: WfsEndpoint | OgcApiEndpoint | undefined\n  firstCollection: string | undefined\n\n  apiQueryUrl$ = combineLatest([\n    this.offset$,\n    this.limit$,\n    this.format$,\n    // only compute the url if the endpoint was created\n    this.endpoint$.pipe(filter((endpoint) => !!endpoint)),\n  ]).pipe(\n    switchMap(([offset, limit, format]) =>\n      this.generateApiQueryUrl(offset, limit, format)\n    )\n  )\n\n  noLimitChecked$ = this.limit$.pipe(\n    map((limit) => limit === '-1' || limit === '')\n  )\n  displayLimit$ = this.limit$.pipe(\n    map((limit) => (limit !== '-1' ? limit : ''))\n  )\n\n  setOffset(value: string) {\n    this.offset$.next(value)\n  }\n\n  setLimit(value: string) {\n    this.limit$.next(value === '' ? '-1' : value)\n  }\n\n  setFormat(value: string | unknown) {\n    this.format$.next(String(value))\n  }\n\n  resetUrl() {\n    this.offset$.next(DEFAULT_PARAMS.OFFSET)\n    this.limit$.next(DEFAULT_PARAMS.LIMIT)\n    this.format$.next(DEFAULT_PARAMS.FORMAT)\n  }\n\n  async parseOutputFormats() {\n    if (!this.endpoint) return\n    const apiUrl = this.apiBaseUrl.endsWith('?')\n      ? this.apiBaseUrl.slice(0, -1)\n      : this.apiBaseUrl\n    const outputFormats = await this.getOutputFormats(apiUrl)\n\n    const formatsList = outputFormats.itemFormats\n      ? this.mapFormats(outputFormats.itemFormats)\n      : this.mapFormats(outputFormats.outputFormats || [])\n\n    this.outputFormats = this.outputFormats\n      .concat(formatsList.filter(Boolean))\n      .filter(\n        (format, index, self) =>\n          index === self.findIndex((t) => t.value === format.value)\n      )\n      .sort((a, b) => a.label.localeCompare(b.label))\n  }\n\n  mapFormats(formats: any[]) {\n    return formats.map((format) => {\n      const normalizedFormat = mimeTypeToFormat(format)\n      return normalizedFormat\n        ? { label: normalizedFormat.toUpperCase(), value: normalizedFormat }\n        : null\n    })\n  }\n\n  async getOutputFormats(url: string): Promise<OutputFormats> {\n    if (!this.endpoint) return {}\n    if (this.endpoint instanceof WfsEndpoint) {\n      this.supportOffset = this.endpoint.supportsStartIndex()\n      return this.endpoint.getServiceInfo() as OutputFormats\n    } else {\n      return (await this.endpoint.getCollectionInfo(\n        this.firstCollection\n      )) as OutputFormats\n    }\n  }\n\n  async createEndpoint() {\n    if (!this.apiBaseUrl || !this.accessServiceProtocol) return\n    if (this.accessServiceProtocol === 'wfs') {\n      this.endpoint = new WfsEndpoint(this.apiBaseUrl)\n      await (this.endpoint as WfsEndpoint).isReady()\n    } else {\n      this.endpoint = new OgcApiEndpoint(this.apiBaseUrl)\n      this.firstCollection = (await this.endpoint.allCollections)[0].name\n    }\n    this.endpoint$.next(this.endpoint)\n  }\n\n  async generateApiQueryUrl(\n    offset: string,\n    limit: string,\n    format: string\n  ): Promise<string> {\n    if (!this.apiBaseUrl || !this.endpoint || !this.apiFeatureType) return ''\n\n    const options = {\n      outputFormat: format,\n      startIndex: offset ? Number(offset) : undefined,\n      maxFeatures: limit !== '-1' ? Number(limit) : undefined,\n      limit: limit !== '-1' ? Number(limit) : limit === '-1' ? -1 : undefined,\n      offset: offset !== '' ? Number(offset) : undefined,\n    }\n\n    if (this.endpoint instanceof WfsEndpoint) {\n      options.maxFeatures = limit !== '-1' ? Number(limit) : undefined\n      return this.endpoint.getFeatureUrl(this.apiFeatureType, options)\n    } else {\n      return await this.endpoint.getCollectionItemsUrl(\n        this.firstCollection,\n        options\n      )\n    }\n  }\n}\n","<div class=\"flex flex-col gap-8\">\n  <div class=\"flex flex-col bg-white p-8 ng-star-inserted shadow-xl gap-8\">\n    <div class=\"flex flex-row\">\n      <div class=\"text-[16px] text-black truncate font-title w-11/12\" translate>\n        record.metadata.api.form.create\n      </div>\n      <button\n        (click)=\"resetUrl()\"\n        class=\"bg-primary-opacity-50 inline-flex items-center justify-center px-2 py-1 text-13 font-medium leading-none text-white rounded capitalize text-primary-lightest hover:bg-primary transition-colors\"\n      >\n        <p class=\"text-[13px] uppercase\" translate>\n          record.metadata.api.form.reset\n        </p>\n      </button>\n    </div>\n    <div class=\"flex flex-row flex-wrap justify-between grow gap-5\">\n      <div class=\"flex flex-col gap-3\">\n        <p class=\"text-[14px]\" translate>record.metadata.api.form.limit</p>\n        <div class=\"flex flex-row items-center gap-2\">\n          <gn-ui-text-input\n            class=\"mr-2 w-20\"\n            (valueChange)=\"setLimit($event)\"\n            [value]=\"displayLimit$ | async\"\n            hint=\"\"\n          >\n          </gn-ui-text-input>\n          <div class=\"flex items-center\">\n            <input\n              class=\"mr-2 cursor-pointer\"\n              type=\"checkbox\"\n              [checked]=\"noLimitChecked$ | async\"\n              (change)=\"setLimit('-1')\"\n            />\n            <span class=\"text-sm\" translate\n              >record.metadata.api.form.limit.all</span\n            >\n          </div>\n        </div>\n      </div>\n      <div class=\"flex flex-col gap-3 relative\">\n        <p class=\"text-sm\" [class.text-gray-600]=\"!supportOffset\" translate>\n          record.metadata.api.form.offset\n        </p>\n        <div class=\"flex items-center\">\n          <gn-ui-text-input\n            class=\"w-20\"\n            [value]=\"offset$ | async\"\n            [disabled]=\"!supportOffset\"\n            (valueChange)=\"supportOffset ? setOffset($event) : null\"\n            hint=\"\"\n          >\n          </gn-ui-text-input>\n          <div\n            *ngIf=\"!supportOffset\"\n            class=\"flex items-center gap-2 text-orange-500 z-10 ml-3\"\n          >\n            <span\n              class=\"material-symbols-outlined\"\n              matTooltip=\"Not supported on this service\"\n            >\n              warning\n            </span>\n          </div>\n        </div>\n      </div>\n      <div class=\"flex flex-col gap-3\">\n        <p class=\"text-sm\" translate>record.metadata.api.form.type</p>\n        <gn-ui-dropdown-selector\n          #dropdown\n          [title]=\"''\"\n          extraBtnClass=\"secondary min-w-full !w-40 !text-black\"\n          [showTitle]=\"false\"\n          class=\"text-black\"\n          [choices]=\"outputFormats\"\n          (selectValue)=\"setFormat($event)\"\n          [selected]=\"format$ | async\"\n        ></gn-ui-dropdown-selector>\n      </div>\n    </div>\n  </div>\n  <div class=\"flex flex-col gap-3 mb-3\">\n    <div class=\"text-sm text-black truncate font-title w-11/12\" translate>\n      record.metadata.api.form.customUrl\n    </div>\n    <div class=\"bg-white rounded-lg\">\n      <gn-ui-copy-text-button\n        [text]=\"apiQueryUrl$ | async\"\n      ></gn-ui-copy-text-button>\n    </div>\n  </div>\n</div>\n"]}
@@ -17,7 +17,7 @@ import { MetadataContactComponent } from './metadata-contact/metadata-contact.co
17
17
  import { MetadataCatalogComponent } from './metadata-catalog/metadata-catalog.component';
18
18
  import { MetadataQualityComponent } from './metadata-quality/metadata-quality.component';
19
19
  import { MetadataQualityItemComponent } from './metadata-quality-item/metadata-quality-item.component';
20
- import { SearchResultsErrorComponent } from './search-results-error/search-results-error.component';
20
+ import { ErrorComponent } from './error/error.component';
21
21
  import { PaginationComponent } from './pagination/pagination.component';
22
22
  import { ThumbnailComponent } from './thumbnail/thumbnail.component';
23
23
  import { UiInputsModule } from '../../../../../libs/ui/inputs/src';
@@ -46,7 +46,7 @@ export class UiElementsModule {
46
46
  MetadataCatalogComponent,
47
47
  MetadataQualityComponent,
48
48
  MetadataQualityItemComponent,
49
- SearchResultsErrorComponent,
49
+ ErrorComponent,
50
50
  PaginationComponent,
51
51
  AvatarComponent,
52
52
  UserPreviewComponent,
@@ -76,7 +76,7 @@ export class UiElementsModule {
76
76
  MetadataCatalogComponent,
77
77
  MetadataQualityComponent,
78
78
  MetadataQualityItemComponent,
79
- SearchResultsErrorComponent,
79
+ ErrorComponent,
80
80
  PaginationComponent,
81
81
  ThumbnailComponent,
82
82
  AvatarComponent,
@@ -129,7 +129,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.7", ngImpor
129
129
  MetadataCatalogComponent,
130
130
  MetadataQualityComponent,
131
131
  MetadataQualityItemComponent,
132
- SearchResultsErrorComponent,
132
+ ErrorComponent,
133
133
  PaginationComponent,
134
134
  AvatarComponent,
135
135
  UserPreviewComponent,
@@ -151,7 +151,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.7", ngImpor
151
151
  MetadataCatalogComponent,
152
152
  MetadataQualityComponent,
153
153
  MetadataQualityItemComponent,
154
- SearchResultsErrorComponent,
154
+ ErrorComponent,
155
155
  PaginationComponent,
156
156
  ThumbnailComponent,
157
157
  AvatarComponent,
@@ -165,4 +165,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.7", ngImpor
165
165
  ],
166
166
  }]
167
167
  }] });
168
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ui-elements.module.js","sourceRoot":"","sources":["../../../../../../../libs/ui/elements/src/lib/ui-elements.module.ts"],"names":[],"mappings":"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","sourcesContent":["import { NgModule } from '@angular/core'\nimport { CommonModule, NgOptimizedImage } from '@angular/common'\nimport { RouterModule } from '@angular/router'\nimport { MatIconModule } from '@angular/material/icon'\nimport { MatTooltipModule } from '@angular/material/tooltip'\nimport { UtilSharedModule } from '../../../../../libs/util/shared/src'\nimport { MetadataInfoComponent } from './metadata-info/metadata-info.component'\nimport { ContentGhostComponent } from './content-ghost/content-ghost.component'\nimport { DownloadItemComponent } from './download-item/download-item.component'\nimport { DownloadsListComponent } from './downloads-list/downloads-list.component'\nimport { ApiCardComponent } from './api-card/api-card.component'\nimport { UiWidgetsModule } from '../../../../../libs/ui/widgets/src'\nimport { UiLayoutModule } from '../../../../../libs/ui/layout/src'\nimport { TranslateModule } from '@ngx-translate/core'\nimport { LinkCardComponent } from './link-card/link-card.component'\nimport { RelatedRecordCardComponent } from './related-record-card/related-record-card.component'\nimport { MetadataContactComponent } from './metadata-contact/metadata-contact.component'\nimport { MetadataCatalogComponent } from './metadata-catalog/metadata-catalog.component'\nimport { MetadataQualityComponent } from './metadata-quality/metadata-quality.component'\nimport { MetadataQualityItemComponent } from './metadata-quality-item/metadata-quality-item.component'\nimport { SearchResultsErrorComponent } from './search-results-error/search-results-error.component'\nimport { PaginationComponent } from './pagination/pagination.component'\nimport { ThumbnailComponent } from './thumbnail/thumbnail.component'\nimport { UiInputsModule } from '../../../../../libs/ui/inputs/src'\nimport { FormsModule } from '@angular/forms'\nimport { AvatarComponent } from './avatar/avatar.component'\nimport { UserPreviewComponent } from './user-preview/user-preview.component'\nimport { GnUiLinkifyDirective } from './metadata-info/linkify.directive'\nimport { PaginationButtonsComponent } from './pagination-buttons/pagination-buttons.component'\nimport { MaxLinesComponent } from './max-lines/max-lines.component'\nimport { RecordApiFormComponent } from './record-api-form/record-api-form.component'\nimport { MarkdownParserComponent } from './markdown-parser/markdown-parser.component'\nimport { ImageOverlayPreviewComponent } from './image-overlay-preview/image-overlay-preview.component'\nimport { UserFeedbackItemComponent } from './user-feedback-item/user-feedback-item.component'\nimport { TimeSincePipe } from './user-feedback-item/time-since.pipe'\n\n@NgModule({\n  imports: [\n    CommonModule,\n    MatIconModule,\n    MatTooltipModule,\n    UiWidgetsModule,\n    UiLayoutModule,\n    TranslateModule.forChild(),\n    UtilSharedModule,\n    RouterModule,\n    UiInputsModule,\n    FormsModule,\n    NgOptimizedImage,\n    MarkdownParserComponent,\n    ThumbnailComponent,\n    TimeSincePipe,\n  ],\n  declarations: [\n    MetadataInfoComponent,\n    ContentGhostComponent,\n    DownloadItemComponent,\n    DownloadsListComponent,\n    ApiCardComponent,\n    RelatedRecordCardComponent,\n    MetadataContactComponent,\n    MetadataCatalogComponent,\n    MetadataQualityComponent,\n    MetadataQualityItemComponent,\n    SearchResultsErrorComponent,\n    PaginationComponent,\n    AvatarComponent,\n    UserPreviewComponent,\n    GnUiLinkifyDirective,\n    PaginationButtonsComponent,\n    MaxLinesComponent,\n    RecordApiFormComponent,\n    UserFeedbackItemComponent,\n    ImageOverlayPreviewComponent,\n  ],\n  exports: [\n    MetadataInfoComponent,\n    ContentGhostComponent,\n    DownloadItemComponent,\n    DownloadsListComponent,\n    ApiCardComponent,\n    RelatedRecordCardComponent,\n    MetadataContactComponent,\n    MetadataCatalogComponent,\n    MetadataQualityComponent,\n    MetadataQualityItemComponent,\n    SearchResultsErrorComponent,\n    PaginationComponent,\n    ThumbnailComponent,\n    AvatarComponent,\n    UserPreviewComponent,\n    PaginationButtonsComponent,\n    MaxLinesComponent,\n    RecordApiFormComponent,\n    MarkdownParserComponent,\n    UserFeedbackItemComponent,\n    ImageOverlayPreviewComponent,\n  ],\n})\nexport class UiElementsModule {}\n"]}
168
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ui-elements.module.js","sourceRoot":"","sources":["../../../../../../../libs/ui/elements/src/lib/ui-elements.module.ts"],"names":[],"mappings":"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","sourcesContent":["import { NgModule } from '@angular/core'\nimport { CommonModule, NgOptimizedImage } from '@angular/common'\nimport { RouterModule } from '@angular/router'\nimport { MatIconModule } from '@angular/material/icon'\nimport { MatTooltipModule } from '@angular/material/tooltip'\nimport { UtilSharedModule } from '../../../../../libs/util/shared/src'\nimport { MetadataInfoComponent } from './metadata-info/metadata-info.component'\nimport { ContentGhostComponent } from './content-ghost/content-ghost.component'\nimport { DownloadItemComponent } from './download-item/download-item.component'\nimport { DownloadsListComponent } from './downloads-list/downloads-list.component'\nimport { ApiCardComponent } from './api-card/api-card.component'\nimport { UiWidgetsModule } from '../../../../../libs/ui/widgets/src'\nimport { UiLayoutModule } from '../../../../../libs/ui/layout/src'\nimport { TranslateModule } from '@ngx-translate/core'\nimport { RelatedRecordCardComponent } from './related-record-card/related-record-card.component'\nimport { MetadataContactComponent } from './metadata-contact/metadata-contact.component'\nimport { MetadataCatalogComponent } from './metadata-catalog/metadata-catalog.component'\nimport { MetadataQualityComponent } from './metadata-quality/metadata-quality.component'\nimport { MetadataQualityItemComponent } from './metadata-quality-item/metadata-quality-item.component'\nimport { ErrorComponent } from './error/error.component'\nimport { PaginationComponent } from './pagination/pagination.component'\nimport { ThumbnailComponent } from './thumbnail/thumbnail.component'\nimport { UiInputsModule } from '../../../../../libs/ui/inputs/src'\nimport { FormsModule } from '@angular/forms'\nimport { AvatarComponent } from './avatar/avatar.component'\nimport { UserPreviewComponent } from './user-preview/user-preview.component'\nimport { GnUiLinkifyDirective } from './metadata-info/linkify.directive'\nimport { PaginationButtonsComponent } from './pagination-buttons/pagination-buttons.component'\nimport { MaxLinesComponent } from './max-lines/max-lines.component'\nimport { RecordApiFormComponent } from './record-api-form/record-api-form.component'\nimport { MarkdownParserComponent } from './markdown-parser/markdown-parser.component'\nimport { ImageOverlayPreviewComponent } from './image-overlay-preview/image-overlay-preview.component'\nimport { UserFeedbackItemComponent } from './user-feedback-item/user-feedback-item.component'\nimport { TimeSincePipe } from './user-feedback-item/time-since.pipe'\n\n@NgModule({\n  imports: [\n    CommonModule,\n    MatIconModule,\n    MatTooltipModule,\n    UiWidgetsModule,\n    UiLayoutModule,\n    TranslateModule.forChild(),\n    UtilSharedModule,\n    RouterModule,\n    UiInputsModule,\n    FormsModule,\n    NgOptimizedImage,\n    MarkdownParserComponent,\n    ThumbnailComponent,\n    TimeSincePipe,\n  ],\n  declarations: [\n    MetadataInfoComponent,\n    ContentGhostComponent,\n    DownloadItemComponent,\n    DownloadsListComponent,\n    ApiCardComponent,\n    RelatedRecordCardComponent,\n    MetadataContactComponent,\n    MetadataCatalogComponent,\n    MetadataQualityComponent,\n    MetadataQualityItemComponent,\n    ErrorComponent,\n    PaginationComponent,\n    AvatarComponent,\n    UserPreviewComponent,\n    GnUiLinkifyDirective,\n    PaginationButtonsComponent,\n    MaxLinesComponent,\n    RecordApiFormComponent,\n    UserFeedbackItemComponent,\n    ImageOverlayPreviewComponent,\n  ],\n  exports: [\n    MetadataInfoComponent,\n    ContentGhostComponent,\n    DownloadItemComponent,\n    DownloadsListComponent,\n    ApiCardComponent,\n    RelatedRecordCardComponent,\n    MetadataContactComponent,\n    MetadataCatalogComponent,\n    MetadataQualityComponent,\n    MetadataQualityItemComponent,\n    ErrorComponent,\n    PaginationComponent,\n    ThumbnailComponent,\n    AvatarComponent,\n    UserPreviewComponent,\n    PaginationButtonsComponent,\n    MaxLinesComponent,\n    RecordApiFormComponent,\n    MarkdownParserComponent,\n    UserFeedbackItemComponent,\n    ImageOverlayPreviewComponent,\n  ],\n})\nexport class UiElementsModule {}\n"]}
@@ -39,17 +39,15 @@ export class UserFeedbackItemComponent {
39
39
  this.onNewAnswerValueChange();
40
40
  }
41
41
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: UserFeedbackItemComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
42
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.7", type: UserFeedbackItemComponent, selector: "gn-ui-user-feedback-item", inputs: { userFeedbackParent: "userFeedbackParent", userFeedBacksAnswers: "userFeedBacksAnswers", isActiveUserEditor: "isActiveUserEditor", activeUser: "activeUser", isLastComment: "isLastComment", isAddUserFeedbackLoading: "isAddUserFeedbackLoading" }, outputs: { newUserFeedbackAnswer: "newUserFeedbackAnswer" }, ngImport: i0, template: "<div\n *ngIf=\"userFeedbackParent.published\"\n class=\"flex flex-col bg-white rounded w-full\"\n [ngClass]=\"[isAnAnswer ? 'ps-4 ' : 'p-4']\"\n>\n <div class=\"flex flex-row\">\n <div class=\"avatar\">\n <img\n class=\"rounded-full\"\n [src]=\"userFeedbackParent.avatarUrl\"\n alt=\"avatar\"\n />\n </div>\n <div class=\"p-4 flex flex-col\">\n <span>{{ userFeedbackParent.authorName }}</span>\n <span> {{ userFeedbackParent.date | timeSince }}</span>\n </div>\n </div>\n <div data-cy=\"commentText\" class=\"mt-4 whitespace-pre-line\">\n {{ userFeedbackParent.comment }}\n </div>\n <div\n class=\"w-full\"\n *ngFor=\"let userFeedBacksAnswer of userFeedBacksAnswers; let last = last\"\n >\n <hr class=\"-mx-4 my-6\" />\n <gn-ui-user-feedback-item\n [userFeedbackParent]=\"userFeedBacksAnswer\"\n [isLastComment]=\"last\"\n ></gn-ui-user-feedback-item>\n </div>\n\n <div *ngIf=\"isActiveUserEditor\" class=\"mt-2 flex flex-col\">\n <hr class=\"-mx-4 my-4\" />\n <div\n id=\"new-comment-buttons\"\n class=\"flex flex-row gap-2 items-center justify-end\"\n >\n <gn-ui-text-area\n [disabled]=\"isAddUserFeedbackLoading\"\n [(value)]=\"newAnswer\"\n (valueChange)=\"onNewAnswerValueChange()\"\n (keyup.control.enter)=\"publishNewAnswer()\"\n [placeholder]=\"\n 'record.metadata.userFeedbacks.newAnswer.placeholder' | translate\n \"\n class=\"grow\"\n extraClass=\"bg-transparent border-0 placeholder-primary-darker text-primary-darker h-9\"\n ></gn-ui-text-area>\n <div *ngIf=\"!isAnswerEmpty\" class=\"flex flex-row justify-end\">\n <gn-ui-button\n [disabled]=\"isAddUserFeedbackLoading\"\n [type]=\"'outline'\"\n (buttonClick)=\"publishNewAnswer()\"\n [title]=\"\n 'record.metadata.userFeedbacks.newAnswer.buttonTitle' | translate\n \"\n extraClass=\"!p-[0.5em] text-primary-darker border-primary-darker h-9\"\n >\n <mat-icon\n class=\"material-symbols-outlined\"\n *ngIf=\"!isAddUserFeedbackLoading\"\n >\n send\n </mat-icon>\n <ng-container *ngIf=\"isAddUserFeedbackLoading\">\n <div class=\"flex justify-center w-full\">\n <gn-ui-spinning-loader></gn-ui-spinning-loader>\n </div>\n </ng-container>\n </gn-ui-button>\n </div>\n </div>\n </div>\n</div>\n", styles: [""], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i3.SpinningLoaderComponent, selector: "gn-ui-spinning-loader" }, { kind: "component", type: i4.ButtonComponent, selector: "gn-ui-button", inputs: ["type", "disabled", "extraClass"], outputs: ["buttonClick"] }, { kind: "component", type: i5.TextAreaComponent, selector: "gn-ui-text-area", inputs: ["value", "disabled", "extraClass", "placeholder", "required"], outputs: ["valueChange"] }, { kind: "component", type: UserFeedbackItemComponent, selector: "gn-ui-user-feedback-item", inputs: ["userFeedbackParent", "userFeedBacksAnswers", "isActiveUserEditor", "activeUser", "isLastComment", "isAddUserFeedbackLoading"], outputs: ["newUserFeedbackAnswer"] }, { kind: "pipe", type: i6.TranslatePipe, name: "translate" }, { kind: "pipe", type: i7.TimeSincePipe, name: "timeSince" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
42
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.7", type: UserFeedbackItemComponent, selector: "gn-ui-user-feedback-item", inputs: { userFeedbackParent: "userFeedbackParent", userFeedBacksAnswers: "userFeedBacksAnswers", activeUser: "activeUser", isLastComment: "isLastComment", isAddUserFeedbackLoading: "isAddUserFeedbackLoading" }, outputs: { newUserFeedbackAnswer: "newUserFeedbackAnswer" }, ngImport: i0, template: "<div\n *ngIf=\"userFeedbackParent.published\"\n class=\"flex flex-col bg-white rounded w-full\"\n [ngClass]=\"[isAnAnswer ? 'ps-4 ' : 'p-4']\"\n>\n <div class=\"flex flex-row\">\n <div class=\"avatar\">\n <img\n class=\"rounded-full\"\n [src]=\"userFeedbackParent.avatarUrl\"\n alt=\"avatar\"\n />\n </div>\n <div class=\"p-4 flex flex-col\">\n <span>{{ userFeedbackParent.authorName }}</span>\n <span> {{ userFeedbackParent.date | timeSince }}</span>\n </div>\n </div>\n <div data-cy=\"commentText\" class=\"mt-4 whitespace-pre-line\">\n {{ userFeedbackParent.comment }}\n </div>\n <div\n class=\"w-full\"\n *ngFor=\"let userFeedBacksAnswer of userFeedBacksAnswers; let last = last\"\n >\n <hr class=\"-mx-4 my-6\" />\n <gn-ui-user-feedback-item\n [userFeedbackParent]=\"userFeedBacksAnswer\"\n [isLastComment]=\"last\"\n ></gn-ui-user-feedback-item>\n </div>\n\n <div *ngIf=\"activeUser\" class=\"mt-2 flex flex-col\">\n <hr class=\"-mx-4 my-4\" />\n <div\n id=\"new-comment-buttons\"\n class=\"flex flex-row gap-2 items-center justify-end\"\n >\n <gn-ui-text-area\n [disabled]=\"isAddUserFeedbackLoading\"\n [(value)]=\"newAnswer\"\n (valueChange)=\"onNewAnswerValueChange()\"\n (keyup.control.enter)=\"publishNewAnswer()\"\n [placeholder]=\"\n 'record.metadata.userFeedbacks.newAnswer.placeholder' | translate\n \"\n class=\"grow\"\n extraClass=\"bg-transparent border-0 placeholder-primary-darker text-primary-darker h-9\"\n ></gn-ui-text-area>\n <div *ngIf=\"!isAnswerEmpty\" class=\"flex flex-row justify-end\">\n <gn-ui-button\n [disabled]=\"isAddUserFeedbackLoading\"\n [type]=\"'outline'\"\n (buttonClick)=\"publishNewAnswer()\"\n [title]=\"\n 'record.metadata.userFeedbacks.newAnswer.buttonTitle' | translate\n \"\n extraClass=\"!p-[0.5em] text-primary-darker border-primary-darker h-9\"\n >\n <mat-icon\n class=\"material-symbols-outlined\"\n *ngIf=\"!isAddUserFeedbackLoading\"\n >\n send\n </mat-icon>\n <ng-container *ngIf=\"isAddUserFeedbackLoading\">\n <div class=\"flex justify-center w-full\">\n <gn-ui-spinning-loader></gn-ui-spinning-loader>\n </div>\n </ng-container>\n </gn-ui-button>\n </div>\n </div>\n </div>\n</div>\n", styles: [""], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i3.SpinningLoaderComponent, selector: "gn-ui-spinning-loader" }, { kind: "component", type: i4.ButtonComponent, selector: "gn-ui-button", inputs: ["type", "disabled", "extraClass"], outputs: ["buttonClick"] }, { kind: "component", type: i5.TextAreaComponent, selector: "gn-ui-text-area", inputs: ["value", "disabled", "extraClass", "placeholder", "required"], outputs: ["valueChange"] }, { kind: "component", type: UserFeedbackItemComponent, selector: "gn-ui-user-feedback-item", inputs: ["userFeedbackParent", "userFeedBacksAnswers", "activeUser", "isLastComment", "isAddUserFeedbackLoading"], outputs: ["newUserFeedbackAnswer"] }, { kind: "pipe", type: i6.TranslatePipe, name: "translate" }, { kind: "pipe", type: i7.TimeSincePipe, name: "timeSince" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
43
43
  }
44
44
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: UserFeedbackItemComponent, decorators: [{
45
45
  type: Component,
46
- args: [{ selector: 'gn-ui-user-feedback-item', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div\n *ngIf=\"userFeedbackParent.published\"\n class=\"flex flex-col bg-white rounded w-full\"\n [ngClass]=\"[isAnAnswer ? 'ps-4 ' : 'p-4']\"\n>\n <div class=\"flex flex-row\">\n <div class=\"avatar\">\n <img\n class=\"rounded-full\"\n [src]=\"userFeedbackParent.avatarUrl\"\n alt=\"avatar\"\n />\n </div>\n <div class=\"p-4 flex flex-col\">\n <span>{{ userFeedbackParent.authorName }}</span>\n <span> {{ userFeedbackParent.date | timeSince }}</span>\n </div>\n </div>\n <div data-cy=\"commentText\" class=\"mt-4 whitespace-pre-line\">\n {{ userFeedbackParent.comment }}\n </div>\n <div\n class=\"w-full\"\n *ngFor=\"let userFeedBacksAnswer of userFeedBacksAnswers; let last = last\"\n >\n <hr class=\"-mx-4 my-6\" />\n <gn-ui-user-feedback-item\n [userFeedbackParent]=\"userFeedBacksAnswer\"\n [isLastComment]=\"last\"\n ></gn-ui-user-feedback-item>\n </div>\n\n <div *ngIf=\"isActiveUserEditor\" class=\"mt-2 flex flex-col\">\n <hr class=\"-mx-4 my-4\" />\n <div\n id=\"new-comment-buttons\"\n class=\"flex flex-row gap-2 items-center justify-end\"\n >\n <gn-ui-text-area\n [disabled]=\"isAddUserFeedbackLoading\"\n [(value)]=\"newAnswer\"\n (valueChange)=\"onNewAnswerValueChange()\"\n (keyup.control.enter)=\"publishNewAnswer()\"\n [placeholder]=\"\n 'record.metadata.userFeedbacks.newAnswer.placeholder' | translate\n \"\n class=\"grow\"\n extraClass=\"bg-transparent border-0 placeholder-primary-darker text-primary-darker h-9\"\n ></gn-ui-text-area>\n <div *ngIf=\"!isAnswerEmpty\" class=\"flex flex-row justify-end\">\n <gn-ui-button\n [disabled]=\"isAddUserFeedbackLoading\"\n [type]=\"'outline'\"\n (buttonClick)=\"publishNewAnswer()\"\n [title]=\"\n 'record.metadata.userFeedbacks.newAnswer.buttonTitle' | translate\n \"\n extraClass=\"!p-[0.5em] text-primary-darker border-primary-darker h-9\"\n >\n <mat-icon\n class=\"material-symbols-outlined\"\n *ngIf=\"!isAddUserFeedbackLoading\"\n >\n send\n </mat-icon>\n <ng-container *ngIf=\"isAddUserFeedbackLoading\">\n <div class=\"flex justify-center w-full\">\n <gn-ui-spinning-loader></gn-ui-spinning-loader>\n </div>\n </ng-container>\n </gn-ui-button>\n </div>\n </div>\n </div>\n</div>\n" }]
46
+ args: [{ selector: 'gn-ui-user-feedback-item', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div\n *ngIf=\"userFeedbackParent.published\"\n class=\"flex flex-col bg-white rounded w-full\"\n [ngClass]=\"[isAnAnswer ? 'ps-4 ' : 'p-4']\"\n>\n <div class=\"flex flex-row\">\n <div class=\"avatar\">\n <img\n class=\"rounded-full\"\n [src]=\"userFeedbackParent.avatarUrl\"\n alt=\"avatar\"\n />\n </div>\n <div class=\"p-4 flex flex-col\">\n <span>{{ userFeedbackParent.authorName }}</span>\n <span> {{ userFeedbackParent.date | timeSince }}</span>\n </div>\n </div>\n <div data-cy=\"commentText\" class=\"mt-4 whitespace-pre-line\">\n {{ userFeedbackParent.comment }}\n </div>\n <div\n class=\"w-full\"\n *ngFor=\"let userFeedBacksAnswer of userFeedBacksAnswers; let last = last\"\n >\n <hr class=\"-mx-4 my-6\" />\n <gn-ui-user-feedback-item\n [userFeedbackParent]=\"userFeedBacksAnswer\"\n [isLastComment]=\"last\"\n ></gn-ui-user-feedback-item>\n </div>\n\n <div *ngIf=\"activeUser\" class=\"mt-2 flex flex-col\">\n <hr class=\"-mx-4 my-4\" />\n <div\n id=\"new-comment-buttons\"\n class=\"flex flex-row gap-2 items-center justify-end\"\n >\n <gn-ui-text-area\n [disabled]=\"isAddUserFeedbackLoading\"\n [(value)]=\"newAnswer\"\n (valueChange)=\"onNewAnswerValueChange()\"\n (keyup.control.enter)=\"publishNewAnswer()\"\n [placeholder]=\"\n 'record.metadata.userFeedbacks.newAnswer.placeholder' | translate\n \"\n class=\"grow\"\n extraClass=\"bg-transparent border-0 placeholder-primary-darker text-primary-darker h-9\"\n ></gn-ui-text-area>\n <div *ngIf=\"!isAnswerEmpty\" class=\"flex flex-row justify-end\">\n <gn-ui-button\n [disabled]=\"isAddUserFeedbackLoading\"\n [type]=\"'outline'\"\n (buttonClick)=\"publishNewAnswer()\"\n [title]=\"\n 'record.metadata.userFeedbacks.newAnswer.buttonTitle' | translate\n \"\n extraClass=\"!p-[0.5em] text-primary-darker border-primary-darker h-9\"\n >\n <mat-icon\n class=\"material-symbols-outlined\"\n *ngIf=\"!isAddUserFeedbackLoading\"\n >\n send\n </mat-icon>\n <ng-container *ngIf=\"isAddUserFeedbackLoading\">\n <div class=\"flex justify-center w-full\">\n <gn-ui-spinning-loader></gn-ui-spinning-loader>\n </div>\n </ng-container>\n </gn-ui-button>\n </div>\n </div>\n </div>\n</div>\n" }]
47
47
  }], propDecorators: { userFeedbackParent: [{
48
48
  type: Input
49
49
  }], userFeedBacksAnswers: [{
50
50
  type: Input
51
- }], isActiveUserEditor: [{
52
- type: Input
53
51
  }], activeUser: [{
54
52
  type: Input
55
53
  }], isLastComment: [{
@@ -59,4 +57,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.7", ngImpor
59
57
  }], newUserFeedbackAnswer: [{
60
58
  type: Output
61
59
  }] } });
62
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXNlci1mZWVkYmFjay1pdGVtLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvdWkvZWxlbWVudHMvc3JjL2xpYi91c2VyLWZlZWRiYWNrLWl0ZW0vdXNlci1mZWVkYmFjay1pdGVtLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvdWkvZWxlbWVudHMvc3JjL2xpYi91c2VyLWZlZWRiYWNrLWl0ZW0vdXNlci1mZWVkYmFjay1pdGVtLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFDTCx1QkFBdUIsRUFDdkIsU0FBUyxFQUNULFlBQVksRUFDWixLQUFLLEVBRUwsTUFBTSxHQUNQLE1BQU0sZUFBZSxDQUFBOzs7Ozs7Ozs7QUFhdEIsTUFBTSxPQUFPLHlCQUF5QjtJQU50QztRQWNZLDBCQUFxQixHQUFHLElBQUksWUFBWSxFQUFnQixDQUFBO1FBRWxFLGVBQVUsR0FBRyxLQUFLLENBQUE7UUFDbEIsY0FBUyxHQUFHLEVBQUUsQ0FBQTtRQUNkLGtCQUFhLEdBQUcsSUFBSSxDQUFBO0tBOEJyQjtJQTVCQyxRQUFRO1FBQ04sSUFBSSxDQUFDLFVBQVUsR0FBRyxDQUFDLENBQUMsSUFBSSxDQUFDLGtCQUFrQixDQUFDLFVBQVUsQ0FBQTtJQUN4RCxDQUFDO0lBRUQsc0JBQXNCO1FBQ3BCLElBQUksQ0FBQyxhQUFhLEdBQUcsSUFBSSxDQUFDLFNBQVMsQ0FBQyxNQUFNLEtBQUssQ0FBQyxDQUFBO0lBQ2xELENBQUM7SUFFRCxnQkFBZ0I7UUFDZCxJQUFJLElBQUksQ0FBQyxTQUFTLENBQUMsSUFBSSxFQUFFLEtBQUssRUFBRTtZQUFFLE9BQU07UUFFeEMsTUFBTSxTQUFTLEdBQWlCO1lBQzlCLEdBQUcsSUFBSSxDQUFDLGtCQUFrQjtZQUMxQixJQUFJLEVBQUUsU0FBUztZQUNmLFNBQVMsRUFBRSxJQUFJO1lBQ2YsT0FBTyxFQUFFLElBQUksQ0FBQyxTQUFTO1lBQ3ZCLFVBQVUsRUFBRSxJQUFJLENBQUMsa0JBQWtCLENBQUMsSUFBSTtZQUN4QyxZQUFZLEVBQUUsSUFBSSxDQUFDLFVBQVUsRUFBRSxFQUFFO1lBQ2pDLFdBQVcsRUFBRSxJQUFJLENBQUMsVUFBVSxFQUFFLEtBQUs7WUFDbkMsSUFBSSxFQUFFLElBQUksSUFBSSxFQUFFO1lBQ2hCLFVBQVUsRUFBRSxHQUFHLElBQUksQ0FBQyxVQUFVLEVBQUUsSUFBSSxJQUFJLElBQUksQ0FBQyxVQUFVLEVBQUUsT0FBTyxFQUFFO1NBQ25FLENBQUE7UUFFRCxJQUFJLENBQUMscUJBQXFCLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxDQUFBO1FBRTFDLElBQUksQ0FBQyxTQUFTLEdBQUcsRUFBRSxDQUFBO1FBQ25CLElBQUksQ0FBQyxzQkFBc0IsRUFBRSxDQUFBO0lBQy9CLENBQUM7OEdBekNVLHlCQUF5QjtrR0FBekIseUJBQXlCLDJYQ3BCdEMseS9FQTJFQSw2NkJEdkRhLHlCQUF5Qjs7MkZBQXpCLHlCQUF5QjtrQkFOckMsU0FBUzsrQkFDRSwwQkFBMEIsbUJBR25CLHVCQUF1QixDQUFDLE1BQU07OEJBR3RDLGtCQUFrQjtzQkFBMUIsS0FBSztnQkFDRyxvQkFBb0I7c0JBQTVCLEtBQUs7Z0JBQ0csa0JBQWtCO3NCQUExQixLQUFLO2dCQUNHLFVBQVU7c0JBQWxCLEtBQUs7Z0JBQ0csYUFBYTtzQkFBckIsS0FBSztnQkFDRyx3QkFBd0I7c0JBQWhDLEtBQUs7Z0JBRUkscUJBQXFCO3NCQUE5QixNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksXG4gIENvbXBvbmVudCxcbiAgRXZlbnRFbWl0dGVyLFxuICBJbnB1dCxcbiAgT25Jbml0LFxuICBPdXRwdXQsXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnXG5pbXBvcnQge1xuICBVc2VyRmVlZGJhY2ssXG4gIFVzZXJGZWVkYmFja1ZpZXdNb2RlbCxcbn0gZnJvbSAnLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb21tb24vZG9tYWluL3NyYy9saWIvbW9kZWwvcmVjb3JkJ1xuaW1wb3J0IHsgVXNlck1vZGVsIH0gZnJvbSAnLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb21tb24vZG9tYWluL3NyYy9saWIvbW9kZWwvdXNlcidcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnZ24tdWktdXNlci1mZWVkYmFjay1pdGVtJyxcbiAgdGVtcGxhdGVVcmw6ICcuL3VzZXItZmVlZGJhY2staXRlbS5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlVXJsczogWycuL3VzZXItZmVlZGJhY2staXRlbS5jb21wb25lbnQuY3NzJ10sXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxufSlcbmV4cG9ydCBjbGFzcyBVc2VyRmVlZGJhY2tJdGVtQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0IHtcbiAgQElucHV0KCkgdXNlckZlZWRiYWNrUGFyZW50OiBVc2VyRmVlZGJhY2tWaWV3TW9kZWxcbiAgQElucHV0KCkgdXNlckZlZWRCYWNrc0Fuc3dlcnM6IFVzZXJGZWVkYmFja1ZpZXdNb2RlbFtdXG4gIEBJbnB1dCgpIGlzQWN0aXZlVXNlckVkaXRvcjogYm9vbGVhblxuICBASW5wdXQoKSBhY3RpdmVVc2VyOiBVc2VyTW9kZWxcbiAgQElucHV0KCkgaXNMYXN0Q29tbWVudDogYm9vbGVhblxuICBASW5wdXQoKSBpc0FkZFVzZXJGZWVkYmFja0xvYWRpbmc6IGJvb2xlYW5cblxuICBAT3V0cHV0KCkgbmV3VXNlckZlZWRiYWNrQW5zd2VyID0gbmV3IEV2ZW50RW1pdHRlcjxVc2VyRmVlZGJhY2s+KClcblxuICBpc0FuQW5zd2VyID0gZmFsc2VcbiAgbmV3QW5zd2VyID0gJydcbiAgaXNBbnN3ZXJFbXB0eSA9IHRydWVcblxuICBuZ09uSW5pdCgpOiB2b2lkIHtcbiAgICB0aGlzLmlzQW5BbnN3ZXIgPSAhIXRoaXMudXNlckZlZWRiYWNrUGFyZW50LnBhcmVudFV1aWRcbiAgfVxuXG4gIG9uTmV3QW5zd2VyVmFsdWVDaGFuZ2UoKSB7XG4gICAgdGhpcy5pc0Fuc3dlckVtcHR5ID0gdGhpcy5uZXdBbnN3ZXIubGVuZ3RoID09PSAwXG4gIH1cblxuICBwdWJsaXNoTmV3QW5zd2VyKCkge1xuICAgIGlmICh0aGlzLm5ld0Fuc3dlci50cmltKCkgPT09ICcnKSByZXR1cm5cblxuICAgIGNvbnN0IG5ld0Fuc3dlcjogVXNlckZlZWRiYWNrID0ge1xuICAgICAgLi4udGhpcy51c2VyRmVlZGJhY2tQYXJlbnQsXG4gICAgICB1dWlkOiB1bmRlZmluZWQsXG4gICAgICBwdWJsaXNoZWQ6IHRydWUsXG4gICAgICBjb21tZW50OiB0aGlzLm5ld0Fuc3dlcixcbiAgICAgIHBhcmVudFV1aWQ6IHRoaXMudXNlckZlZWRiYWNrUGFyZW50LnV1aWQsXG4gICAgICBhdXRob3JVc2VySWQ6IHRoaXMuYWN0aXZlVXNlcj8uaWQsXG4gICAgICBhdXRob3JFbWFpbDogdGhpcy5hY3RpdmVVc2VyPy5lbWFpbCxcbiAgICAgIGRhdGU6IG5ldyBEYXRlKCksXG4gICAgICBhdXRob3JOYW1lOiBgJHt0aGlzLmFjdGl2ZVVzZXI/Lm5hbWV9ICR7dGhpcy5hY3RpdmVVc2VyPy5zdXJuYW1lfWAsXG4gICAgfVxuXG4gICAgdGhpcy5uZXdVc2VyRmVlZGJhY2tBbnN3ZXIuZW1pdChuZXdBbnN3ZXIpXG5cbiAgICB0aGlzLm5ld0Fuc3dlciA9ICcnXG4gICAgdGhpcy5vbk5ld0Fuc3dlclZhbHVlQ2hhbmdlKClcbiAgfVxufVxuIiwiPGRpdlxuICAqbmdJZj1cInVzZXJGZWVkYmFja1BhcmVudC5wdWJsaXNoZWRcIlxuICBjbGFzcz1cImZsZXggZmxleC1jb2wgYmctd2hpdGUgcm91bmRlZCB3LWZ1bGxcIlxuICBbbmdDbGFzc109XCJbaXNBbkFuc3dlciA/ICdwcy00ICcgOiAncC00J11cIlxuPlxuICA8ZGl2IGNsYXNzPVwiZmxleCBmbGV4LXJvd1wiPlxuICAgIDxkaXYgY2xhc3M9XCJhdmF0YXJcIj5cbiAgICAgIDxpbWdcbiAgICAgICAgY2xhc3M9XCJyb3VuZGVkLWZ1bGxcIlxuICAgICAgICBbc3JjXT1cInVzZXJGZWVkYmFja1BhcmVudC5hdmF0YXJVcmxcIlxuICAgICAgICBhbHQ9XCJhdmF0YXJcIlxuICAgICAgLz5cbiAgICA8L2Rpdj5cbiAgICA8ZGl2IGNsYXNzPVwicC00IGZsZXggZmxleC1jb2xcIj5cbiAgICAgIDxzcGFuPnt7IHVzZXJGZWVkYmFja1BhcmVudC5hdXRob3JOYW1lIH19PC9zcGFuPlxuICAgICAgPHNwYW4+IHt7IHVzZXJGZWVkYmFja1BhcmVudC5kYXRlIHwgdGltZVNpbmNlIH19PC9zcGFuPlxuICAgIDwvZGl2PlxuICA8L2Rpdj5cbiAgPGRpdiBkYXRhLWN5PVwiY29tbWVudFRleHRcIiBjbGFzcz1cIm10LTQgd2hpdGVzcGFjZS1wcmUtbGluZVwiPlxuICAgIHt7IHVzZXJGZWVkYmFja1BhcmVudC5jb21tZW50IH19XG4gIDwvZGl2PlxuICA8ZGl2XG4gICAgY2xhc3M9XCJ3LWZ1bGxcIlxuICAgICpuZ0Zvcj1cImxldCB1c2VyRmVlZEJhY2tzQW5zd2VyIG9mIHVzZXJGZWVkQmFja3NBbnN3ZXJzOyBsZXQgbGFzdCA9IGxhc3RcIlxuICA+XG4gICAgPGhyIGNsYXNzPVwiLW14LTQgbXktNlwiIC8+XG4gICAgPGduLXVpLXVzZXItZmVlZGJhY2staXRlbVxuICAgICAgW3VzZXJGZWVkYmFja1BhcmVudF09XCJ1c2VyRmVlZEJhY2tzQW5zd2VyXCJcbiAgICAgIFtpc0xhc3RDb21tZW50XT1cImxhc3RcIlxuICAgID48L2duLXVpLXVzZXItZmVlZGJhY2staXRlbT5cbiAgPC9kaXY+XG5cbiAgPGRpdiAqbmdJZj1cImlzQWN0aXZlVXNlckVkaXRvclwiIGNsYXNzPVwibXQtMiBmbGV4IGZsZXgtY29sXCI+XG4gICAgPGhyIGNsYXNzPVwiLW14LTQgbXktNFwiIC8+XG4gICAgPGRpdlxuICAgICAgaWQ9XCJuZXctY29tbWVudC1idXR0b25zXCJcbiAgICAgIGNsYXNzPVwiZmxleCBmbGV4LXJvdyBnYXAtMiBpdGVtcy1jZW50ZXIganVzdGlmeS1lbmRcIlxuICAgID5cbiAgICAgIDxnbi11aS10ZXh0LWFyZWFcbiAgICAgICAgW2Rpc2FibGVkXT1cImlzQWRkVXNlckZlZWRiYWNrTG9hZGluZ1wiXG4gICAgICAgIFsodmFsdWUpXT1cIm5ld0Fuc3dlclwiXG4gICAgICAgICh2YWx1ZUNoYW5nZSk9XCJvbk5ld0Fuc3dlclZhbHVlQ2hhbmdlKClcIlxuICAgICAgICAoa2V5dXAuY29udHJvbC5lbnRlcik9XCJwdWJsaXNoTmV3QW5zd2VyKClcIlxuICAgICAgICBbcGxhY2Vob2xkZXJdPVwiXG4gICAgICAgICAgJ3JlY29yZC5tZXRhZGF0YS51c2VyRmVlZGJhY2tzLm5ld0Fuc3dlci5wbGFjZWhvbGRlcicgfCB0cmFuc2xhdGVcbiAgICAgICAgXCJcbiAgICAgICAgY2xhc3M9XCJncm93XCJcbiAgICAgICAgZXh0cmFDbGFzcz1cImJnLXRyYW5zcGFyZW50IGJvcmRlci0wIHBsYWNlaG9sZGVyLXByaW1hcnktZGFya2VyIHRleHQtcHJpbWFyeS1kYXJrZXIgaC05XCJcbiAgICAgID48L2duLXVpLXRleHQtYXJlYT5cbiAgICAgIDxkaXYgKm5nSWY9XCIhaXNBbnN3ZXJFbXB0eVwiIGNsYXNzPVwiZmxleCBmbGV4LXJvdyBqdXN0aWZ5LWVuZFwiPlxuICAgICAgICA8Z24tdWktYnV0dG9uXG4gICAgICAgICAgW2Rpc2FibGVkXT1cImlzQWRkVXNlckZlZWRiYWNrTG9hZGluZ1wiXG4gICAgICAgICAgW3R5cGVdPVwiJ291dGxpbmUnXCJcbiAgICAgICAgICAoYnV0dG9uQ2xpY2spPVwicHVibGlzaE5ld0Fuc3dlcigpXCJcbiAgICAgICAgICBbdGl0bGVdPVwiXG4gICAgICAgICAgICAncmVjb3JkLm1ldGFkYXRhLnVzZXJGZWVkYmFja3MubmV3QW5zd2VyLmJ1dHRvblRpdGxlJyB8IHRyYW5zbGF0ZVxuICAgICAgICAgIFwiXG4gICAgICAgICAgZXh0cmFDbGFzcz1cIiFwLVswLjVlbV0gdGV4dC1wcmltYXJ5LWRhcmtlciBib3JkZXItcHJpbWFyeS1kYXJrZXIgaC05XCJcbiAgICAgICAgPlxuICAgICAgICAgIDxtYXQtaWNvblxuICAgICAgICAgICAgY2xhc3M9XCJtYXRlcmlhbC1zeW1ib2xzLW91dGxpbmVkXCJcbiAgICAgICAgICAgICpuZ0lmPVwiIWlzQWRkVXNlckZlZWRiYWNrTG9hZGluZ1wiXG4gICAgICAgICAgPlxuICAgICAgICAgICAgc2VuZFxuICAgICAgICAgIDwvbWF0LWljb24+XG4gICAgICAgICAgPG5nLWNvbnRhaW5lciAqbmdJZj1cImlzQWRkVXNlckZlZWRiYWNrTG9hZGluZ1wiPlxuICAgICAgICAgICAgPGRpdiBjbGFzcz1cImZsZXgganVzdGlmeS1jZW50ZXIgdy1mdWxsXCI+XG4gICAgICAgICAgICAgIDxnbi11aS1zcGlubmluZy1sb2FkZXI+PC9nbi11aS1zcGlubmluZy1sb2FkZXI+XG4gICAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgICA8L25nLWNvbnRhaW5lcj5cbiAgICAgICAgPC9nbi11aS1idXR0b24+XG4gICAgICA8L2Rpdj5cbiAgICA8L2Rpdj5cbiAgPC9kaXY+XG48L2Rpdj5cbiJdfQ==
60
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXNlci1mZWVkYmFjay1pdGVtLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvdWkvZWxlbWVudHMvc3JjL2xpYi91c2VyLWZlZWRiYWNrLWl0ZW0vdXNlci1mZWVkYmFjay1pdGVtLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvdWkvZWxlbWVudHMvc3JjL2xpYi91c2VyLWZlZWRiYWNrLWl0ZW0vdXNlci1mZWVkYmFjay1pdGVtLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFDTCx1QkFBdUIsRUFDdkIsU0FBUyxFQUNULFlBQVksRUFDWixLQUFLLEVBRUwsTUFBTSxHQUNQLE1BQU0sZUFBZSxDQUFBOzs7Ozs7Ozs7QUFhdEIsTUFBTSxPQUFPLHlCQUF5QjtJQU50QztRQWFZLDBCQUFxQixHQUFHLElBQUksWUFBWSxFQUFnQixDQUFBO1FBRWxFLGVBQVUsR0FBRyxLQUFLLENBQUE7UUFDbEIsY0FBUyxHQUFHLEVBQUUsQ0FBQTtRQUNkLGtCQUFhLEdBQUcsSUFBSSxDQUFBO0tBOEJyQjtJQTVCQyxRQUFRO1FBQ04sSUFBSSxDQUFDLFVBQVUsR0FBRyxDQUFDLENBQUMsSUFBSSxDQUFDLGtCQUFrQixDQUFDLFVBQVUsQ0FBQTtJQUN4RCxDQUFDO0lBRUQsc0JBQXNCO1FBQ3BCLElBQUksQ0FBQyxhQUFhLEdBQUcsSUFBSSxDQUFDLFNBQVMsQ0FBQyxNQUFNLEtBQUssQ0FBQyxDQUFBO0lBQ2xELENBQUM7SUFFRCxnQkFBZ0I7UUFDZCxJQUFJLElBQUksQ0FBQyxTQUFTLENBQUMsSUFBSSxFQUFFLEtBQUssRUFBRTtZQUFFLE9BQU07UUFFeEMsTUFBTSxTQUFTLEdBQWlCO1lBQzlCLEdBQUcsSUFBSSxDQUFDLGtCQUFrQjtZQUMxQixJQUFJLEVBQUUsU0FBUztZQUNmLFNBQVMsRUFBRSxJQUFJO1lBQ2YsT0FBTyxFQUFFLElBQUksQ0FBQyxTQUFTO1lBQ3ZCLFVBQVUsRUFBRSxJQUFJLENBQUMsa0JBQWtCLENBQUMsSUFBSTtZQUN4QyxZQUFZLEVBQUUsSUFBSSxDQUFDLFVBQVUsRUFBRSxFQUFFO1lBQ2pDLFdBQVcsRUFBRSxJQUFJLENBQUMsVUFBVSxFQUFFLEtBQUs7WUFDbkMsSUFBSSxFQUFFLElBQUksSUFBSSxFQUFFO1lBQ2hCLFVBQVUsRUFBRSxHQUFHLElBQUksQ0FBQyxVQUFVLEVBQUUsSUFBSSxJQUFJLElBQUksQ0FBQyxVQUFVLEVBQUUsT0FBTyxFQUFFO1NBQ25FLENBQUE7UUFFRCxJQUFJLENBQUMscUJBQXFCLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxDQUFBO1FBRTFDLElBQUksQ0FBQyxTQUFTLEdBQUcsRUFBRSxDQUFBO1FBQ25CLElBQUksQ0FBQyxzQkFBc0IsRUFBRSxDQUFBO0lBQy9CLENBQUM7OEdBeENVLHlCQUF5QjtrR0FBekIseUJBQXlCLGlWQ3BCdEMsaS9FQTJFQSw2NkJEdkRhLHlCQUF5Qjs7MkZBQXpCLHlCQUF5QjtrQkFOckMsU0FBUzsrQkFDRSwwQkFBMEIsbUJBR25CLHVCQUF1QixDQUFDLE1BQU07OEJBR3RDLGtCQUFrQjtzQkFBMUIsS0FBSztnQkFDRyxvQkFBb0I7c0JBQTVCLEtBQUs7Z0JBQ0csVUFBVTtzQkFBbEIsS0FBSztnQkFDRyxhQUFhO3NCQUFyQixLQUFLO2dCQUNHLHdCQUF3QjtzQkFBaEMsS0FBSztnQkFFSSxxQkFBcUI7c0JBQTlCLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSxcbiAgQ29tcG9uZW50LFxuICBFdmVudEVtaXR0ZXIsXG4gIElucHV0LFxuICBPbkluaXQsXG4gIE91dHB1dCxcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSdcbmltcG9ydCB7XG4gIFVzZXJGZWVkYmFjayxcbiAgVXNlckZlZWRiYWNrVmlld01vZGVsLFxufSBmcm9tICcuLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbW1vbi9kb21haW4vc3JjL2xpYi9tb2RlbC9yZWNvcmQnXG5pbXBvcnQgeyBVc2VyTW9kZWwgfSBmcm9tICcuLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbW1vbi9kb21haW4vc3JjL2xpYi9tb2RlbC91c2VyJ1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdnbi11aS11c2VyLWZlZWRiYWNrLWl0ZW0nLFxuICB0ZW1wbGF0ZVVybDogJy4vdXNlci1mZWVkYmFjay1pdGVtLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vdXNlci1mZWVkYmFjay1pdGVtLmNvbXBvbmVudC5jc3MnXSxcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG59KVxuZXhwb3J0IGNsYXNzIFVzZXJGZWVkYmFja0l0ZW1Db21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xuICBASW5wdXQoKSB1c2VyRmVlZGJhY2tQYXJlbnQ6IFVzZXJGZWVkYmFja1ZpZXdNb2RlbFxuICBASW5wdXQoKSB1c2VyRmVlZEJhY2tzQW5zd2VyczogVXNlckZlZWRiYWNrVmlld01vZGVsW11cbiAgQElucHV0KCkgYWN0aXZlVXNlcjogVXNlck1vZGVsXG4gIEBJbnB1dCgpIGlzTGFzdENvbW1lbnQ6IGJvb2xlYW5cbiAgQElucHV0KCkgaXNBZGRVc2VyRmVlZGJhY2tMb2FkaW5nOiBib29sZWFuXG5cbiAgQE91dHB1dCgpIG5ld1VzZXJGZWVkYmFja0Fuc3dlciA9IG5ldyBFdmVudEVtaXR0ZXI8VXNlckZlZWRiYWNrPigpXG5cbiAgaXNBbkFuc3dlciA9IGZhbHNlXG4gIG5ld0Fuc3dlciA9ICcnXG4gIGlzQW5zd2VyRW1wdHkgPSB0cnVlXG5cbiAgbmdPbkluaXQoKTogdm9pZCB7XG4gICAgdGhpcy5pc0FuQW5zd2VyID0gISF0aGlzLnVzZXJGZWVkYmFja1BhcmVudC5wYXJlbnRVdWlkXG4gIH1cblxuICBvbk5ld0Fuc3dlclZhbHVlQ2hhbmdlKCkge1xuICAgIHRoaXMuaXNBbnN3ZXJFbXB0eSA9IHRoaXMubmV3QW5zd2VyLmxlbmd0aCA9PT0gMFxuICB9XG5cbiAgcHVibGlzaE5ld0Fuc3dlcigpIHtcbiAgICBpZiAodGhpcy5uZXdBbnN3ZXIudHJpbSgpID09PSAnJykgcmV0dXJuXG5cbiAgICBjb25zdCBuZXdBbnN3ZXI6IFVzZXJGZWVkYmFjayA9IHtcbiAgICAgIC4uLnRoaXMudXNlckZlZWRiYWNrUGFyZW50LFxuICAgICAgdXVpZDogdW5kZWZpbmVkLFxuICAgICAgcHVibGlzaGVkOiB0cnVlLFxuICAgICAgY29tbWVudDogdGhpcy5uZXdBbnN3ZXIsXG4gICAgICBwYXJlbnRVdWlkOiB0aGlzLnVzZXJGZWVkYmFja1BhcmVudC51dWlkLFxuICAgICAgYXV0aG9yVXNlcklkOiB0aGlzLmFjdGl2ZVVzZXI/LmlkLFxuICAgICAgYXV0aG9yRW1haWw6IHRoaXMuYWN0aXZlVXNlcj8uZW1haWwsXG4gICAgICBkYXRlOiBuZXcgRGF0ZSgpLFxuICAgICAgYXV0aG9yTmFtZTogYCR7dGhpcy5hY3RpdmVVc2VyPy5uYW1lfSAke3RoaXMuYWN0aXZlVXNlcj8uc3VybmFtZX1gLFxuICAgIH1cblxuICAgIHRoaXMubmV3VXNlckZlZWRiYWNrQW5zd2VyLmVtaXQobmV3QW5zd2VyKVxuXG4gICAgdGhpcy5uZXdBbnN3ZXIgPSAnJ1xuICAgIHRoaXMub25OZXdBbnN3ZXJWYWx1ZUNoYW5nZSgpXG4gIH1cbn1cbiIsIjxkaXZcbiAgKm5nSWY9XCJ1c2VyRmVlZGJhY2tQYXJlbnQucHVibGlzaGVkXCJcbiAgY2xhc3M9XCJmbGV4IGZsZXgtY29sIGJnLXdoaXRlIHJvdW5kZWQgdy1mdWxsXCJcbiAgW25nQ2xhc3NdPVwiW2lzQW5BbnN3ZXIgPyAncHMtNCAnIDogJ3AtNCddXCJcbj5cbiAgPGRpdiBjbGFzcz1cImZsZXggZmxleC1yb3dcIj5cbiAgICA8ZGl2IGNsYXNzPVwiYXZhdGFyXCI+XG4gICAgICA8aW1nXG4gICAgICAgIGNsYXNzPVwicm91bmRlZC1mdWxsXCJcbiAgICAgICAgW3NyY109XCJ1c2VyRmVlZGJhY2tQYXJlbnQuYXZhdGFyVXJsXCJcbiAgICAgICAgYWx0PVwiYXZhdGFyXCJcbiAgICAgIC8+XG4gICAgPC9kaXY+XG4gICAgPGRpdiBjbGFzcz1cInAtNCBmbGV4IGZsZXgtY29sXCI+XG4gICAgICA8c3Bhbj57eyB1c2VyRmVlZGJhY2tQYXJlbnQuYXV0aG9yTmFtZSB9fTwvc3Bhbj5cbiAgICAgIDxzcGFuPiB7eyB1c2VyRmVlZGJhY2tQYXJlbnQuZGF0ZSB8IHRpbWVTaW5jZSB9fTwvc3Bhbj5cbiAgICA8L2Rpdj5cbiAgPC9kaXY+XG4gIDxkaXYgZGF0YS1jeT1cImNvbW1lbnRUZXh0XCIgY2xhc3M9XCJtdC00IHdoaXRlc3BhY2UtcHJlLWxpbmVcIj5cbiAgICB7eyB1c2VyRmVlZGJhY2tQYXJlbnQuY29tbWVudCB9fVxuICA8L2Rpdj5cbiAgPGRpdlxuICAgIGNsYXNzPVwidy1mdWxsXCJcbiAgICAqbmdGb3I9XCJsZXQgdXNlckZlZWRCYWNrc0Fuc3dlciBvZiB1c2VyRmVlZEJhY2tzQW5zd2VyczsgbGV0IGxhc3QgPSBsYXN0XCJcbiAgPlxuICAgIDxociBjbGFzcz1cIi1teC00IG15LTZcIiAvPlxuICAgIDxnbi11aS11c2VyLWZlZWRiYWNrLWl0ZW1cbiAgICAgIFt1c2VyRmVlZGJhY2tQYXJlbnRdPVwidXNlckZlZWRCYWNrc0Fuc3dlclwiXG4gICAgICBbaXNMYXN0Q29tbWVudF09XCJsYXN0XCJcbiAgICA+PC9nbi11aS11c2VyLWZlZWRiYWNrLWl0ZW0+XG4gIDwvZGl2PlxuXG4gIDxkaXYgKm5nSWY9XCJhY3RpdmVVc2VyXCIgY2xhc3M9XCJtdC0yIGZsZXggZmxleC1jb2xcIj5cbiAgICA8aHIgY2xhc3M9XCItbXgtNCBteS00XCIgLz5cbiAgICA8ZGl2XG4gICAgICBpZD1cIm5ldy1jb21tZW50LWJ1dHRvbnNcIlxuICAgICAgY2xhc3M9XCJmbGV4IGZsZXgtcm93IGdhcC0yIGl0ZW1zLWNlbnRlciBqdXN0aWZ5LWVuZFwiXG4gICAgPlxuICAgICAgPGduLXVpLXRleHQtYXJlYVxuICAgICAgICBbZGlzYWJsZWRdPVwiaXNBZGRVc2VyRmVlZGJhY2tMb2FkaW5nXCJcbiAgICAgICAgWyh2YWx1ZSldPVwibmV3QW5zd2VyXCJcbiAgICAgICAgKHZhbHVlQ2hhbmdlKT1cIm9uTmV3QW5zd2VyVmFsdWVDaGFuZ2UoKVwiXG4gICAgICAgIChrZXl1cC5jb250cm9sLmVudGVyKT1cInB1Ymxpc2hOZXdBbnN3ZXIoKVwiXG4gICAgICAgIFtwbGFjZWhvbGRlcl09XCJcbiAgICAgICAgICAncmVjb3JkLm1ldGFkYXRhLnVzZXJGZWVkYmFja3MubmV3QW5zd2VyLnBsYWNlaG9sZGVyJyB8IHRyYW5zbGF0ZVxuICAgICAgICBcIlxuICAgICAgICBjbGFzcz1cImdyb3dcIlxuICAgICAgICBleHRyYUNsYXNzPVwiYmctdHJhbnNwYXJlbnQgYm9yZGVyLTAgcGxhY2Vob2xkZXItcHJpbWFyeS1kYXJrZXIgdGV4dC1wcmltYXJ5LWRhcmtlciBoLTlcIlxuICAgICAgPjwvZ24tdWktdGV4dC1hcmVhPlxuICAgICAgPGRpdiAqbmdJZj1cIiFpc0Fuc3dlckVtcHR5XCIgY2xhc3M9XCJmbGV4IGZsZXgtcm93IGp1c3RpZnktZW5kXCI+XG4gICAgICAgIDxnbi11aS1idXR0b25cbiAgICAgICAgICBbZGlzYWJsZWRdPVwiaXNBZGRVc2VyRmVlZGJhY2tMb2FkaW5nXCJcbiAgICAgICAgICBbdHlwZV09XCInb3V0bGluZSdcIlxuICAgICAgICAgIChidXR0b25DbGljayk9XCJwdWJsaXNoTmV3QW5zd2VyKClcIlxuICAgICAgICAgIFt0aXRsZV09XCJcbiAgICAgICAgICAgICdyZWNvcmQubWV0YWRhdGEudXNlckZlZWRiYWNrcy5uZXdBbnN3ZXIuYnV0dG9uVGl0bGUnIHwgdHJhbnNsYXRlXG4gICAgICAgICAgXCJcbiAgICAgICAgICBleHRyYUNsYXNzPVwiIXAtWzAuNWVtXSB0ZXh0LXByaW1hcnktZGFya2VyIGJvcmRlci1wcmltYXJ5LWRhcmtlciBoLTlcIlxuICAgICAgICA+XG4gICAgICAgICAgPG1hdC1pY29uXG4gICAgICAgICAgICBjbGFzcz1cIm1hdGVyaWFsLXN5bWJvbHMtb3V0bGluZWRcIlxuICAgICAgICAgICAgKm5nSWY9XCIhaXNBZGRVc2VyRmVlZGJhY2tMb2FkaW5nXCJcbiAgICAgICAgICA+XG4gICAgICAgICAgICBzZW5kXG4gICAgICAgICAgPC9tYXQtaWNvbj5cbiAgICAgICAgICA8bmctY29udGFpbmVyICpuZ0lmPVwiaXNBZGRVc2VyRmVlZGJhY2tMb2FkaW5nXCI+XG4gICAgICAgICAgICA8ZGl2IGNsYXNzPVwiZmxleCBqdXN0aWZ5LWNlbnRlciB3LWZ1bGxcIj5cbiAgICAgICAgICAgICAgPGduLXVpLXNwaW5uaW5nLWxvYWRlcj48L2duLXVpLXNwaW5uaW5nLWxvYWRlcj5cbiAgICAgICAgICAgIDwvZGl2PlxuICAgICAgICAgIDwvbmctY29udGFpbmVyPlxuICAgICAgICA8L2duLXVpLWJ1dHRvbj5cbiAgICAgIDwvZGl2PlxuICAgIDwvZGl2PlxuICA8L2Rpdj5cbjwvZGl2PlxuIl19
@@ -1,4 +1,5 @@
1
1
  import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output, } from '@angular/core';
2
+ import { FormsModule } from '@angular/forms';
2
3
  import * as i0 from "@angular/core";
3
4
  import * as i1 from "@angular/forms";
4
5
  export class CheckToggleComponent {
@@ -10,11 +11,11 @@ export class CheckToggleComponent {
10
11
  this.toggled.emit(event);
11
12
  }
12
13
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: CheckToggleComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
13
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.7", type: CheckToggleComponent, selector: "gn-ui-check-toggle", inputs: { title: "title", label: "label", value: "value", color: "color" }, outputs: { toggled: "toggled" }, ngImport: i0, template: "<label class=\"inline-flex relative items-start cursor-pointer\" [title]=\"title\">\n <span class=\"shrink-0\">\n <input\n type=\"checkbox\"\n class=\"sr-only peer\"\n [ngModel]=\"value\"\n (ngModelChange)=\"toggle($event)\"\n />\n <div\n class=\"w-11 h-6 bg-gray-200 peer-focus:outline-none peer-focus:ring-2 rounded-full peer-checked:after:translate-x-full peer-checked:after:border-white after:content-[''] after:absolute after:top-[2px] after:left-[2px] after:bg-white after:border-gray-300 after:border after:rounded-full after:h-5 after:w-5 after:transition-all\"\n [class]=\"\n color === 'secondary'\n ? 'peer-focus:ring-secondary-lighter peer-checked:bg-secondary'\n : 'peer-focus:ring-primary-lighter peer-checked:bg-primary'\n \"\n ></div>\n </span>\n <span class=\"ml-3 mt-[2px] text-sm font-medium\">{{ label }}</span>\n</label>\n", styles: [""], dependencies: [{ kind: "directive", type: i1.CheckboxControlValueAccessor, selector: "input[type=checkbox][formControlName],input[type=checkbox][formControl],input[type=checkbox][ngModel]" }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
14
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.7", type: CheckToggleComponent, isStandalone: true, selector: "gn-ui-check-toggle", inputs: { title: "title", label: "label", value: "value", color: "color" }, outputs: { toggled: "toggled" }, ngImport: i0, template: "<label class=\"inline-flex relative items-start cursor-pointer\" [title]=\"title\">\n <span class=\"shrink-0\">\n <input\n type=\"checkbox\"\n class=\"sr-only peer\"\n [ngModel]=\"value\"\n (ngModelChange)=\"toggle($event)\"\n />\n <div\n class=\"w-11 h-6 bg-gray-200 peer-focus:outline-none peer-focus:ring-2 rounded-full peer-checked:after:translate-x-full peer-checked:after:border-white after:content-[''] after:absolute after:top-[2px] after:left-[2px] after:bg-white after:border-gray-300 after:border after:rounded-full after:h-5 after:w-5 after:transition-all\"\n [class]=\"\n color === 'secondary'\n ? 'peer-focus:ring-secondary-lighter peer-checked:bg-secondary'\n : 'peer-focus:ring-primary-lighter peer-checked:bg-primary'\n \"\n ></div>\n </span>\n <span class=\"ml-3 mt-[2px] text-sm font-medium\">{{ label }}</span>\n</label>\n", styles: [""], dependencies: [{ kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i1.CheckboxControlValueAccessor, selector: "input[type=checkbox][formControlName],input[type=checkbox][formControl],input[type=checkbox][ngModel]" }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
14
15
  }
15
16
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: CheckToggleComponent, decorators: [{
16
17
  type: Component,
17
- args: [{ selector: 'gn-ui-check-toggle', changeDetection: ChangeDetectionStrategy.OnPush, template: "<label class=\"inline-flex relative items-start cursor-pointer\" [title]=\"title\">\n <span class=\"shrink-0\">\n <input\n type=\"checkbox\"\n class=\"sr-only peer\"\n [ngModel]=\"value\"\n (ngModelChange)=\"toggle($event)\"\n />\n <div\n class=\"w-11 h-6 bg-gray-200 peer-focus:outline-none peer-focus:ring-2 rounded-full peer-checked:after:translate-x-full peer-checked:after:border-white after:content-[''] after:absolute after:top-[2px] after:left-[2px] after:bg-white after:border-gray-300 after:border after:rounded-full after:h-5 after:w-5 after:transition-all\"\n [class]=\"\n color === 'secondary'\n ? 'peer-focus:ring-secondary-lighter peer-checked:bg-secondary'\n : 'peer-focus:ring-primary-lighter peer-checked:bg-primary'\n \"\n ></div>\n </span>\n <span class=\"ml-3 mt-[2px] text-sm font-medium\">{{ label }}</span>\n</label>\n" }]
18
+ args: [{ selector: 'gn-ui-check-toggle', changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, imports: [FormsModule], template: "<label class=\"inline-flex relative items-start cursor-pointer\" [title]=\"title\">\n <span class=\"shrink-0\">\n <input\n type=\"checkbox\"\n class=\"sr-only peer\"\n [ngModel]=\"value\"\n (ngModelChange)=\"toggle($event)\"\n />\n <div\n class=\"w-11 h-6 bg-gray-200 peer-focus:outline-none peer-focus:ring-2 rounded-full peer-checked:after:translate-x-full peer-checked:after:border-white after:content-[''] after:absolute after:top-[2px] after:left-[2px] after:bg-white after:border-gray-300 after:border after:rounded-full after:h-5 after:w-5 after:transition-all\"\n [class]=\"\n color === 'secondary'\n ? 'peer-focus:ring-secondary-lighter peer-checked:bg-secondary'\n : 'peer-focus:ring-primary-lighter peer-checked:bg-primary'\n \"\n ></div>\n </span>\n <span class=\"ml-3 mt-[2px] text-sm font-medium\">{{ label }}</span>\n</label>\n" }]
18
19
  }], propDecorators: { title: [{
19
20
  type: Input
20
21
  }], label: [{
@@ -26,4 +27,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.7", ngImpor
26
27
  }], toggled: [{
27
28
  type: Output
28
29
  }] } });
29
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hlY2stdG9nZ2xlLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvdWkvaW5wdXRzL3NyYy9saWIvY2hlY2stdG9nZ2xlL2NoZWNrLXRvZ2dsZS5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL3VpL2lucHV0cy9zcmMvbGliL2NoZWNrLXRvZ2dsZS9jaGVjay10b2dnbGUuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUNMLHVCQUF1QixFQUN2QixTQUFTLEVBQ1QsWUFBWSxFQUNaLEtBQUssRUFDTCxNQUFNLEdBQ1AsTUFBTSxlQUFlLENBQUE7OztBQVF0QixNQUFNLE9BQU8sb0JBQW9CO0lBTmpDO1FBVVcsVUFBSyxHQUE0QixTQUFTLENBQUE7UUFDekMsWUFBTyxHQUFHLElBQUksWUFBWSxFQUFFLENBQUE7S0FLdkM7SUFIQyxNQUFNLENBQUMsS0FBWTtRQUNqQixJQUFJLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQTtJQUMxQixDQUFDOzhHQVRVLG9CQUFvQjtrR0FBcEIsb0JBQW9CLHVLQ2RqQyx1NUJBbUJBOzsyRkRMYSxvQkFBb0I7a0JBTmhDLFNBQVM7K0JBQ0Usb0JBQW9CLG1CQUdiLHVCQUF1QixDQUFDLE1BQU07OEJBR3RDLEtBQUs7c0JBQWIsS0FBSztnQkFDRyxLQUFLO3NCQUFiLEtBQUs7Z0JBQ0csS0FBSztzQkFBYixLQUFLO2dCQUNHLEtBQUs7c0JBQWIsS0FBSztnQkFDSSxPQUFPO3NCQUFoQixNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksXG4gIENvbXBvbmVudCxcbiAgRXZlbnRFbWl0dGVyLFxuICBJbnB1dCxcbiAgT3V0cHV0LFxufSBmcm9tICdAYW5ndWxhci9jb3JlJ1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdnbi11aS1jaGVjay10b2dnbGUnLFxuICB0ZW1wbGF0ZVVybDogJy4vY2hlY2stdG9nZ2xlLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vY2hlY2stdG9nZ2xlLmNvbXBvbmVudC5jc3MnXSxcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG59KVxuZXhwb3J0IGNsYXNzIENoZWNrVG9nZ2xlQ29tcG9uZW50IHtcbiAgQElucHV0KCkgdGl0bGU6IHN0cmluZ1xuICBASW5wdXQoKSBsYWJlbDogc3RyaW5nXG4gIEBJbnB1dCgpIHZhbHVlOiBib29sZWFuXG4gIEBJbnB1dCgpIGNvbG9yOiAncHJpbWFyeScgfCAnc2Vjb25kYXJ5JyA9ICdwcmltYXJ5J1xuICBAT3V0cHV0KCkgdG9nZ2xlZCA9IG5ldyBFdmVudEVtaXR0ZXIoKVxuXG4gIHRvZ2dsZShldmVudDogRXZlbnQpIHtcbiAgICB0aGlzLnRvZ2dsZWQuZW1pdChldmVudClcbiAgfVxufVxuIiwiPGxhYmVsIGNsYXNzPVwiaW5saW5lLWZsZXggcmVsYXRpdmUgaXRlbXMtc3RhcnQgY3Vyc29yLXBvaW50ZXJcIiBbdGl0bGVdPVwidGl0bGVcIj5cbiAgPHNwYW4gY2xhc3M9XCJzaHJpbmstMFwiPlxuICAgIDxpbnB1dFxuICAgICAgdHlwZT1cImNoZWNrYm94XCJcbiAgICAgIGNsYXNzPVwic3Itb25seSBwZWVyXCJcbiAgICAgIFtuZ01vZGVsXT1cInZhbHVlXCJcbiAgICAgIChuZ01vZGVsQ2hhbmdlKT1cInRvZ2dsZSgkZXZlbnQpXCJcbiAgICAvPlxuICAgIDxkaXZcbiAgICAgIGNsYXNzPVwidy0xMSBoLTYgYmctZ3JheS0yMDAgcGVlci1mb2N1czpvdXRsaW5lLW5vbmUgcGVlci1mb2N1czpyaW5nLTIgcm91bmRlZC1mdWxsIHBlZXItY2hlY2tlZDphZnRlcjp0cmFuc2xhdGUteC1mdWxsIHBlZXItY2hlY2tlZDphZnRlcjpib3JkZXItd2hpdGUgYWZ0ZXI6Y29udGVudC1bJyddIGFmdGVyOmFic29sdXRlIGFmdGVyOnRvcC1bMnB4XSBhZnRlcjpsZWZ0LVsycHhdIGFmdGVyOmJnLXdoaXRlIGFmdGVyOmJvcmRlci1ncmF5LTMwMCBhZnRlcjpib3JkZXIgYWZ0ZXI6cm91bmRlZC1mdWxsIGFmdGVyOmgtNSBhZnRlcjp3LTUgYWZ0ZXI6dHJhbnNpdGlvbi1hbGxcIlxuICAgICAgW2NsYXNzXT1cIlxuICAgICAgICBjb2xvciA9PT0gJ3NlY29uZGFyeSdcbiAgICAgICAgICA/ICdwZWVyLWZvY3VzOnJpbmctc2Vjb25kYXJ5LWxpZ2h0ZXIgcGVlci1jaGVja2VkOmJnLXNlY29uZGFyeSdcbiAgICAgICAgICA6ICdwZWVyLWZvY3VzOnJpbmctcHJpbWFyeS1saWdodGVyIHBlZXItY2hlY2tlZDpiZy1wcmltYXJ5J1xuICAgICAgXCJcbiAgICA+PC9kaXY+XG4gIDwvc3Bhbj5cbiAgPHNwYW4gY2xhc3M9XCJtbC0zIG10LVsycHhdIHRleHQtc20gZm9udC1tZWRpdW1cIj57eyBsYWJlbCB9fTwvc3Bhbj5cbjwvbGFiZWw+XG4iXX0=
30
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hlY2stdG9nZ2xlLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvdWkvaW5wdXRzL3NyYy9saWIvY2hlY2stdG9nZ2xlL2NoZWNrLXRvZ2dsZS5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL3VpL2lucHV0cy9zcmMvbGliL2NoZWNrLXRvZ2dsZS9jaGVjay10b2dnbGUuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUNMLHVCQUF1QixFQUN2QixTQUFTLEVBQ1QsWUFBWSxFQUNaLEtBQUssRUFDTCxNQUFNLEdBQ1AsTUFBTSxlQUFlLENBQUE7QUFDdEIsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLGdCQUFnQixDQUFBOzs7QUFVNUMsTUFBTSxPQUFPLG9CQUFvQjtJQVJqQztRQVlXLFVBQUssR0FBNEIsU0FBUyxDQUFBO1FBQ3pDLFlBQU8sR0FBRyxJQUFJLFlBQVksRUFBRSxDQUFBO0tBS3ZDO0lBSEMsTUFBTSxDQUFDLEtBQVk7UUFDakIsSUFBSSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUE7SUFDMUIsQ0FBQzs4R0FUVSxvQkFBb0I7a0dBQXBCLG9CQUFvQiwyTENqQmpDLHU1QkFtQkEseURESlksV0FBVzs7MkZBRVYsb0JBQW9CO2tCQVJoQyxTQUFTOytCQUNFLG9CQUFvQixtQkFHYix1QkFBdUIsQ0FBQyxNQUFNLGNBQ25DLElBQUksV0FDUCxDQUFDLFdBQVcsQ0FBQzs4QkFHYixLQUFLO3NCQUFiLEtBQUs7Z0JBQ0csS0FBSztzQkFBYixLQUFLO2dCQUNHLEtBQUs7c0JBQWIsS0FBSztnQkFDRyxLQUFLO3NCQUFiLEtBQUs7Z0JBQ0ksT0FBTztzQkFBaEIsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIENoYW5nZURldGVjdGlvblN0cmF0ZWd5LFxuICBDb21wb25lbnQsXG4gIEV2ZW50RW1pdHRlcixcbiAgSW5wdXQsXG4gIE91dHB1dCxcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSdcbmltcG9ydCB7IEZvcm1zTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnXG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2duLXVpLWNoZWNrLXRvZ2dsZScsXG4gIHRlbXBsYXRlVXJsOiAnLi9jaGVjay10b2dnbGUuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi9jaGVjay10b2dnbGUuY29tcG9uZW50LmNzcyddLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgaW1wb3J0czogW0Zvcm1zTW9kdWxlXSxcbn0pXG5leHBvcnQgY2xhc3MgQ2hlY2tUb2dnbGVDb21wb25lbnQge1xuICBASW5wdXQoKSB0aXRsZTogc3RyaW5nXG4gIEBJbnB1dCgpIGxhYmVsOiBzdHJpbmdcbiAgQElucHV0KCkgdmFsdWU6IGJvb2xlYW5cbiAgQElucHV0KCkgY29sb3I6ICdwcmltYXJ5JyB8ICdzZWNvbmRhcnknID0gJ3ByaW1hcnknXG4gIEBPdXRwdXQoKSB0b2dnbGVkID0gbmV3IEV2ZW50RW1pdHRlcigpXG5cbiAgdG9nZ2xlKGV2ZW50OiBFdmVudCkge1xuICAgIHRoaXMudG9nZ2xlZC5lbWl0KGV2ZW50KVxuICB9XG59XG4iLCI8bGFiZWwgY2xhc3M9XCJpbmxpbmUtZmxleCByZWxhdGl2ZSBpdGVtcy1zdGFydCBjdXJzb3ItcG9pbnRlclwiIFt0aXRsZV09XCJ0aXRsZVwiPlxuICA8c3BhbiBjbGFzcz1cInNocmluay0wXCI+XG4gICAgPGlucHV0XG4gICAgICB0eXBlPVwiY2hlY2tib3hcIlxuICAgICAgY2xhc3M9XCJzci1vbmx5IHBlZXJcIlxuICAgICAgW25nTW9kZWxdPVwidmFsdWVcIlxuICAgICAgKG5nTW9kZWxDaGFuZ2UpPVwidG9nZ2xlKCRldmVudClcIlxuICAgIC8+XG4gICAgPGRpdlxuICAgICAgY2xhc3M9XCJ3LTExIGgtNiBiZy1ncmF5LTIwMCBwZWVyLWZvY3VzOm91dGxpbmUtbm9uZSBwZWVyLWZvY3VzOnJpbmctMiByb3VuZGVkLWZ1bGwgcGVlci1jaGVja2VkOmFmdGVyOnRyYW5zbGF0ZS14LWZ1bGwgcGVlci1jaGVja2VkOmFmdGVyOmJvcmRlci13aGl0ZSBhZnRlcjpjb250ZW50LVsnJ10gYWZ0ZXI6YWJzb2x1dGUgYWZ0ZXI6dG9wLVsycHhdIGFmdGVyOmxlZnQtWzJweF0gYWZ0ZXI6Ymctd2hpdGUgYWZ0ZXI6Ym9yZGVyLWdyYXktMzAwIGFmdGVyOmJvcmRlciBhZnRlcjpyb3VuZGVkLWZ1bGwgYWZ0ZXI6aC01IGFmdGVyOnctNSBhZnRlcjp0cmFuc2l0aW9uLWFsbFwiXG4gICAgICBbY2xhc3NdPVwiXG4gICAgICAgIGNvbG9yID09PSAnc2Vjb25kYXJ5J1xuICAgICAgICAgID8gJ3BlZXItZm9jdXM6cmluZy1zZWNvbmRhcnktbGlnaHRlciBwZWVyLWNoZWNrZWQ6Ymctc2Vjb25kYXJ5J1xuICAgICAgICAgIDogJ3BlZXItZm9jdXM6cmluZy1wcmltYXJ5LWxpZ2h0ZXIgcGVlci1jaGVja2VkOmJnLXByaW1hcnknXG4gICAgICBcIlxuICAgID48L2Rpdj5cbiAgPC9zcGFuPlxuICA8c3BhbiBjbGFzcz1cIm1sLTMgbXQtWzJweF0gdGV4dC1zbSBmb250LW1lZGl1bVwiPnt7IGxhYmVsIH19PC9zcGFuPlxuPC9sYWJlbD5cbiJdfQ==