geonetwork-ui 2.7.0-dev.76c515d5b → 2.7.0-dev.816935147

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 (31) hide show
  1. package/esm2022/libs/common/domain/src/lib/model/record/metadata.model.mjs +11 -1
  2. package/esm2022/libs/ui/elements/src/lib/api-card/api-card.component.mjs +3 -3
  3. package/esm2022/libs/ui/elements/src/lib/metadata-quality/metadata-quality.component.mjs +1 -4
  4. package/esm2022/libs/util/shared/src/lib/record/quality-score.util.mjs +4 -5
  5. package/esm2022/translations/de.json +10 -0
  6. package/esm2022/translations/en.json +10 -0
  7. package/esm2022/translations/es.json +10 -0
  8. package/esm2022/translations/fr.json +10 -0
  9. package/esm2022/translations/it.json +10 -0
  10. package/esm2022/translations/nl.json +10 -0
  11. package/esm2022/translations/pt.json +10 -0
  12. package/esm2022/translations/sk.json +10 -0
  13. package/fesm2022/geonetwork-ui.mjs +106 -19
  14. package/fesm2022/geonetwork-ui.mjs.map +1 -1
  15. package/libs/common/domain/src/lib/model/record/metadata.model.d.ts.map +1 -1
  16. package/libs/ui/elements/src/lib/metadata-quality/metadata-quality.component.d.ts +0 -1
  17. package/libs/ui/elements/src/lib/metadata-quality/metadata-quality.component.d.ts.map +1 -1
  18. package/libs/util/shared/src/lib/record/quality-score.util.d.ts.map +1 -1
  19. package/package.json +11 -10
  20. package/src/libs/common/domain/src/lib/model/record/metadata.model.ts +11 -0
  21. package/src/libs/ui/elements/src/lib/api-card/api-card.component.html +4 -1
  22. package/src/libs/ui/elements/src/lib/metadata-quality/metadata-quality.component.ts +0 -4
  23. package/src/libs/util/shared/src/lib/record/quality-score.util.ts +3 -7
  24. package/translations/de.json +10 -0
  25. package/translations/en.json +10 -0
  26. package/translations/es.json +10 -0
  27. package/translations/fr.json +10 -0
  28. package/translations/it.json +10 -0
  29. package/translations/nl.json +10 -0
  30. package/translations/pt.json +10 -0
  31. package/translations/sk.json +10 -0
@@ -908,6 +908,16 @@ const RecordStatusValues = [
908
908
  'planned',
909
909
  'required',
910
910
  ];
911
+ marker('record.metadata.api.accessServiceProtocol.wms');
912
+ marker('record.metadata.api.accessServiceProtocol.wfs');
913
+ marker('record.metadata.api.accessServiceProtocol.wps');
914
+ marker('record.metadata.api.accessServiceProtocol.wmts');
915
+ marker('record.metadata.api.accessServiceProtocol.esriRest');
916
+ marker('record.metadata.api.accessServiceProtocol.ogcFeatures');
917
+ marker('record.metadata.api.accessServiceProtocol.GPFDL');
918
+ marker('record.metadata.api.accessServiceProtocol.tms');
919
+ marker('record.metadata.api.accessServiceProtocol.maplibre-style');
920
+ marker('record.metadata.api.accessServiceProtocol.other');
911
921
 
912
922
  function getUpdateFrequencyFromFrequencyCode(frequencyCode) {
913
923
  return frequencyCode &&
@@ -19086,6 +19096,16 @@ var de = {
19086
19096
  "record.kind.service": "",
19087
19097
  "record.metadata.about": "Beschreibung",
19088
19098
  "record.metadata.api": "API",
19099
+ "record.metadata.api.accessServiceProtocol.GPFDL": "",
19100
+ "record.metadata.api.accessServiceProtocol.esriRest": "",
19101
+ "record.metadata.api.accessServiceProtocol.maplibre-style": "",
19102
+ "record.metadata.api.accessServiceProtocol.ogcFeatures": "",
19103
+ "record.metadata.api.accessServiceProtocol.other": "",
19104
+ "record.metadata.api.accessServiceProtocol.tms": "",
19105
+ "record.metadata.api.accessServiceProtocol.wfs": "",
19106
+ "record.metadata.api.accessServiceProtocol.wms": "",
19107
+ "record.metadata.api.accessServiceProtocol.wmts": "",
19108
+ "record.metadata.api.accessServiceProtocol.wps": "",
19089
19109
  "record.metadata.api.form.closeButton": "Schließen",
19090
19110
  "record.metadata.api.form.closeForm": "Formular schließen",
19091
19111
  "record.metadata.api.form.create": "Ihre Anfrage erstellen",
@@ -19704,6 +19724,16 @@ var en = {
19704
19724
  "record.kind.service": "Service",
19705
19725
  "record.metadata.about": "Description",
19706
19726
  "record.metadata.api": "API",
19727
+ "record.metadata.api.accessServiceProtocol.GPFDL": "GPFDL",
19728
+ "record.metadata.api.accessServiceProtocol.esriRest": "esriRest",
19729
+ "record.metadata.api.accessServiceProtocol.maplibre-style": "maplibre-style",
19730
+ "record.metadata.api.accessServiceProtocol.ogcFeatures": "ogcFeatures",
19731
+ "record.metadata.api.accessServiceProtocol.other": "other",
19732
+ "record.metadata.api.accessServiceProtocol.tms": "tms",
19733
+ "record.metadata.api.accessServiceProtocol.wfs": "wfs",
19734
+ "record.metadata.api.accessServiceProtocol.wms": "wms",
19735
+ "record.metadata.api.accessServiceProtocol.wmts": "wmts",
19736
+ "record.metadata.api.accessServiceProtocol.wps": "wps",
19707
19737
  "record.metadata.api.form.closeButton": "Close",
19708
19738
  "record.metadata.api.form.closeForm": "Close the form",
19709
19739
  "record.metadata.api.form.create": "Create your request",
@@ -20322,6 +20352,16 @@ var es = {
20322
20352
  "record.kind.service": "",
20323
20353
  "record.metadata.about": "",
20324
20354
  "record.metadata.api": "",
20355
+ "record.metadata.api.accessServiceProtocol.GPFDL": "",
20356
+ "record.metadata.api.accessServiceProtocol.esriRest": "",
20357
+ "record.metadata.api.accessServiceProtocol.maplibre-style": "",
20358
+ "record.metadata.api.accessServiceProtocol.ogcFeatures": "",
20359
+ "record.metadata.api.accessServiceProtocol.other": "",
20360
+ "record.metadata.api.accessServiceProtocol.tms": "",
20361
+ "record.metadata.api.accessServiceProtocol.wfs": "",
20362
+ "record.metadata.api.accessServiceProtocol.wms": "",
20363
+ "record.metadata.api.accessServiceProtocol.wmts": "",
20364
+ "record.metadata.api.accessServiceProtocol.wps": "",
20325
20365
  "record.metadata.api.form.closeButton": "",
20326
20366
  "record.metadata.api.form.closeForm": "",
20327
20367
  "record.metadata.api.form.create": "",
@@ -20940,6 +20980,16 @@ var fr = {
20940
20980
  "record.kind.service": "Service",
20941
20981
  "record.metadata.about": "A propos",
20942
20982
  "record.metadata.api": "API",
20983
+ "record.metadata.api.accessServiceProtocol.GPFDL": "",
20984
+ "record.metadata.api.accessServiceProtocol.esriRest": "",
20985
+ "record.metadata.api.accessServiceProtocol.maplibre-style": "",
20986
+ "record.metadata.api.accessServiceProtocol.ogcFeatures": "",
20987
+ "record.metadata.api.accessServiceProtocol.other": "autre",
20988
+ "record.metadata.api.accessServiceProtocol.tms": "",
20989
+ "record.metadata.api.accessServiceProtocol.wfs": "",
20990
+ "record.metadata.api.accessServiceProtocol.wms": "",
20991
+ "record.metadata.api.accessServiceProtocol.wmts": "",
20992
+ "record.metadata.api.accessServiceProtocol.wps": "",
20943
20993
  "record.metadata.api.form.closeButton": "Fermer",
20944
20994
  "record.metadata.api.form.closeForm": "Fermer le panneau de personnalisation",
20945
20995
  "record.metadata.api.form.create": "Paramétrer votre requête",
@@ -21558,6 +21608,16 @@ var it = {
21558
21608
  "record.kind.service": "Servizio",
21559
21609
  "record.metadata.about": "Descrizione",
21560
21610
  "record.metadata.api": "API",
21611
+ "record.metadata.api.accessServiceProtocol.GPFDL": "",
21612
+ "record.metadata.api.accessServiceProtocol.esriRest": "",
21613
+ "record.metadata.api.accessServiceProtocol.maplibre-style": "",
21614
+ "record.metadata.api.accessServiceProtocol.ogcFeatures": "",
21615
+ "record.metadata.api.accessServiceProtocol.other": "",
21616
+ "record.metadata.api.accessServiceProtocol.tms": "",
21617
+ "record.metadata.api.accessServiceProtocol.wfs": "",
21618
+ "record.metadata.api.accessServiceProtocol.wms": "",
21619
+ "record.metadata.api.accessServiceProtocol.wmts": "",
21620
+ "record.metadata.api.accessServiceProtocol.wps": "",
21561
21621
  "record.metadata.api.form.closeButton": "Chiude",
21562
21622
  "record.metadata.api.form.closeForm": "Chiude il pannello di personalizzazione",
21563
21623
  "record.metadata.api.form.create": "Configura la sua richiesta",
@@ -22176,6 +22236,16 @@ var nl = {
22176
22236
  "record.kind.service": "",
22177
22237
  "record.metadata.about": "",
22178
22238
  "record.metadata.api": "",
22239
+ "record.metadata.api.accessServiceProtocol.GPFDL": "",
22240
+ "record.metadata.api.accessServiceProtocol.esriRest": "",
22241
+ "record.metadata.api.accessServiceProtocol.maplibre-style": "",
22242
+ "record.metadata.api.accessServiceProtocol.ogcFeatures": "",
22243
+ "record.metadata.api.accessServiceProtocol.other": "",
22244
+ "record.metadata.api.accessServiceProtocol.tms": "",
22245
+ "record.metadata.api.accessServiceProtocol.wfs": "",
22246
+ "record.metadata.api.accessServiceProtocol.wms": "",
22247
+ "record.metadata.api.accessServiceProtocol.wmts": "",
22248
+ "record.metadata.api.accessServiceProtocol.wps": "",
22179
22249
  "record.metadata.api.form.closeButton": "",
22180
22250
  "record.metadata.api.form.closeForm": "",
22181
22251
  "record.metadata.api.form.create": "",
@@ -22794,6 +22864,16 @@ var pt = {
22794
22864
  "record.kind.service": "",
22795
22865
  "record.metadata.about": "",
22796
22866
  "record.metadata.api": "",
22867
+ "record.metadata.api.accessServiceProtocol.GPFDL": "",
22868
+ "record.metadata.api.accessServiceProtocol.esriRest": "",
22869
+ "record.metadata.api.accessServiceProtocol.maplibre-style": "",
22870
+ "record.metadata.api.accessServiceProtocol.ogcFeatures": "",
22871
+ "record.metadata.api.accessServiceProtocol.other": "",
22872
+ "record.metadata.api.accessServiceProtocol.tms": "",
22873
+ "record.metadata.api.accessServiceProtocol.wfs": "",
22874
+ "record.metadata.api.accessServiceProtocol.wms": "",
22875
+ "record.metadata.api.accessServiceProtocol.wmts": "",
22876
+ "record.metadata.api.accessServiceProtocol.wps": "",
22797
22877
  "record.metadata.api.form.closeButton": "",
22798
22878
  "record.metadata.api.form.closeForm": "",
22799
22879
  "record.metadata.api.form.create": "",
@@ -23412,6 +23492,16 @@ var sk = {
23412
23492
  "record.kind.service": "",
23413
23493
  "record.metadata.about": "O",
23414
23494
  "record.metadata.api": "API",
23495
+ "record.metadata.api.accessServiceProtocol.GPFDL": "",
23496
+ "record.metadata.api.accessServiceProtocol.esriRest": "",
23497
+ "record.metadata.api.accessServiceProtocol.maplibre-style": "",
23498
+ "record.metadata.api.accessServiceProtocol.ogcFeatures": "",
23499
+ "record.metadata.api.accessServiceProtocol.other": "",
23500
+ "record.metadata.api.accessServiceProtocol.tms": "",
23501
+ "record.metadata.api.accessServiceProtocol.wfs": "",
23502
+ "record.metadata.api.accessServiceProtocol.wms": "",
23503
+ "record.metadata.api.accessServiceProtocol.wmts": "",
23504
+ "record.metadata.api.accessServiceProtocol.wps": "",
23415
23505
  "record.metadata.api.form.closeButton": "Zavrieť",
23416
23506
  "record.metadata.api.form.closeForm": "Zavrieť formulár",
23417
23507
  "record.metadata.api.form.create": "Vytvoriť požiadavku",
@@ -25064,7 +25154,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
25064
25154
  }] } });
25065
25155
 
25066
25156
  var name = "geonetwork-ui";
25067
- var version = "2.7.0-dev.76c515d5b";
25157
+ var version = "2.7.0-dev.816935147";
25068
25158
  var engines = {
25069
25159
  node: ">=20"
25070
25160
  };
@@ -25097,27 +25187,28 @@ var peerDependencies = {
25097
25187
  "@ngrx/operators": "18.x",
25098
25188
  "@ngx-translate/core": "16.x",
25099
25189
  "@ngx-translate/http-loader": "16.x",
25190
+ "flag-icons": "^7.3.2",
25100
25191
  rxjs: "7.x",
25101
25192
  "zone.js": "*",
25102
25193
  tailwindcss: "3.x"
25103
25194
  };
25104
25195
  var dependencies = {
25105
- "@biesbjerg/ngx-translate-extract-marker": "^1.0.0",
25106
- "@camptocamp/ogc-client": "1.1.1-dev.3e2d3cc",
25107
- "@geospatial-sdk/core": "0.0.5-dev.31",
25108
- "@geospatial-sdk/geocoding": "0.0.5-dev.31",
25109
- "@geospatial-sdk/legend": "0.0.5-dev.31",
25110
- "@geospatial-sdk/openlayers": "0.0.5-dev.31",
25196
+ "@biesbjerg/ngx-translate-extract-marker": "~1.0.0",
25197
+ "@camptocamp/ogc-client": "1.2.1-dev.b1a75df",
25198
+ "@geospatial-sdk/core": "0.0.5-dev.37",
25199
+ "@geospatial-sdk/geocoding": "0.0.5-dev.37",
25200
+ "@geospatial-sdk/legend": "0.0.5-dev.37",
25201
+ "@geospatial-sdk/openlayers": "0.0.5-dev.37",
25111
25202
  "@ltd/j-toml": "~1.35.2",
25112
25203
  "@messageformat/core": "^3.0.1",
25113
25204
  "@ng-icons/core": "29.10.0",
25114
25205
  "@ng-icons/iconoir": "29.10.0",
25115
25206
  "@ng-icons/material-icons": "29.10.0",
25116
25207
  "@ng-icons/tabler-icons": "29.10.0",
25117
- "@nx/angular": "20.2.2",
25208
+ "@nx/angular": "20.3.4",
25118
25209
  "@rgrove/parse-xml": "4.2.0",
25119
25210
  alasql: "4.6.0",
25120
- axios: "1.8.2",
25211
+ axios: "1.8.4",
25121
25212
  basiclightbox: "^5.0.4",
25122
25213
  "chart.js": "4.4.7",
25123
25214
  "chroma-js": "3.1.2",
@@ -25144,7 +25235,7 @@ var dependencies = {
25144
25235
  tslib: "^2.3.0",
25145
25236
  typeorm: "^0.3.14",
25146
25237
  "whatwg-fetch": "^3.6.2",
25147
- xlsx: "https://cdn.sheetjs.com/xlsx-0.20.2/xlsx-0.20.2.tgz"
25238
+ xlsx: "https://cdn.sheetjs.com/xlsx-0.20.3/xlsx-0.20.3.tgz"
25148
25239
  };
25149
25240
  var packageJson = {
25150
25241
  name: name,
@@ -25172,7 +25263,6 @@ const ValidatorMapper = {
25172
25263
  updateFrequency: (record) => !!record?.updateFrequency,
25173
25264
  topics: (record) => (record?.topics?.length ?? 0) > 0,
25174
25265
  organisation: (record) => !!record?.contacts?.[0]?.organization?.name,
25175
- capabilities: (record) => record?.onlineResources?.some((resource) => resource?.url?.href.toLowerCase().includes('capabilities')),
25176
25266
  source: (record) => !!record?.extras?.sourcesIdentifiers,
25177
25267
  };
25178
25268
  function getAllKeysValidator() {
@@ -25188,12 +25278,12 @@ function getMappersFromKind(kind) {
25188
25278
  'contacts',
25189
25279
  ];
25190
25280
  switch (kind) {
25191
- case 'service':
25192
- kindKeys = ['capabilities'];
25193
- break;
25194
25281
  case 'reuse':
25195
25282
  kindKeys = ['topics', 'organisation', 'source'];
25196
25283
  break;
25284
+ case 'service':
25285
+ kindKeys = [];
25286
+ break;
25197
25287
  case 'dataset':
25198
25288
  default:
25199
25289
  kindKeys = ['updateFrequency', 'topics', 'organisation'];
@@ -32170,9 +32260,6 @@ class MetadataQualityComponent {
32170
32260
  get computedQualityScore() {
32171
32261
  return Math.round((this.items.filter(({ value }) => value).length * 100) / this.items.length);
32172
32262
  }
32173
- hasGetCapabilities(url) {
32174
- return url.toLowerCase().includes('capabilities');
32175
- }
32176
32263
  initialize() {
32177
32264
  if (!this.propsToValidate) {
32178
32265
  this.propsToValidate = getAllKeysValidator();
@@ -32569,7 +32656,7 @@ class ApiCardComponent {
32569
32656
  }
32570
32657
  }
32571
32658
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ApiCardComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
32572
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: ApiCardComponent, isStandalone: true, selector: "gn-ui-api-card", inputs: { link: "link", currentLink: "currentLink", size: "size" }, outputs: { openRecordApiForm: "openRecordApiForm" }, usesOnChanges: true, ngImport: i0, template: "<div\n class=\"group flex justify-between rounded filter overflow-hidden card-shadow\"\n [ngClass]=\"cardClass\"\n>\n <ng-container *ngIf=\"size !== 'S'\">\n <div class=\"flex-1 min-w-0\">\n <ng-container *ngTemplateOutlet=\"content\"></ng-container>\n </div>\n <div class=\"flex items-center min-w-[32px]\">\n <ng-container *ngTemplateOutlet=\"buttons\"></ng-container>\n </div>\n </ng-container>\n <ng-container *ngIf=\"size === 'S'\">\n <ng-container *ngTemplateOutlet=\"content\"></ng-container>\n </ng-container>\n</div>\n\n<ng-template #buttons>\n <div class=\"flex flex-row gap-2\">\n <gn-ui-copy-text-button\n [text]=\"link.url\"\n [tooltipText]=\"'tooltip.url.copy' | translate\"\n [displayText]=\"false\"\n class=\"border border-gray-300 rounded-lg pt-1 px-2 h-[34px]\"\n ></gn-ui-copy-text-button>\n <button\n *ngIf=\"displayApiFormButton\"\n type=\"button\"\n class=\"gn-ui-card-icon\"\n [ngClass]=\"{\n 'py-2 px-4 rounded-r-md bg-gray-400 hover:bg-gray-600 focus:bg-gray-800 text-white':\n displayText,\n }\"\n [matTooltip]=\"\n !currentlyActive\n ? ('record.metadata.api.form.openForm' | translate)\n : ('record.metadata.api.form.closeForm' | translate)\n \"\n matTooltipPosition=\"above\"\n (click)=\"openRecordApiFormPanel()\"\n >\n <ng-icon\n class=\"pointer-events-none align-middle card-icon\"\n name=\"iconoirSettings\"\n [ngClass]=\"{\n 'text-secondary opacity-100': currentlyActive,\n }\"\n ></ng-icon>\n </button>\n </div>\n</ng-template>\n\n<ng-template #content>\n <div class=\"flex-1 min-w-0\">\n <div class=\"gn-ui-card-title\">\n {{ link.description || link.name }}\n </div>\n <div class=\"gn-ui-card-detail\">\n {{ link.name }}\n </div>\n </div>\n <div class=\"flex flex-row justify-between\">\n <div class=\"flex flex-row gap-2.5 items-center pt-1\">\n <span\n *ngIf=\"link.accessServiceProtocol !== 'GPFDL'\"\n class=\"bg-primary-opacity-50 uppercase inline-flex items-center justify-center px-2 py-1 text-13 font-medium leading-none text-white rounded text-primary-lightest group-hover:bg-primary transition-colors\"\n [ngClass]=\"{\n '!bg-primary': currentlyActive,\n }\"\n >{{ link.accessServiceProtocol }}</span\n >\n <span\n *ngIf=\"link.accessServiceProtocol === 'GPFDL'\"\n class=\"bg-primary-opacity-50 uppercase inline-flex items-center justify-center px-2 py-1 text-13 font-medium leading-none text-white rounded text-primary-lightest group-hover:bg-primary transition-colors\"\n [ngClass]=\"{\n '!bg-primary': currentlyActive,\n }\"\n translate\n >\n record.metadata.api.gpfdl</span\n >\n </div>\n <div *ngIf=\"size === 'S'\">\n <ng-container *ngTemplateOutlet=\"buttons\"></ng-container>\n </div>\n </div>\n</ng-template>\n", styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1$2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1$2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1$2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: CopyTextButtonComponent, selector: "gn-ui-copy-text-button", inputs: ["text", "tooltipText", "displayText", "rows"] }, { kind: "directive", type: TranslateDirective, selector: "[translate],[ngx-translate]", inputs: ["translate", "translateParams"] }, { kind: "pipe", type: TranslatePipe, name: "translate" }, { kind: "ngmodule", type: MatTooltipModule }, { kind: "directive", type: i2$2.MatTooltip, selector: "[matTooltip]", inputs: ["matTooltipPosition", "matTooltipPositionAtOrigin", "matTooltipDisabled", "matTooltipShowDelay", "matTooltipHideDelay", "matTooltipTouchGestures", "matTooltip", "matTooltipClass"], exportAs: ["matTooltip"] }, { kind: "component", type: NgIcon, selector: "ng-icon", inputs: ["name", "svg", "size", "strokeWidth", "color"] }], viewProviders: [
32659
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: ApiCardComponent, isStandalone: true, selector: "gn-ui-api-card", inputs: { link: "link", currentLink: "currentLink", size: "size" }, outputs: { openRecordApiForm: "openRecordApiForm" }, usesOnChanges: true, ngImport: i0, template: "<div\n class=\"group flex justify-between rounded filter overflow-hidden card-shadow\"\n [ngClass]=\"cardClass\"\n>\n <ng-container *ngIf=\"size !== 'S'\">\n <div class=\"flex-1 min-w-0\">\n <ng-container *ngTemplateOutlet=\"content\"></ng-container>\n </div>\n <div class=\"flex items-center min-w-[32px]\">\n <ng-container *ngTemplateOutlet=\"buttons\"></ng-container>\n </div>\n </ng-container>\n <ng-container *ngIf=\"size === 'S'\">\n <ng-container *ngTemplateOutlet=\"content\"></ng-container>\n </ng-container>\n</div>\n\n<ng-template #buttons>\n <div class=\"flex flex-row gap-2\">\n <gn-ui-copy-text-button\n [text]=\"link.url\"\n [tooltipText]=\"'tooltip.url.copy' | translate\"\n [displayText]=\"false\"\n class=\"border border-gray-300 rounded-lg pt-1 px-2 h-[34px]\"\n ></gn-ui-copy-text-button>\n <button\n *ngIf=\"displayApiFormButton\"\n type=\"button\"\n class=\"gn-ui-card-icon\"\n [ngClass]=\"{\n 'py-2 px-4 rounded-r-md bg-gray-400 hover:bg-gray-600 focus:bg-gray-800 text-white':\n displayText,\n }\"\n [matTooltip]=\"\n !currentlyActive\n ? ('record.metadata.api.form.openForm' | translate)\n : ('record.metadata.api.form.closeForm' | translate)\n \"\n matTooltipPosition=\"above\"\n (click)=\"openRecordApiFormPanel()\"\n >\n <ng-icon\n class=\"pointer-events-none align-middle card-icon\"\n name=\"iconoirSettings\"\n [ngClass]=\"{\n 'text-secondary opacity-100': currentlyActive,\n }\"\n ></ng-icon>\n </button>\n </div>\n</ng-template>\n\n<ng-template #content>\n <div class=\"flex-1 min-w-0\">\n <div class=\"gn-ui-card-title\">\n {{ link.description || link.name }}\n </div>\n <div class=\"gn-ui-card-detail\">\n {{ link.name }}\n </div>\n </div>\n <div class=\"flex flex-row justify-between\">\n <div class=\"flex flex-row gap-2.5 items-center pt-1\">\n <span\n *ngIf=\"link.accessServiceProtocol !== 'GPFDL'\"\n class=\"bg-primary-opacity-50 uppercase inline-flex items-center justify-center px-2 py-1 text-13 font-medium leading-none text-white rounded text-primary-lightest group-hover:bg-primary transition-colors\"\n [ngClass]=\"{\n '!bg-primary': currentlyActive,\n }\"\n translate\n >record.metadata.api.accessServiceProtocol.{{\n link.accessServiceProtocol\n }}</span\n >\n <span\n *ngIf=\"link.accessServiceProtocol === 'GPFDL'\"\n class=\"bg-primary-opacity-50 uppercase inline-flex items-center justify-center px-2 py-1 text-13 font-medium leading-none text-white rounded text-primary-lightest group-hover:bg-primary transition-colors\"\n [ngClass]=\"{\n '!bg-primary': currentlyActive,\n }\"\n translate\n >\n record.metadata.api.gpfdl</span\n >\n </div>\n <div *ngIf=\"size === 'S'\">\n <ng-container *ngTemplateOutlet=\"buttons\"></ng-container>\n </div>\n </div>\n</ng-template>\n", styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1$2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1$2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1$2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: CopyTextButtonComponent, selector: "gn-ui-copy-text-button", inputs: ["text", "tooltipText", "displayText", "rows"] }, { kind: "directive", type: TranslateDirective, selector: "[translate],[ngx-translate]", inputs: ["translate", "translateParams"] }, { kind: "pipe", type: TranslatePipe, name: "translate" }, { kind: "ngmodule", type: MatTooltipModule }, { kind: "directive", type: i2$2.MatTooltip, selector: "[matTooltip]", inputs: ["matTooltipPosition", "matTooltipPositionAtOrigin", "matTooltipDisabled", "matTooltipShowDelay", "matTooltipHideDelay", "matTooltipTouchGestures", "matTooltip", "matTooltipClass"], exportAs: ["matTooltip"] }, { kind: "component", type: NgIcon, selector: "ng-icon", inputs: ["name", "svg", "size", "strokeWidth", "color"] }], viewProviders: [
32573
32660
  provideIcons({
32574
32661
  iconoirSettings,
32575
32662
  }),
@@ -32588,7 +32675,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
32588
32675
  provideIcons({
32589
32676
  iconoirSettings,
32590
32677
  }),
32591
- ], template: "<div\n class=\"group flex justify-between rounded filter overflow-hidden card-shadow\"\n [ngClass]=\"cardClass\"\n>\n <ng-container *ngIf=\"size !== 'S'\">\n <div class=\"flex-1 min-w-0\">\n <ng-container *ngTemplateOutlet=\"content\"></ng-container>\n </div>\n <div class=\"flex items-center min-w-[32px]\">\n <ng-container *ngTemplateOutlet=\"buttons\"></ng-container>\n </div>\n </ng-container>\n <ng-container *ngIf=\"size === 'S'\">\n <ng-container *ngTemplateOutlet=\"content\"></ng-container>\n </ng-container>\n</div>\n\n<ng-template #buttons>\n <div class=\"flex flex-row gap-2\">\n <gn-ui-copy-text-button\n [text]=\"link.url\"\n [tooltipText]=\"'tooltip.url.copy' | translate\"\n [displayText]=\"false\"\n class=\"border border-gray-300 rounded-lg pt-1 px-2 h-[34px]\"\n ></gn-ui-copy-text-button>\n <button\n *ngIf=\"displayApiFormButton\"\n type=\"button\"\n class=\"gn-ui-card-icon\"\n [ngClass]=\"{\n 'py-2 px-4 rounded-r-md bg-gray-400 hover:bg-gray-600 focus:bg-gray-800 text-white':\n displayText,\n }\"\n [matTooltip]=\"\n !currentlyActive\n ? ('record.metadata.api.form.openForm' | translate)\n : ('record.metadata.api.form.closeForm' | translate)\n \"\n matTooltipPosition=\"above\"\n (click)=\"openRecordApiFormPanel()\"\n >\n <ng-icon\n class=\"pointer-events-none align-middle card-icon\"\n name=\"iconoirSettings\"\n [ngClass]=\"{\n 'text-secondary opacity-100': currentlyActive,\n }\"\n ></ng-icon>\n </button>\n </div>\n</ng-template>\n\n<ng-template #content>\n <div class=\"flex-1 min-w-0\">\n <div class=\"gn-ui-card-title\">\n {{ link.description || link.name }}\n </div>\n <div class=\"gn-ui-card-detail\">\n {{ link.name }}\n </div>\n </div>\n <div class=\"flex flex-row justify-between\">\n <div class=\"flex flex-row gap-2.5 items-center pt-1\">\n <span\n *ngIf=\"link.accessServiceProtocol !== 'GPFDL'\"\n class=\"bg-primary-opacity-50 uppercase inline-flex items-center justify-center px-2 py-1 text-13 font-medium leading-none text-white rounded text-primary-lightest group-hover:bg-primary transition-colors\"\n [ngClass]=\"{\n '!bg-primary': currentlyActive,\n }\"\n >{{ link.accessServiceProtocol }}</span\n >\n <span\n *ngIf=\"link.accessServiceProtocol === 'GPFDL'\"\n class=\"bg-primary-opacity-50 uppercase inline-flex items-center justify-center px-2 py-1 text-13 font-medium leading-none text-white rounded text-primary-lightest group-hover:bg-primary transition-colors\"\n [ngClass]=\"{\n '!bg-primary': currentlyActive,\n }\"\n translate\n >\n record.metadata.api.gpfdl</span\n >\n </div>\n <div *ngIf=\"size === 'S'\">\n <ng-container *ngTemplateOutlet=\"buttons\"></ng-container>\n </div>\n </div>\n</ng-template>\n" }]
32678
+ ], template: "<div\n class=\"group flex justify-between rounded filter overflow-hidden card-shadow\"\n [ngClass]=\"cardClass\"\n>\n <ng-container *ngIf=\"size !== 'S'\">\n <div class=\"flex-1 min-w-0\">\n <ng-container *ngTemplateOutlet=\"content\"></ng-container>\n </div>\n <div class=\"flex items-center min-w-[32px]\">\n <ng-container *ngTemplateOutlet=\"buttons\"></ng-container>\n </div>\n </ng-container>\n <ng-container *ngIf=\"size === 'S'\">\n <ng-container *ngTemplateOutlet=\"content\"></ng-container>\n </ng-container>\n</div>\n\n<ng-template #buttons>\n <div class=\"flex flex-row gap-2\">\n <gn-ui-copy-text-button\n [text]=\"link.url\"\n [tooltipText]=\"'tooltip.url.copy' | translate\"\n [displayText]=\"false\"\n class=\"border border-gray-300 rounded-lg pt-1 px-2 h-[34px]\"\n ></gn-ui-copy-text-button>\n <button\n *ngIf=\"displayApiFormButton\"\n type=\"button\"\n class=\"gn-ui-card-icon\"\n [ngClass]=\"{\n 'py-2 px-4 rounded-r-md bg-gray-400 hover:bg-gray-600 focus:bg-gray-800 text-white':\n displayText,\n }\"\n [matTooltip]=\"\n !currentlyActive\n ? ('record.metadata.api.form.openForm' | translate)\n : ('record.metadata.api.form.closeForm' | translate)\n \"\n matTooltipPosition=\"above\"\n (click)=\"openRecordApiFormPanel()\"\n >\n <ng-icon\n class=\"pointer-events-none align-middle card-icon\"\n name=\"iconoirSettings\"\n [ngClass]=\"{\n 'text-secondary opacity-100': currentlyActive,\n }\"\n ></ng-icon>\n </button>\n </div>\n</ng-template>\n\n<ng-template #content>\n <div class=\"flex-1 min-w-0\">\n <div class=\"gn-ui-card-title\">\n {{ link.description || link.name }}\n </div>\n <div class=\"gn-ui-card-detail\">\n {{ link.name }}\n </div>\n </div>\n <div class=\"flex flex-row justify-between\">\n <div class=\"flex flex-row gap-2.5 items-center pt-1\">\n <span\n *ngIf=\"link.accessServiceProtocol !== 'GPFDL'\"\n class=\"bg-primary-opacity-50 uppercase inline-flex items-center justify-center px-2 py-1 text-13 font-medium leading-none text-white rounded text-primary-lightest group-hover:bg-primary transition-colors\"\n [ngClass]=\"{\n '!bg-primary': currentlyActive,\n }\"\n translate\n >record.metadata.api.accessServiceProtocol.{{\n link.accessServiceProtocol\n }}</span\n >\n <span\n *ngIf=\"link.accessServiceProtocol === 'GPFDL'\"\n class=\"bg-primary-opacity-50 uppercase inline-flex items-center justify-center px-2 py-1 text-13 font-medium leading-none text-white rounded text-primary-lightest group-hover:bg-primary transition-colors\"\n [ngClass]=\"{\n '!bg-primary': currentlyActive,\n }\"\n translate\n >\n record.metadata.api.gpfdl</span\n >\n </div>\n <div *ngIf=\"size === 'S'\">\n <ng-container *ngTemplateOutlet=\"buttons\"></ng-container>\n </div>\n </div>\n</ng-template>\n" }]
32592
32679
  }], propDecorators: { link: [{
32593
32680
  type: Input
32594
32681
  }], currentLink: [{