geonetwork-ui 2.7.0-dev.fd871c105 → 2.7.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (91) hide show
  1. package/esm2022/libs/api/repository/src/lib/gn4/gn4.provider.mjs +7 -3
  2. package/esm2022/libs/api/repository/src/lib/gn4/platform/gn4-platform.service.mjs +20 -6
  3. package/esm2022/libs/common/domain/src/lib/model/record/metadata.model.mjs +1 -1
  4. package/esm2022/libs/common/domain/src/lib/platform.service.interface.mjs +1 -1
  5. package/esm2022/libs/feature/dataviz/src/lib/service/data.service.mjs +4 -4
  6. package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-topics/form-field-topics.component.mjs +55 -0
  7. package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field.component.mjs +6 -6
  8. package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/index.mjs +2 -2
  9. package/esm2022/libs/feature/editor/src/lib/fields.config.mjs +51 -45
  10. package/esm2022/libs/feature/record/src/lib/state/mdview.facade.mjs +4 -2
  11. package/esm2022/libs/feature/search/src/lib/favorites/favorite-star/favorite-star.component.mjs +24 -17
  12. package/esm2022/libs/ui/elements/src/lib/metadata-info/metadata-info.component.mjs +3 -3
  13. package/esm2022/libs/ui/inputs/src/lib/star-toggle/star-toggle.component.mjs +5 -5
  14. package/esm2022/libs/ui/search/src/lib/results-hits-search-kind/results-hits-search-kind.component.mjs +8 -4
  15. package/esm2022/libs/util/shared/src/lib/links/link-utils.mjs +33 -8
  16. package/esm2022/libs/util/shared/src/lib/utils/index.mjs +2 -1
  17. package/esm2022/libs/util/shared/src/lib/utils/scroll.mjs +40 -0
  18. package/esm2022/translations/de.json +25 -23
  19. package/esm2022/translations/en.json +26 -23
  20. package/esm2022/translations/es.json +25 -23
  21. package/esm2022/translations/fr.json +25 -23
  22. package/esm2022/translations/it.json +25 -23
  23. package/esm2022/translations/nl.json +25 -23
  24. package/esm2022/translations/pt.json +25 -23
  25. package/esm2022/translations/sk.json +25 -23
  26. package/fesm2022/geonetwork-ui.mjs +449 -332
  27. package/fesm2022/geonetwork-ui.mjs.map +1 -1
  28. package/libs/api/repository/src/lib/gn4/gn4.provider.d.ts +5 -1
  29. package/libs/api/repository/src/lib/gn4/gn4.provider.d.ts.map +1 -1
  30. package/libs/api/repository/src/lib/gn4/platform/gn4-platform.service.d.ts +6 -2
  31. package/libs/api/repository/src/lib/gn4/platform/gn4-platform.service.d.ts.map +1 -1
  32. package/libs/common/domain/src/lib/model/record/metadata.model.d.ts +1 -1
  33. package/libs/common/domain/src/lib/platform.service.interface.d.ts +1 -0
  34. package/libs/common/domain/src/lib/platform.service.interface.d.ts.map +1 -1
  35. package/libs/feature/dataviz/src/lib/service/data.service.d.ts +1 -1
  36. package/libs/feature/dataviz/src/lib/service/data.service.d.ts.map +1 -1
  37. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-topics/form-field-topics.component.d.ts +20 -0
  38. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-topics/form-field-topics.component.d.ts.map +1 -0
  39. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field.component.d.ts +1 -1
  40. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field.component.d.ts.map +1 -1
  41. package/libs/feature/editor/src/lib/components/record-form/form-field/index.d.ts +1 -1
  42. package/libs/feature/editor/src/lib/components/record-form/form-field/index.d.ts.map +1 -1
  43. package/libs/feature/editor/src/lib/fields.config.d.ts +4 -4
  44. package/libs/feature/editor/src/lib/fields.config.d.ts.map +1 -1
  45. package/libs/feature/record/src/lib/state/mdview.facade.d.ts.map +1 -1
  46. package/libs/feature/search/src/lib/favorites/favorite-star/favorite-star.component.d.ts +1 -0
  47. package/libs/feature/search/src/lib/favorites/favorite-star/favorite-star.component.d.ts.map +1 -1
  48. package/libs/ui/elements/src/lib/downloads-list/downloads-list.component.d.ts +1 -1
  49. package/libs/ui/elements/src/lib/external-link-card/external-link-card.component.d.ts +1 -1
  50. package/libs/ui/search/src/lib/results-hits-search-kind/results-hits-search-kind.component.d.ts.map +1 -1
  51. package/libs/util/shared/src/lib/links/link-utils.d.ts +26 -7
  52. package/libs/util/shared/src/lib/links/link-utils.d.ts.map +1 -1
  53. package/libs/util/shared/src/lib/utils/index.d.ts +1 -0
  54. package/libs/util/shared/src/lib/utils/index.d.ts.map +1 -1
  55. package/libs/util/shared/src/lib/utils/scroll.d.ts +12 -0
  56. package/libs/util/shared/src/lib/utils/scroll.d.ts.map +1 -0
  57. package/package.json +2 -2
  58. package/src/libs/api/repository/src/lib/gn4/gn4.provider.ts +13 -2
  59. package/src/libs/api/repository/src/lib/gn4/platform/gn4-platform.service.ts +17 -6
  60. package/src/libs/common/domain/src/lib/model/record/metadata.model.ts +1 -1
  61. package/src/libs/common/domain/src/lib/platform.service.interface.ts +1 -0
  62. package/src/libs/feature/dataviz/src/lib/service/data.service.ts +4 -4
  63. package/src/libs/feature/editor/src/lib/components/record-form/form-field/{form-field-inspire-field/form-field-inspire-theme.component.html → form-field-topics/form-field-topics.component.html} +6 -6
  64. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-topics/form-field-topics.component.ts +57 -0
  65. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field.component.html +3 -3
  66. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field.component.ts +3 -3
  67. package/src/libs/feature/editor/src/lib/components/record-form/form-field/index.ts +1 -1
  68. package/src/libs/feature/editor/src/lib/fields.config.ts +51 -45
  69. package/src/libs/feature/record/src/lib/state/mdview.facade.ts +4 -2
  70. package/src/libs/feature/search/src/lib/favorites/favorite-star/favorite-star.component.ts +23 -16
  71. package/src/libs/ui/elements/src/lib/metadata-info/metadata-info.component.html +5 -1
  72. package/src/libs/ui/inputs/src/lib/star-toggle/star-toggle.component.html +4 -3
  73. package/src/libs/ui/inputs/src/lib/star-toggle/star-toggle.component.ts +2 -2
  74. package/src/libs/ui/search/src/lib/results-hits-search-kind/results-hits-search-kind.component.html +1 -4
  75. package/src/libs/ui/search/src/lib/results-hits-search-kind/results-hits-search-kind.component.ts +5 -1
  76. package/src/libs/util/shared/src/lib/links/link-utils.ts +32 -7
  77. package/src/libs/util/shared/src/lib/utils/index.ts +1 -0
  78. package/src/libs/util/shared/src/lib/utils/scroll.ts +48 -0
  79. package/translations/de.json +25 -23
  80. package/translations/en.json +26 -23
  81. package/translations/es.json +25 -23
  82. package/translations/fr.json +25 -23
  83. package/translations/it.json +25 -23
  84. package/translations/nl.json +25 -23
  85. package/translations/pt.json +25 -23
  86. package/translations/sk.json +25 -23
  87. package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-inspire-field/form-field-inspire-theme.component.mjs +0 -55
  88. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-inspire-field/form-field-inspire-theme.component.d.ts +0 -20
  89. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-inspire-field/form-field-inspire-theme.component.d.ts.map +0 -1
  90. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-inspire-field/form-field-inspire-theme.component.ts +0 -57
  91. /package/src/libs/feature/editor/src/lib/components/record-form/form-field/{form-field-inspire-field/form-field-inspire-theme.component.css → form-field-topics/form-field-topics.component.css} +0 -0
@@ -52,7 +52,9 @@ export class MdViewFacade {
52
52
  if (link.type === 'service' &&
53
53
  link.accessServiceProtocol === 'ogcFeatures') {
54
54
  return from(this.dataService.getItemsFromOgcApi(link.url.href)).pipe(map((collectionRecords) => {
55
- return collectionRecords && collectionRecords.geometry
55
+ return collectionRecords &&
56
+ collectionRecords[0] &&
57
+ collectionRecords[0].geometry
56
58
  ? link
57
59
  : null;
58
60
  }), defaultIfEmpty(null), catchError((e) => {
@@ -114,4 +116,4 @@ export class MdViewFacade {
114
116
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MdViewFacade, decorators: [{
115
117
  type: Injectable
116
118
  }], ctorParameters: () => [{ type: i1.Store }, { type: i2.LinkClassifierService }, { type: i3.AvatarServiceInterface }, { type: i4.DataService }] });
117
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"mdview.facade.js","sourceRoot":"","sources":["../../../../../../../../libs/feature/record/src/lib/state/mdview.facade.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core'\nimport { select, Store } from '@ngrx/store'\nimport {\n  catchError,\n  defaultIfEmpty,\n  filter,\n  map,\n  mergeMap,\n  shareReplay,\n  switchMap,\n  toArray,\n} from 'rxjs/operators'\nimport * as MdViewActions from './mdview.actions'\nimport * as MdViewSelectors from './mdview.selectors'\nimport { LinkClassifierService, LinkUsage } from '../../../../../../libs/util/shared/src'\nimport { DatavizChartConfigModel } from '../../../../../../libs/common/domain/src/lib/model/dataviz/dataviz-configuration.model'\nimport {\n  CatalogRecord,\n  UserFeedback,\n} from '../../../../../../libs/common/domain/src/lib/model/record'\nimport { AvatarServiceInterface } from '../../../../../../libs/api/repository/src'\nimport { OgcApiRecord } from '@camptocamp/ogc-client'\nimport { from, of, Observable } from 'rxjs'\nimport { DataService } from '../../../../../../libs/feature/dataviz/src'\n\n@Injectable()\n/**\n * The Metadata View Facade is used to render complete metadata records.\n * Supply it with an incomplete record (at least containing the uuid) and the\n * corresponding full record will be loaded.\n * To clear the current record use the `close()` method.\n */\nexport class MdViewFacade {\n  constructor(\n    private store: Store,\n    public linkClassifier: LinkClassifierService,\n    private avatarService: AvatarServiceInterface,\n    public dataService: DataService\n  ) {}\n\n  isPresent$ = this.store.pipe(\n    select(MdViewSelectors.getMetadataUuid),\n    map((uuid) => !!uuid)\n  )\n\n  isMetadataLoading$ = this.store.pipe(\n    select(MdViewSelectors.getMetadataIsLoading)\n  )\n\n  metadata$ = this.store.pipe(\n    select(MdViewSelectors.getMetadata),\n    filter((md) => !!md)\n  )\n\n  featureCatalog$ = this.store.pipe(select(MdViewSelectors.getFeatureCatalog))\n\n  isIncomplete$ = this.store.pipe(\n    select(MdViewSelectors.getMetadataIsIncomplete),\n    filter((incomplete) => incomplete !== null)\n  )\n\n  isHighUpdateFrequency$ = this.metadata$.pipe(\n    map((record) => {\n      if (record.updateFrequency instanceof Object) {\n        return (\n          record.updateFrequency.per === 'day' &&\n          record.updateFrequency.updatedTimes > 1\n        )\n      }\n\n      return record.updateFrequency === 'continual'\n    })\n  )\n\n  error$ = this.store.pipe(select(MdViewSelectors.getMetadataError))\n\n  related$ = this.store.pipe(select(MdViewSelectors.getRelated))\n\n  sources$ = this.store.pipe(select(MdViewSelectors.getSources))\n\n  sourceOf$ = this.store.pipe(select(MdViewSelectors.getSourceOf))\n\n  chartConfig$ = this.store.pipe(select(MdViewSelectors.getChartConfig))\n\n  allLinks$ = this.metadata$.pipe(\n    map((record) =>\n      'onlineResources' in record ? record.onlineResources : []\n    ),\n    shareReplay(1)\n  )\n\n  apiLinks$ = this.allLinks$.pipe(\n    map((links) =>\n      links.filter((link) => this.linkClassifier.hasUsage(link, LinkUsage.API))\n    ),\n    shareReplay(1)\n  )\n\n  mapApiLinks$ = this.allLinks$.pipe(\n    map((links) =>\n      links.filter((link) =>\n        this.linkClassifier.hasUsage(link, LinkUsage.MAP_API)\n      )\n    ),\n    shareReplay(1)\n  )\n\n  downloadLinks$ = this.allLinks$.pipe(\n    map((links) =>\n      links.filter((link) =>\n        this.linkClassifier.hasUsage(link, LinkUsage.DOWNLOAD)\n      )\n    )\n  )\n\n  dataLinks$ = this.allLinks$.pipe(\n    map((links) =>\n      links.filter((link) => this.linkClassifier.hasUsage(link, LinkUsage.DATA))\n    )\n  )\n\n  geoDataLinks$ = this.allLinks$.pipe(\n    map((links) =>\n      links.filter((link) =>\n        this.linkClassifier.hasUsage(link, LinkUsage.GEODATA)\n      )\n    )\n  )\n\n  geoDataLinksWithGeometry$ = this.allLinks$.pipe(\n    switchMap((links) =>\n      from(links).pipe(\n        mergeMap((link) => {\n          if (this.linkClassifier.hasUsage(link, LinkUsage.GEODATA)) {\n            if (\n              link.type === 'service' &&\n              link.accessServiceProtocol === 'ogcFeatures'\n            ) {\n              return from(\n                this.dataService.getItemsFromOgcApi(link.url.href)\n              ).pipe(\n                map((collectionRecords: OgcApiRecord) => {\n                  return collectionRecords && collectionRecords.geometry\n                    ? link\n                    : null\n                }),\n                defaultIfEmpty(null),\n                catchError((e) => {\n                  console.error(e)\n                  return of(null)\n                })\n              )\n            } else {\n              return of(link)\n            }\n          } else {\n            return of(null)\n          }\n        }),\n        toArray(),\n        map((links) => links.filter((link) => link !== null))\n      )\n    )\n  )\n\n  landingPageLinks$ = this.metadata$.pipe(\n    map((record) => ('landingPage' in record ? [record.landingPage] : []))\n  )\n\n  otherLinks$ = this.allLinks$.pipe(\n    map((links) =>\n      links.filter((link) =>\n        this.linkClassifier.hasUsage(link, LinkUsage.UNKNOWN)\n      )\n    )\n  )\n\n  userFeedbacks$ = this.store.pipe(select(MdViewSelectors.getUserFeedbacks))\n  isAllUserFeedbackLoading$ = this.store.pipe(\n    select(MdViewSelectors.getAllUserFeedbacksLoading)\n  )\n  isAddUserFeedbackLoading$ = this.store.pipe(\n    select(MdViewSelectors.getAddUserFeedbacksLoading)\n  )\n\n  /**\n   * This will show an incomplete record (e.g. from a search result) as a preview\n   * Note: the full record will not be loaded automatically; use the `loadFull` method for that\n   */\n  setIncompleteMetadata(incomplete: CatalogRecord) {\n    this.store.dispatch(MdViewActions.setIncompleteMetadata({ incomplete }))\n  }\n\n  /**\n   * This will trigger the load of a full metadata record\n   */\n  loadFull(uuid: string) {\n    this.store.dispatch(MdViewActions.loadFullMetadata({ uuid }))\n  }\n\n  closeMetadata() {\n    this.store.dispatch(MdViewActions.closeMetadata())\n  }\n\n  setChartConfig(chartConfig: DatavizChartConfigModel) {\n    this.store.dispatch(MdViewActions.setChartConfig({ chartConfig }))\n  }\n\n  /**\n   * UserFeedbacks\n   */\n  addUserFeedback(userFeedback: UserFeedback) {\n    this.store.dispatch(MdViewActions.addUserFeedback({ userFeedback }))\n  }\n\n  loadUserFeedbacks(datasetUuid: string) {\n    this.store.dispatch(MdViewActions.loadUserFeedbacks({ datasetUuid }))\n  }\n\n  /**\n   * loadFeatureCatalog\n   */\n  loadFeatureCatalog(metadata: CatalogRecord) {\n    this.store.dispatch(MdViewActions.loadFeatureCatalog({ metadata }))\n  }\n}\n"]}
119
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"mdview.facade.js","sourceRoot":"","sources":["../../../../../../../../libs/feature/record/src/lib/state/mdview.facade.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core'\nimport { select, Store } from '@ngrx/store'\nimport {\n  catchError,\n  defaultIfEmpty,\n  filter,\n  map,\n  mergeMap,\n  shareReplay,\n  switchMap,\n  toArray,\n} from 'rxjs/operators'\nimport * as MdViewActions from './mdview.actions'\nimport * as MdViewSelectors from './mdview.selectors'\nimport { LinkClassifierService, LinkUsage } from '../../../../../../libs/util/shared/src'\nimport { DatavizChartConfigModel } from '../../../../../../libs/common/domain/src/lib/model/dataviz/dataviz-configuration.model'\nimport {\n  CatalogRecord,\n  UserFeedback,\n} from '../../../../../../libs/common/domain/src/lib/model/record'\nimport { AvatarServiceInterface } from '../../../../../../libs/api/repository/src'\nimport { OgcApiRecord } from '@camptocamp/ogc-client'\nimport { from, of, Observable } from 'rxjs'\nimport { DataService } from '../../../../../../libs/feature/dataviz/src'\n\n@Injectable()\n/**\n * The Metadata View Facade is used to render complete metadata records.\n * Supply it with an incomplete record (at least containing the uuid) and the\n * corresponding full record will be loaded.\n * To clear the current record use the `close()` method.\n */\nexport class MdViewFacade {\n  constructor(\n    private store: Store,\n    public linkClassifier: LinkClassifierService,\n    private avatarService: AvatarServiceInterface,\n    public dataService: DataService\n  ) {}\n\n  isPresent$ = this.store.pipe(\n    select(MdViewSelectors.getMetadataUuid),\n    map((uuid) => !!uuid)\n  )\n\n  isMetadataLoading$ = this.store.pipe(\n    select(MdViewSelectors.getMetadataIsLoading)\n  )\n\n  metadata$ = this.store.pipe(\n    select(MdViewSelectors.getMetadata),\n    filter((md) => !!md)\n  )\n\n  featureCatalog$ = this.store.pipe(select(MdViewSelectors.getFeatureCatalog))\n\n  isIncomplete$ = this.store.pipe(\n    select(MdViewSelectors.getMetadataIsIncomplete),\n    filter((incomplete) => incomplete !== null)\n  )\n\n  isHighUpdateFrequency$ = this.metadata$.pipe(\n    map((record) => {\n      if (record.updateFrequency instanceof Object) {\n        return (\n          record.updateFrequency.per === 'day' &&\n          record.updateFrequency.updatedTimes > 1\n        )\n      }\n\n      return record.updateFrequency === 'continual'\n    })\n  )\n\n  error$ = this.store.pipe(select(MdViewSelectors.getMetadataError))\n\n  related$ = this.store.pipe(select(MdViewSelectors.getRelated))\n\n  sources$ = this.store.pipe(select(MdViewSelectors.getSources))\n\n  sourceOf$ = this.store.pipe(select(MdViewSelectors.getSourceOf))\n\n  chartConfig$ = this.store.pipe(select(MdViewSelectors.getChartConfig))\n\n  allLinks$ = this.metadata$.pipe(\n    map((record) =>\n      'onlineResources' in record ? record.onlineResources : []\n    ),\n    shareReplay(1)\n  )\n\n  apiLinks$ = this.allLinks$.pipe(\n    map((links) =>\n      links.filter((link) => this.linkClassifier.hasUsage(link, LinkUsage.API))\n    ),\n    shareReplay(1)\n  )\n\n  mapApiLinks$ = this.allLinks$.pipe(\n    map((links) =>\n      links.filter((link) =>\n        this.linkClassifier.hasUsage(link, LinkUsage.MAP_API)\n      )\n    ),\n    shareReplay(1)\n  )\n\n  downloadLinks$ = this.allLinks$.pipe(\n    map((links) =>\n      links.filter((link) =>\n        this.linkClassifier.hasUsage(link, LinkUsage.DOWNLOAD)\n      )\n    )\n  )\n\n  dataLinks$ = this.allLinks$.pipe(\n    map((links) =>\n      links.filter((link) => this.linkClassifier.hasUsage(link, LinkUsage.DATA))\n    )\n  )\n\n  geoDataLinks$ = this.allLinks$.pipe(\n    map((links) =>\n      links.filter((link) =>\n        this.linkClassifier.hasUsage(link, LinkUsage.GEODATA)\n      )\n    )\n  )\n\n  geoDataLinksWithGeometry$ = this.allLinks$.pipe(\n    switchMap((links) =>\n      from(links).pipe(\n        mergeMap((link) => {\n          if (this.linkClassifier.hasUsage(link, LinkUsage.GEODATA)) {\n            if (\n              link.type === 'service' &&\n              link.accessServiceProtocol === 'ogcFeatures'\n            ) {\n              return from(\n                this.dataService.getItemsFromOgcApi(link.url.href)\n              ).pipe(\n                map((collectionRecords: OgcApiRecord[]) => {\n                  return collectionRecords &&\n                    collectionRecords[0] &&\n                    collectionRecords[0].geometry\n                    ? link\n                    : null\n                }),\n                defaultIfEmpty(null),\n                catchError((e) => {\n                  console.error(e)\n                  return of(null)\n                })\n              )\n            } else {\n              return of(link)\n            }\n          } else {\n            return of(null)\n          }\n        }),\n        toArray(),\n        map((links) => links.filter((link) => link !== null))\n      )\n    )\n  )\n\n  landingPageLinks$ = this.metadata$.pipe(\n    map((record) => ('landingPage' in record ? [record.landingPage] : []))\n  )\n\n  otherLinks$ = this.allLinks$.pipe(\n    map((links) =>\n      links.filter((link) =>\n        this.linkClassifier.hasUsage(link, LinkUsage.UNKNOWN)\n      )\n    )\n  )\n\n  userFeedbacks$ = this.store.pipe(select(MdViewSelectors.getUserFeedbacks))\n  isAllUserFeedbackLoading$ = this.store.pipe(\n    select(MdViewSelectors.getAllUserFeedbacksLoading)\n  )\n  isAddUserFeedbackLoading$ = this.store.pipe(\n    select(MdViewSelectors.getAddUserFeedbacksLoading)\n  )\n\n  /**\n   * This will show an incomplete record (e.g. from a search result) as a preview\n   * Note: the full record will not be loaded automatically; use the `loadFull` method for that\n   */\n  setIncompleteMetadata(incomplete: CatalogRecord) {\n    this.store.dispatch(MdViewActions.setIncompleteMetadata({ incomplete }))\n  }\n\n  /**\n   * This will trigger the load of a full metadata record\n   */\n  loadFull(uuid: string) {\n    this.store.dispatch(MdViewActions.loadFullMetadata({ uuid }))\n  }\n\n  closeMetadata() {\n    this.store.dispatch(MdViewActions.closeMetadata())\n  }\n\n  setChartConfig(chartConfig: DatavizChartConfigModel) {\n    this.store.dispatch(MdViewActions.setChartConfig({ chartConfig }))\n  }\n\n  /**\n   * UserFeedbacks\n   */\n  addUserFeedback(userFeedback: UserFeedback) {\n    this.store.dispatch(MdViewActions.addUserFeedback({ userFeedback }))\n  }\n\n  loadUserFeedbacks(datasetUuid: string) {\n    this.store.dispatch(MdViewActions.loadUserFeedbacks({ datasetUuid }))\n  }\n\n  /**\n   * loadFeatureCatalog\n   */\n  loadFeatureCatalog(metadata: CatalogRecord) {\n    this.store.dispatch(MdViewActions.loadFeatureCatalog({ metadata }))\n  }\n}\n"]}
@@ -34,6 +34,7 @@ export class FavoriteStarComponent {
34
34
  this.displayLabel = false;
35
35
  this.displayCount = true;
36
36
  this.isFavorite$ = this.favoritesService.myFavoritesUuid$.pipe(map((favorites) => favorites.indexOf(this.record.uniqueIdentifier) > -1));
37
+ this.supportsAuthentication = this.platformService.supportsAuthentication();
37
38
  this.isAnonymous$ = this.platformService.isAnonymous();
38
39
  this.loading = false;
39
40
  this.loginUrl = this.authService.loginUrl;
@@ -43,20 +44,22 @@ export class FavoriteStarComponent {
43
44
  })));
44
45
  }
45
46
  ngAfterViewInit() {
46
- this.subscription = this.isAnonymous$
47
- .pipe(withLatestFrom(this.loginMessage$))
48
- .subscribe(([anonymous, loginMessage]) => {
49
- if (anonymous) {
50
- tippy(this.starToggleRef.nativeElement, {
51
- appendTo: () => document.body,
52
- content: loginMessage,
53
- allowHTML: true,
54
- interactive: true,
55
- zIndex: 60,
56
- maxWidth: 250,
57
- });
58
- }
59
- });
47
+ if (this.supportsAuthentication) {
48
+ this.subscription = this.isAnonymous$
49
+ .pipe(withLatestFrom(this.loginMessage$))
50
+ .subscribe(([anonymous, loginMessage]) => {
51
+ if (anonymous) {
52
+ tippy(this.starToggleRef.nativeElement, {
53
+ appendTo: () => document.body,
54
+ content: loginMessage,
55
+ allowHTML: true,
56
+ interactive: true,
57
+ zIndex: 60,
58
+ maxWidth: 250,
59
+ });
60
+ }
61
+ });
62
+ }
60
63
  this.countSubscription = this.favoritesService.myFavoritesUuid$
61
64
  .pipe(pairwise())
62
65
  .subscribe(([oldFavs, newFavs]) => {
@@ -75,8 +78,12 @@ export class FavoriteStarComponent {
75
78
  });
76
79
  }
77
80
  ngOnDestroy() {
78
- this.subscription.unsubscribe();
79
- this.countSubscription.unsubscribe();
81
+ if (this.subscription) {
82
+ this.subscription.unsubscribe();
83
+ }
84
+ if (this.countSubscription) {
85
+ this.countSubscription.unsubscribe();
86
+ }
80
87
  }
81
88
  toggleFavorite(isFavorite) {
82
89
  this.loading = true;
@@ -111,4 +118,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
111
118
  type: ViewChild,
112
119
  args: [StarToggleComponent, { read: ElementRef }]
113
120
  }] } });
114
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"favorite-star.component.js","sourceRoot":"","sources":["../../../../../../../../../libs/feature/search/src/lib/favorites/favorite-star/favorite-star.component.ts","../../../../../../../../../libs/feature/search/src/lib/favorites/favorite-star/favorite-star.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  Input,\n  OnDestroy,\n  ViewChild,\n} from '@angular/core'\nimport {\n  map,\n  pairwise,\n  startWith,\n  switchMap,\n  withLatestFrom,\n} from 'rxjs/operators'\nimport tippy from 'tippy.js'\nimport { TranslateService } from '@ngx-translate/core'\nimport { StarToggleComponent } from '../../../../../../../libs/ui/inputs/src'\nimport { Observable, Subscription } from 'rxjs'\nimport { CatalogRecord } from '../../../../../../../libs/common/domain/src/lib/model/record'\nimport { AuthService, FavoritesService } from '../../../../../../../libs/api/repository/src'\nimport { PlatformServiceInterface } from '../../../../../../../libs/common/domain/src/lib/platform.service.interface'\nimport { CommonModule } from '@angular/common'\n\n@Component({\n  selector: 'gn-ui-favorite-star',\n  templateUrl: './favorite-star.component.html',\n  styleUrls: ['./favorite-star.component.css'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true,\n  imports: [CommonModule, StarToggleComponent],\n})\nexport class FavoriteStarComponent implements AfterViewInit, OnDestroy {\n  @Input() displayLabel? = false\n  @Input() displayCount? = true\n  @Input() set record(value) {\n    this.record_ = value\n    this.favoriteCount =\n      'extras' in this.record_ && 'favoriteCount' in this.record_.extras\n        ? (this.record_.extras.favoriteCount as number)\n        : null\n  }\n  get record() {\n    return this.record_\n  }\n  isFavorite$ = this.favoritesService.myFavoritesUuid$.pipe(\n    map((favorites) => favorites.indexOf(this.record.uniqueIdentifier) > -1)\n  )\n  isAnonymous$ = this.platformService.isAnonymous()\n  record_: Partial<CatalogRecord>\n  favoriteCount: number | null\n  loading = false\n  loginUrl = this.authService.loginUrl\n  loginMessage$: Observable<string> = this.translateService.onLangChange.pipe(\n    startWith(null), // make sure to wait for translations to be loaded with and without language change\n    switchMap(() =>\n      this.translateService.get('favorite.not.authenticated.tooltip', {\n        link: this.loginUrl,\n      })\n    )\n  )\n  @ViewChild(StarToggleComponent, { read: ElementRef })\n  starToggleRef: ElementRef\n  subscription: Subscription\n  countSubscription: Subscription\n\n  get hasFavoriteCount() {\n    return this.favoriteCount !== null\n  }\n\n  constructor(\n    private favoritesService: FavoritesService,\n    private platformService: PlatformServiceInterface,\n    private changeDetector: ChangeDetectorRef,\n    private authService: AuthService,\n    private translateService: TranslateService\n  ) {}\n\n  ngAfterViewInit(): void {\n    this.subscription = this.isAnonymous$\n      .pipe(withLatestFrom(this.loginMessage$))\n      .subscribe(([anonymous, loginMessage]) => {\n        if (anonymous) {\n          tippy(this.starToggleRef.nativeElement, {\n            appendTo: () => document.body,\n            content: loginMessage,\n            allowHTML: true,\n            interactive: true,\n            zIndex: 60,\n            maxWidth: 250,\n          })\n        }\n      })\n    this.countSubscription = this.favoritesService.myFavoritesUuid$\n      .pipe(pairwise())\n      .subscribe(([oldFavs, newFavs]) => {\n        const editedFavs = (\n          oldFavs.length < newFavs.length\n            ? newFavs.slice(-1)\n            : oldFavs.filter((fav) => !newFavs.includes(fav))\n        )[0]\n        if (\n          this.hasFavoriteCount &&\n          editedFavs === this.record.uniqueIdentifier\n        ) {\n          if (newFavs.includes(editedFavs)) {\n            this.favoriteCount += 1\n          } else {\n            this.favoriteCount += -1\n          }\n        }\n      })\n  }\n\n  ngOnDestroy(): void {\n    this.subscription.unsubscribe()\n    this.countSubscription.unsubscribe()\n  }\n\n  toggleFavorite(isFavorite) {\n    this.loading = true\n    ;(isFavorite\n      ? this.favoritesService.addToFavorites([this.record.uniqueIdentifier])\n      : this.favoritesService.removeFromFavorites([\n          this.record.uniqueIdentifier,\n        ])\n    ).subscribe({\n      complete: () => {\n        this.loading = false\n        this.changeDetector.detectChanges()\n      },\n      error: () => {\n        this.loading = false\n        this.changeDetector.detectChanges()\n      },\n    })\n  }\n}\n","<div class=\"flex flex-row items-center\">\n  <span\n    class=\"align-text-top mr-1.5 mt-0.5\"\n    data-test=\"favorite-count\"\n    *ngIf=\"hasFavoriteCount && displayCount\"\n    >{{ favoriteCount }}</span\n  >\n  <gn-ui-star-toggle\n    [toggled]=\"isFavorite$ | async\"\n    (newValue)=\"toggleFavorite($event)\"\n    [disabled]=\"loading || (isAnonymous$ | async)\"\n    [displayLabel]=\"displayLabel\"\n  ></gn-ui-star-toggle>\n</div>\n"]}
121
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"favorite-star.component.js","sourceRoot":"","sources":["../../../../../../../../../libs/feature/search/src/lib/favorites/favorite-star/favorite-star.component.ts","../../../../../../../../../libs/feature/search/src/lib/favorites/favorite-star/favorite-star.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  Input,\n  OnDestroy,\n  ViewChild,\n} from '@angular/core'\nimport {\n  map,\n  pairwise,\n  startWith,\n  switchMap,\n  withLatestFrom,\n} from 'rxjs/operators'\nimport tippy from 'tippy.js'\nimport { TranslateService } from '@ngx-translate/core'\nimport { StarToggleComponent } from '../../../../../../../libs/ui/inputs/src'\nimport { Observable, Subscription } from 'rxjs'\nimport { CatalogRecord } from '../../../../../../../libs/common/domain/src/lib/model/record'\nimport { AuthService, FavoritesService } from '../../../../../../../libs/api/repository/src'\nimport { PlatformServiceInterface } from '../../../../../../../libs/common/domain/src/lib/platform.service.interface'\nimport { CommonModule } from '@angular/common'\n\n@Component({\n  selector: 'gn-ui-favorite-star',\n  templateUrl: './favorite-star.component.html',\n  styleUrls: ['./favorite-star.component.css'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true,\n  imports: [CommonModule, StarToggleComponent],\n})\nexport class FavoriteStarComponent implements AfterViewInit, OnDestroy {\n  @Input() displayLabel? = false\n  @Input() displayCount? = true\n  @Input() set record(value) {\n    this.record_ = value\n    this.favoriteCount =\n      'extras' in this.record_ && 'favoriteCount' in this.record_.extras\n        ? (this.record_.extras.favoriteCount as number)\n        : null\n  }\n  get record() {\n    return this.record_\n  }\n  isFavorite$ = this.favoritesService.myFavoritesUuid$.pipe(\n    map((favorites) => favorites.indexOf(this.record.uniqueIdentifier) > -1)\n  )\n  supportsAuthentication = this.platformService.supportsAuthentication()\n  isAnonymous$ = this.platformService.isAnonymous()\n  record_: Partial<CatalogRecord>\n  favoriteCount: number | null\n  loading = false\n  loginUrl = this.authService.loginUrl\n  loginMessage$: Observable<string> = this.translateService.onLangChange.pipe(\n    startWith(null), // make sure to wait for translations to be loaded with and without language change\n    switchMap(() =>\n      this.translateService.get('favorite.not.authenticated.tooltip', {\n        link: this.loginUrl,\n      })\n    )\n  )\n  @ViewChild(StarToggleComponent, { read: ElementRef })\n  starToggleRef: ElementRef\n  subscription: Subscription\n  countSubscription: Subscription\n\n  get hasFavoriteCount() {\n    return this.favoriteCount !== null\n  }\n\n  constructor(\n    private favoritesService: FavoritesService,\n    private platformService: PlatformServiceInterface,\n    private changeDetector: ChangeDetectorRef,\n    private authService: AuthService,\n    private translateService: TranslateService\n  ) {}\n\n  ngAfterViewInit(): void {\n    if (this.supportsAuthentication) {\n      this.subscription = this.isAnonymous$\n        .pipe(withLatestFrom(this.loginMessage$))\n        .subscribe(([anonymous, loginMessage]) => {\n          if (anonymous) {\n            tippy(this.starToggleRef.nativeElement, {\n              appendTo: () => document.body,\n              content: loginMessage,\n              allowHTML: true,\n              interactive: true,\n              zIndex: 60,\n              maxWidth: 250,\n            })\n          }\n        })\n    }\n    this.countSubscription = this.favoritesService.myFavoritesUuid$\n      .pipe(pairwise())\n      .subscribe(([oldFavs, newFavs]) => {\n        const editedFavs = (\n          oldFavs.length < newFavs.length\n            ? newFavs.slice(-1)\n            : oldFavs.filter((fav) => !newFavs.includes(fav))\n        )[0]\n        if (\n          this.hasFavoriteCount &&\n          editedFavs === this.record.uniqueIdentifier\n        ) {\n          if (newFavs.includes(editedFavs)) {\n            this.favoriteCount += 1\n          } else {\n            this.favoriteCount += -1\n          }\n        }\n      })\n  }\n\n  ngOnDestroy(): void {\n    if (this.subscription) {\n      this.subscription.unsubscribe()\n    }\n    if (this.countSubscription) {\n      this.countSubscription.unsubscribe()\n    }\n  }\n\n  toggleFavorite(isFavorite) {\n    this.loading = true\n    ;(isFavorite\n      ? this.favoritesService.addToFavorites([this.record.uniqueIdentifier])\n      : this.favoritesService.removeFromFavorites([\n          this.record.uniqueIdentifier,\n        ])\n    ).subscribe({\n      complete: () => {\n        this.loading = false\n        this.changeDetector.detectChanges()\n      },\n      error: () => {\n        this.loading = false\n        this.changeDetector.detectChanges()\n      },\n    })\n  }\n}\n","<div class=\"flex flex-row items-center\">\n  <span\n    class=\"align-text-top mr-1.5 mt-0.5\"\n    data-test=\"favorite-count\"\n    *ngIf=\"hasFavoriteCount && displayCount\"\n    >{{ favoriteCount }}</span\n  >\n  <gn-ui-star-toggle\n    [toggled]=\"isFavorite$ | async\"\n    (newValue)=\"toggleFavorite($event)\"\n    [disabled]=\"loading || (isAnonymous$ | async)\"\n    [displayLabel]=\"displayLabel\"\n  ></gn-ui-star-toggle>\n</div>\n"]}
@@ -89,7 +89,7 @@ export class MetadataInfoComponent {
89
89
  return this.dateService.formatDateTime(date);
90
90
  }
91
91
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MetadataInfoComponent, deps: [{ token: i1.DateService }], target: i0.ɵɵFactoryTarget.Component }); }
92
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: MetadataInfoComponent, isStandalone: true, selector: "gn-ui-metadata-info", inputs: { metadata: "metadata", incomplete: "incomplete" }, outputs: { keyword: "keyword" }, ngImport: i0, template: "<div class=\"mb-6 md-description sm:mb-4 sm:pr-16\">\n <gn-ui-content-ghost\n ghostClass=\"h-[178px]\"\n [showContent]=\"fieldReady('abstract')\"\n >\n <gn-ui-max-lines [maxLines]=\"6\" *ngIf=\"metadata.abstract\">\n <div class=\"mb-6\">\n <gn-ui-markdown-parser\n [textContent]=\"metadata.abstract\"\n ></gn-ui-markdown-parser>\n </div>\n </gn-ui-max-lines>\n </gn-ui-content-ghost>\n\n <p\n class=\"mt-6 mb-3 font-medium text-black text-sm\"\n translate\n *ngIf=\"!fieldReady('keywords') || metadata.keywords?.length\"\n >\n record.metadata.keywords\n </p>\n\n <gn-ui-content-ghost\n ghostClass=\"h-[31px] w-3/4\"\n [showContent]=\"fieldReady('keywords')\"\n >\n <div *ngIf=\"metadata.keywords?.length\">\n <div class=\"metadata-info-keywords sm:pb-4 flex flex-wrap gap-2\">\n <gn-ui-badge\n class=\"inline-block lowercase\"\n (click)=\"onKeywordClick(keyword)\"\n [clickable]=\"true\"\n *ngFor=\"let keyword of metadata.keywords\"\n >{{ keyword.label }}</gn-ui-badge\n >\n </div>\n </div>\n </gn-ui-content-ghost>\n</div>\n\n<gn-ui-expandable-panel\n *ngIf=\"\n metadata.licenses ||\n metadata.legalConstraints ||\n metadata.securityConstraints ||\n metadata.otherConstraints\n \"\n [title]=\"'record.metadata.usage' | translate\"\n data-test=\"usage-panel\"\n>\n <div class=\"flex flex-col gap-[10px] mr-4 py-[12px] rounded text-gray-900\">\n <ng-container *ngFor=\"let license of licenses\">\n <div *ngIf=\"license.url; else noUrl\" class=\"text-primary\">\n <a\n [href]=\"license.url\"\n target=\"_blank\"\n class=\"cursor-pointer hover:underline transition-all\"\n >\n {{ license.text }}\n <ng-icon\n class=\"!w-[12px] !h-[12px] !text-[12px] opacity-75 shrink-0\"\n name=\"matOpenInNew\"\n ></ng-icon>\n </a>\n </div>\n <ng-template #noUrl>\n <div class=\"text-primary\" gnUiLinkify>\n {{ license.text }}\n </div>\n </ng-template>\n </ng-container>\n <ng-container *ngIf=\"legalConstraints.length\">\n <div class=\"mb-6\">\n <gn-ui-markdown-parser\n *ngFor=\"let constraint of legalConstraints\"\n [textContent]=\"constraint\"\n >\n </gn-ui-markdown-parser>\n </div>\n </ng-container>\n <ng-container *ngIf=\"otherConstraints.length\">\n <div gnUiLinkify *ngFor=\"let constraint of otherConstraints\">\n <span\n translate\n class=\"font-medium text-black text-sm mb-[2px] mt-[16px]\"\n >\n record.metadata.otherConstraints\n </span>\n <div class=\"mb-6\">\n <gn-ui-markdown-parser [textContent]=\"constraint\">\n </gn-ui-markdown-parser>\n </div>\n </div>\n </ng-container>\n\n <span class=\"noUsage\" *ngIf=\"!hasUsage\">\n {{ 'record.metadata.noUsage' | translate }}\n </span>\n </div>\n</gn-ui-expandable-panel>\n<gn-ui-expandable-panel\n *ngIf=\"\n (metadata.kind === 'dataset' && metadata.lineage) ||\n metadata.resourceUpdated ||\n metadata.updateFrequency ||\n (metadata.kind === 'dataset' && metadata.status)\n \"\n [title]=\"'record.metadata.details' | translate\"\n data-test=\"details-panel\"\n>\n <div *ngIf=\"metadata.lineage\" class=\"text-gray-900 flex flex-col mt-4 gap-2\">\n <p class=\"whitespace-pre-line break-words text-gray-900\" gnUiLinkify>\n {{ metadata.lineage }}\n </p>\n </div>\n <div class=\"flex flex-row gap-6 mt-5 mb-8\" *ngIf=\"resourceContact\">\n <div\n *ngIf=\"resourceContact.organization?.logoUrl?.href\"\n class=\"flex items-center justify-center border-solid border border-gray-300 rounded-md bg-white h-32 overflow-hidden\"\n >\n <gn-ui-thumbnail\n class=\"relative h-full w-full\"\n [thumbnailUrl]=\"resourceContact.organization.logoUrl.href\"\n fit=\"contain\"\n ></gn-ui-thumbnail>\n </div>\n <div class=\"flex flex-col gap-1\">\n <p class=\"text-sm font-medium\" translate>record.metadata.producer</p>\n <div\n class=\"text-primary font-title text-21 mr-2 cursor-pointer hover:underline\"\n data-cy=\"organization-name\"\n >\n {{ resourceContact.organization?.name }}\n </div>\n <div *ngIf=\"resourceContact.organization?.website\">\n <a\n [href]=\"resourceContact.organization.website\"\n target=\"_blank\"\n class=\"contact-website text-primary text-sm cursor-pointer hover:underline transition-all\"\n >{{ resourceContact.organization.website }}\n <ng-icon\n class=\"!w-[12px] !h-[12px] !text-[12px] opacity-75 shrink-0\"\n name=\"matOpenInNew\"\n ></ng-icon>\n </a>\n </div>\n <div class=\"mt-4\" *ngIf=\"resourceContact.email\">\n <div class=\"flex\">\n <ng-icon\n class=\"!w-5 !h-5 !text-[20px] opacity-75 shrink-0\"\n name=\"matMailOutline\"\n ></ng-icon>\n <a\n *ngIf=\"resourceContact.email\"\n [href]=\"'mailto:' + resourceContact.email\"\n class=\"text-sm hover:underline ml-2\"\n target=\"_blank\"\n data-cy=\"contact-email\"\n >{{ resourceContact?.email }}</a\n >\n </div>\n </div>\n </div>\n </div>\n <div\n class=\"py-6 px-6 rounded bg-gray-100 grid grid-cols-2 gap-y-6 gap-x-[20px] text-gray-700\"\n >\n <div *ngIf=\"metadata.resourceCreated\">\n <p class=\"text-sm\" translate>record.metadata.creation</p>\n <p class=\"text-primary font-medium mt-1\">\n {{ formatDate(metadata.resourceCreated) }}\n </p>\n </div>\n <div *ngIf=\"metadata.resourcePublished\">\n <p class=\"text-sm\" translate>record.metadata.publication</p>\n <p class=\"text-primary font-medium mt-1\">\n {{ formatDate(metadata.resourcePublished) }}\n </p>\n </div>\n <div *ngIf=\"updateFrequency\">\n <p class=\"text-sm\" translate>record.metadata.updateFrequency</p>\n <p\n class=\"text-primary font-medium mt-1 updateFrequency\"\n translate\n [translateParams]=\"{ count: updatedTimes }\"\n >\n {{ updateFrequency }}\n </p>\n </div>\n <div *ngIf=\"metadata.otherLanguages?.length\">\n <p class=\"text-sm mb-1\" translate>record.metadata.languages</p>\n <div class=\"flex flex-row gap-1 flex-wrap\">\n <p\n class=\"text-primary font-medium\"\n translate\n *ngFor=\"let language of metadata.otherLanguages\"\n >\n language.{{ language }}\n </p>\n </div>\n </div>\n <div *ngIf=\"temporalExtent\">\n <p class=\"text-sm\" translate>record.metadata.temporalExtent</p>\n <div class=\"flex flex-row gap-1 mb-1 text-primary font-medium\">\n <p\n *ngIf=\"temporalExtent.start && temporalExtent.end\"\n translate\n [translateParams]=\"{\n start: temporalExtent.start,\n end: temporalExtent.end,\n }\"\n >\n record.metadata.temporalExtent.fromDateToDate\n </p>\n <p\n *ngIf=\"temporalExtent.start && !temporalExtent.end\"\n translate\n [translateParams]=\"{ start: temporalExtent.start }\"\n >\n record.metadata.temporalExtent.sinceDate\n </p>\n <p\n *ngIf=\"!temporalExtent.start && temporalExtent.end\"\n translate\n [translateParams]=\"{ end: temporalExtent.end }\"\n >\n record.metadata.temporalExtent.untilDate\n </p>\n </div>\n </div>\n </div>\n</gn-ui-expandable-panel>\n<gn-ui-expandable-panel\n *ngIf=\"metadata.kind !== 'dataset' && metadata.spatialExtents\"\n [title]=\"'service.metadata.spatialExtent' | translate\"\n data-test=\"spatial-extent-panel\"\n>\n <gn-ui-spatial-extent\n class=\"flex h-[271px] w-full rounded-lg border border-gray-100 mt-3 mb-6\"\n [spatialExtents]=\"metadata.spatialExtents\"\n ></gn-ui-spatial-extent>\n</gn-ui-expandable-panel>\n<gn-ui-expandable-panel\n *ngIf=\"metadata.landingPage\"\n [title]=\"'service.metadata.other' | translate\"\n data-test=\"other-panel\"\n>\n <div class=\"flex flex-col gap-4 mr-4 py-5 rounded text-gray-700\">\n <div *ngIf=\"metadata.recordUpdated\">\n <p class=\"text-sm\" translate>record.metadata.updatedOn</p>\n <p class=\"text-primary font-medium\">\n {{ metadata.recordUpdated && formatDateTime(metadata.recordUpdated) }}\n </p>\n </div>\n <div *ngIf=\"metadata.landingPage\">\n <p class=\"text-sm\" translate>record.metadata.sheet</p>\n <p class=\"text-primary font-medium\" translate>\n <a [href]=\"metadata.landingPage\" target=\"_blank\">\n <span class=\"break-all\" gnUiLinkify>{{ metadata.landingPage }}</span>\n </a>\n </p>\n </div>\n <div *ngIf=\"metadata.ownerOrganization\">\n <p class=\"text-sm\" translate>record.metadata.owner</p>\n <p class=\"text-primary font-medium\">\n {{ metadata.ownerOrganization.name }}\n </p>\n </div>\n <div *ngIf=\"metadata.uniqueIdentifier\">\n <p class=\"text-sm\" translate>record.metadata.uniqueId</p>\n <div class=\"flex flex-row content-align items-end gap-1\">\n <gn-ui-copy-text-button\n [text]=\"metadata.uniqueIdentifier\"\n [tooltipText]=\"'tooltip.id.copy' | translate\"\n [displayText]=\"false\"\n ></gn-ui-copy-text-button>\n <p class=\"text-primary font-medium\">\n {{ metadata.uniqueIdentifier }}\n </p>\n </div>\n </div>\n <div *ngIf=\"metadata.topics?.length\">\n <p class=\"text-sm mb-1\" translate>record.metadata.topics</p>\n <div class=\"sm:pb-4 sm:pr-16\">\n <gn-ui-badge\n [clickable]=\"false\"\n class=\"inline-block mr-2 mb-2 lowercase\"\n *ngFor=\"let topic of metadata.topics\"\n >{{ topic }}</gn-ui-badge\n >\n </div>\n </div>\n </div>\n</gn-ui-expandable-panel>\n", styles: [".md-description ::ng-deep a{@apply underline text-blue-600 hover:text-blue-800;}.info-grid>:nth-last-child(n+3){padding-bottom:10px;@apply border-b border-gray-300;}:host ::ng-deep gn-ui-copy-text-button button ng-icon{transform:scale(.8)}:host{--gn-ui-badge-background-color: var(--color-primary-white);--gn-ui-badge-text-color: var(--color-primary-darkest)}:host .metadata-info-keywords ::ng-deep gn-ui-badge:hover{--gn-ui-badge-text-color: white}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: TranslateDirective, selector: "[translate],[ngx-translate]", inputs: ["translate", "translateParams"] }, { kind: "pipe", type: TranslatePipe, name: "translate" }, { kind: "component", type: MarkdownParserComponent, selector: "gn-ui-markdown-parser", inputs: ["textContent", "whitoutStyles"] }, { kind: "component", type: ExpandablePanelComponent, selector: "gn-ui-expandable-panel", inputs: ["title", "iconColor", "collapsed"] }, { kind: "component", type: BadgeComponent, selector: "gn-ui-badge", inputs: ["clickable", "removable"], outputs: ["badgeRemoveClicked"] }, { kind: "component", type: ContentGhostComponent, selector: "gn-ui-content-ghost", inputs: ["showContent", "ghostClass"] }, { kind: "component", type: ThumbnailComponent, selector: "gn-ui-thumbnail", inputs: ["thumbnailUrl", "fit"], outputs: ["placeholderShown"] }, { kind: "component", type: MaxLinesComponent, selector: "gn-ui-max-lines", inputs: ["maxLines"] }, { kind: "component", type: CopyTextButtonComponent, selector: "gn-ui-copy-text-button", inputs: ["text", "tooltipText", "displayText", "rows"] }, { kind: "component", type: NgIcon, selector: "ng-icon", inputs: ["name", "svg", "size", "strokeWidth", "color"] }, { kind: "directive", type: GnUiLinkifyDirective, selector: "[gnUiLinkify]" }, { kind: "component", type: SpatialExtentComponent, selector: "gn-ui-spatial-extent", inputs: ["spatialExtents"] }], viewProviders: [
92
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: MetadataInfoComponent, isStandalone: true, selector: "gn-ui-metadata-info", inputs: { metadata: "metadata", incomplete: "incomplete" }, outputs: { keyword: "keyword" }, ngImport: i0, template: "<div class=\"mb-6 md-description sm:mb-4 sm:pr-16\">\n <gn-ui-content-ghost\n ghostClass=\"h-[178px]\"\n [showContent]=\"fieldReady('abstract')\"\n >\n <gn-ui-max-lines [maxLines]=\"6\" *ngIf=\"metadata.abstract\">\n <div class=\"mb-6\">\n <gn-ui-markdown-parser\n [textContent]=\"metadata.abstract\"\n ></gn-ui-markdown-parser>\n </div>\n </gn-ui-max-lines>\n </gn-ui-content-ghost>\n\n <p\n class=\"mt-6 mb-3 font-medium text-black text-sm\"\n translate\n *ngIf=\"!fieldReady('keywords') || metadata.keywords?.length\"\n >\n record.metadata.keywords\n </p>\n\n <gn-ui-content-ghost\n ghostClass=\"h-[31px] w-3/4\"\n [showContent]=\"fieldReady('keywords')\"\n >\n <div *ngIf=\"metadata.keywords?.length\">\n <div class=\"metadata-info-keywords sm:pb-4 flex flex-wrap gap-2\">\n <gn-ui-badge\n class=\"inline-block lowercase\"\n (click)=\"onKeywordClick(keyword)\"\n [clickable]=\"true\"\n *ngFor=\"let keyword of metadata.keywords\"\n >{{ keyword.label }}</gn-ui-badge\n >\n </div>\n </div>\n </gn-ui-content-ghost>\n</div>\n\n<gn-ui-expandable-panel\n *ngIf=\"\n metadata.licenses ||\n metadata.legalConstraints ||\n metadata.securityConstraints ||\n metadata.otherConstraints\n \"\n [title]=\"'record.metadata.usage' | translate\"\n data-test=\"usage-panel\"\n>\n <div class=\"flex flex-col gap-[10px] mr-4 py-[12px] rounded text-gray-900\">\n <ng-container *ngFor=\"let license of licenses\">\n <div *ngIf=\"license.url; else noUrl\" class=\"text-primary\">\n <a\n [href]=\"license.url\"\n target=\"_blank\"\n class=\"cursor-pointer hover:underline transition-all\"\n >\n {{ license.text }}\n <ng-icon\n class=\"!w-[12px] !h-[12px] !text-[12px] opacity-75 shrink-0\"\n name=\"matOpenInNew\"\n ></ng-icon>\n </a>\n </div>\n <ng-template #noUrl>\n <div class=\"text-primary\" gnUiLinkify>\n {{ license.text }}\n </div>\n </ng-template>\n </ng-container>\n <ng-container *ngIf=\"legalConstraints.length\">\n <div class=\"mb-6\">\n <gn-ui-markdown-parser\n *ngFor=\"let constraint of legalConstraints\"\n [textContent]=\"constraint\"\n >\n </gn-ui-markdown-parser>\n </div>\n </ng-container>\n <ng-container *ngIf=\"otherConstraints.length\">\n <div gnUiLinkify *ngFor=\"let constraint of otherConstraints\">\n <span\n translate\n class=\"font-medium text-black text-sm mb-[2px] mt-[16px]\"\n >\n record.metadata.otherConstraints\n </span>\n <div class=\"mb-6\">\n <gn-ui-markdown-parser [textContent]=\"constraint\">\n </gn-ui-markdown-parser>\n </div>\n </div>\n </ng-container>\n\n <span class=\"noUsage\" *ngIf=\"!hasUsage\">\n {{ 'record.metadata.noUsage' | translate }}\n </span>\n </div>\n</gn-ui-expandable-panel>\n<gn-ui-expandable-panel\n *ngIf=\"\n (metadata.kind === 'dataset' && metadata.lineage) ||\n metadata.resourceUpdated ||\n metadata.updateFrequency ||\n (metadata.kind === 'dataset' && metadata.status)\n \"\n [title]=\"'record.metadata.details' | translate\"\n data-test=\"details-panel\"\n>\n <div *ngIf=\"metadata.lineage\" class=\"text-gray-900 flex flex-col mt-4 gap-2\">\n <p class=\"whitespace-pre-line break-words text-gray-900\" gnUiLinkify>\n {{ metadata.lineage }}\n </p>\n </div>\n <div class=\"flex flex-row gap-6 mt-5 mb-8\" *ngIf=\"resourceContact\">\n <div\n *ngIf=\"resourceContact.organization?.logoUrl?.href\"\n class=\"flex items-center justify-center border-solid border border-gray-300 rounded-md bg-white h-32 overflow-hidden\"\n >\n <gn-ui-thumbnail\n class=\"relative h-full w-full\"\n [thumbnailUrl]=\"resourceContact.organization.logoUrl.href\"\n fit=\"contain\"\n ></gn-ui-thumbnail>\n </div>\n <div class=\"flex flex-col gap-1\">\n <p class=\"text-sm font-medium\" translate>record.metadata.producer</p>\n <div\n class=\"text-primary font-title text-21 mr-2 cursor-pointer hover:underline\"\n data-cy=\"organization-name\"\n >\n {{ resourceContact.organization?.name }}\n </div>\n <div *ngIf=\"resourceContact.organization?.website\">\n <a\n [href]=\"resourceContact.organization.website\"\n target=\"_blank\"\n class=\"contact-website text-primary text-sm cursor-pointer hover:underline transition-all\"\n >{{ resourceContact.organization.website }}\n <ng-icon\n class=\"!w-[12px] !h-[12px] !text-[12px] opacity-75 shrink-0\"\n name=\"matOpenInNew\"\n ></ng-icon>\n </a>\n </div>\n <div class=\"mt-4\" *ngIf=\"resourceContact.email\">\n <div class=\"flex\">\n <ng-icon\n class=\"!w-5 !h-5 !text-[20px] opacity-75 shrink-0\"\n name=\"matMailOutline\"\n ></ng-icon>\n <a\n *ngIf=\"resourceContact.email\"\n [href]=\"'mailto:' + resourceContact.email\"\n class=\"text-sm hover:underline ml-2\"\n target=\"_blank\"\n data-cy=\"contact-email\"\n >{{ resourceContact?.email }}</a\n >\n </div>\n </div>\n </div>\n </div>\n <div\n class=\"py-6 px-6 rounded bg-gray-100 grid grid-cols-2 gap-y-6 gap-x-[20px] text-gray-700\"\n >\n <div *ngIf=\"metadata.resourceCreated\">\n <p class=\"text-sm\" translate>record.metadata.creation</p>\n <p class=\"text-primary font-medium mt-1\">\n {{ formatDate(metadata.resourceCreated) }}\n </p>\n </div>\n <div *ngIf=\"metadata.resourcePublished\">\n <p class=\"text-sm\" translate>record.metadata.publication</p>\n <p class=\"text-primary font-medium mt-1\">\n {{ formatDate(metadata.resourcePublished) }}\n </p>\n </div>\n <div *ngIf=\"updateFrequency\">\n <p class=\"text-sm\" translate>record.metadata.updateFrequency</p>\n <p\n class=\"text-primary font-medium mt-1 updateFrequency\"\n translate\n [translateParams]=\"{ count: updatedTimes }\"\n >\n {{ updateFrequency }}\n </p>\n </div>\n <div *ngIf=\"metadata.otherLanguages?.length\">\n <p class=\"text-sm mb-1\" translate>record.metadata.languages</p>\n <div class=\"flex flex-row gap-1 flex-wrap\">\n <p\n class=\"text-primary font-medium\"\n translate\n *ngFor=\"let language of metadata.otherLanguages\"\n >\n language.{{ language }}\n </p>\n </div>\n </div>\n <div *ngIf=\"temporalExtent\">\n <p class=\"text-sm\" translate>record.metadata.temporalExtent</p>\n <div class=\"flex flex-row gap-1 mb-1 text-primary font-medium\">\n <p\n *ngIf=\"temporalExtent.start && temporalExtent.end\"\n translate\n [translateParams]=\"{\n start: temporalExtent.start,\n end: temporalExtent.end,\n }\"\n >\n record.metadata.temporalExtent.fromDateToDate\n </p>\n <p\n *ngIf=\"temporalExtent.start && !temporalExtent.end\"\n translate\n [translateParams]=\"{ start: temporalExtent.start }\"\n >\n record.metadata.temporalExtent.sinceDate\n </p>\n <p\n *ngIf=\"!temporalExtent.start && temporalExtent.end\"\n translate\n [translateParams]=\"{ end: temporalExtent.end }\"\n >\n record.metadata.temporalExtent.untilDate\n </p>\n </div>\n </div>\n </div>\n</gn-ui-expandable-panel>\n<gn-ui-expandable-panel\n *ngIf=\"\n metadata.kind !== 'dataset' &&\n metadata.spatialExtents &&\n metadata.spatialExtents.length\n \"\n [title]=\"'service.metadata.spatialExtent' | translate\"\n data-test=\"spatial-extent-panel\"\n>\n <gn-ui-spatial-extent\n class=\"flex h-[271px] w-full rounded-lg border border-gray-100 mt-3 mb-6\"\n [spatialExtents]=\"metadata.spatialExtents\"\n ></gn-ui-spatial-extent>\n</gn-ui-expandable-panel>\n<gn-ui-expandable-panel\n *ngIf=\"metadata.landingPage\"\n [title]=\"'service.metadata.other' | translate\"\n data-test=\"other-panel\"\n>\n <div class=\"flex flex-col gap-4 mr-4 py-5 rounded text-gray-700\">\n <div *ngIf=\"metadata.recordUpdated\">\n <p class=\"text-sm\" translate>record.metadata.updatedOn</p>\n <p class=\"text-primary font-medium\">\n {{ metadata.recordUpdated && formatDateTime(metadata.recordUpdated) }}\n </p>\n </div>\n <div *ngIf=\"metadata.landingPage\">\n <p class=\"text-sm\" translate>record.metadata.sheet</p>\n <p class=\"text-primary font-medium\" translate>\n <a [href]=\"metadata.landingPage\" target=\"_blank\">\n <span class=\"break-all\" gnUiLinkify>{{ metadata.landingPage }}</span>\n </a>\n </p>\n </div>\n <div *ngIf=\"metadata.ownerOrganization\">\n <p class=\"text-sm\" translate>record.metadata.owner</p>\n <p class=\"text-primary font-medium\">\n {{ metadata.ownerOrganization.name }}\n </p>\n </div>\n <div *ngIf=\"metadata.uniqueIdentifier\">\n <p class=\"text-sm\" translate>record.metadata.uniqueId</p>\n <div class=\"flex flex-row content-align items-end gap-1\">\n <gn-ui-copy-text-button\n [text]=\"metadata.uniqueIdentifier\"\n [tooltipText]=\"'tooltip.id.copy' | translate\"\n [displayText]=\"false\"\n ></gn-ui-copy-text-button>\n <p class=\"text-primary font-medium\">\n {{ metadata.uniqueIdentifier }}\n </p>\n </div>\n </div>\n <div *ngIf=\"metadata.topics?.length\">\n <p class=\"text-sm mb-1\" translate>record.metadata.topics</p>\n <div class=\"sm:pb-4 sm:pr-16\">\n <gn-ui-badge\n [clickable]=\"false\"\n class=\"inline-block mr-2 mb-2 lowercase\"\n *ngFor=\"let topic of metadata.topics\"\n >{{ topic }}</gn-ui-badge\n >\n </div>\n </div>\n </div>\n</gn-ui-expandable-panel>\n", styles: [".md-description ::ng-deep a{@apply underline text-blue-600 hover:text-blue-800;}.info-grid>:nth-last-child(n+3){padding-bottom:10px;@apply border-b border-gray-300;}:host ::ng-deep gn-ui-copy-text-button button ng-icon{transform:scale(.8)}:host{--gn-ui-badge-background-color: var(--color-primary-white);--gn-ui-badge-text-color: var(--color-primary-darkest)}:host .metadata-info-keywords ::ng-deep gn-ui-badge:hover{--gn-ui-badge-text-color: white}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: TranslateDirective, selector: "[translate],[ngx-translate]", inputs: ["translate", "translateParams"] }, { kind: "pipe", type: TranslatePipe, name: "translate" }, { kind: "component", type: MarkdownParserComponent, selector: "gn-ui-markdown-parser", inputs: ["textContent", "whitoutStyles"] }, { kind: "component", type: ExpandablePanelComponent, selector: "gn-ui-expandable-panel", inputs: ["title", "iconColor", "collapsed"] }, { kind: "component", type: BadgeComponent, selector: "gn-ui-badge", inputs: ["clickable", "removable"], outputs: ["badgeRemoveClicked"] }, { kind: "component", type: ContentGhostComponent, selector: "gn-ui-content-ghost", inputs: ["showContent", "ghostClass"] }, { kind: "component", type: ThumbnailComponent, selector: "gn-ui-thumbnail", inputs: ["thumbnailUrl", "fit"], outputs: ["placeholderShown"] }, { kind: "component", type: MaxLinesComponent, selector: "gn-ui-max-lines", inputs: ["maxLines"] }, { kind: "component", type: CopyTextButtonComponent, selector: "gn-ui-copy-text-button", inputs: ["text", "tooltipText", "displayText", "rows"] }, { kind: "component", type: NgIcon, selector: "ng-icon", inputs: ["name", "svg", "size", "strokeWidth", "color"] }, { kind: "directive", type: GnUiLinkifyDirective, selector: "[gnUiLinkify]" }, { kind: "component", type: SpatialExtentComponent, selector: "gn-ui-spatial-extent", inputs: ["spatialExtents"] }], viewProviders: [
93
93
  provideIcons({
94
94
  matOpenInNew,
95
95
  matMailOutline,
@@ -117,7 +117,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
117
117
  matOpenInNew,
118
118
  matMailOutline,
119
119
  }),
120
- ], template: "<div class=\"mb-6 md-description sm:mb-4 sm:pr-16\">\n <gn-ui-content-ghost\n ghostClass=\"h-[178px]\"\n [showContent]=\"fieldReady('abstract')\"\n >\n <gn-ui-max-lines [maxLines]=\"6\" *ngIf=\"metadata.abstract\">\n <div class=\"mb-6\">\n <gn-ui-markdown-parser\n [textContent]=\"metadata.abstract\"\n ></gn-ui-markdown-parser>\n </div>\n </gn-ui-max-lines>\n </gn-ui-content-ghost>\n\n <p\n class=\"mt-6 mb-3 font-medium text-black text-sm\"\n translate\n *ngIf=\"!fieldReady('keywords') || metadata.keywords?.length\"\n >\n record.metadata.keywords\n </p>\n\n <gn-ui-content-ghost\n ghostClass=\"h-[31px] w-3/4\"\n [showContent]=\"fieldReady('keywords')\"\n >\n <div *ngIf=\"metadata.keywords?.length\">\n <div class=\"metadata-info-keywords sm:pb-4 flex flex-wrap gap-2\">\n <gn-ui-badge\n class=\"inline-block lowercase\"\n (click)=\"onKeywordClick(keyword)\"\n [clickable]=\"true\"\n *ngFor=\"let keyword of metadata.keywords\"\n >{{ keyword.label }}</gn-ui-badge\n >\n </div>\n </div>\n </gn-ui-content-ghost>\n</div>\n\n<gn-ui-expandable-panel\n *ngIf=\"\n metadata.licenses ||\n metadata.legalConstraints ||\n metadata.securityConstraints ||\n metadata.otherConstraints\n \"\n [title]=\"'record.metadata.usage' | translate\"\n data-test=\"usage-panel\"\n>\n <div class=\"flex flex-col gap-[10px] mr-4 py-[12px] rounded text-gray-900\">\n <ng-container *ngFor=\"let license of licenses\">\n <div *ngIf=\"license.url; else noUrl\" class=\"text-primary\">\n <a\n [href]=\"license.url\"\n target=\"_blank\"\n class=\"cursor-pointer hover:underline transition-all\"\n >\n {{ license.text }}\n <ng-icon\n class=\"!w-[12px] !h-[12px] !text-[12px] opacity-75 shrink-0\"\n name=\"matOpenInNew\"\n ></ng-icon>\n </a>\n </div>\n <ng-template #noUrl>\n <div class=\"text-primary\" gnUiLinkify>\n {{ license.text }}\n </div>\n </ng-template>\n </ng-container>\n <ng-container *ngIf=\"legalConstraints.length\">\n <div class=\"mb-6\">\n <gn-ui-markdown-parser\n *ngFor=\"let constraint of legalConstraints\"\n [textContent]=\"constraint\"\n >\n </gn-ui-markdown-parser>\n </div>\n </ng-container>\n <ng-container *ngIf=\"otherConstraints.length\">\n <div gnUiLinkify *ngFor=\"let constraint of otherConstraints\">\n <span\n translate\n class=\"font-medium text-black text-sm mb-[2px] mt-[16px]\"\n >\n record.metadata.otherConstraints\n </span>\n <div class=\"mb-6\">\n <gn-ui-markdown-parser [textContent]=\"constraint\">\n </gn-ui-markdown-parser>\n </div>\n </div>\n </ng-container>\n\n <span class=\"noUsage\" *ngIf=\"!hasUsage\">\n {{ 'record.metadata.noUsage' | translate }}\n </span>\n </div>\n</gn-ui-expandable-panel>\n<gn-ui-expandable-panel\n *ngIf=\"\n (metadata.kind === 'dataset' && metadata.lineage) ||\n metadata.resourceUpdated ||\n metadata.updateFrequency ||\n (metadata.kind === 'dataset' && metadata.status)\n \"\n [title]=\"'record.metadata.details' | translate\"\n data-test=\"details-panel\"\n>\n <div *ngIf=\"metadata.lineage\" class=\"text-gray-900 flex flex-col mt-4 gap-2\">\n <p class=\"whitespace-pre-line break-words text-gray-900\" gnUiLinkify>\n {{ metadata.lineage }}\n </p>\n </div>\n <div class=\"flex flex-row gap-6 mt-5 mb-8\" *ngIf=\"resourceContact\">\n <div\n *ngIf=\"resourceContact.organization?.logoUrl?.href\"\n class=\"flex items-center justify-center border-solid border border-gray-300 rounded-md bg-white h-32 overflow-hidden\"\n >\n <gn-ui-thumbnail\n class=\"relative h-full w-full\"\n [thumbnailUrl]=\"resourceContact.organization.logoUrl.href\"\n fit=\"contain\"\n ></gn-ui-thumbnail>\n </div>\n <div class=\"flex flex-col gap-1\">\n <p class=\"text-sm font-medium\" translate>record.metadata.producer</p>\n <div\n class=\"text-primary font-title text-21 mr-2 cursor-pointer hover:underline\"\n data-cy=\"organization-name\"\n >\n {{ resourceContact.organization?.name }}\n </div>\n <div *ngIf=\"resourceContact.organization?.website\">\n <a\n [href]=\"resourceContact.organization.website\"\n target=\"_blank\"\n class=\"contact-website text-primary text-sm cursor-pointer hover:underline transition-all\"\n >{{ resourceContact.organization.website }}\n <ng-icon\n class=\"!w-[12px] !h-[12px] !text-[12px] opacity-75 shrink-0\"\n name=\"matOpenInNew\"\n ></ng-icon>\n </a>\n </div>\n <div class=\"mt-4\" *ngIf=\"resourceContact.email\">\n <div class=\"flex\">\n <ng-icon\n class=\"!w-5 !h-5 !text-[20px] opacity-75 shrink-0\"\n name=\"matMailOutline\"\n ></ng-icon>\n <a\n *ngIf=\"resourceContact.email\"\n [href]=\"'mailto:' + resourceContact.email\"\n class=\"text-sm hover:underline ml-2\"\n target=\"_blank\"\n data-cy=\"contact-email\"\n >{{ resourceContact?.email }}</a\n >\n </div>\n </div>\n </div>\n </div>\n <div\n class=\"py-6 px-6 rounded bg-gray-100 grid grid-cols-2 gap-y-6 gap-x-[20px] text-gray-700\"\n >\n <div *ngIf=\"metadata.resourceCreated\">\n <p class=\"text-sm\" translate>record.metadata.creation</p>\n <p class=\"text-primary font-medium mt-1\">\n {{ formatDate(metadata.resourceCreated) }}\n </p>\n </div>\n <div *ngIf=\"metadata.resourcePublished\">\n <p class=\"text-sm\" translate>record.metadata.publication</p>\n <p class=\"text-primary font-medium mt-1\">\n {{ formatDate(metadata.resourcePublished) }}\n </p>\n </div>\n <div *ngIf=\"updateFrequency\">\n <p class=\"text-sm\" translate>record.metadata.updateFrequency</p>\n <p\n class=\"text-primary font-medium mt-1 updateFrequency\"\n translate\n [translateParams]=\"{ count: updatedTimes }\"\n >\n {{ updateFrequency }}\n </p>\n </div>\n <div *ngIf=\"metadata.otherLanguages?.length\">\n <p class=\"text-sm mb-1\" translate>record.metadata.languages</p>\n <div class=\"flex flex-row gap-1 flex-wrap\">\n <p\n class=\"text-primary font-medium\"\n translate\n *ngFor=\"let language of metadata.otherLanguages\"\n >\n language.{{ language }}\n </p>\n </div>\n </div>\n <div *ngIf=\"temporalExtent\">\n <p class=\"text-sm\" translate>record.metadata.temporalExtent</p>\n <div class=\"flex flex-row gap-1 mb-1 text-primary font-medium\">\n <p\n *ngIf=\"temporalExtent.start && temporalExtent.end\"\n translate\n [translateParams]=\"{\n start: temporalExtent.start,\n end: temporalExtent.end,\n }\"\n >\n record.metadata.temporalExtent.fromDateToDate\n </p>\n <p\n *ngIf=\"temporalExtent.start && !temporalExtent.end\"\n translate\n [translateParams]=\"{ start: temporalExtent.start }\"\n >\n record.metadata.temporalExtent.sinceDate\n </p>\n <p\n *ngIf=\"!temporalExtent.start && temporalExtent.end\"\n translate\n [translateParams]=\"{ end: temporalExtent.end }\"\n >\n record.metadata.temporalExtent.untilDate\n </p>\n </div>\n </div>\n </div>\n</gn-ui-expandable-panel>\n<gn-ui-expandable-panel\n *ngIf=\"metadata.kind !== 'dataset' && metadata.spatialExtents\"\n [title]=\"'service.metadata.spatialExtent' | translate\"\n data-test=\"spatial-extent-panel\"\n>\n <gn-ui-spatial-extent\n class=\"flex h-[271px] w-full rounded-lg border border-gray-100 mt-3 mb-6\"\n [spatialExtents]=\"metadata.spatialExtents\"\n ></gn-ui-spatial-extent>\n</gn-ui-expandable-panel>\n<gn-ui-expandable-panel\n *ngIf=\"metadata.landingPage\"\n [title]=\"'service.metadata.other' | translate\"\n data-test=\"other-panel\"\n>\n <div class=\"flex flex-col gap-4 mr-4 py-5 rounded text-gray-700\">\n <div *ngIf=\"metadata.recordUpdated\">\n <p class=\"text-sm\" translate>record.metadata.updatedOn</p>\n <p class=\"text-primary font-medium\">\n {{ metadata.recordUpdated && formatDateTime(metadata.recordUpdated) }}\n </p>\n </div>\n <div *ngIf=\"metadata.landingPage\">\n <p class=\"text-sm\" translate>record.metadata.sheet</p>\n <p class=\"text-primary font-medium\" translate>\n <a [href]=\"metadata.landingPage\" target=\"_blank\">\n <span class=\"break-all\" gnUiLinkify>{{ metadata.landingPage }}</span>\n </a>\n </p>\n </div>\n <div *ngIf=\"metadata.ownerOrganization\">\n <p class=\"text-sm\" translate>record.metadata.owner</p>\n <p class=\"text-primary font-medium\">\n {{ metadata.ownerOrganization.name }}\n </p>\n </div>\n <div *ngIf=\"metadata.uniqueIdentifier\">\n <p class=\"text-sm\" translate>record.metadata.uniqueId</p>\n <div class=\"flex flex-row content-align items-end gap-1\">\n <gn-ui-copy-text-button\n [text]=\"metadata.uniqueIdentifier\"\n [tooltipText]=\"'tooltip.id.copy' | translate\"\n [displayText]=\"false\"\n ></gn-ui-copy-text-button>\n <p class=\"text-primary font-medium\">\n {{ metadata.uniqueIdentifier }}\n </p>\n </div>\n </div>\n <div *ngIf=\"metadata.topics?.length\">\n <p class=\"text-sm mb-1\" translate>record.metadata.topics</p>\n <div class=\"sm:pb-4 sm:pr-16\">\n <gn-ui-badge\n [clickable]=\"false\"\n class=\"inline-block mr-2 mb-2 lowercase\"\n *ngFor=\"let topic of metadata.topics\"\n >{{ topic }}</gn-ui-badge\n >\n </div>\n </div>\n </div>\n</gn-ui-expandable-panel>\n", styles: [".md-description ::ng-deep a{@apply underline text-blue-600 hover:text-blue-800;}.info-grid>:nth-last-child(n+3){padding-bottom:10px;@apply border-b border-gray-300;}:host ::ng-deep gn-ui-copy-text-button button ng-icon{transform:scale(.8)}:host{--gn-ui-badge-background-color: var(--color-primary-white);--gn-ui-badge-text-color: var(--color-primary-darkest)}:host .metadata-info-keywords ::ng-deep gn-ui-badge:hover{--gn-ui-badge-text-color: white}\n"] }]
120
+ ], template: "<div class=\"mb-6 md-description sm:mb-4 sm:pr-16\">\n <gn-ui-content-ghost\n ghostClass=\"h-[178px]\"\n [showContent]=\"fieldReady('abstract')\"\n >\n <gn-ui-max-lines [maxLines]=\"6\" *ngIf=\"metadata.abstract\">\n <div class=\"mb-6\">\n <gn-ui-markdown-parser\n [textContent]=\"metadata.abstract\"\n ></gn-ui-markdown-parser>\n </div>\n </gn-ui-max-lines>\n </gn-ui-content-ghost>\n\n <p\n class=\"mt-6 mb-3 font-medium text-black text-sm\"\n translate\n *ngIf=\"!fieldReady('keywords') || metadata.keywords?.length\"\n >\n record.metadata.keywords\n </p>\n\n <gn-ui-content-ghost\n ghostClass=\"h-[31px] w-3/4\"\n [showContent]=\"fieldReady('keywords')\"\n >\n <div *ngIf=\"metadata.keywords?.length\">\n <div class=\"metadata-info-keywords sm:pb-4 flex flex-wrap gap-2\">\n <gn-ui-badge\n class=\"inline-block lowercase\"\n (click)=\"onKeywordClick(keyword)\"\n [clickable]=\"true\"\n *ngFor=\"let keyword of metadata.keywords\"\n >{{ keyword.label }}</gn-ui-badge\n >\n </div>\n </div>\n </gn-ui-content-ghost>\n</div>\n\n<gn-ui-expandable-panel\n *ngIf=\"\n metadata.licenses ||\n metadata.legalConstraints ||\n metadata.securityConstraints ||\n metadata.otherConstraints\n \"\n [title]=\"'record.metadata.usage' | translate\"\n data-test=\"usage-panel\"\n>\n <div class=\"flex flex-col gap-[10px] mr-4 py-[12px] rounded text-gray-900\">\n <ng-container *ngFor=\"let license of licenses\">\n <div *ngIf=\"license.url; else noUrl\" class=\"text-primary\">\n <a\n [href]=\"license.url\"\n target=\"_blank\"\n class=\"cursor-pointer hover:underline transition-all\"\n >\n {{ license.text }}\n <ng-icon\n class=\"!w-[12px] !h-[12px] !text-[12px] opacity-75 shrink-0\"\n name=\"matOpenInNew\"\n ></ng-icon>\n </a>\n </div>\n <ng-template #noUrl>\n <div class=\"text-primary\" gnUiLinkify>\n {{ license.text }}\n </div>\n </ng-template>\n </ng-container>\n <ng-container *ngIf=\"legalConstraints.length\">\n <div class=\"mb-6\">\n <gn-ui-markdown-parser\n *ngFor=\"let constraint of legalConstraints\"\n [textContent]=\"constraint\"\n >\n </gn-ui-markdown-parser>\n </div>\n </ng-container>\n <ng-container *ngIf=\"otherConstraints.length\">\n <div gnUiLinkify *ngFor=\"let constraint of otherConstraints\">\n <span\n translate\n class=\"font-medium text-black text-sm mb-[2px] mt-[16px]\"\n >\n record.metadata.otherConstraints\n </span>\n <div class=\"mb-6\">\n <gn-ui-markdown-parser [textContent]=\"constraint\">\n </gn-ui-markdown-parser>\n </div>\n </div>\n </ng-container>\n\n <span class=\"noUsage\" *ngIf=\"!hasUsage\">\n {{ 'record.metadata.noUsage' | translate }}\n </span>\n </div>\n</gn-ui-expandable-panel>\n<gn-ui-expandable-panel\n *ngIf=\"\n (metadata.kind === 'dataset' && metadata.lineage) ||\n metadata.resourceUpdated ||\n metadata.updateFrequency ||\n (metadata.kind === 'dataset' && metadata.status)\n \"\n [title]=\"'record.metadata.details' | translate\"\n data-test=\"details-panel\"\n>\n <div *ngIf=\"metadata.lineage\" class=\"text-gray-900 flex flex-col mt-4 gap-2\">\n <p class=\"whitespace-pre-line break-words text-gray-900\" gnUiLinkify>\n {{ metadata.lineage }}\n </p>\n </div>\n <div class=\"flex flex-row gap-6 mt-5 mb-8\" *ngIf=\"resourceContact\">\n <div\n *ngIf=\"resourceContact.organization?.logoUrl?.href\"\n class=\"flex items-center justify-center border-solid border border-gray-300 rounded-md bg-white h-32 overflow-hidden\"\n >\n <gn-ui-thumbnail\n class=\"relative h-full w-full\"\n [thumbnailUrl]=\"resourceContact.organization.logoUrl.href\"\n fit=\"contain\"\n ></gn-ui-thumbnail>\n </div>\n <div class=\"flex flex-col gap-1\">\n <p class=\"text-sm font-medium\" translate>record.metadata.producer</p>\n <div\n class=\"text-primary font-title text-21 mr-2 cursor-pointer hover:underline\"\n data-cy=\"organization-name\"\n >\n {{ resourceContact.organization?.name }}\n </div>\n <div *ngIf=\"resourceContact.organization?.website\">\n <a\n [href]=\"resourceContact.organization.website\"\n target=\"_blank\"\n class=\"contact-website text-primary text-sm cursor-pointer hover:underline transition-all\"\n >{{ resourceContact.organization.website }}\n <ng-icon\n class=\"!w-[12px] !h-[12px] !text-[12px] opacity-75 shrink-0\"\n name=\"matOpenInNew\"\n ></ng-icon>\n </a>\n </div>\n <div class=\"mt-4\" *ngIf=\"resourceContact.email\">\n <div class=\"flex\">\n <ng-icon\n class=\"!w-5 !h-5 !text-[20px] opacity-75 shrink-0\"\n name=\"matMailOutline\"\n ></ng-icon>\n <a\n *ngIf=\"resourceContact.email\"\n [href]=\"'mailto:' + resourceContact.email\"\n class=\"text-sm hover:underline ml-2\"\n target=\"_blank\"\n data-cy=\"contact-email\"\n >{{ resourceContact?.email }}</a\n >\n </div>\n </div>\n </div>\n </div>\n <div\n class=\"py-6 px-6 rounded bg-gray-100 grid grid-cols-2 gap-y-6 gap-x-[20px] text-gray-700\"\n >\n <div *ngIf=\"metadata.resourceCreated\">\n <p class=\"text-sm\" translate>record.metadata.creation</p>\n <p class=\"text-primary font-medium mt-1\">\n {{ formatDate(metadata.resourceCreated) }}\n </p>\n </div>\n <div *ngIf=\"metadata.resourcePublished\">\n <p class=\"text-sm\" translate>record.metadata.publication</p>\n <p class=\"text-primary font-medium mt-1\">\n {{ formatDate(metadata.resourcePublished) }}\n </p>\n </div>\n <div *ngIf=\"updateFrequency\">\n <p class=\"text-sm\" translate>record.metadata.updateFrequency</p>\n <p\n class=\"text-primary font-medium mt-1 updateFrequency\"\n translate\n [translateParams]=\"{ count: updatedTimes }\"\n >\n {{ updateFrequency }}\n </p>\n </div>\n <div *ngIf=\"metadata.otherLanguages?.length\">\n <p class=\"text-sm mb-1\" translate>record.metadata.languages</p>\n <div class=\"flex flex-row gap-1 flex-wrap\">\n <p\n class=\"text-primary font-medium\"\n translate\n *ngFor=\"let language of metadata.otherLanguages\"\n >\n language.{{ language }}\n </p>\n </div>\n </div>\n <div *ngIf=\"temporalExtent\">\n <p class=\"text-sm\" translate>record.metadata.temporalExtent</p>\n <div class=\"flex flex-row gap-1 mb-1 text-primary font-medium\">\n <p\n *ngIf=\"temporalExtent.start && temporalExtent.end\"\n translate\n [translateParams]=\"{\n start: temporalExtent.start,\n end: temporalExtent.end,\n }\"\n >\n record.metadata.temporalExtent.fromDateToDate\n </p>\n <p\n *ngIf=\"temporalExtent.start && !temporalExtent.end\"\n translate\n [translateParams]=\"{ start: temporalExtent.start }\"\n >\n record.metadata.temporalExtent.sinceDate\n </p>\n <p\n *ngIf=\"!temporalExtent.start && temporalExtent.end\"\n translate\n [translateParams]=\"{ end: temporalExtent.end }\"\n >\n record.metadata.temporalExtent.untilDate\n </p>\n </div>\n </div>\n </div>\n</gn-ui-expandable-panel>\n<gn-ui-expandable-panel\n *ngIf=\"\n metadata.kind !== 'dataset' &&\n metadata.spatialExtents &&\n metadata.spatialExtents.length\n \"\n [title]=\"'service.metadata.spatialExtent' | translate\"\n data-test=\"spatial-extent-panel\"\n>\n <gn-ui-spatial-extent\n class=\"flex h-[271px] w-full rounded-lg border border-gray-100 mt-3 mb-6\"\n [spatialExtents]=\"metadata.spatialExtents\"\n ></gn-ui-spatial-extent>\n</gn-ui-expandable-panel>\n<gn-ui-expandable-panel\n *ngIf=\"metadata.landingPage\"\n [title]=\"'service.metadata.other' | translate\"\n data-test=\"other-panel\"\n>\n <div class=\"flex flex-col gap-4 mr-4 py-5 rounded text-gray-700\">\n <div *ngIf=\"metadata.recordUpdated\">\n <p class=\"text-sm\" translate>record.metadata.updatedOn</p>\n <p class=\"text-primary font-medium\">\n {{ metadata.recordUpdated && formatDateTime(metadata.recordUpdated) }}\n </p>\n </div>\n <div *ngIf=\"metadata.landingPage\">\n <p class=\"text-sm\" translate>record.metadata.sheet</p>\n <p class=\"text-primary font-medium\" translate>\n <a [href]=\"metadata.landingPage\" target=\"_blank\">\n <span class=\"break-all\" gnUiLinkify>{{ metadata.landingPage }}</span>\n </a>\n </p>\n </div>\n <div *ngIf=\"metadata.ownerOrganization\">\n <p class=\"text-sm\" translate>record.metadata.owner</p>\n <p class=\"text-primary font-medium\">\n {{ metadata.ownerOrganization.name }}\n </p>\n </div>\n <div *ngIf=\"metadata.uniqueIdentifier\">\n <p class=\"text-sm\" translate>record.metadata.uniqueId</p>\n <div class=\"flex flex-row content-align items-end gap-1\">\n <gn-ui-copy-text-button\n [text]=\"metadata.uniqueIdentifier\"\n [tooltipText]=\"'tooltip.id.copy' | translate\"\n [displayText]=\"false\"\n ></gn-ui-copy-text-button>\n <p class=\"text-primary font-medium\">\n {{ metadata.uniqueIdentifier }}\n </p>\n </div>\n </div>\n <div *ngIf=\"metadata.topics?.length\">\n <p class=\"text-sm mb-1\" translate>record.metadata.topics</p>\n <div class=\"sm:pb-4 sm:pr-16\">\n <gn-ui-badge\n [clickable]=\"false\"\n class=\"inline-block mr-2 mb-2 lowercase\"\n *ngFor=\"let topic of metadata.topics\"\n >{{ topic }}</gn-ui-badge\n >\n </div>\n </div>\n </div>\n</gn-ui-expandable-panel>\n", styles: [".md-description ::ng-deep a{@apply underline text-blue-600 hover:text-blue-800;}.info-grid>:nth-last-child(n+3){padding-bottom:10px;@apply border-b border-gray-300;}:host ::ng-deep gn-ui-copy-text-button button ng-icon{transform:scale(.8)}:host{--gn-ui-badge-background-color: var(--color-primary-white);--gn-ui-badge-text-color: var(--color-primary-darkest)}:host .metadata-info-keywords ::ng-deep gn-ui-badge:hover{--gn-ui-badge-text-color: white}\n"] }]
121
121
  }], ctorParameters: () => [{ type: i1.DateService }], propDecorators: { metadata: [{
122
122
  type: Input
123
123
  }], incomplete: [{
@@ -125,4 +125,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
125
125
  }], keyword: [{
126
126
  type: Output
127
127
  }] } });
128
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"metadata-info.component.js","sourceRoot":"","sources":["../../../../../../../../libs/ui/elements/src/lib/metadata-info/metadata-info.component.ts","../../../../../../../../libs/ui/elements/src/lib/metadata-info/metadata-info.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  EventEmitter,\n  Input,\n  Output,\n} from '@angular/core'\nimport {\n  CatalogRecord,\n  Keyword,\n} from '../../../../../../libs/common/domain/src/lib/model/record'\nimport { DateService, getTemporalRangeUnion } from '../../../../../../libs/util/shared/src'\nimport { MarkdownParserComponent } from '../markdown-parser/markdown-parser.component'\nimport {\n  ExpandablePanelComponent,\n  MaxLinesComponent,\n} from '../../../../../../libs/ui/layout/src'\nimport { TranslateDirective, TranslatePipe } from '@ngx-translate/core'\nimport {\n  BadgeComponent,\n  CopyTextButtonComponent,\n} from '../../../../../../libs/ui/inputs/src'\nimport { ContentGhostComponent } from '../content-ghost/content-ghost.component'\nimport { NgIcon, provideIcons } from '@ng-icons/core'\nimport { matOpenInNew } from '@ng-icons/material-icons/baseline'\nimport { matMailOutline } from '@ng-icons/material-icons/outline'\nimport { ThumbnailComponent } from '../thumbnail/thumbnail.component'\nimport { GnUiLinkifyDirective } from './linkify.directive'\n\nimport { CommonModule } from '@angular/common'\nimport { SpatialExtentComponent } from '../../../../../../libs/ui/map/src'\n\n@Component({\n  selector: 'gn-ui-metadata-info',\n  templateUrl: './metadata-info.component.html',\n  styleUrls: ['./metadata-info.component.css'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true,\n  imports: [\n    CommonModule,\n    TranslateDirective,\n    TranslatePipe,\n    MarkdownParserComponent,\n    ExpandablePanelComponent,\n    BadgeComponent,\n    ContentGhostComponent,\n    ThumbnailComponent,\n    MaxLinesComponent,\n    CopyTextButtonComponent,\n    NgIcon,\n    GnUiLinkifyDirective,\n    SpatialExtentComponent,\n  ],\n  viewProviders: [\n    provideIcons({\n      matOpenInNew,\n      matMailOutline,\n    }),\n  ],\n})\nexport class MetadataInfoComponent {\n  @Input() metadata: Partial<CatalogRecord>\n  @Input() incomplete: boolean\n  @Output() keyword = new EventEmitter<Keyword>()\n  updatedTimes: number\n\n  constructor(private dateService: DateService) {}\n\n  get hasUsage() {\n    return (\n      this.metadata.extras?.isOpenData === true ||\n      (this.metadata.legalConstraints?.length > 0 &&\n        this.legalConstraints.length > 0) ||\n      (this.metadata.otherConstraints?.length > 0 &&\n        this.otherConstraints.length > 0) ||\n      (this.metadata.licenses?.length > 0 && this.licenses.length > 0)\n    )\n  }\n\n  get legalConstraints() {\n    let array = []\n    if (this.metadata.legalConstraints?.length) {\n      const licensesTexts = this.metadata.licenses.map(\n        (license) => license.text\n      )\n      array = array.concat(\n        this.metadata.legalConstraints\n          .filter((c) => c.text && !licensesTexts.includes(c.text))\n          .map((c) => c.text)\n      )\n    }\n    return array\n  }\n\n  get otherConstraints() {\n    let array = []\n    if (this.metadata.otherConstraints?.length) {\n      array = array.concat(\n        this.metadata.otherConstraints.filter((c) => c.text).map((c) => c.text)\n      )\n    }\n    return array\n  }\n\n  get licenses(): { text: string; url: string }[] {\n    let array = []\n    if (this.metadata.licenses?.length) {\n      array = array.concat(\n        this.metadata.licenses\n          .filter((c) => c.text)\n          .map((c) => ({ text: c.text, url: c.url }))\n      )\n    }\n    return array\n  }\n\n  get updateFrequency(): string {\n    if (this.metadata.updateFrequency instanceof Object) {\n      this.updatedTimes = this.metadata.updateFrequency.updatedTimes\n      return `domain.record.updateFrequency.${this.metadata.updateFrequency.per}`\n    } else if (typeof this.metadata.updateFrequency === 'string') {\n      return `domain.record.updateFrequency.${this.metadata.updateFrequency}`\n    } else {\n      return undefined\n    }\n  }\n\n  get temporalExtent(): { start: string; end: string } {\n    const temporalExtents =\n      this.metadata.kind === 'dataset' ? this.metadata.temporalExtents : []\n    return getTemporalRangeUnion(temporalExtents, this.dateService)\n  }\n\n  get shownOrganization() {\n    return this.metadata.ownerOrganization\n  }\n\n  get resourceContact() {\n    return this.metadata.contactsForResource?.[0]\n  }\n\n  fieldReady(propName: string) {\n    return !this.incomplete || propName in this.metadata\n  }\n\n  onKeywordClick(keyword: Keyword) {\n    this.keyword.emit(keyword)\n  }\n\n  formatDate(date: Date): string {\n    return this.dateService.formatDate(date)\n  }\n\n  formatDateTime(date: Date): string {\n    return this.dateService.formatDateTime(date)\n  }\n}\n","<div class=\"mb-6 md-description sm:mb-4 sm:pr-16\">\n  <gn-ui-content-ghost\n    ghostClass=\"h-[178px]\"\n    [showContent]=\"fieldReady('abstract')\"\n  >\n    <gn-ui-max-lines [maxLines]=\"6\" *ngIf=\"metadata.abstract\">\n      <div class=\"mb-6\">\n        <gn-ui-markdown-parser\n          [textContent]=\"metadata.abstract\"\n        ></gn-ui-markdown-parser>\n      </div>\n    </gn-ui-max-lines>\n  </gn-ui-content-ghost>\n\n  <p\n    class=\"mt-6 mb-3 font-medium text-black text-sm\"\n    translate\n    *ngIf=\"!fieldReady('keywords') || metadata.keywords?.length\"\n  >\n    record.metadata.keywords\n  </p>\n\n  <gn-ui-content-ghost\n    ghostClass=\"h-[31px] w-3/4\"\n    [showContent]=\"fieldReady('keywords')\"\n  >\n    <div *ngIf=\"metadata.keywords?.length\">\n      <div class=\"metadata-info-keywords sm:pb-4 flex flex-wrap gap-2\">\n        <gn-ui-badge\n          class=\"inline-block lowercase\"\n          (click)=\"onKeywordClick(keyword)\"\n          [clickable]=\"true\"\n          *ngFor=\"let keyword of metadata.keywords\"\n          >{{ keyword.label }}</gn-ui-badge\n        >\n      </div>\n    </div>\n  </gn-ui-content-ghost>\n</div>\n\n<gn-ui-expandable-panel\n  *ngIf=\"\n    metadata.licenses ||\n    metadata.legalConstraints ||\n    metadata.securityConstraints ||\n    metadata.otherConstraints\n  \"\n  [title]=\"'record.metadata.usage' | translate\"\n  data-test=\"usage-panel\"\n>\n  <div class=\"flex flex-col gap-[10px] mr-4 py-[12px] rounded text-gray-900\">\n    <ng-container *ngFor=\"let license of licenses\">\n      <div *ngIf=\"license.url; else noUrl\" class=\"text-primary\">\n        <a\n          [href]=\"license.url\"\n          target=\"_blank\"\n          class=\"cursor-pointer hover:underline transition-all\"\n        >\n          {{ license.text }}\n          <ng-icon\n            class=\"!w-[12px] !h-[12px] !text-[12px] opacity-75 shrink-0\"\n            name=\"matOpenInNew\"\n          ></ng-icon>\n        </a>\n      </div>\n      <ng-template #noUrl>\n        <div class=\"text-primary\" gnUiLinkify>\n          {{ license.text }}\n        </div>\n      </ng-template>\n    </ng-container>\n    <ng-container *ngIf=\"legalConstraints.length\">\n      <div class=\"mb-6\">\n        <gn-ui-markdown-parser\n          *ngFor=\"let constraint of legalConstraints\"\n          [textContent]=\"constraint\"\n        >\n        </gn-ui-markdown-parser>\n      </div>\n    </ng-container>\n    <ng-container *ngIf=\"otherConstraints.length\">\n      <div gnUiLinkify *ngFor=\"let constraint of otherConstraints\">\n        <span\n          translate\n          class=\"font-medium text-black text-sm mb-[2px] mt-[16px]\"\n        >\n          record.metadata.otherConstraints\n        </span>\n        <div class=\"mb-6\">\n          <gn-ui-markdown-parser [textContent]=\"constraint\">\n          </gn-ui-markdown-parser>\n        </div>\n      </div>\n    </ng-container>\n\n    <span class=\"noUsage\" *ngIf=\"!hasUsage\">\n      {{ 'record.metadata.noUsage' | translate }}\n    </span>\n  </div>\n</gn-ui-expandable-panel>\n<gn-ui-expandable-panel\n  *ngIf=\"\n    (metadata.kind === 'dataset' && metadata.lineage) ||\n    metadata.resourceUpdated ||\n    metadata.updateFrequency ||\n    (metadata.kind === 'dataset' && metadata.status)\n  \"\n  [title]=\"'record.metadata.details' | translate\"\n  data-test=\"details-panel\"\n>\n  <div *ngIf=\"metadata.lineage\" class=\"text-gray-900 flex flex-col mt-4 gap-2\">\n    <p class=\"whitespace-pre-line break-words text-gray-900\" gnUiLinkify>\n      {{ metadata.lineage }}\n    </p>\n  </div>\n  <div class=\"flex flex-row gap-6 mt-5 mb-8\" *ngIf=\"resourceContact\">\n    <div\n      *ngIf=\"resourceContact.organization?.logoUrl?.href\"\n      class=\"flex items-center justify-center border-solid border border-gray-300 rounded-md bg-white h-32 overflow-hidden\"\n    >\n      <gn-ui-thumbnail\n        class=\"relative h-full w-full\"\n        [thumbnailUrl]=\"resourceContact.organization.logoUrl.href\"\n        fit=\"contain\"\n      ></gn-ui-thumbnail>\n    </div>\n    <div class=\"flex flex-col gap-1\">\n      <p class=\"text-sm font-medium\" translate>record.metadata.producer</p>\n      <div\n        class=\"text-primary font-title text-21 mr-2 cursor-pointer hover:underline\"\n        data-cy=\"organization-name\"\n      >\n        {{ resourceContact.organization?.name }}\n      </div>\n      <div *ngIf=\"resourceContact.organization?.website\">\n        <a\n          [href]=\"resourceContact.organization.website\"\n          target=\"_blank\"\n          class=\"contact-website text-primary text-sm cursor-pointer hover:underline transition-all\"\n          >{{ resourceContact.organization.website }}\n          <ng-icon\n            class=\"!w-[12px] !h-[12px] !text-[12px] opacity-75 shrink-0\"\n            name=\"matOpenInNew\"\n          ></ng-icon>\n        </a>\n      </div>\n      <div class=\"mt-4\" *ngIf=\"resourceContact.email\">\n        <div class=\"flex\">\n          <ng-icon\n            class=\"!w-5 !h-5 !text-[20px] opacity-75 shrink-0\"\n            name=\"matMailOutline\"\n          ></ng-icon>\n          <a\n            *ngIf=\"resourceContact.email\"\n            [href]=\"'mailto:' + resourceContact.email\"\n            class=\"text-sm hover:underline ml-2\"\n            target=\"_blank\"\n            data-cy=\"contact-email\"\n            >{{ resourceContact?.email }}</a\n          >\n        </div>\n      </div>\n    </div>\n  </div>\n  <div\n    class=\"py-6 px-6 rounded bg-gray-100 grid grid-cols-2 gap-y-6 gap-x-[20px] text-gray-700\"\n  >\n    <div *ngIf=\"metadata.resourceCreated\">\n      <p class=\"text-sm\" translate>record.metadata.creation</p>\n      <p class=\"text-primary font-medium mt-1\">\n        {{ formatDate(metadata.resourceCreated) }}\n      </p>\n    </div>\n    <div *ngIf=\"metadata.resourcePublished\">\n      <p class=\"text-sm\" translate>record.metadata.publication</p>\n      <p class=\"text-primary font-medium mt-1\">\n        {{ formatDate(metadata.resourcePublished) }}\n      </p>\n    </div>\n    <div *ngIf=\"updateFrequency\">\n      <p class=\"text-sm\" translate>record.metadata.updateFrequency</p>\n      <p\n        class=\"text-primary font-medium mt-1 updateFrequency\"\n        translate\n        [translateParams]=\"{ count: updatedTimes }\"\n      >\n        {{ updateFrequency }}\n      </p>\n    </div>\n    <div *ngIf=\"metadata.otherLanguages?.length\">\n      <p class=\"text-sm mb-1\" translate>record.metadata.languages</p>\n      <div class=\"flex flex-row gap-1 flex-wrap\">\n        <p\n          class=\"text-primary font-medium\"\n          translate\n          *ngFor=\"let language of metadata.otherLanguages\"\n        >\n          language.{{ language }}\n        </p>\n      </div>\n    </div>\n    <div *ngIf=\"temporalExtent\">\n      <p class=\"text-sm\" translate>record.metadata.temporalExtent</p>\n      <div class=\"flex flex-row gap-1 mb-1 text-primary font-medium\">\n        <p\n          *ngIf=\"temporalExtent.start && temporalExtent.end\"\n          translate\n          [translateParams]=\"{\n            start: temporalExtent.start,\n            end: temporalExtent.end,\n          }\"\n        >\n          record.metadata.temporalExtent.fromDateToDate\n        </p>\n        <p\n          *ngIf=\"temporalExtent.start && !temporalExtent.end\"\n          translate\n          [translateParams]=\"{ start: temporalExtent.start }\"\n        >\n          record.metadata.temporalExtent.sinceDate\n        </p>\n        <p\n          *ngIf=\"!temporalExtent.start && temporalExtent.end\"\n          translate\n          [translateParams]=\"{ end: temporalExtent.end }\"\n        >\n          record.metadata.temporalExtent.untilDate\n        </p>\n      </div>\n    </div>\n  </div>\n</gn-ui-expandable-panel>\n<gn-ui-expandable-panel\n  *ngIf=\"metadata.kind !== 'dataset' && metadata.spatialExtents\"\n  [title]=\"'service.metadata.spatialExtent' | translate\"\n  data-test=\"spatial-extent-panel\"\n>\n  <gn-ui-spatial-extent\n    class=\"flex h-[271px] w-full rounded-lg border border-gray-100 mt-3 mb-6\"\n    [spatialExtents]=\"metadata.spatialExtents\"\n  ></gn-ui-spatial-extent>\n</gn-ui-expandable-panel>\n<gn-ui-expandable-panel\n  *ngIf=\"metadata.landingPage\"\n  [title]=\"'service.metadata.other' | translate\"\n  data-test=\"other-panel\"\n>\n  <div class=\"flex flex-col gap-4 mr-4 py-5 rounded text-gray-700\">\n    <div *ngIf=\"metadata.recordUpdated\">\n      <p class=\"text-sm\" translate>record.metadata.updatedOn</p>\n      <p class=\"text-primary font-medium\">\n        {{ metadata.recordUpdated && formatDateTime(metadata.recordUpdated) }}\n      </p>\n    </div>\n    <div *ngIf=\"metadata.landingPage\">\n      <p class=\"text-sm\" translate>record.metadata.sheet</p>\n      <p class=\"text-primary font-medium\" translate>\n        <a [href]=\"metadata.landingPage\" target=\"_blank\">\n          <span class=\"break-all\" gnUiLinkify>{{ metadata.landingPage }}</span>\n        </a>\n      </p>\n    </div>\n    <div *ngIf=\"metadata.ownerOrganization\">\n      <p class=\"text-sm\" translate>record.metadata.owner</p>\n      <p class=\"text-primary font-medium\">\n        {{ metadata.ownerOrganization.name }}\n      </p>\n    </div>\n    <div *ngIf=\"metadata.uniqueIdentifier\">\n      <p class=\"text-sm\" translate>record.metadata.uniqueId</p>\n      <div class=\"flex flex-row content-align items-end gap-1\">\n        <gn-ui-copy-text-button\n          [text]=\"metadata.uniqueIdentifier\"\n          [tooltipText]=\"'tooltip.id.copy' | translate\"\n          [displayText]=\"false\"\n        ></gn-ui-copy-text-button>\n        <p class=\"text-primary font-medium\">\n          {{ metadata.uniqueIdentifier }}\n        </p>\n      </div>\n    </div>\n    <div *ngIf=\"metadata.topics?.length\">\n      <p class=\"text-sm mb-1\" translate>record.metadata.topics</p>\n      <div class=\"sm:pb-4 sm:pr-16\">\n        <gn-ui-badge\n          [clickable]=\"false\"\n          class=\"inline-block mr-2 mb-2 lowercase\"\n          *ngFor=\"let topic of metadata.topics\"\n          >{{ topic }}</gn-ui-badge\n        >\n      </div>\n    </div>\n  </div>\n</gn-ui-expandable-panel>\n"]}
128
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"metadata-info.component.js","sourceRoot":"","sources":["../../../../../../../../libs/ui/elements/src/lib/metadata-info/metadata-info.component.ts","../../../../../../../../libs/ui/elements/src/lib/metadata-info/metadata-info.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  EventEmitter,\n  Input,\n  Output,\n} from '@angular/core'\nimport {\n  CatalogRecord,\n  Keyword,\n} from '../../../../../../libs/common/domain/src/lib/model/record'\nimport { DateService, getTemporalRangeUnion } from '../../../../../../libs/util/shared/src'\nimport { MarkdownParserComponent } from '../markdown-parser/markdown-parser.component'\nimport {\n  ExpandablePanelComponent,\n  MaxLinesComponent,\n} from '../../../../../../libs/ui/layout/src'\nimport { TranslateDirective, TranslatePipe } from '@ngx-translate/core'\nimport {\n  BadgeComponent,\n  CopyTextButtonComponent,\n} from '../../../../../../libs/ui/inputs/src'\nimport { ContentGhostComponent } from '../content-ghost/content-ghost.component'\nimport { NgIcon, provideIcons } from '@ng-icons/core'\nimport { matOpenInNew } from '@ng-icons/material-icons/baseline'\nimport { matMailOutline } from '@ng-icons/material-icons/outline'\nimport { ThumbnailComponent } from '../thumbnail/thumbnail.component'\nimport { GnUiLinkifyDirective } from './linkify.directive'\n\nimport { CommonModule } from '@angular/common'\nimport { SpatialExtentComponent } from '../../../../../../libs/ui/map/src'\n\n@Component({\n  selector: 'gn-ui-metadata-info',\n  templateUrl: './metadata-info.component.html',\n  styleUrls: ['./metadata-info.component.css'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true,\n  imports: [\n    CommonModule,\n    TranslateDirective,\n    TranslatePipe,\n    MarkdownParserComponent,\n    ExpandablePanelComponent,\n    BadgeComponent,\n    ContentGhostComponent,\n    ThumbnailComponent,\n    MaxLinesComponent,\n    CopyTextButtonComponent,\n    NgIcon,\n    GnUiLinkifyDirective,\n    SpatialExtentComponent,\n  ],\n  viewProviders: [\n    provideIcons({\n      matOpenInNew,\n      matMailOutline,\n    }),\n  ],\n})\nexport class MetadataInfoComponent {\n  @Input() metadata: Partial<CatalogRecord>\n  @Input() incomplete: boolean\n  @Output() keyword = new EventEmitter<Keyword>()\n  updatedTimes: number\n\n  constructor(private dateService: DateService) {}\n\n  get hasUsage() {\n    return (\n      this.metadata.extras?.isOpenData === true ||\n      (this.metadata.legalConstraints?.length > 0 &&\n        this.legalConstraints.length > 0) ||\n      (this.metadata.otherConstraints?.length > 0 &&\n        this.otherConstraints.length > 0) ||\n      (this.metadata.licenses?.length > 0 && this.licenses.length > 0)\n    )\n  }\n\n  get legalConstraints() {\n    let array = []\n    if (this.metadata.legalConstraints?.length) {\n      const licensesTexts = this.metadata.licenses.map(\n        (license) => license.text\n      )\n      array = array.concat(\n        this.metadata.legalConstraints\n          .filter((c) => c.text && !licensesTexts.includes(c.text))\n          .map((c) => c.text)\n      )\n    }\n    return array\n  }\n\n  get otherConstraints() {\n    let array = []\n    if (this.metadata.otherConstraints?.length) {\n      array = array.concat(\n        this.metadata.otherConstraints.filter((c) => c.text).map((c) => c.text)\n      )\n    }\n    return array\n  }\n\n  get licenses(): { text: string; url: string }[] {\n    let array = []\n    if (this.metadata.licenses?.length) {\n      array = array.concat(\n        this.metadata.licenses\n          .filter((c) => c.text)\n          .map((c) => ({ text: c.text, url: c.url }))\n      )\n    }\n    return array\n  }\n\n  get updateFrequency(): string {\n    if (this.metadata.updateFrequency instanceof Object) {\n      this.updatedTimes = this.metadata.updateFrequency.updatedTimes\n      return `domain.record.updateFrequency.${this.metadata.updateFrequency.per}`\n    } else if (typeof this.metadata.updateFrequency === 'string') {\n      return `domain.record.updateFrequency.${this.metadata.updateFrequency}`\n    } else {\n      return undefined\n    }\n  }\n\n  get temporalExtent(): { start: string; end: string } {\n    const temporalExtents =\n      this.metadata.kind === 'dataset' ? this.metadata.temporalExtents : []\n    return getTemporalRangeUnion(temporalExtents, this.dateService)\n  }\n\n  get shownOrganization() {\n    return this.metadata.ownerOrganization\n  }\n\n  get resourceContact() {\n    return this.metadata.contactsForResource?.[0]\n  }\n\n  fieldReady(propName: string) {\n    return !this.incomplete || propName in this.metadata\n  }\n\n  onKeywordClick(keyword: Keyword) {\n    this.keyword.emit(keyword)\n  }\n\n  formatDate(date: Date): string {\n    return this.dateService.formatDate(date)\n  }\n\n  formatDateTime(date: Date): string {\n    return this.dateService.formatDateTime(date)\n  }\n}\n","<div class=\"mb-6 md-description sm:mb-4 sm:pr-16\">\n  <gn-ui-content-ghost\n    ghostClass=\"h-[178px]\"\n    [showContent]=\"fieldReady('abstract')\"\n  >\n    <gn-ui-max-lines [maxLines]=\"6\" *ngIf=\"metadata.abstract\">\n      <div class=\"mb-6\">\n        <gn-ui-markdown-parser\n          [textContent]=\"metadata.abstract\"\n        ></gn-ui-markdown-parser>\n      </div>\n    </gn-ui-max-lines>\n  </gn-ui-content-ghost>\n\n  <p\n    class=\"mt-6 mb-3 font-medium text-black text-sm\"\n    translate\n    *ngIf=\"!fieldReady('keywords') || metadata.keywords?.length\"\n  >\n    record.metadata.keywords\n  </p>\n\n  <gn-ui-content-ghost\n    ghostClass=\"h-[31px] w-3/4\"\n    [showContent]=\"fieldReady('keywords')\"\n  >\n    <div *ngIf=\"metadata.keywords?.length\">\n      <div class=\"metadata-info-keywords sm:pb-4 flex flex-wrap gap-2\">\n        <gn-ui-badge\n          class=\"inline-block lowercase\"\n          (click)=\"onKeywordClick(keyword)\"\n          [clickable]=\"true\"\n          *ngFor=\"let keyword of metadata.keywords\"\n          >{{ keyword.label }}</gn-ui-badge\n        >\n      </div>\n    </div>\n  </gn-ui-content-ghost>\n</div>\n\n<gn-ui-expandable-panel\n  *ngIf=\"\n    metadata.licenses ||\n    metadata.legalConstraints ||\n    metadata.securityConstraints ||\n    metadata.otherConstraints\n  \"\n  [title]=\"'record.metadata.usage' | translate\"\n  data-test=\"usage-panel\"\n>\n  <div class=\"flex flex-col gap-[10px] mr-4 py-[12px] rounded text-gray-900\">\n    <ng-container *ngFor=\"let license of licenses\">\n      <div *ngIf=\"license.url; else noUrl\" class=\"text-primary\">\n        <a\n          [href]=\"license.url\"\n          target=\"_blank\"\n          class=\"cursor-pointer hover:underline transition-all\"\n        >\n          {{ license.text }}\n          <ng-icon\n            class=\"!w-[12px] !h-[12px] !text-[12px] opacity-75 shrink-0\"\n            name=\"matOpenInNew\"\n          ></ng-icon>\n        </a>\n      </div>\n      <ng-template #noUrl>\n        <div class=\"text-primary\" gnUiLinkify>\n          {{ license.text }}\n        </div>\n      </ng-template>\n    </ng-container>\n    <ng-container *ngIf=\"legalConstraints.length\">\n      <div class=\"mb-6\">\n        <gn-ui-markdown-parser\n          *ngFor=\"let constraint of legalConstraints\"\n          [textContent]=\"constraint\"\n        >\n        </gn-ui-markdown-parser>\n      </div>\n    </ng-container>\n    <ng-container *ngIf=\"otherConstraints.length\">\n      <div gnUiLinkify *ngFor=\"let constraint of otherConstraints\">\n        <span\n          translate\n          class=\"font-medium text-black text-sm mb-[2px] mt-[16px]\"\n        >\n          record.metadata.otherConstraints\n        </span>\n        <div class=\"mb-6\">\n          <gn-ui-markdown-parser [textContent]=\"constraint\">\n          </gn-ui-markdown-parser>\n        </div>\n      </div>\n    </ng-container>\n\n    <span class=\"noUsage\" *ngIf=\"!hasUsage\">\n      {{ 'record.metadata.noUsage' | translate }}\n    </span>\n  </div>\n</gn-ui-expandable-panel>\n<gn-ui-expandable-panel\n  *ngIf=\"\n    (metadata.kind === 'dataset' && metadata.lineage) ||\n    metadata.resourceUpdated ||\n    metadata.updateFrequency ||\n    (metadata.kind === 'dataset' && metadata.status)\n  \"\n  [title]=\"'record.metadata.details' | translate\"\n  data-test=\"details-panel\"\n>\n  <div *ngIf=\"metadata.lineage\" class=\"text-gray-900 flex flex-col mt-4 gap-2\">\n    <p class=\"whitespace-pre-line break-words text-gray-900\" gnUiLinkify>\n      {{ metadata.lineage }}\n    </p>\n  </div>\n  <div class=\"flex flex-row gap-6 mt-5 mb-8\" *ngIf=\"resourceContact\">\n    <div\n      *ngIf=\"resourceContact.organization?.logoUrl?.href\"\n      class=\"flex items-center justify-center border-solid border border-gray-300 rounded-md bg-white h-32 overflow-hidden\"\n    >\n      <gn-ui-thumbnail\n        class=\"relative h-full w-full\"\n        [thumbnailUrl]=\"resourceContact.organization.logoUrl.href\"\n        fit=\"contain\"\n      ></gn-ui-thumbnail>\n    </div>\n    <div class=\"flex flex-col gap-1\">\n      <p class=\"text-sm font-medium\" translate>record.metadata.producer</p>\n      <div\n        class=\"text-primary font-title text-21 mr-2 cursor-pointer hover:underline\"\n        data-cy=\"organization-name\"\n      >\n        {{ resourceContact.organization?.name }}\n      </div>\n      <div *ngIf=\"resourceContact.organization?.website\">\n        <a\n          [href]=\"resourceContact.organization.website\"\n          target=\"_blank\"\n          class=\"contact-website text-primary text-sm cursor-pointer hover:underline transition-all\"\n          >{{ resourceContact.organization.website }}\n          <ng-icon\n            class=\"!w-[12px] !h-[12px] !text-[12px] opacity-75 shrink-0\"\n            name=\"matOpenInNew\"\n          ></ng-icon>\n        </a>\n      </div>\n      <div class=\"mt-4\" *ngIf=\"resourceContact.email\">\n        <div class=\"flex\">\n          <ng-icon\n            class=\"!w-5 !h-5 !text-[20px] opacity-75 shrink-0\"\n            name=\"matMailOutline\"\n          ></ng-icon>\n          <a\n            *ngIf=\"resourceContact.email\"\n            [href]=\"'mailto:' + resourceContact.email\"\n            class=\"text-sm hover:underline ml-2\"\n            target=\"_blank\"\n            data-cy=\"contact-email\"\n            >{{ resourceContact?.email }}</a\n          >\n        </div>\n      </div>\n    </div>\n  </div>\n  <div\n    class=\"py-6 px-6 rounded bg-gray-100 grid grid-cols-2 gap-y-6 gap-x-[20px] text-gray-700\"\n  >\n    <div *ngIf=\"metadata.resourceCreated\">\n      <p class=\"text-sm\" translate>record.metadata.creation</p>\n      <p class=\"text-primary font-medium mt-1\">\n        {{ formatDate(metadata.resourceCreated) }}\n      </p>\n    </div>\n    <div *ngIf=\"metadata.resourcePublished\">\n      <p class=\"text-sm\" translate>record.metadata.publication</p>\n      <p class=\"text-primary font-medium mt-1\">\n        {{ formatDate(metadata.resourcePublished) }}\n      </p>\n    </div>\n    <div *ngIf=\"updateFrequency\">\n      <p class=\"text-sm\" translate>record.metadata.updateFrequency</p>\n      <p\n        class=\"text-primary font-medium mt-1 updateFrequency\"\n        translate\n        [translateParams]=\"{ count: updatedTimes }\"\n      >\n        {{ updateFrequency }}\n      </p>\n    </div>\n    <div *ngIf=\"metadata.otherLanguages?.length\">\n      <p class=\"text-sm mb-1\" translate>record.metadata.languages</p>\n      <div class=\"flex flex-row gap-1 flex-wrap\">\n        <p\n          class=\"text-primary font-medium\"\n          translate\n          *ngFor=\"let language of metadata.otherLanguages\"\n        >\n          language.{{ language }}\n        </p>\n      </div>\n    </div>\n    <div *ngIf=\"temporalExtent\">\n      <p class=\"text-sm\" translate>record.metadata.temporalExtent</p>\n      <div class=\"flex flex-row gap-1 mb-1 text-primary font-medium\">\n        <p\n          *ngIf=\"temporalExtent.start && temporalExtent.end\"\n          translate\n          [translateParams]=\"{\n            start: temporalExtent.start,\n            end: temporalExtent.end,\n          }\"\n        >\n          record.metadata.temporalExtent.fromDateToDate\n        </p>\n        <p\n          *ngIf=\"temporalExtent.start && !temporalExtent.end\"\n          translate\n          [translateParams]=\"{ start: temporalExtent.start }\"\n        >\n          record.metadata.temporalExtent.sinceDate\n        </p>\n        <p\n          *ngIf=\"!temporalExtent.start && temporalExtent.end\"\n          translate\n          [translateParams]=\"{ end: temporalExtent.end }\"\n        >\n          record.metadata.temporalExtent.untilDate\n        </p>\n      </div>\n    </div>\n  </div>\n</gn-ui-expandable-panel>\n<gn-ui-expandable-panel\n  *ngIf=\"\n    metadata.kind !== 'dataset' &&\n    metadata.spatialExtents &&\n    metadata.spatialExtents.length\n  \"\n  [title]=\"'service.metadata.spatialExtent' | translate\"\n  data-test=\"spatial-extent-panel\"\n>\n  <gn-ui-spatial-extent\n    class=\"flex h-[271px] w-full rounded-lg border border-gray-100 mt-3 mb-6\"\n    [spatialExtents]=\"metadata.spatialExtents\"\n  ></gn-ui-spatial-extent>\n</gn-ui-expandable-panel>\n<gn-ui-expandable-panel\n  *ngIf=\"metadata.landingPage\"\n  [title]=\"'service.metadata.other' | translate\"\n  data-test=\"other-panel\"\n>\n  <div class=\"flex flex-col gap-4 mr-4 py-5 rounded text-gray-700\">\n    <div *ngIf=\"metadata.recordUpdated\">\n      <p class=\"text-sm\" translate>record.metadata.updatedOn</p>\n      <p class=\"text-primary font-medium\">\n        {{ metadata.recordUpdated && formatDateTime(metadata.recordUpdated) }}\n      </p>\n    </div>\n    <div *ngIf=\"metadata.landingPage\">\n      <p class=\"text-sm\" translate>record.metadata.sheet</p>\n      <p class=\"text-primary font-medium\" translate>\n        <a [href]=\"metadata.landingPage\" target=\"_blank\">\n          <span class=\"break-all\" gnUiLinkify>{{ metadata.landingPage }}</span>\n        </a>\n      </p>\n    </div>\n    <div *ngIf=\"metadata.ownerOrganization\">\n      <p class=\"text-sm\" translate>record.metadata.owner</p>\n      <p class=\"text-primary font-medium\">\n        {{ metadata.ownerOrganization.name }}\n      </p>\n    </div>\n    <div *ngIf=\"metadata.uniqueIdentifier\">\n      <p class=\"text-sm\" translate>record.metadata.uniqueId</p>\n      <div class=\"flex flex-row content-align items-end gap-1\">\n        <gn-ui-copy-text-button\n          [text]=\"metadata.uniqueIdentifier\"\n          [tooltipText]=\"'tooltip.id.copy' | translate\"\n          [displayText]=\"false\"\n        ></gn-ui-copy-text-button>\n        <p class=\"text-primary font-medium\">\n          {{ metadata.uniqueIdentifier }}\n        </p>\n      </div>\n    </div>\n    <div *ngIf=\"metadata.topics?.length\">\n      <p class=\"text-sm mb-1\" translate>record.metadata.topics</p>\n      <div class=\"sm:pb-4 sm:pr-16\">\n        <gn-ui-badge\n          [clickable]=\"false\"\n          class=\"inline-block mr-2 mb-2 lowercase\"\n          *ngFor=\"let topic of metadata.topics\"\n          >{{ topic }}</gn-ui-badge\n        >\n      </div>\n    </div>\n  </div>\n</gn-ui-expandable-panel>\n"]}
@@ -4,7 +4,7 @@ import { NgIcon, provideIcons, provideNgIconsConfig } from '@ng-icons/core';
4
4
  import { CommonModule } from '@angular/common';
5
5
  import { matStar, matStarBorder } from '@ng-icons/material-icons/baseline';
6
6
  import { ButtonComponent } from '../button/button.component';
7
- import { TranslateDirective } from '@ngx-translate/core';
7
+ import { TranslatePipe } from '@ngx-translate/core';
8
8
  import * as i0 from "@angular/core";
9
9
  import * as i1 from "@angular/common";
10
10
  export class StarToggleComponent {
@@ -27,7 +27,7 @@ export class StarToggleComponent {
27
27
  event.preventDefault();
28
28
  }
29
29
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: StarToggleComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
30
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: StarToggleComponent, isStandalone: true, selector: "gn-ui-star-toggle", inputs: { toggled: "toggled", disabled: "disabled", displayLabel: "displayLabel" }, outputs: { newValue: "newValue" }, viewQueries: [{ propertyName: "overlay", first: true, predicate: ["starOverlay"], descendants: true }], ngImport: i0, template: "<div class=\"inline-block relative align-middle cursor-pointer\">\n <gn-ui-button\n [type]=\"'outline'\"\n [disabled]=\"disabled\"\n (buttonClick)=\"toggle($event)\"\n [ngClass]=\"{\n enabled: toggled,\n disabled: !toggled || disabled,\n 'transition hover:scale-125 will-change-transform': !disabled,\n }\"\n >\n <ng-icon [name]=\"toggled ? 'matStar' : 'matStarBorder'\"></ng-icon>\n <span *ngIf=\"displayLabel\" class=\"mx-2 text-[16px] content-center\" translate\n >favorite.starToggle.label</span\n >\n </gn-ui-button>\n <svg\n #starOverlay\n class=\"star-toggle-overlay\"\n width=\"40px\"\n height=\"40px\"\n viewBox=\"-15 -15 30 30\"\n [style]=\"displayLabel ? 'left: 16px' : 'left: 50%'\"\n >\n <g>\n <path d=\"M 0,13.229167 V 0\" />\n <path d=\"M -12.484186,4.0880377 0,0\" />\n <path d=\"M -7.6784102,-10.70262 0,0\" />\n <path d=\"M 7.8734079,-10.70262 0,0\" />\n <path d=\"M 12.679184,4.0880376 0,0\" />\n </g>\n </svg>\n</div>\n", styles: ["button.enabled{color:var(--star-toggle-enabled-color, var(--color-secondary))}button.disabled{color:var(--star-toggle-disabled-color, var(--color-primary))}.star-filled{font-variation-settings:\"FILL\" 1}.star-toggle-overlay{stroke:var(--color-secondary);stroke-width:3.5px;stroke-linecap:round;position:absolute;top:50%;width:2.5em;height:2.5em;transform:translate(-50%,-50%);pointer-events:none;stroke-dasharray:5 20;stroke-dashoffset:-15;animation:overlay-dash .8s cubic-bezier(.16,.66,.44,.96) forwards;animation-play-state:paused}@keyframes overlay-dash{to{stroke-dashoffset:7}}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: NgIcon, selector: "ng-icon", inputs: ["name", "svg", "size", "strokeWidth", "color"] }, { kind: "component", type: ButtonComponent, selector: "gn-ui-button", inputs: ["type", "disabled", "extraClass"], outputs: ["buttonClick"] }, { kind: "directive", type: TranslateDirective, selector: "[translate],[ngx-translate]", inputs: ["translate", "translateParams"] }], viewProviders: [
30
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: StarToggleComponent, isStandalone: true, selector: "gn-ui-star-toggle", inputs: { toggled: "toggled", disabled: "disabled", displayLabel: "displayLabel" }, outputs: { newValue: "newValue" }, viewQueries: [{ propertyName: "overlay", first: true, predicate: ["starOverlay"], descendants: true }], ngImport: i0, template: "<div class=\"inline-block relative align-middle cursor-pointer\">\n <gn-ui-button\n [type]=\"'outline'\"\n [disabled]=\"disabled\"\n (buttonClick)=\"toggle($event)\"\n [ngClass]=\"{\n enabled: toggled,\n disabled: !toggled || disabled,\n 'transition hover:scale-125 will-change-transform': !disabled,\n }\"\n >\n <ng-icon [name]=\"toggled ? 'matStar' : 'matStarBorder'\"></ng-icon>\n <span *ngIf=\"displayLabel\" class=\"mx-2 text-[16px] content-center\">{{\n (toggled ? 'favorite.starToggle.remove' : 'favorite.starToggle.add')\n | translate\n }}</span>\n </gn-ui-button>\n <svg\n #starOverlay\n class=\"star-toggle-overlay\"\n width=\"40px\"\n height=\"40px\"\n viewBox=\"-15 -15 30 30\"\n [style]=\"displayLabel ? 'left: 16px' : 'left: 50%'\"\n >\n <g>\n <path d=\"M 0,13.229167 V 0\" />\n <path d=\"M -12.484186,4.0880377 0,0\" />\n <path d=\"M -7.6784102,-10.70262 0,0\" />\n <path d=\"M 7.8734079,-10.70262 0,0\" />\n <path d=\"M 12.679184,4.0880376 0,0\" />\n </g>\n </svg>\n</div>\n", styles: ["button.enabled{color:var(--star-toggle-enabled-color, var(--color-secondary))}button.disabled{color:var(--star-toggle-disabled-color, var(--color-primary))}.star-filled{font-variation-settings:\"FILL\" 1}.star-toggle-overlay{stroke:var(--color-secondary);stroke-width:3.5px;stroke-linecap:round;position:absolute;top:50%;width:2.5em;height:2.5em;transform:translate(-50%,-50%);pointer-events:none;stroke-dasharray:5 20;stroke-dashoffset:-15;animation:overlay-dash .8s cubic-bezier(.16,.66,.44,.96) forwards;animation-play-state:paused}@keyframes overlay-dash{to{stroke-dashoffset:7}}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: NgIcon, selector: "ng-icon", inputs: ["name", "svg", "size", "strokeWidth", "color"] }, { kind: "component", type: ButtonComponent, selector: "gn-ui-button", inputs: ["type", "disabled", "extraClass"], outputs: ["buttonClick"] }, { kind: "pipe", type: TranslatePipe, name: "translate" }], viewProviders: [
31
31
  provideIcons({ matStar, matStarBorder }),
32
32
  provideNgIconsConfig({
33
33
  size: '1.5em',
@@ -36,12 +36,12 @@ export class StarToggleComponent {
36
36
  }
37
37
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: StarToggleComponent, decorators: [{
38
38
  type: Component,
39
- args: [{ selector: 'gn-ui-star-toggle', changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, imports: [CommonModule, NgIcon, ButtonComponent, TranslateDirective], viewProviders: [
39
+ args: [{ selector: 'gn-ui-star-toggle', changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, imports: [CommonModule, NgIcon, ButtonComponent, TranslatePipe], viewProviders: [
40
40
  provideIcons({ matStar, matStarBorder }),
41
41
  provideNgIconsConfig({
42
42
  size: '1.5em',
43
43
  }),
44
- ], template: "<div class=\"inline-block relative align-middle cursor-pointer\">\n <gn-ui-button\n [type]=\"'outline'\"\n [disabled]=\"disabled\"\n (buttonClick)=\"toggle($event)\"\n [ngClass]=\"{\n enabled: toggled,\n disabled: !toggled || disabled,\n 'transition hover:scale-125 will-change-transform': !disabled,\n }\"\n >\n <ng-icon [name]=\"toggled ? 'matStar' : 'matStarBorder'\"></ng-icon>\n <span *ngIf=\"displayLabel\" class=\"mx-2 text-[16px] content-center\" translate\n >favorite.starToggle.label</span\n >\n </gn-ui-button>\n <svg\n #starOverlay\n class=\"star-toggle-overlay\"\n width=\"40px\"\n height=\"40px\"\n viewBox=\"-15 -15 30 30\"\n [style]=\"displayLabel ? 'left: 16px' : 'left: 50%'\"\n >\n <g>\n <path d=\"M 0,13.229167 V 0\" />\n <path d=\"M -12.484186,4.0880377 0,0\" />\n <path d=\"M -7.6784102,-10.70262 0,0\" />\n <path d=\"M 7.8734079,-10.70262 0,0\" />\n <path d=\"M 12.679184,4.0880376 0,0\" />\n </g>\n </svg>\n</div>\n", styles: ["button.enabled{color:var(--star-toggle-enabled-color, var(--color-secondary))}button.disabled{color:var(--star-toggle-disabled-color, var(--color-primary))}.star-filled{font-variation-settings:\"FILL\" 1}.star-toggle-overlay{stroke:var(--color-secondary);stroke-width:3.5px;stroke-linecap:round;position:absolute;top:50%;width:2.5em;height:2.5em;transform:translate(-50%,-50%);pointer-events:none;stroke-dasharray:5 20;stroke-dashoffset:-15;animation:overlay-dash .8s cubic-bezier(.16,.66,.44,.96) forwards;animation-play-state:paused}@keyframes overlay-dash{to{stroke-dashoffset:7}}\n"] }]
44
+ ], template: "<div class=\"inline-block relative align-middle cursor-pointer\">\n <gn-ui-button\n [type]=\"'outline'\"\n [disabled]=\"disabled\"\n (buttonClick)=\"toggle($event)\"\n [ngClass]=\"{\n enabled: toggled,\n disabled: !toggled || disabled,\n 'transition hover:scale-125 will-change-transform': !disabled,\n }\"\n >\n <ng-icon [name]=\"toggled ? 'matStar' : 'matStarBorder'\"></ng-icon>\n <span *ngIf=\"displayLabel\" class=\"mx-2 text-[16px] content-center\">{{\n (toggled ? 'favorite.starToggle.remove' : 'favorite.starToggle.add')\n | translate\n }}</span>\n </gn-ui-button>\n <svg\n #starOverlay\n class=\"star-toggle-overlay\"\n width=\"40px\"\n height=\"40px\"\n viewBox=\"-15 -15 30 30\"\n [style]=\"displayLabel ? 'left: 16px' : 'left: 50%'\"\n >\n <g>\n <path d=\"M 0,13.229167 V 0\" />\n <path d=\"M -12.484186,4.0880377 0,0\" />\n <path d=\"M -7.6784102,-10.70262 0,0\" />\n <path d=\"M 7.8734079,-10.70262 0,0\" />\n <path d=\"M 12.679184,4.0880376 0,0\" />\n </g>\n </svg>\n</div>\n", styles: ["button.enabled{color:var(--star-toggle-enabled-color, var(--color-secondary))}button.disabled{color:var(--star-toggle-disabled-color, var(--color-primary))}.star-filled{font-variation-settings:\"FILL\" 1}.star-toggle-overlay{stroke:var(--color-secondary);stroke-width:3.5px;stroke-linecap:round;position:absolute;top:50%;width:2.5em;height:2.5em;transform:translate(-50%,-50%);pointer-events:none;stroke-dasharray:5 20;stroke-dashoffset:-15;animation:overlay-dash .8s cubic-bezier(.16,.66,.44,.96) forwards;animation-play-state:paused}@keyframes overlay-dash{to{stroke-dashoffset:7}}\n"] }]
45
45
  }], propDecorators: { toggled: [{
46
46
  type: Input
47
47
  }], disabled: [{
@@ -54,4 +54,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
54
54
  type: ViewChild,
55
55
  args: ['starOverlay']
56
56
  }] } });
57
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3Rhci10b2dnbGUuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy91aS9pbnB1dHMvc3JjL2xpYi9zdGFyLXRvZ2dsZS9zdGFyLXRvZ2dsZS5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL3VpL2lucHV0cy9zcmMvbGliL3N0YXItdG9nZ2xlL3N0YXItdG9nZ2xlLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFDTCx1QkFBdUIsRUFDdkIsU0FBUyxFQUNULFVBQVUsRUFDVixZQUFZLEVBQ1osS0FBSyxFQUNMLE1BQU0sRUFDTixTQUFTLEdBQ1YsTUFBTSxlQUFlLENBQUE7QUFDdEIsT0FBTyxFQUFFLHVCQUF1QixFQUFFLE1BQU0sd0NBQXdDLENBQUE7QUFDaEYsT0FBTyxFQUFFLE1BQU0sRUFBRSxZQUFZLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQTtBQUMzRSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUE7QUFDOUMsT0FBTyxFQUFFLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxtQ0FBbUMsQ0FBQTtBQUMxRSxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sNEJBQTRCLENBQUE7QUFDNUQsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0scUJBQXFCLENBQUE7OztBQWdCeEQsTUFBTSxPQUFPLG1CQUFtQjtJQWRoQztRQWdCVyxhQUFRLEdBQUcsS0FBSyxDQUFBO1FBQ2hCLGlCQUFZLEdBQUcsS0FBSyxDQUFBO1FBQ25CLGFBQVEsR0FBRyxJQUFJLFlBQVksRUFBVyxDQUFBO0tBZ0JqRDtJQWJDLE1BQU0sQ0FBQyxLQUFZO1FBQ2pCLElBQUksQ0FBQyxJQUFJLENBQUMsUUFBUSxFQUFFLENBQUM7WUFDbkIsSUFBSSxDQUFDLE9BQU8sR0FBRyxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUE7WUFDNUIsSUFBSSxJQUFJLENBQUMsT0FBTyxFQUFFLENBQUM7Z0JBQ2pCLE1BQU0sSUFBSSxHQUFHLElBQUksQ0FBQyxPQUFPLENBQUMsYUFBYSxDQUFDLGFBQWEsRUFBRSxDQUFDLENBQUMsQ0FBQyxDQUFBO2dCQUMxRCxJQUFJLENBQUMsTUFBTSxFQUFFLENBQUE7Z0JBQ2IsSUFBSSxDQUFDLElBQUksRUFBRSxDQUFBO1lBQ2IsQ0FBQztZQUNELElBQUksQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsQ0FBQTtRQUNsQyxDQUFDO1FBQ0QsdUJBQXVCLENBQUMsS0FBSyxDQUFDLENBQUE7UUFDOUIsS0FBSyxDQUFDLGNBQWMsRUFBRSxDQUFBO0lBQ3hCLENBQUM7K0dBbkJVLG1CQUFtQjttR0FBbkIsbUJBQW1CLDRTQzlCaEMsZ2hDQWlDQSxrb0JEWFksWUFBWSxpT0FBRSxNQUFNLDZHQUFFLGVBQWUsK0hBQUUsa0JBQWtCLHVHQUNwRDtZQUNiLFlBQVksQ0FBQyxFQUFFLE9BQU8sRUFBRSxhQUFhLEVBQUUsQ0FBQztZQUN4QyxvQkFBb0IsQ0FBQztnQkFDbkIsSUFBSSxFQUFFLE9BQU87YUFDZCxDQUFDO1NBQ0g7OzRGQUVVLG1CQUFtQjtrQkFkL0IsU0FBUzsrQkFDRSxtQkFBbUIsbUJBR1osdUJBQXVCLENBQUMsTUFBTSxjQUNuQyxJQUFJLFdBQ1AsQ0FBQyxZQUFZLEVBQUUsTUFBTSxFQUFFLGVBQWUsRUFBRSxrQkFBa0IsQ0FBQyxpQkFDckQ7d0JBQ2IsWUFBWSxDQUFDLEVBQUUsT0FBTyxFQUFFLGFBQWEsRUFBRSxDQUFDO3dCQUN4QyxvQkFBb0IsQ0FBQzs0QkFDbkIsSUFBSSxFQUFFLE9BQU87eUJBQ2QsQ0FBQztxQkFDSDs4QkFHUSxPQUFPO3NCQUFmLEtBQUs7Z0JBQ0csUUFBUTtzQkFBaEIsS0FBSztnQkFDRyxZQUFZO3NCQUFwQixLQUFLO2dCQUNJLFFBQVE7c0JBQWpCLE1BQU07Z0JBQ21CLE9BQU87c0JBQWhDLFNBQVM7dUJBQUMsYUFBYSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIENoYW5nZURldGVjdGlvblN0cmF0ZWd5LFxuICBDb21wb25lbnQsXG4gIEVsZW1lbnRSZWYsXG4gIEV2ZW50RW1pdHRlcixcbiAgSW5wdXQsXG4gIE91dHB1dCxcbiAgVmlld0NoaWxkLFxufSBmcm9tICdAYW5ndWxhci9jb3JlJ1xuaW1wb3J0IHsgcHJvcGFnYXRlVG9Eb2N1bWVudE9ubHkgfSBmcm9tICcuLi8uLi8uLi8uLi8uLi8uLi9saWJzL3V0aWwvc2hhcmVkL3NyYydcbmltcG9ydCB7IE5nSWNvbiwgcHJvdmlkZUljb25zLCBwcm92aWRlTmdJY29uc0NvbmZpZyB9IGZyb20gJ0BuZy1pY29ucy9jb3JlJ1xuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJ1xuaW1wb3J0IHsgbWF0U3RhciwgbWF0U3RhckJvcmRlciB9IGZyb20gJ0BuZy1pY29ucy9tYXRlcmlhbC1pY29ucy9iYXNlbGluZSdcbmltcG9ydCB7IEJ1dHRvbkNvbXBvbmVudCB9IGZyb20gJy4uL2J1dHRvbi9idXR0b24uY29tcG9uZW50J1xuaW1wb3J0IHsgVHJhbnNsYXRlRGlyZWN0aXZlIH0gZnJvbSAnQG5neC10cmFuc2xhdGUvY29yZSdcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnZ24tdWktc3Rhci10b2dnbGUnLFxuICB0ZW1wbGF0ZVVybDogJy4vc3Rhci10b2dnbGUuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi9zdGFyLXRvZ2dsZS5jb21wb25lbnQuY3NzJ10sXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxuICBzdGFuZGFsb25lOiB0cnVlLFxuICBpbXBvcnRzOiBbQ29tbW9uTW9kdWxlLCBOZ0ljb24sIEJ1dHRvbkNvbXBvbmVudCwgVHJhbnNsYXRlRGlyZWN0aXZlXSxcbiAgdmlld1Byb3ZpZGVyczogW1xuICAgIHByb3ZpZGVJY29ucyh7IG1hdFN0YXIsIG1hdFN0YXJCb3JkZXIgfSksXG4gICAgcHJvdmlkZU5nSWNvbnNDb25maWcoe1xuICAgICAgc2l6ZTogJzEuNWVtJyxcbiAgICB9KSxcbiAgXSxcbn0pXG5leHBvcnQgY2xhc3MgU3RhclRvZ2dsZUNvbXBvbmVudCB7XG4gIEBJbnB1dCgpIHRvZ2dsZWQhOiBib29sZWFuXG4gIEBJbnB1dCgpIGRpc2FibGVkID0gZmFsc2VcbiAgQElucHV0KCkgZGlzcGxheUxhYmVsID0gZmFsc2VcbiAgQE91dHB1dCgpIG5ld1ZhbHVlID0gbmV3IEV2ZW50RW1pdHRlcjxib29sZWFuPigpXG4gIEBWaWV3Q2hpbGQoJ3N0YXJPdmVybGF5Jykgb3ZlcmxheTogRWxlbWVudFJlZlxuXG4gIHRvZ2dsZShldmVudDogRXZlbnQpIHtcbiAgICBpZiAoIXRoaXMuZGlzYWJsZWQpIHtcbiAgICAgIHRoaXMudG9nZ2xlZCA9ICF0aGlzLnRvZ2dsZWRcbiAgICAgIGlmICh0aGlzLnRvZ2dsZWQpIHtcbiAgICAgICAgY29uc3QgYW5pbSA9IHRoaXMub3ZlcmxheS5uYXRpdmVFbGVtZW50LmdldEFuaW1hdGlvbnMoKVswXVxuICAgICAgICBhbmltLmNhbmNlbCgpXG4gICAgICAgIGFuaW0ucGxheSgpXG4gICAgICB9XG4gICAgICB0aGlzLm5ld1ZhbHVlLmVtaXQodGhpcy50b2dnbGVkKVxuICAgIH1cbiAgICBwcm9wYWdhdGVUb0RvY3VtZW50T25seShldmVudClcbiAgICBldmVudC5wcmV2ZW50RGVmYXVsdCgpXG4gIH1cbn1cbiIsIjxkaXYgY2xhc3M9XCJpbmxpbmUtYmxvY2sgcmVsYXRpdmUgYWxpZ24tbWlkZGxlIGN1cnNvci1wb2ludGVyXCI+XG4gIDxnbi11aS1idXR0b25cbiAgICBbdHlwZV09XCInb3V0bGluZSdcIlxuICAgIFtkaXNhYmxlZF09XCJkaXNhYmxlZFwiXG4gICAgKGJ1dHRvbkNsaWNrKT1cInRvZ2dsZSgkZXZlbnQpXCJcbiAgICBbbmdDbGFzc109XCJ7XG4gICAgICBlbmFibGVkOiB0b2dnbGVkLFxuICAgICAgZGlzYWJsZWQ6ICF0b2dnbGVkIHx8IGRpc2FibGVkLFxuICAgICAgJ3RyYW5zaXRpb24gaG92ZXI6c2NhbGUtMTI1IHdpbGwtY2hhbmdlLXRyYW5zZm9ybSc6ICFkaXNhYmxlZCxcbiAgICB9XCJcbiAgPlxuICAgIDxuZy1pY29uIFtuYW1lXT1cInRvZ2dsZWQgPyAnbWF0U3RhcicgOiAnbWF0U3RhckJvcmRlcidcIj48L25nLWljb24+XG4gICAgPHNwYW4gKm5nSWY9XCJkaXNwbGF5TGFiZWxcIiBjbGFzcz1cIm14LTIgdGV4dC1bMTZweF0gY29udGVudC1jZW50ZXJcIiB0cmFuc2xhdGVcbiAgICAgID5mYXZvcml0ZS5zdGFyVG9nZ2xlLmxhYmVsPC9zcGFuXG4gICAgPlxuICA8L2duLXVpLWJ1dHRvbj5cbiAgPHN2Z1xuICAgICNzdGFyT3ZlcmxheVxuICAgIGNsYXNzPVwic3Rhci10b2dnbGUtb3ZlcmxheVwiXG4gICAgd2lkdGg9XCI0MHB4XCJcbiAgICBoZWlnaHQ9XCI0MHB4XCJcbiAgICB2aWV3Qm94PVwiLTE1IC0xNSAzMCAzMFwiXG4gICAgW3N0eWxlXT1cImRpc3BsYXlMYWJlbCA/ICdsZWZ0OiAxNnB4JyA6ICdsZWZ0OiA1MCUnXCJcbiAgPlxuICAgIDxnPlxuICAgICAgPHBhdGggZD1cIk0gMCwxMy4yMjkxNjcgViAwXCIgLz5cbiAgICAgIDxwYXRoIGQ9XCJNIC0xMi40ODQxODYsNC4wODgwMzc3IDAsMFwiIC8+XG4gICAgICA8cGF0aCBkPVwiTSAtNy42Nzg0MTAyLC0xMC43MDI2MiAwLDBcIiAvPlxuICAgICAgPHBhdGggZD1cIk0gNy44NzM0MDc5LC0xMC43MDI2MiAwLDBcIiAvPlxuICAgICAgPHBhdGggZD1cIk0gMTIuNjc5MTg0LDQuMDg4MDM3NiAwLDBcIiAvPlxuICAgIDwvZz5cbiAgPC9zdmc+XG48L2Rpdj5cbiJdfQ==
57
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3Rhci10b2dnbGUuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy91aS9pbnB1dHMvc3JjL2xpYi9zdGFyLXRvZ2dsZS9zdGFyLXRvZ2dsZS5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL3VpL2lucHV0cy9zcmMvbGliL3N0YXItdG9nZ2xlL3N0YXItdG9nZ2xlLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFDTCx1QkFBdUIsRUFDdkIsU0FBUyxFQUNULFVBQVUsRUFDVixZQUFZLEVBQ1osS0FBSyxFQUNMLE1BQU0sRUFDTixTQUFTLEdBQ1YsTUFBTSxlQUFlLENBQUE7QUFDdEIsT0FBTyxFQUFFLHVCQUF1QixFQUFFLE1BQU0sd0NBQXdDLENBQUE7QUFDaEYsT0FBTyxFQUFFLE1BQU0sRUFBRSxZQUFZLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQTtBQUMzRSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUE7QUFDOUMsT0FBTyxFQUFFLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxtQ0FBbUMsQ0FBQTtBQUMxRSxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sNEJBQTRCLENBQUE7QUFDNUQsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLHFCQUFxQixDQUFBOzs7QUFnQm5ELE1BQU0sT0FBTyxtQkFBbUI7SUFkaEM7UUFnQlcsYUFBUSxHQUFHLEtBQUssQ0FBQTtRQUNoQixpQkFBWSxHQUFHLEtBQUssQ0FBQTtRQUNuQixhQUFRLEdBQUcsSUFBSSxZQUFZLEVBQVcsQ0FBQTtLQWdCakQ7SUFiQyxNQUFNLENBQUMsS0FBWTtRQUNqQixJQUFJLENBQUMsSUFBSSxDQUFDLFFBQVEsRUFBRSxDQUFDO1lBQ25CLElBQUksQ0FBQyxPQUFPLEdBQUcsQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFBO1lBQzVCLElBQUksSUFBSSxDQUFDLE9BQU8sRUFBRSxDQUFDO2dCQUNqQixNQUFNLElBQUksR0FBRyxJQUFJLENBQUMsT0FBTyxDQUFDLGFBQWEsQ0FBQyxhQUFhLEVBQUUsQ0FBQyxDQUFDLENBQUMsQ0FBQTtnQkFDMUQsSUFBSSxDQUFDLE1BQU0sRUFBRSxDQUFBO2dCQUNiLElBQUksQ0FBQyxJQUFJLEVBQUUsQ0FBQTtZQUNiLENBQUM7WUFDRCxJQUFJLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLENBQUE7UUFDbEMsQ0FBQztRQUNELHVCQUF1QixDQUFDLEtBQUssQ0FBQyxDQUFBO1FBQzlCLEtBQUssQ0FBQyxjQUFjLEVBQUUsQ0FBQTtJQUN4QixDQUFDOytHQW5CVSxtQkFBbUI7bUdBQW5CLG1CQUFtQiw0U0M5QmhDLDBrQ0FrQ0Esa29CRFpZLFlBQVksaU9BQUUsTUFBTSw2R0FBRSxlQUFlLDBIQUFFLGFBQWEsdUNBQy9DO1lBQ2IsWUFBWSxDQUFDLEVBQUUsT0FBTyxFQUFFLGFBQWEsRUFBRSxDQUFDO1lBQ3hDLG9CQUFvQixDQUFDO2dCQUNuQixJQUFJLEVBQUUsT0FBTzthQUNkLENBQUM7U0FDSDs7NEZBRVUsbUJBQW1CO2tCQWQvQixTQUFTOytCQUNFLG1CQUFtQixtQkFHWix1QkFBdUIsQ0FBQyxNQUFNLGNBQ25DLElBQUksV0FDUCxDQUFDLFlBQVksRUFBRSxNQUFNLEVBQUUsZUFBZSxFQUFFLGFBQWEsQ0FBQyxpQkFDaEQ7d0JBQ2IsWUFBWSxDQUFDLEVBQUUsT0FBTyxFQUFFLGFBQWEsRUFBRSxDQUFDO3dCQUN4QyxvQkFBb0IsQ0FBQzs0QkFDbkIsSUFBSSxFQUFFLE9BQU87eUJBQ2QsQ0FBQztxQkFDSDs4QkFHUSxPQUFPO3NCQUFmLEtBQUs7Z0JBQ0csUUFBUTtzQkFBaEIsS0FBSztnQkFDRyxZQUFZO3NCQUFwQixLQUFLO2dCQUNJLFFBQVE7c0JBQWpCLE1BQU07Z0JBQ21CLE9BQU87c0JBQWhDLFNBQVM7dUJBQUMsYUFBYSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIENoYW5nZURldGVjdGlvblN0cmF0ZWd5LFxuICBDb21wb25lbnQsXG4gIEVsZW1lbnRSZWYsXG4gIEV2ZW50RW1pdHRlcixcbiAgSW5wdXQsXG4gIE91dHB1dCxcbiAgVmlld0NoaWxkLFxufSBmcm9tICdAYW5ndWxhci9jb3JlJ1xuaW1wb3J0IHsgcHJvcGFnYXRlVG9Eb2N1bWVudE9ubHkgfSBmcm9tICcuLi8uLi8uLi8uLi8uLi8uLi9saWJzL3V0aWwvc2hhcmVkL3NyYydcbmltcG9ydCB7IE5nSWNvbiwgcHJvdmlkZUljb25zLCBwcm92aWRlTmdJY29uc0NvbmZpZyB9IGZyb20gJ0BuZy1pY29ucy9jb3JlJ1xuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJ1xuaW1wb3J0IHsgbWF0U3RhciwgbWF0U3RhckJvcmRlciB9IGZyb20gJ0BuZy1pY29ucy9tYXRlcmlhbC1pY29ucy9iYXNlbGluZSdcbmltcG9ydCB7IEJ1dHRvbkNvbXBvbmVudCB9IGZyb20gJy4uL2J1dHRvbi9idXR0b24uY29tcG9uZW50J1xuaW1wb3J0IHsgVHJhbnNsYXRlUGlwZSB9IGZyb20gJ0BuZ3gtdHJhbnNsYXRlL2NvcmUnXG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2duLXVpLXN0YXItdG9nZ2xlJyxcbiAgdGVtcGxhdGVVcmw6ICcuL3N0YXItdG9nZ2xlLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vc3Rhci10b2dnbGUuY29tcG9uZW50LmNzcyddLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgaW1wb3J0czogW0NvbW1vbk1vZHVsZSwgTmdJY29uLCBCdXR0b25Db21wb25lbnQsIFRyYW5zbGF0ZVBpcGVdLFxuICB2aWV3UHJvdmlkZXJzOiBbXG4gICAgcHJvdmlkZUljb25zKHsgbWF0U3RhciwgbWF0U3RhckJvcmRlciB9KSxcbiAgICBwcm92aWRlTmdJY29uc0NvbmZpZyh7XG4gICAgICBzaXplOiAnMS41ZW0nLFxuICAgIH0pLFxuICBdLFxufSlcbmV4cG9ydCBjbGFzcyBTdGFyVG9nZ2xlQ29tcG9uZW50IHtcbiAgQElucHV0KCkgdG9nZ2xlZCE6IGJvb2xlYW5cbiAgQElucHV0KCkgZGlzYWJsZWQgPSBmYWxzZVxuICBASW5wdXQoKSBkaXNwbGF5TGFiZWwgPSBmYWxzZVxuICBAT3V0cHV0KCkgbmV3VmFsdWUgPSBuZXcgRXZlbnRFbWl0dGVyPGJvb2xlYW4+KClcbiAgQFZpZXdDaGlsZCgnc3Rhck92ZXJsYXknKSBvdmVybGF5OiBFbGVtZW50UmVmXG5cbiAgdG9nZ2xlKGV2ZW50OiBFdmVudCkge1xuICAgIGlmICghdGhpcy5kaXNhYmxlZCkge1xuICAgICAgdGhpcy50b2dnbGVkID0gIXRoaXMudG9nZ2xlZFxuICAgICAgaWYgKHRoaXMudG9nZ2xlZCkge1xuICAgICAgICBjb25zdCBhbmltID0gdGhpcy5vdmVybGF5Lm5hdGl2ZUVsZW1lbnQuZ2V0QW5pbWF0aW9ucygpWzBdXG4gICAgICAgIGFuaW0uY2FuY2VsKClcbiAgICAgICAgYW5pbS5wbGF5KClcbiAgICAgIH1cbiAgICAgIHRoaXMubmV3VmFsdWUuZW1pdCh0aGlzLnRvZ2dsZWQpXG4gICAgfVxuICAgIHByb3BhZ2F0ZVRvRG9jdW1lbnRPbmx5KGV2ZW50KVxuICAgIGV2ZW50LnByZXZlbnREZWZhdWx0KClcbiAgfVxufVxuIiwiPGRpdiBjbGFzcz1cImlubGluZS1ibG9jayByZWxhdGl2ZSBhbGlnbi1taWRkbGUgY3Vyc29yLXBvaW50ZXJcIj5cbiAgPGduLXVpLWJ1dHRvblxuICAgIFt0eXBlXT1cIidvdXRsaW5lJ1wiXG4gICAgW2Rpc2FibGVkXT1cImRpc2FibGVkXCJcbiAgICAoYnV0dG9uQ2xpY2spPVwidG9nZ2xlKCRldmVudClcIlxuICAgIFtuZ0NsYXNzXT1cIntcbiAgICAgIGVuYWJsZWQ6IHRvZ2dsZWQsXG4gICAgICBkaXNhYmxlZDogIXRvZ2dsZWQgfHwgZGlzYWJsZWQsXG4gICAgICAndHJhbnNpdGlvbiBob3ZlcjpzY2FsZS0xMjUgd2lsbC1jaGFuZ2UtdHJhbnNmb3JtJzogIWRpc2FibGVkLFxuICAgIH1cIlxuICA+XG4gICAgPG5nLWljb24gW25hbWVdPVwidG9nZ2xlZCA/ICdtYXRTdGFyJyA6ICdtYXRTdGFyQm9yZGVyJ1wiPjwvbmctaWNvbj5cbiAgICA8c3BhbiAqbmdJZj1cImRpc3BsYXlMYWJlbFwiIGNsYXNzPVwibXgtMiB0ZXh0LVsxNnB4XSBjb250ZW50LWNlbnRlclwiPnt7XG4gICAgICAodG9nZ2xlZCA/ICdmYXZvcml0ZS5zdGFyVG9nZ2xlLnJlbW92ZScgOiAnZmF2b3JpdGUuc3RhclRvZ2dsZS5hZGQnKVxuICAgICAgICB8IHRyYW5zbGF0ZVxuICAgIH19PC9zcGFuPlxuICA8L2duLXVpLWJ1dHRvbj5cbiAgPHN2Z1xuICAgICNzdGFyT3ZlcmxheVxuICAgIGNsYXNzPVwic3Rhci10b2dnbGUtb3ZlcmxheVwiXG4gICAgd2lkdGg9XCI0MHB4XCJcbiAgICBoZWlnaHQ9XCI0MHB4XCJcbiAgICB2aWV3Qm94PVwiLTE1IC0xNSAzMCAzMFwiXG4gICAgW3N0eWxlXT1cImRpc3BsYXlMYWJlbCA/ICdsZWZ0OiAxNnB4JyA6ICdsZWZ0OiA1MCUnXCJcbiAgPlxuICAgIDxnPlxuICAgICAgPHBhdGggZD1cIk0gMCwxMy4yMjkxNjcgViAwXCIgLz5cbiAgICAgIDxwYXRoIGQ9XCJNIC0xMi40ODQxODYsNC4wODgwMzc3IDAsMFwiIC8+XG4gICAgICA8cGF0aCBkPVwiTSAtNy42Nzg0MTAyLC0xMC43MDI2MiAwLDBcIiAvPlxuICAgICAgPHBhdGggZD1cIk0gNy44NzM0MDc5LC0xMC43MDI2MiAwLDBcIiAvPlxuICAgICAgPHBhdGggZD1cIk0gMTIuNjc5MTg0LDQuMDg4MDM3NiAwLDBcIiAvPlxuICAgIDwvZz5cbiAgPC9zdmc+XG48L2Rpdj5cbiJdfQ==