geonetwork-ui 2.6.0-dev.502fa026d → 2.6.0-dev.b306f1194

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 (71) hide show
  1. package/esm2022/libs/common/domain/src/lib/model/record/metadata.model.mjs +1 -1
  2. package/esm2022/libs/feature/search/src/lib/favorites/favorite-star/favorite-star.component.mjs +3 -3
  3. package/esm2022/libs/ui/elements/src/index.mjs +2 -1
  4. package/esm2022/libs/ui/elements/src/lib/api-card/api-card.component.mjs +27 -6
  5. package/esm2022/libs/ui/elements/src/lib/download-item/download-item.component.mjs +22 -6
  6. package/esm2022/libs/ui/elements/src/lib/downloads-list/downloads-list.component.mjs +3 -3
  7. package/esm2022/libs/ui/elements/src/lib/internal-link-card/internal-link-card.component.mjs +163 -0
  8. package/esm2022/libs/ui/elements/src/lib/link-card/link-card.component.mjs +29 -7
  9. package/esm2022/libs/ui/elements/src/lib/metadata-catalog/metadata-catalog.component.mjs +3 -3
  10. package/esm2022/libs/ui/elements/src/lib/metadata-quality/metadata-quality.component.mjs +3 -3
  11. package/esm2022/libs/ui/elements/src/lib/record-api-form/record-api-form.component.mjs +3 -2
  12. package/esm2022/libs/ui/elements/src/lib/ui-elements.module.mjs +10 -4
  13. package/esm2022/libs/ui/layout/src/lib/carousel/carousel.component.mjs +3 -3
  14. package/esm2022/libs/ui/widgets/src/lib/progress-bar/progress-bar.component.mjs +3 -3
  15. package/esm2022/libs/util/shared/src/lib/links/link-utils.mjs +21 -19
  16. package/esm2022/translations/de.json +7 -0
  17. package/esm2022/translations/en.json +8 -1
  18. package/esm2022/translations/es.json +7 -0
  19. package/esm2022/translations/fr.json +7 -0
  20. package/esm2022/translations/it.json +7 -1
  21. package/esm2022/translations/nl.json +7 -0
  22. package/esm2022/translations/pt.json +7 -0
  23. package/fesm2022/geonetwork-ui.mjs +315 -55
  24. package/fesm2022/geonetwork-ui.mjs.map +1 -1
  25. package/libs/common/domain/src/lib/model/record/metadata.model.d.ts +1 -0
  26. package/libs/common/domain/src/lib/model/record/metadata.model.d.ts.map +1 -1
  27. package/libs/ui/elements/src/index.d.ts +1 -0
  28. package/libs/ui/elements/src/index.d.ts.map +1 -1
  29. package/libs/ui/elements/src/lib/api-card/api-card.component.d.ts +9 -1
  30. package/libs/ui/elements/src/lib/api-card/api-card.component.d.ts.map +1 -1
  31. package/libs/ui/elements/src/lib/download-item/download-item.component.d.ts +8 -1
  32. package/libs/ui/elements/src/lib/download-item/download-item.component.d.ts.map +1 -1
  33. package/libs/ui/elements/src/lib/internal-link-card/internal-link-card.component.d.ts +43 -0
  34. package/libs/ui/elements/src/lib/internal-link-card/internal-link-card.component.d.ts.map +1 -0
  35. package/libs/ui/elements/src/lib/link-card/link-card.component.d.ts +10 -2
  36. package/libs/ui/elements/src/lib/link-card/link-card.component.d.ts.map +1 -1
  37. package/libs/ui/elements/src/lib/record-api-form/record-api-form.component.d.ts.map +1 -1
  38. package/libs/ui/elements/src/lib/ui-elements.module.d.ts +2 -1
  39. package/libs/ui/elements/src/lib/ui-elements.module.d.ts.map +1 -1
  40. package/libs/util/shared/src/lib/links/link-utils.d.ts +16 -16
  41. package/libs/util/shared/src/lib/links/link-utils.d.ts.map +1 -1
  42. package/package.json +1 -1
  43. package/src/libs/common/domain/src/lib/model/record/metadata.model.ts +1 -0
  44. package/src/libs/feature/search/src/lib/favorites/favorite-star/favorite-star.component.html +1 -1
  45. package/src/libs/ui/elements/src/index.ts +1 -0
  46. package/src/libs/ui/elements/src/lib/api-card/api-card.component.html +64 -38
  47. package/src/libs/ui/elements/src/lib/api-card/api-card.component.ts +26 -2
  48. package/src/libs/ui/elements/src/lib/download-item/download-item.component.html +17 -17
  49. package/src/libs/ui/elements/src/lib/download-item/download-item.component.ts +20 -2
  50. package/src/libs/ui/elements/src/lib/downloads-list/downloads-list.component.html +7 -6
  51. package/src/libs/ui/elements/src/lib/internal-link-card/internal-link-card.component.css +0 -0
  52. package/src/libs/ui/elements/src/lib/internal-link-card/internal-link-card.component.html +156 -0
  53. package/src/libs/ui/elements/src/lib/internal-link-card/internal-link-card.component.ts +190 -0
  54. package/src/libs/ui/elements/src/lib/link-card/link-card.component.html +27 -29
  55. package/src/libs/ui/elements/src/lib/link-card/link-card.component.ts +33 -3
  56. package/src/libs/ui/elements/src/lib/metadata-catalog/metadata-catalog.component.html +1 -1
  57. package/src/libs/ui/elements/src/lib/metadata-quality/metadata-quality.component.html +4 -2
  58. package/src/libs/ui/elements/src/lib/record-api-form/record-api-form.component.ts +2 -1
  59. package/src/libs/ui/elements/src/lib/ui-elements.module.ts +3 -0
  60. package/src/libs/ui/layout/src/lib/carousel/carousel.component.css +0 -4
  61. package/src/libs/ui/widgets/src/lib/progress-bar/progress-bar.component.html +2 -2
  62. package/src/libs/util/shared/src/lib/links/link-utils.ts +20 -18
  63. package/tailwind.base.css +34 -1
  64. package/translations/de.json +7 -0
  65. package/translations/en.json +8 -1
  66. package/translations/es.json +7 -0
  67. package/translations/fr.json +7 -0
  68. package/translations/it.json +7 -1
  69. package/translations/nl.json +7 -0
  70. package/translations/pt.json +7 -0
  71. package/translations/sk.json +7 -0
@@ -47,4 +47,4 @@ export const RecordStatusValues = [
47
47
  'deprecated',
48
48
  'removed',
49
49
  ];
50
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"metadata.model.js","sourceRoot":"","sources":["../../../../../../../../../libs/common/domain/src/lib/model/record/metadata.model.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,yCAAyC,CAAA;AAgBhE,MAAM,CAAC,uCAAuC,CAAC,CAAA;AAC/C,MAAM,CAAC,0CAA0C,CAAC,CAAA;AAClD,MAAM,CAAC,wCAAwC,CAAC,CAAA;AAChD,MAAM,CAAC,yCAAyC,CAAC,CAAA;AACjD,MAAM,CAAC,yCAAyC,CAAC,CAAA;AACjD,MAAM,CAAC,wCAAwC,CAAC,CAAA;AAEhD,MAAM,CAAC,MAAM,yBAAyB,GAAG;IACvC,SAAS;IACT,YAAY;IACZ,UAAU;IACV,WAAW;IACX,WAAW;IACX,UAAU;IACV,OAAO;IACP,QAAQ;IACR,aAAa;IACb,aAAa;IACb,SAAS;IACT,WAAW;IACX,YAAY;IACZ,UAAU;IACV,YAAY;CACJ,CAAA;AAIV,MAAM,CAAC,mCAAmC,CAAC,CAAA;AAC3C,MAAM,CAAC,oCAAoC,CAAC,CAAA;AAC5C,MAAM,CAAC,qCAAqC,CAAC,CAAA;AAC7C,MAAM,CAAC,oCAAoC,CAAC,CAAA;AAE5C,MAAM,CAAC,qCAAqC,CAAC,CAAA;AAC7C,MAAM,CAAC,sCAAsC,CAAC,CAAA;AAC9C,MAAM,CAAC,2CAA2C,CAAC,CAAA;AACnD,MAAM,CAAC,uCAAuC,CAAC,CAAA;AAC/C,MAAM,CAAC,yCAAyC,CAAC,CAAA;AACjD,MAAM,CAAC,0CAA0C,CAAC,CAAA;AAClD,MAAM,CAAC,wCAAwC,CAAC,CAAA;AAChD,MAAM,CAAC,2CAA2C,CAAC,CAAA;AACnD,MAAM,CAAC,0CAA0C,CAAC,CAAA;AAUlD,MAAM,CAAC,gCAAgC,CAAC,CAAA;AACxC,MAAM,CAAC,8BAA8B,CAAC,CAAA;AACtC,MAAM,CAAC,wCAAwC,CAAC,CAAA;AAChD,MAAM,CAAC,iCAAiC,CAAC,CAAA;AACzC,MAAM,CAAC,8BAA8B,CAAC,CAAA;AAEtC,MAAM,CAAC,MAAM,kBAAkB,GAAG;IAChC,WAAW;IACX,SAAS;IACT,mBAAmB;IACnB,YAAY;IACZ,SAAS;CACV,CAAA","sourcesContent":["import { marker } from '@biesbjerg/ngx-translate-extract-marker'\nimport type { Individual } from './contact.model'\nimport type { Organization } from './organization.model'\nimport type { Geometry } from 'geojson'\nimport { KeywordType, ThesaurusModel } from '../thesaurus'\nimport {\n  ConstraintTranslations,\n  KeywordTranslations,\n  LanguageCode,\n  OnlineResourceTranslations,\n  RecordTranslations,\n  SpatialExtentTranslations,\n} from './translation.model'\n\ntype Uuid = string\n\nmarker('domain.record.updateFrequency.unknown')\nmarker('domain.record.updateFrequency.notPlanned')\nmarker('domain.record.updateFrequency.asNeeded')\nmarker('domain.record.updateFrequency.irregular')\nmarker('domain.record.updateFrequency.continual')\nmarker('domain.record.updateFrequency.periodic')\n\nexport const updateFrequencyCodeValues = [\n  'unknown',\n  'notPlanned',\n  'asNeeded',\n  'irregular',\n  'continual',\n  'periodic',\n  'daily',\n  'weekly',\n  'fortnightly',\n  'semimonthly',\n  'monthly',\n  'quarterly',\n  'biannually',\n  'annually',\n  'biennially',\n] as const\n\nexport type UpdateFrequencyCode = (typeof updateFrequencyCodeValues)[number]\n\nmarker('domain.record.updateFrequency.day')\nmarker('domain.record.updateFrequency.week')\nmarker('domain.record.updateFrequency.month')\nmarker('domain.record.updateFrequency.year')\n\nmarker('domain.record.updateFrequency.daily')\nmarker('domain.record.updateFrequency.weekly')\nmarker('domain.record.updateFrequency.fortnightly')\nmarker('domain.record.updateFrequency.monthly')\nmarker('domain.record.updateFrequency.quarterly')\nmarker('domain.record.updateFrequency.biannually')\nmarker('domain.record.updateFrequency.annually')\nmarker('domain.record.updateFrequency.semimonthly')\nmarker('domain.record.updateFrequency.biennially')\n\nexport type UpdateFrequencyCustom = {\n  updatedTimes: number // this should be an integer\n  per: 'day' | 'week' | 'month' | 'year'\n}\nexport type UpdateFrequency = UpdateFrequencyCode | UpdateFrequencyCustom\n\nexport type RecordKind = 'dataset' | 'service' | 'reuse'\n\nmarker('domain.record.status.completed')\nmarker('domain.record.status.ongoing')\nmarker('domain.record.status.under_development')\nmarker('domain.record.status.deprecated')\nmarker('domain.record.status.removed')\n\nexport const RecordStatusValues = [\n  'completed',\n  'ongoing',\n  'under_development',\n  'deprecated',\n  'removed',\n]\nexport type RecordStatus = (typeof RecordStatusValues)[number]\n\nexport type Constraint = {\n  text: string\n  url?: URL\n\n  translations?: ConstraintTranslations\n}\n\nexport type SpatialRepresentationType =\n  | 'grid'\n  | 'vector'\n  | 'tin'\n  | 'table'\n  | 'point'\n\nexport interface Keyword {\n  key?: string\n  label: string\n  description?: string\n  type: KeywordType\n  thesaurus?: ThesaurusModel\n  bbox?: [number, number, number, number]\n\n  translations?: KeywordTranslations\n}\n\nexport interface BaseRecord {\n  uniqueIdentifier: Uuid\n  ownerOrganization: Organization\n  contacts: Array<Individual>\n  title: string\n  abstract: string\n  recordCreated?: Date\n  recordPublished?: Date\n  recordUpdated: Date\n  kind: RecordKind\n  topics: Array<string> // TODO: handle codelists\n  keywords: Array<Keyword>\n  licenses: Array<Constraint>\n  legalConstraints: Array<Constraint>\n  securityConstraints: Array<Constraint>\n  otherConstraints: Array<Constraint>\n  overviews: Array<GraphicOverview>\n  extras?: Record<string, unknown>\n  landingPage?: URL\n  updateFrequency?: UpdateFrequency\n\n  // information related to the resource (dataset, service)\n  resourceIdentifier?: string\n  contactsForResource: Array<Individual>\n  resourceCreated?: Date\n  resourcePublished?: Date\n  resourceUpdated?: Date\n\n  // multilingual support\n  defaultLanguage: LanguageCode\n  otherLanguages: Array<LanguageCode> // this should include all non-default languages present in the metadata, even if incompletely translated\n\n  translations?: RecordTranslations\n\n  // to add: canonical url\n  // to add: source catalog (??)\n  // to add: is open data ?\n}\n\n// TODO: handle actual codelists\nexport type ServiceProtocol =\n  | 'wms'\n  | 'wfs'\n  | 'wps'\n  | 'wmts'\n  | 'esriRest'\n  | 'ogcFeatures'\n  | 'GPFDL'\n  | 'other'\n\nexport type OnlineResourceType = 'service' | 'download' | 'link' | 'endpoint'\n\nexport interface DatasetServiceDistribution {\n  type: 'service'\n  url: URL\n  accessServiceProtocol: ServiceProtocol\n  identifierInService?: string // should we keep the identifierInService? read-write duplicate with name\n  name?: string\n  description?: string\n  translations?: OnlineResourceTranslations\n}\n\nexport interface DatasetDownloadDistribution {\n  type: 'download'\n  url: URL\n  mimeType?: string\n  sizeBytes?: number\n  // removed because what's the use? encoding can be exposed by the file server or\n  // even found out by trial and error; besides we can reasonably expect unicode or iso most of the time\n  // textEncoding?: string\n  name?: string\n  description?: string\n  accessServiceProtocol?: ServiceProtocol\n  translations?: OnlineResourceTranslations\n}\n\nexport interface OnlineLinkResource {\n  type: 'link'\n  url: URL\n  name?: string\n  description?: string\n  translations?: OnlineResourceTranslations\n}\n\nexport type DatasetOnlineResource = (\n  | DatasetServiceDistribution\n  | DatasetDownloadDistribution\n  | OnlineLinkResource\n) & {\n  type: OnlineResourceType\n}\n\nexport interface GraphicOverview {\n  url: URL\n  description?: string\n}\n\nexport interface DatasetSpatialExtent {\n  bbox?: [number, number, number, number]\n  geometry?: Geometry\n  description?: string\n  translations?: SpatialExtentTranslations\n}\n\n/**\n * Period if both start and end are provided\n * Instant if only start is provided\n */\nexport interface DatasetTemporalExtent {\n  start: Date\n  end?: Date\n}\n\nexport interface DatasetRecord extends BaseRecord {\n  kind: 'dataset'\n  status: RecordStatus\n  lineage: string // Explanation of the origin of this record (e.g: how, why)\"\n  onlineResources: Array<DatasetOnlineResource>\n  spatialExtents: Array<DatasetSpatialExtent>\n  temporalExtents: Array<DatasetTemporalExtent>\n  spatialRepresentation?: SpatialRepresentationType\n}\n\nexport type DatasetFeatureCatalog = {\n  featureTypes: Array<{\n    name: string\n    definition: string\n    attributes: Array<{ name: string; title: string }>\n  }>\n}\n\nexport interface ServiceEndpoint {\n  endpointUrl: URL\n  protocol: string\n  type: 'endpoint'\n  description?: string\n  translations?: OnlineResourceTranslations\n}\n\nexport type ServiceOnlineResource = (ServiceEndpoint | OnlineLinkResource) & {\n  type: OnlineResourceType\n}\n\nexport interface ServiceRecord extends BaseRecord {\n  kind: 'service'\n  onlineResources: Array<ServiceOnlineResource>\n  spatialExtents: Array<DatasetSpatialExtent>\n}\n\nexport interface ReuseRecord extends BaseRecord {\n  kind: 'reuse'\n  lineage: string // Explanation of the origin of this record (e.g: how, why)\"\n  onlineResources: Array<OnlineLinkResource>\n  reuseType: ReuseType\n  spatialExtents: Array<DatasetSpatialExtent>\n  temporalExtents: Array<DatasetTemporalExtent>\n}\n\nexport interface DatasetFeatureType {\n  aliases: string\n  code: string\n  isAbstract: string\n  typeName: string\n  definition: string\n  attributeTable: Array<{ name: string; definition: string }>\n}\n\nexport type ReuseType = 'application' | 'map' | 'other'\n\nexport type OnlineResource = DatasetOnlineResource | ServiceOnlineResource\n\nexport type CatalogRecord = DatasetRecord | ReuseRecord | ServiceRecord\n\nexport type CatalogRecordKeys =\n  | keyof DatasetRecord\n  | keyof ReuseRecord\n  | keyof ServiceRecord\n"]}
50
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"metadata.model.js","sourceRoot":"","sources":["../../../../../../../../../libs/common/domain/src/lib/model/record/metadata.model.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,yCAAyC,CAAA;AAgBhE,MAAM,CAAC,uCAAuC,CAAC,CAAA;AAC/C,MAAM,CAAC,0CAA0C,CAAC,CAAA;AAClD,MAAM,CAAC,wCAAwC,CAAC,CAAA;AAChD,MAAM,CAAC,yCAAyC,CAAC,CAAA;AACjD,MAAM,CAAC,yCAAyC,CAAC,CAAA;AACjD,MAAM,CAAC,wCAAwC,CAAC,CAAA;AAEhD,MAAM,CAAC,MAAM,yBAAyB,GAAG;IACvC,SAAS;IACT,YAAY;IACZ,UAAU;IACV,WAAW;IACX,WAAW;IACX,UAAU;IACV,OAAO;IACP,QAAQ;IACR,aAAa;IACb,aAAa;IACb,SAAS;IACT,WAAW;IACX,YAAY;IACZ,UAAU;IACV,YAAY;CACJ,CAAA;AAIV,MAAM,CAAC,mCAAmC,CAAC,CAAA;AAC3C,MAAM,CAAC,oCAAoC,CAAC,CAAA;AAC5C,MAAM,CAAC,qCAAqC,CAAC,CAAA;AAC7C,MAAM,CAAC,oCAAoC,CAAC,CAAA;AAE5C,MAAM,CAAC,qCAAqC,CAAC,CAAA;AAC7C,MAAM,CAAC,sCAAsC,CAAC,CAAA;AAC9C,MAAM,CAAC,2CAA2C,CAAC,CAAA;AACnD,MAAM,CAAC,uCAAuC,CAAC,CAAA;AAC/C,MAAM,CAAC,yCAAyC,CAAC,CAAA;AACjD,MAAM,CAAC,0CAA0C,CAAC,CAAA;AAClD,MAAM,CAAC,wCAAwC,CAAC,CAAA;AAChD,MAAM,CAAC,2CAA2C,CAAC,CAAA;AACnD,MAAM,CAAC,0CAA0C,CAAC,CAAA;AAUlD,MAAM,CAAC,gCAAgC,CAAC,CAAA;AACxC,MAAM,CAAC,8BAA8B,CAAC,CAAA;AACtC,MAAM,CAAC,wCAAwC,CAAC,CAAA;AAChD,MAAM,CAAC,iCAAiC,CAAC,CAAA;AACzC,MAAM,CAAC,8BAA8B,CAAC,CAAA;AAEtC,MAAM,CAAC,MAAM,kBAAkB,GAAG;IAChC,WAAW;IACX,SAAS;IACT,mBAAmB;IACnB,YAAY;IACZ,SAAS;CACV,CAAA","sourcesContent":["import { marker } from '@biesbjerg/ngx-translate-extract-marker'\nimport type { Individual } from './contact.model'\nimport type { Organization } from './organization.model'\nimport type { Geometry } from 'geojson'\nimport { KeywordType, ThesaurusModel } from '../thesaurus'\nimport {\n  ConstraintTranslations,\n  KeywordTranslations,\n  LanguageCode,\n  OnlineResourceTranslations,\n  RecordTranslations,\n  SpatialExtentTranslations,\n} from './translation.model'\n\ntype Uuid = string\n\nmarker('domain.record.updateFrequency.unknown')\nmarker('domain.record.updateFrequency.notPlanned')\nmarker('domain.record.updateFrequency.asNeeded')\nmarker('domain.record.updateFrequency.irregular')\nmarker('domain.record.updateFrequency.continual')\nmarker('domain.record.updateFrequency.periodic')\n\nexport const updateFrequencyCodeValues = [\n  'unknown',\n  'notPlanned',\n  'asNeeded',\n  'irregular',\n  'continual',\n  'periodic',\n  'daily',\n  'weekly',\n  'fortnightly',\n  'semimonthly',\n  'monthly',\n  'quarterly',\n  'biannually',\n  'annually',\n  'biennially',\n] as const\n\nexport type UpdateFrequencyCode = (typeof updateFrequencyCodeValues)[number]\n\nmarker('domain.record.updateFrequency.day')\nmarker('domain.record.updateFrequency.week')\nmarker('domain.record.updateFrequency.month')\nmarker('domain.record.updateFrequency.year')\n\nmarker('domain.record.updateFrequency.daily')\nmarker('domain.record.updateFrequency.weekly')\nmarker('domain.record.updateFrequency.fortnightly')\nmarker('domain.record.updateFrequency.monthly')\nmarker('domain.record.updateFrequency.quarterly')\nmarker('domain.record.updateFrequency.biannually')\nmarker('domain.record.updateFrequency.annually')\nmarker('domain.record.updateFrequency.semimonthly')\nmarker('domain.record.updateFrequency.biennially')\n\nexport type UpdateFrequencyCustom = {\n  updatedTimes: number // this should be an integer\n  per: 'day' | 'week' | 'month' | 'year'\n}\nexport type UpdateFrequency = UpdateFrequencyCode | UpdateFrequencyCustom\n\nexport type RecordKind = 'dataset' | 'service' | 'reuse'\n\nmarker('domain.record.status.completed')\nmarker('domain.record.status.ongoing')\nmarker('domain.record.status.under_development')\nmarker('domain.record.status.deprecated')\nmarker('domain.record.status.removed')\n\nexport const RecordStatusValues = [\n  'completed',\n  'ongoing',\n  'under_development',\n  'deprecated',\n  'removed',\n]\nexport type RecordStatus = (typeof RecordStatusValues)[number]\n\nexport type Constraint = {\n  text: string\n  url?: URL\n\n  translations?: ConstraintTranslations\n}\n\nexport type SpatialRepresentationType =\n  | 'grid'\n  | 'vector'\n  | 'tin'\n  | 'table'\n  | 'point'\n\nexport interface Keyword {\n  key?: string\n  label: string\n  description?: string\n  type: KeywordType\n  thesaurus?: ThesaurusModel\n  bbox?: [number, number, number, number]\n\n  translations?: KeywordTranslations\n}\n\nexport interface BaseRecord {\n  uniqueIdentifier: Uuid\n  ownerOrganization: Organization\n  contacts: Array<Individual>\n  title: string\n  abstract: string\n  recordCreated?: Date\n  recordPublished?: Date\n  recordUpdated: Date\n  kind: RecordKind\n  topics: Array<string> // TODO: handle codelists\n  keywords: Array<Keyword>\n  licenses: Array<Constraint>\n  legalConstraints: Array<Constraint>\n  securityConstraints: Array<Constraint>\n  otherConstraints: Array<Constraint>\n  overviews: Array<GraphicOverview>\n  extras?: Record<string, unknown>\n  landingPage?: URL\n  updateFrequency?: UpdateFrequency\n\n  // information related to the resource (dataset, service)\n  resourceIdentifier?: string\n  contactsForResource: Array<Individual>\n  resourceCreated?: Date\n  resourcePublished?: Date\n  resourceUpdated?: Date\n\n  // multilingual support\n  defaultLanguage: LanguageCode\n  otherLanguages: Array<LanguageCode> // this should include all non-default languages present in the metadata, even if incompletely translated\n\n  translations?: RecordTranslations\n\n  // to add: canonical url\n  // to add: source catalog (??)\n  // to add: is open data ?\n}\n\n// TODO: handle actual codelists\nexport type ServiceProtocol =\n  | 'wms'\n  | 'wfs'\n  | 'wps'\n  | 'wmts'\n  | 'esriRest'\n  | 'ogcFeatures'\n  | 'GPFDL'\n  | 'other'\n\nexport type OnlineResourceType = 'service' | 'download' | 'link' | 'endpoint'\n\nexport interface DatasetServiceDistribution {\n  type: 'service'\n  url: URL\n  accessServiceProtocol: ServiceProtocol\n  identifierInService?: string // should we keep the identifierInService? read-write duplicate with name\n  name?: string\n  description?: string\n  translations?: OnlineResourceTranslations\n}\n\nexport interface DatasetDownloadDistribution {\n  type: 'download'\n  url: URL\n  mimeType?: string\n  sizeBytes?: number\n  // removed because what's the use? encoding can be exposed by the file server or\n  // even found out by trial and error; besides we can reasonably expect unicode or iso most of the time\n  // textEncoding?: string\n  name?: string\n  description?: string\n  accessServiceProtocol?: ServiceProtocol\n  translations?: OnlineResourceTranslations\n}\n\nexport interface OnlineLinkResource {\n  type: 'link'\n  url: URL\n  name?: string\n  description?: string\n  translations?: OnlineResourceTranslations\n  mimeType?: string\n}\n\nexport type DatasetOnlineResource = (\n  | DatasetServiceDistribution\n  | DatasetDownloadDistribution\n  | OnlineLinkResource\n) & {\n  type: OnlineResourceType\n}\n\nexport interface GraphicOverview {\n  url: URL\n  description?: string\n}\n\nexport interface DatasetSpatialExtent {\n  bbox?: [number, number, number, number]\n  geometry?: Geometry\n  description?: string\n  translations?: SpatialExtentTranslations\n}\n\n/**\n * Period if both start and end are provided\n * Instant if only start is provided\n */\nexport interface DatasetTemporalExtent {\n  start: Date\n  end?: Date\n}\n\nexport interface DatasetRecord extends BaseRecord {\n  kind: 'dataset'\n  status: RecordStatus\n  lineage: string // Explanation of the origin of this record (e.g: how, why)\"\n  onlineResources: Array<DatasetOnlineResource>\n  spatialExtents: Array<DatasetSpatialExtent>\n  temporalExtents: Array<DatasetTemporalExtent>\n  spatialRepresentation?: SpatialRepresentationType\n}\n\nexport type DatasetFeatureCatalog = {\n  featureTypes: Array<{\n    name: string\n    definition: string\n    attributes: Array<{ name: string; title: string }>\n  }>\n}\n\nexport interface ServiceEndpoint {\n  endpointUrl: URL\n  protocol: string\n  type: 'endpoint'\n  description?: string\n  translations?: OnlineResourceTranslations\n}\n\nexport type ServiceOnlineResource = (ServiceEndpoint | OnlineLinkResource) & {\n  type: OnlineResourceType\n}\n\nexport interface ServiceRecord extends BaseRecord {\n  kind: 'service'\n  onlineResources: Array<ServiceOnlineResource>\n  spatialExtents: Array<DatasetSpatialExtent>\n}\n\nexport interface ReuseRecord extends BaseRecord {\n  kind: 'reuse'\n  lineage: string // Explanation of the origin of this record (e.g: how, why)\"\n  onlineResources: Array<OnlineLinkResource>\n  reuseType: ReuseType\n  spatialExtents: Array<DatasetSpatialExtent>\n  temporalExtents: Array<DatasetTemporalExtent>\n}\n\nexport interface DatasetFeatureType {\n  aliases: string\n  code: string\n  isAbstract: string\n  typeName: string\n  definition: string\n  attributeTable: Array<{ name: string; definition: string }>\n}\n\nexport type ReuseType = 'application' | 'map' | 'other'\n\nexport type OnlineResource = DatasetOnlineResource | ServiceOnlineResource\n\nexport type CatalogRecord = DatasetRecord | ReuseRecord | ServiceRecord\n\nexport type CatalogRecordKeys =\n  | keyof DatasetRecord\n  | keyof ReuseRecord\n  | keyof ServiceRecord\n"]}
@@ -94,11 +94,11 @@ export class FavoriteStarComponent {
94
94
  });
95
95
  }
96
96
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FavoriteStarComponent, deps: [{ token: i1.FavoritesService }, { token: i2.PlatformServiceInterface }, { token: i0.ChangeDetectorRef }, { token: i1.AuthService }, { token: i3.TranslateService }], target: i0.ɵɵFactoryTarget.Component }); }
97
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: FavoriteStarComponent, isStandalone: true, selector: "gn-ui-favorite-star", inputs: { displayCount: "displayCount", record: "record" }, viewQueries: [{ propertyName: "starToggleRef", first: true, predicate: StarToggleComponent, descendants: true, read: ElementRef }], ngImport: i0, template: "<div class=\"flex flex-row items-center\">\n <span\n class=\"align-text-top mr-1.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 ></gn-ui-star-toggle>\n <span\n class=\"align-text-top ml-1.5\"\n data-test=\"favorite-count\"\n *ngIf=\"!displayCount\"\n translate=\"datahub.record.addToFavorites\"\n ></span>\n</div>\n", styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i4.AsyncPipe, name: "async" }, { kind: "component", type: StarToggleComponent, selector: "gn-ui-star-toggle", inputs: ["toggled", "disabled"], outputs: ["newValue"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
97
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: FavoriteStarComponent, isStandalone: true, selector: "gn-ui-favorite-star", inputs: { displayCount: "displayCount", record: "record" }, viewQueries: [{ propertyName: "starToggleRef", first: true, predicate: StarToggleComponent, descendants: true, read: ElementRef }], ngImport: i0, template: "<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 ></gn-ui-star-toggle>\n <span\n class=\"align-text-top ml-1.5\"\n data-test=\"favorite-count\"\n *ngIf=\"!displayCount\"\n translate=\"datahub.record.addToFavorites\"\n ></span>\n</div>\n", styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i4.AsyncPipe, name: "async" }, { kind: "component", type: StarToggleComponent, selector: "gn-ui-star-toggle", inputs: ["toggled", "disabled"], outputs: ["newValue"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
98
98
  }
99
99
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FavoriteStarComponent, decorators: [{
100
100
  type: Component,
101
- args: [{ selector: 'gn-ui-favorite-star', changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, imports: [CommonModule, StarToggleComponent], template: "<div class=\"flex flex-row items-center\">\n <span\n class=\"align-text-top mr-1.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 ></gn-ui-star-toggle>\n <span\n class=\"align-text-top ml-1.5\"\n data-test=\"favorite-count\"\n *ngIf=\"!displayCount\"\n translate=\"datahub.record.addToFavorites\"\n ></span>\n</div>\n" }]
101
+ args: [{ selector: 'gn-ui-favorite-star', changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, imports: [CommonModule, StarToggleComponent], template: "<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 ></gn-ui-star-toggle>\n <span\n class=\"align-text-top ml-1.5\"\n data-test=\"favorite-count\"\n *ngIf=\"!displayCount\"\n translate=\"datahub.record.addToFavorites\"\n ></span>\n</div>\n" }]
102
102
  }], ctorParameters: () => [{ type: i1.FavoritesService }, { type: i2.PlatformServiceInterface }, { type: i0.ChangeDetectorRef }, { type: i1.AuthService }, { type: i3.TranslateService }], propDecorators: { displayCount: [{
103
103
  type: Input
104
104
  }], record: [{
@@ -107,4 +107,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
107
107
  type: ViewChild,
108
108
  args: [StarToggleComponent, { read: ElementRef }]
109
109
  }] } });
110
- //# 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 { map, pairwise, withLatestFrom } 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() 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.get(\n    'favorite.not.authenticated.tooltip',\n    {\n      link: this.loginUrl,\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: 40,\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\"\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  ></gn-ui-star-toggle>\n  <span\n    class=\"align-text-top ml-1.5\"\n    data-test=\"favorite-count\"\n    *ngIf=\"!displayCount\"\n    translate=\"datahub.record.addToFavorites\"\n  ></span>\n</div>\n"]}
110
+ //# 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 { map, pairwise, withLatestFrom } 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() 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.get(\n    'favorite.not.authenticated.tooltip',\n    {\n      link: this.loginUrl,\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: 40,\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  ></gn-ui-star-toggle>\n  <span\n    class=\"align-text-top ml-1.5\"\n    data-test=\"favorite-count\"\n    *ngIf=\"!displayCount\"\n    translate=\"datahub.record.addToFavorites\"\n  ></span>\n</div>\n"]}
@@ -23,4 +23,5 @@ export * from './lib/ui-elements.module';
23
23
  export * from './lib/user-feedback-item/user-feedback-item.component';
24
24
  export * from './lib/user-preview/user-preview.component';
25
25
  export * from './lib/application-banner/application-banner.component';
26
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzL3VpL2VsZW1lbnRzL3NyYy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLG1DQUFtQyxDQUFBO0FBQ2pELGNBQWMsK0JBQStCLENBQUE7QUFDN0MsY0FBYyx5REFBeUQsQ0FBQTtBQUN2RSxjQUFjLDZDQUE2QyxDQUFBO0FBQzNELGNBQWMsNkNBQTZDLENBQUE7QUFDM0QsY0FBYywrQ0FBK0MsQ0FBQTtBQUM3RCxjQUFjLDZCQUE2QixDQUFBO0FBQzNDLGNBQWMseUNBQXlDLENBQUE7QUFDdkQsY0FBYyw2REFBNkQsQ0FBQTtBQUMzRSxjQUFjLHFDQUFxQyxDQUFBO0FBQ25ELGNBQWMsaURBQWlELENBQUE7QUFDL0QsY0FBYyxpREFBaUQsQ0FBQTtBQUMvRCxjQUFjLG1EQUFtRCxDQUFBO0FBQ2pFLGNBQWMsbURBQW1ELENBQUE7QUFDakUsY0FBYyw2Q0FBNkMsQ0FBQTtBQUMzRCxjQUFjLDZEQUE2RCxDQUFBO0FBQzNFLGNBQWMsbURBQW1ELENBQUE7QUFDakUsY0FBYywyQ0FBMkMsQ0FBQTtBQUN6RCxjQUFjLGlEQUFpRCxDQUFBO0FBQy9ELGNBQWMseURBQXlELENBQUE7QUFDdkUsY0FBYyxxQ0FBcUMsQ0FBQTtBQUNuRCxjQUFjLDBCQUEwQixDQUFBO0FBQ3hDLGNBQWMsdURBQXVELENBQUE7QUFDckUsY0FBYywyQ0FBMkMsQ0FBQTtBQUN6RCxjQUFjLHVEQUF1RCxDQUFBIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9saWIvYXBpLWNhcmQvYXBpLWNhcmQuY29tcG9uZW50J1xuZXhwb3J0ICogZnJvbSAnLi9saWIvYXZhdGFyL2F2YXRhci5jb21wb25lbnQnXG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb25maXJtYXRpb24tZGlhbG9nL2NvbmZpcm1hdGlvbi1kaWFsb2cuY29tcG9uZW50J1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29udGVudC1naG9zdC9jb250ZW50LWdob3N0LmNvbXBvbmVudCdcbmV4cG9ydCAqIGZyb20gJy4vbGliL2Rvd25sb2FkLWl0ZW0vZG93bmxvYWQtaXRlbS5jb21wb25lbnQnXG5leHBvcnQgKiBmcm9tICcuL2xpYi9kb3dubG9hZHMtbGlzdC9kb3dubG9hZHMtbGlzdC5jb21wb25lbnQnXG5leHBvcnQgKiBmcm9tICcuL2xpYi9lcnJvci9lcnJvci5jb21wb25lbnQnXG5leHBvcnQgKiBmcm9tICcuL2xpYi9pbWFnZS1pbnB1dC9pbWFnZS1pbnB1dC5jb21wb25lbnQnXG5leHBvcnQgKiBmcm9tICcuL2xpYi9pbWFnZS1vdmVybGF5LXByZXZpZXcvaW1hZ2Utb3ZlcmxheS1wcmV2aWV3LmNvbXBvbmVudCdcbmV4cG9ydCAqIGZyb20gJy4vbGliL2xpbmstY2FyZC9saW5rLWNhcmQuY29tcG9uZW50J1xuZXhwb3J0ICogZnJvbSAnLi9saWIvbWFya2Rvd24tZWRpdG9yL21hcmtkb3duLWVkaXRvci5jb21wb25lbnQnXG5leHBvcnQgKiBmcm9tICcuL2xpYi9tYXJrZG93bi1wYXJzZXIvbWFya2Rvd24tcGFyc2VyLmNvbXBvbmVudCdcbmV4cG9ydCAqIGZyb20gJy4vbGliL21ldGFkYXRhLWNhdGFsb2cvbWV0YWRhdGEtY2F0YWxvZy5jb21wb25lbnQnXG5leHBvcnQgKiBmcm9tICcuL2xpYi9tZXRhZGF0YS1jb250YWN0L21ldGFkYXRhLWNvbnRhY3QuY29tcG9uZW50J1xuZXhwb3J0ICogZnJvbSAnLi9saWIvbWV0YWRhdGEtaW5mby9tZXRhZGF0YS1pbmZvLmNvbXBvbmVudCdcbmV4cG9ydCAqIGZyb20gJy4vbGliL21ldGFkYXRhLXF1YWxpdHktaXRlbS9tZXRhZGF0YS1xdWFsaXR5LWl0ZW0uY29tcG9uZW50J1xuZXhwb3J0ICogZnJvbSAnLi9saWIvbWV0YWRhdGEtcXVhbGl0eS9tZXRhZGF0YS1xdWFsaXR5LmNvbXBvbmVudCdcbmV4cG9ydCAqIGZyb20gJy4vbGliL25vdGlmaWNhdGlvbi9ub3RpZmljYXRpb24uY29tcG9uZW50J1xuZXhwb3J0ICogZnJvbSAnLi9saWIvcmVjb3JkLWFwaS1mb3JtL3JlY29yZC1hcGktZm9ybS5jb21wb25lbnQnXG5leHBvcnQgKiBmcm9tICcuL2xpYi9yZWxhdGVkLXJlY29yZC1jYXJkL3JlbGF0ZWQtcmVjb3JkLWNhcmQuY29tcG9uZW50J1xuZXhwb3J0ICogZnJvbSAnLi9saWIvdGh1bWJuYWlsL3RodW1ibmFpbC5jb21wb25lbnQnXG5leHBvcnQgKiBmcm9tICcuL2xpYi91aS1lbGVtZW50cy5tb2R1bGUnXG5leHBvcnQgKiBmcm9tICcuL2xpYi91c2VyLWZlZWRiYWNrLWl0ZW0vdXNlci1mZWVkYmFjay1pdGVtLmNvbXBvbmVudCdcbmV4cG9ydCAqIGZyb20gJy4vbGliL3VzZXItcHJldmlldy91c2VyLXByZXZpZXcuY29tcG9uZW50J1xuZXhwb3J0ICogZnJvbSAnLi9saWIvYXBwbGljYXRpb24tYmFubmVyL2FwcGxpY2F0aW9uLWJhbm5lci5jb21wb25lbnQnXG4iXX0=
26
+ export * from './lib/internal-link-card/internal-link-card.component';
27
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzL3VpL2VsZW1lbnRzL3NyYy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLG1DQUFtQyxDQUFBO0FBQ2pELGNBQWMsK0JBQStCLENBQUE7QUFDN0MsY0FBYyx5REFBeUQsQ0FBQTtBQUN2RSxjQUFjLDZDQUE2QyxDQUFBO0FBQzNELGNBQWMsNkNBQTZDLENBQUE7QUFDM0QsY0FBYywrQ0FBK0MsQ0FBQTtBQUM3RCxjQUFjLDZCQUE2QixDQUFBO0FBQzNDLGNBQWMseUNBQXlDLENBQUE7QUFDdkQsY0FBYyw2REFBNkQsQ0FBQTtBQUMzRSxjQUFjLHFDQUFxQyxDQUFBO0FBQ25ELGNBQWMsaURBQWlELENBQUE7QUFDL0QsY0FBYyxpREFBaUQsQ0FBQTtBQUMvRCxjQUFjLG1EQUFtRCxDQUFBO0FBQ2pFLGNBQWMsbURBQW1ELENBQUE7QUFDakUsY0FBYyw2Q0FBNkMsQ0FBQTtBQUMzRCxjQUFjLDZEQUE2RCxDQUFBO0FBQzNFLGNBQWMsbURBQW1ELENBQUE7QUFDakUsY0FBYywyQ0FBMkMsQ0FBQTtBQUN6RCxjQUFjLGlEQUFpRCxDQUFBO0FBQy9ELGNBQWMseURBQXlELENBQUE7QUFDdkUsY0FBYyxxQ0FBcUMsQ0FBQTtBQUNuRCxjQUFjLDBCQUEwQixDQUFBO0FBQ3hDLGNBQWMsdURBQXVELENBQUE7QUFDckUsY0FBYywyQ0FBMkMsQ0FBQTtBQUN6RCxjQUFjLHVEQUF1RCxDQUFBO0FBQ3JFLGNBQWMsdURBQXVELENBQUEiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2xpYi9hcGktY2FyZC9hcGktY2FyZC5jb21wb25lbnQnXG5leHBvcnQgKiBmcm9tICcuL2xpYi9hdmF0YXIvYXZhdGFyLmNvbXBvbmVudCdcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbmZpcm1hdGlvbi1kaWFsb2cvY29uZmlybWF0aW9uLWRpYWxvZy5jb21wb25lbnQnXG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb250ZW50LWdob3N0L2NvbnRlbnQtZ2hvc3QuY29tcG9uZW50J1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZG93bmxvYWQtaXRlbS9kb3dubG9hZC1pdGVtLmNvbXBvbmVudCdcbmV4cG9ydCAqIGZyb20gJy4vbGliL2Rvd25sb2Fkcy1saXN0L2Rvd25sb2Fkcy1saXN0LmNvbXBvbmVudCdcbmV4cG9ydCAqIGZyb20gJy4vbGliL2Vycm9yL2Vycm9yLmNvbXBvbmVudCdcbmV4cG9ydCAqIGZyb20gJy4vbGliL2ltYWdlLWlucHV0L2ltYWdlLWlucHV0LmNvbXBvbmVudCdcbmV4cG9ydCAqIGZyb20gJy4vbGliL2ltYWdlLW92ZXJsYXktcHJldmlldy9pbWFnZS1vdmVybGF5LXByZXZpZXcuY29tcG9uZW50J1xuZXhwb3J0ICogZnJvbSAnLi9saWIvbGluay1jYXJkL2xpbmstY2FyZC5jb21wb25lbnQnXG5leHBvcnQgKiBmcm9tICcuL2xpYi9tYXJrZG93bi1lZGl0b3IvbWFya2Rvd24tZWRpdG9yLmNvbXBvbmVudCdcbmV4cG9ydCAqIGZyb20gJy4vbGliL21hcmtkb3duLXBhcnNlci9tYXJrZG93bi1wYXJzZXIuY29tcG9uZW50J1xuZXhwb3J0ICogZnJvbSAnLi9saWIvbWV0YWRhdGEtY2F0YWxvZy9tZXRhZGF0YS1jYXRhbG9nLmNvbXBvbmVudCdcbmV4cG9ydCAqIGZyb20gJy4vbGliL21ldGFkYXRhLWNvbnRhY3QvbWV0YWRhdGEtY29udGFjdC5jb21wb25lbnQnXG5leHBvcnQgKiBmcm9tICcuL2xpYi9tZXRhZGF0YS1pbmZvL21ldGFkYXRhLWluZm8uY29tcG9uZW50J1xuZXhwb3J0ICogZnJvbSAnLi9saWIvbWV0YWRhdGEtcXVhbGl0eS1pdGVtL21ldGFkYXRhLXF1YWxpdHktaXRlbS5jb21wb25lbnQnXG5leHBvcnQgKiBmcm9tICcuL2xpYi9tZXRhZGF0YS1xdWFsaXR5L21ldGFkYXRhLXF1YWxpdHkuY29tcG9uZW50J1xuZXhwb3J0ICogZnJvbSAnLi9saWIvbm90aWZpY2F0aW9uL25vdGlmaWNhdGlvbi5jb21wb25lbnQnXG5leHBvcnQgKiBmcm9tICcuL2xpYi9yZWNvcmQtYXBpLWZvcm0vcmVjb3JkLWFwaS1mb3JtLmNvbXBvbmVudCdcbmV4cG9ydCAqIGZyb20gJy4vbGliL3JlbGF0ZWQtcmVjb3JkLWNhcmQvcmVsYXRlZC1yZWNvcmQtY2FyZC5jb21wb25lbnQnXG5leHBvcnQgKiBmcm9tICcuL2xpYi90aHVtYm5haWwvdGh1bWJuYWlsLmNvbXBvbmVudCdcbmV4cG9ydCAqIGZyb20gJy4vbGliL3VpLWVsZW1lbnRzLm1vZHVsZSdcbmV4cG9ydCAqIGZyb20gJy4vbGliL3VzZXItZmVlZGJhY2staXRlbS91c2VyLWZlZWRiYWNrLWl0ZW0uY29tcG9uZW50J1xuZXhwb3J0ICogZnJvbSAnLi9saWIvdXNlci1wcmV2aWV3L3VzZXItcHJldmlldy5jb21wb25lbnQnXG5leHBvcnQgKiBmcm9tICcuL2xpYi9hcHBsaWNhdGlvbi1iYW5uZXIvYXBwbGljYXRpb24tYmFubmVyLmNvbXBvbmVudCdcbmV4cG9ydCAqIGZyb20gJy4vbGliL2ludGVybmFsLWxpbmstY2FyZC9pbnRlcm5hbC1saW5rLWNhcmQuY29tcG9uZW50J1xuIl19
@@ -4,16 +4,35 @@ import { CopyTextButtonComponent } from '../../../../../../libs/ui/inputs/src';
4
4
  import { TranslateModule } from '@ngx-translate/core';
5
5
  import { MatTooltipModule } from '@angular/material/tooltip';
6
6
  import { NgIcon, provideIcons } from '@ng-icons/core';
7
- import { matMoreHoriz } from '@ng-icons/material-icons/baseline';
7
+ import { iconoirSettings } from '@ng-icons/iconoir';
8
8
  import * as i0 from "@angular/core";
9
9
  import * as i1 from "@angular/common";
10
10
  import * as i2 from "@ngx-translate/core";
11
11
  import * as i3 from "@angular/material/tooltip";
12
12
  export class ApiCardComponent {
13
13
  constructor() {
14
+ this.sizeClassMap = {
15
+ L: 'gn-ui-card-l py-2 px-5 flex-row',
16
+ M: 'gn-ui-card-m py-2 px-5 flex-row',
17
+ S: 'gn-ui-card-s p-4 flex-col',
18
+ XS: 'gn-ui-card-xs py-2 px-5 flex-row',
19
+ };
20
+ this.cardClass = '';
14
21
  this.currentlyActive = false;
15
22
  this.openRecordApiForm = new EventEmitter();
16
23
  }
24
+ set size(value) {
25
+ this._size = value;
26
+ this.cardClass = this.sizeClassMap[value];
27
+ }
28
+ get size() {
29
+ return this._size;
30
+ }
31
+ get generatedText() {
32
+ return this.link.accessServiceProtocol === 'wfs'
33
+ ? 'datahub.search.filter.generatedByWfs'
34
+ : 'datahub.search.filter.generatedByAPI';
35
+ }
17
36
  ngOnInit() {
18
37
  this.displayApiFormButton =
19
38
  this.link.accessServiceProtocol === 'ogcFeatures' ||
@@ -31,9 +50,9 @@ export class ApiCardComponent {
31
50
  }
32
51
  }
33
52
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ApiCardComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
34
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: ApiCardComponent, isStandalone: true, selector: "gn-ui-api-card", inputs: { link: "link", currentLink: "currentLink" }, outputs: { openRecordApiForm: "openRecordApiForm" }, usesOnChanges: true, ngImport: i0, template: "<div\n class=\"group flex flex-col justify-between h-40 pt-5 pb-6 px-7 rounded filter overflow-hidden cursor-default\"\n>\n <div\n class=\"font-title font-medium text-21 text-black text-ellipsis overflow-hidden break-words pb-5 h-[4.5rem]\"\n >\n {{ link.name || link.description }}\n </div>\n <div class=\"\">\n <div class=\"flex flex-row justify-between\">\n <span\n *ngIf=\"link.accessServiceProtocol !== 'GPFDL'\"\n class=\"bg-primary-opacity-50 uppercase inline-flex items-center justify-center px-2 py-1 text-13 font-medium leading-none text-white rounded text-primary-lightest group-hover:bg-primary transition-colors\"\n [ngClass]=\"{\n '!bg-primary': currentlyActive,\n }\"\n >{{ link.accessServiceProtocol }}</span\n >\n <span\n *ngIf=\"link.accessServiceProtocol === 'GPFDL'\"\n class=\"bg-primary-opacity-50 uppercase inline-flex items-center justify-center px-2 py-1 text-13 font-medium leading-none text-white rounded text-primary-lightest group-hover:bg-primary transition-colors\"\n [ngClass]=\"{\n '!bg-primary': currentlyActive,\n }\"\n translate\n >\n record.metadata.api.gpfdl</span\n >\n <div class=\"flex flex-row gap-2 items-center\">\n <gn-ui-copy-text-button\n [text]=\"link.url\"\n [tooltipText]=\"'tooltip.url.copy' | translate\"\n [displayText]=\"false\"\n ></gn-ui-copy-text-button>\n <button\n *ngIf=\"displayApiFormButton\"\n type=\"button\"\n [ngClass]=\"{\n 'py-2 px-4 rounded-r-md bg-gray-400 hover:bg-gray-600 focus:bg-gray-800 text-white':\n displayText,\n }\"\n [matTooltip]=\"\n !currentlyActive\n ? ('record.metadata.api.form.openForm' | translate)\n : ('record.metadata.api.form.closeForm' | translate)\n \"\n matTooltipPosition=\"above\"\n (click)=\"openRecordApiFormPanel()\"\n >\n <ng-icon\n class=\"pointer-events-none align-middle card-icon\"\n name=\"matMoreHoriz\"\n [ngClass]=\"{\n 'text-secondary opacity-100': currentlyActive,\n }\"\n ></ng-icon>\n </button>\n </div>\n </div>\n </div>\n</div>\n", styles: [""], 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: CopyTextButtonComponent, selector: "gn-ui-copy-text-button", inputs: ["text", "tooltipText", "displayText", "rows"] }, { kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i2.TranslatePipe, name: "translate" }, { kind: "directive", type: i2.TranslateDirective, selector: "[translate],[ngx-translate]", inputs: ["translate", "translateParams"] }, { kind: "ngmodule", type: MatTooltipModule }, { kind: "directive", type: i3.MatTooltip, selector: "[matTooltip]", inputs: ["matTooltipPosition", "matTooltipPositionAtOrigin", "matTooltipDisabled", "matTooltipShowDelay", "matTooltipHideDelay", "matTooltipTouchGestures", "matTooltip", "matTooltipClass"], exportAs: ["matTooltip"] }, { kind: "component", type: NgIcon, selector: "ng-icon", inputs: ["name", "svg", "size", "strokeWidth", "color"] }], viewProviders: [
53
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: ApiCardComponent, isStandalone: true, selector: "gn-ui-api-card", inputs: { link: "link", currentLink: "currentLink", size: "size" }, outputs: { openRecordApiForm: "openRecordApiForm" }, usesOnChanges: true, ngImport: i0, template: "<div\n class=\"group flex justify-between rounded filter overflow-hidden\"\n [ngClass]=\"cardClass\"\n>\n <ng-container *ngIf=\"size !== 'S'\">\n <div>\n <ng-container *ngTemplateOutlet=\"content\"></ng-container>\n </div>\n <div class=\"flex items-center\">\n <ng-container *ngTemplateOutlet=\"buttons\"></ng-container>\n </div>\n </ng-container>\n <ng-container *ngIf=\"size === 'S'\">\n <ng-container *ngTemplateOutlet=\"content\"></ng-container>\n </ng-container>\n</div>\n\n<ng-template #buttons>\n <div class=\"flex flex-row gap-2\">\n <gn-ui-copy-text-button\n [text]=\"link.url\"\n [tooltipText]=\"'tooltip.url.copy' | translate\"\n [displayText]=\"false\"\n class=\"border border-gray-300 rounded-lg pt-1 px-2 h-[34px]\"\n ></gn-ui-copy-text-button>\n <button\n *ngIf=\"displayApiFormButton\"\n type=\"button\"\n class=\"gn-ui-card-icon\"\n [ngClass]=\"{\n 'py-2 px-4 rounded-r-md bg-gray-400 hover:bg-gray-600 focus:bg-gray-800 text-white':\n displayText,\n }\"\n [matTooltip]=\"\n !currentlyActive\n ? ('record.metadata.api.form.openForm' | translate)\n : ('record.metadata.api.form.closeForm' | translate)\n \"\n matTooltipPosition=\"above\"\n (click)=\"openRecordApiFormPanel()\"\n >\n <ng-icon\n class=\"pointer-events-none align-middle card-icon\"\n name=\"iconoirSettings\"\n [ngClass]=\"{\n 'text-secondary opacity-100': currentlyActive,\n }\"\n ></ng-icon>\n </button>\n </div>\n</ng-template>\n\n<ng-template #content>\n <div>\n <div class=\"gn-ui-card-title\">\n {{ link.description || link.name }}\n </div>\n <div class=\"gn-ui-card-detail\">\n {{ link.name }}\n </div>\n </div>\n <div class=\"flex flex-row justify-between\">\n <div class=\"flex flex-row gap-2.5 items-center pt-1\">\n <span\n *ngIf=\"link.accessServiceProtocol !== 'GPFDL'\"\n class=\"bg-primary-opacity-50 uppercase inline-flex items-center justify-center px-2 py-1 text-13 font-medium leading-none text-white rounded text-primary-lightest group-hover:bg-primary transition-colors\"\n [ngClass]=\"{\n '!bg-primary': currentlyActive,\n }\"\n >{{ link.accessServiceProtocol }}</span\n >\n <span\n *ngIf=\"link.accessServiceProtocol === 'GPFDL'\"\n class=\"bg-primary-opacity-50 uppercase inline-flex items-center justify-center px-2 py-1 text-13 font-medium leading-none text-white rounded text-primary-lightest group-hover:bg-primary transition-colors\"\n [ngClass]=\"{\n '!bg-primary': currentlyActive,\n }\"\n translate\n >\n record.metadata.api.gpfdl</span\n >\n </div>\n <div *ngIf=\"size === 'S'\">\n <ng-container *ngTemplateOutlet=\"buttons\"></ng-container>\n </div>\n </div>\n</ng-template>\n", styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: CopyTextButtonComponent, selector: "gn-ui-copy-text-button", inputs: ["text", "tooltipText", "displayText", "rows"] }, { kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i2.TranslatePipe, name: "translate" }, { kind: "directive", type: i2.TranslateDirective, selector: "[translate],[ngx-translate]", inputs: ["translate", "translateParams"] }, { kind: "ngmodule", type: MatTooltipModule }, { kind: "directive", type: i3.MatTooltip, selector: "[matTooltip]", inputs: ["matTooltipPosition", "matTooltipPositionAtOrigin", "matTooltipDisabled", "matTooltipShowDelay", "matTooltipHideDelay", "matTooltipTouchGestures", "matTooltip", "matTooltipClass"], exportAs: ["matTooltip"] }, { kind: "component", type: NgIcon, selector: "ng-icon", inputs: ["name", "svg", "size", "strokeWidth", "color"] }], viewProviders: [
35
54
  provideIcons({
36
- matMoreHoriz,
55
+ iconoirSettings,
37
56
  }),
38
57
  ], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
39
58
  }
@@ -47,14 +66,16 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
47
66
  NgIcon,
48
67
  ], viewProviders: [
49
68
  provideIcons({
50
- matMoreHoriz,
69
+ iconoirSettings,
51
70
  }),
52
- ], template: "<div\n class=\"group flex flex-col justify-between h-40 pt-5 pb-6 px-7 rounded filter overflow-hidden cursor-default\"\n>\n <div\n class=\"font-title font-medium text-21 text-black text-ellipsis overflow-hidden break-words pb-5 h-[4.5rem]\"\n >\n {{ link.name || link.description }}\n </div>\n <div class=\"\">\n <div class=\"flex flex-row justify-between\">\n <span\n *ngIf=\"link.accessServiceProtocol !== 'GPFDL'\"\n class=\"bg-primary-opacity-50 uppercase inline-flex items-center justify-center px-2 py-1 text-13 font-medium leading-none text-white rounded text-primary-lightest group-hover:bg-primary transition-colors\"\n [ngClass]=\"{\n '!bg-primary': currentlyActive,\n }\"\n >{{ link.accessServiceProtocol }}</span\n >\n <span\n *ngIf=\"link.accessServiceProtocol === 'GPFDL'\"\n class=\"bg-primary-opacity-50 uppercase inline-flex items-center justify-center px-2 py-1 text-13 font-medium leading-none text-white rounded text-primary-lightest group-hover:bg-primary transition-colors\"\n [ngClass]=\"{\n '!bg-primary': currentlyActive,\n }\"\n translate\n >\n record.metadata.api.gpfdl</span\n >\n <div class=\"flex flex-row gap-2 items-center\">\n <gn-ui-copy-text-button\n [text]=\"link.url\"\n [tooltipText]=\"'tooltip.url.copy' | translate\"\n [displayText]=\"false\"\n ></gn-ui-copy-text-button>\n <button\n *ngIf=\"displayApiFormButton\"\n type=\"button\"\n [ngClass]=\"{\n 'py-2 px-4 rounded-r-md bg-gray-400 hover:bg-gray-600 focus:bg-gray-800 text-white':\n displayText,\n }\"\n [matTooltip]=\"\n !currentlyActive\n ? ('record.metadata.api.form.openForm' | translate)\n : ('record.metadata.api.form.closeForm' | translate)\n \"\n matTooltipPosition=\"above\"\n (click)=\"openRecordApiFormPanel()\"\n >\n <ng-icon\n class=\"pointer-events-none align-middle card-icon\"\n name=\"matMoreHoriz\"\n [ngClass]=\"{\n 'text-secondary opacity-100': currentlyActive,\n }\"\n ></ng-icon>\n </button>\n </div>\n </div>\n </div>\n</div>\n" }]
71
+ ], template: "<div\n class=\"group flex justify-between rounded filter overflow-hidden\"\n [ngClass]=\"cardClass\"\n>\n <ng-container *ngIf=\"size !== 'S'\">\n <div>\n <ng-container *ngTemplateOutlet=\"content\"></ng-container>\n </div>\n <div class=\"flex items-center\">\n <ng-container *ngTemplateOutlet=\"buttons\"></ng-container>\n </div>\n </ng-container>\n <ng-container *ngIf=\"size === 'S'\">\n <ng-container *ngTemplateOutlet=\"content\"></ng-container>\n </ng-container>\n</div>\n\n<ng-template #buttons>\n <div class=\"flex flex-row gap-2\">\n <gn-ui-copy-text-button\n [text]=\"link.url\"\n [tooltipText]=\"'tooltip.url.copy' | translate\"\n [displayText]=\"false\"\n class=\"border border-gray-300 rounded-lg pt-1 px-2 h-[34px]\"\n ></gn-ui-copy-text-button>\n <button\n *ngIf=\"displayApiFormButton\"\n type=\"button\"\n class=\"gn-ui-card-icon\"\n [ngClass]=\"{\n 'py-2 px-4 rounded-r-md bg-gray-400 hover:bg-gray-600 focus:bg-gray-800 text-white':\n displayText,\n }\"\n [matTooltip]=\"\n !currentlyActive\n ? ('record.metadata.api.form.openForm' | translate)\n : ('record.metadata.api.form.closeForm' | translate)\n \"\n matTooltipPosition=\"above\"\n (click)=\"openRecordApiFormPanel()\"\n >\n <ng-icon\n class=\"pointer-events-none align-middle card-icon\"\n name=\"iconoirSettings\"\n [ngClass]=\"{\n 'text-secondary opacity-100': currentlyActive,\n }\"\n ></ng-icon>\n </button>\n </div>\n</ng-template>\n\n<ng-template #content>\n <div>\n <div class=\"gn-ui-card-title\">\n {{ link.description || link.name }}\n </div>\n <div class=\"gn-ui-card-detail\">\n {{ link.name }}\n </div>\n </div>\n <div class=\"flex flex-row justify-between\">\n <div class=\"flex flex-row gap-2.5 items-center pt-1\">\n <span\n *ngIf=\"link.accessServiceProtocol !== 'GPFDL'\"\n class=\"bg-primary-opacity-50 uppercase inline-flex items-center justify-center px-2 py-1 text-13 font-medium leading-none text-white rounded text-primary-lightest group-hover:bg-primary transition-colors\"\n [ngClass]=\"{\n '!bg-primary': currentlyActive,\n }\"\n >{{ link.accessServiceProtocol }}</span\n >\n <span\n *ngIf=\"link.accessServiceProtocol === 'GPFDL'\"\n class=\"bg-primary-opacity-50 uppercase inline-flex items-center justify-center px-2 py-1 text-13 font-medium leading-none text-white rounded text-primary-lightest group-hover:bg-primary transition-colors\"\n [ngClass]=\"{\n '!bg-primary': currentlyActive,\n }\"\n translate\n >\n record.metadata.api.gpfdl</span\n >\n </div>\n <div *ngIf=\"size === 'S'\">\n <ng-container *ngTemplateOutlet=\"buttons\"></ng-container>\n </div>\n </div>\n</ng-template>\n" }]
53
72
  }], propDecorators: { link: [{
54
73
  type: Input
55
74
  }], currentLink: [{
56
75
  type: Input
76
+ }], size: [{
77
+ type: Input
57
78
  }], openRecordApiForm: [{
58
79
  type: Output
59
80
  }] } });
60
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"api-card.component.js","sourceRoot":"","sources":["../../../../../../../../libs/ui/elements/src/lib/api-card/api-card.component.ts","../../../../../../../../libs/ui/elements/src/lib/api-card/api-card.component.html"],"names":[],"mappings":"AACA,OAAO,EACL,uBAAuB,EACvB,SAAS,EACT,YAAY,EACZ,KAAK,EAGL,MAAM,GAEP,MAAM,eAAe,CAAA;AACtB,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAA;AAC9C,OAAO,EAAE,uBAAuB,EAAE,MAAM,sCAAsC,CAAA;AAC9E,OAAO,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAA;AACrD,OAAO,EAAE,gBAAgB,EAAE,MAAM,2BAA2B,CAAA;AAC5D,OAAO,EAAE,MAAM,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAA;AACrD,OAAO,EAAE,YAAY,EAAE,MAAM,mCAAmC,CAAA;;;;;AAqBhE,MAAM,OAAO,gBAAgB;IAnB7B;QAuBE,oBAAe,GAAG,KAAK,CAAA;QACb,sBAAiB,GACzB,IAAI,YAAY,EAA8B,CAAA;KAoBjD;IAlBC,QAAQ;QACN,IAAI,CAAC,oBAAoB;YACvB,IAAI,CAAC,IAAI,CAAC,qBAAqB,KAAK,aAAa;gBACjD,IAAI,CAAC,IAAI,CAAC,qBAAqB,KAAK,KAAK;gBACzC,IAAI,CAAC,IAAI,CAAC,qBAAqB,KAAK,OAAO,CAAA;IAC/C,CAAC;IAED,WAAW,CAAC,OAAsB;QAChC,IAAI,CAAC,eAAe;YAClB,OAAO,CAAC,WAAW,CAAC,YAAY,KAAK,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK,CAAA;IACjE,CAAC;IAED,sBAAsB;QACpB,IAAI,IAAI,CAAC,oBAAoB,EAAE,CAAC;YAC9B,IAAI,CAAC,eAAe,GAAG,CAAC,IAAI,CAAC,eAAe,CAAA;YAC5C,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,SAAS,CAAC,CAAA;QAC3E,CAAC;IACH,CAAC;+GAzBU,gBAAgB;mGAAhB,gBAAgB,0MCrC7B,6zEA6DA,yDDpCI,YAAY,iOACZ,uBAAuB,0HACvB,eAAe,kOACf,gBAAgB,6TAChB,MAAM,kGAEO;YACb,YAAY,CAAC;gBACX,YAAY;aACb,CAAC;SACH;;4FAEU,gBAAgB;kBAnB5B,SAAS;+BACE,gBAAgB,mBAGT,uBAAuB,CAAC,MAAM,cACnC,IAAI,WACP;wBACP,YAAY;wBACZ,uBAAuB;wBACvB,eAAe;wBACf,gBAAgB;wBAChB,MAAM;qBACP,iBACc;wBACb,YAAY,CAAC;4BACX,YAAY;yBACb,CAAC;qBACH;8BAGQ,IAAI;sBAAZ,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBAGI,iBAAiB;sBAA1B,MAAM","sourcesContent":["import { DatasetServiceDistribution } from '../../../../../../libs/common/domain/src/lib/model/record'\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnInit,\n  Output,\n  SimpleChanges,\n} from '@angular/core'\nimport { CommonModule } from '@angular/common'\nimport { CopyTextButtonComponent } from '../../../../../../libs/ui/inputs/src'\nimport { TranslateModule } from '@ngx-translate/core'\nimport { MatTooltipModule } from '@angular/material/tooltip'\nimport { NgIcon, provideIcons } from '@ng-icons/core'\nimport { matMoreHoriz } from '@ng-icons/material-icons/baseline'\n\n@Component({\n  selector: 'gn-ui-api-card',\n  templateUrl: './api-card.component.html',\n  styleUrls: ['./api-card.component.css'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true,\n  imports: [\n    CommonModule,\n    CopyTextButtonComponent,\n    TranslateModule,\n    MatTooltipModule,\n    NgIcon,\n  ],\n  viewProviders: [\n    provideIcons({\n      matMoreHoriz,\n    }),\n  ],\n})\nexport class ApiCardComponent implements OnInit, OnChanges {\n  @Input() link: DatasetServiceDistribution\n  @Input() currentLink: DatasetServiceDistribution\n  displayApiFormButton: boolean\n  currentlyActive = false\n  @Output() openRecordApiForm: EventEmitter<DatasetServiceDistribution> =\n    new EventEmitter<DatasetServiceDistribution>()\n\n  ngOnInit() {\n    this.displayApiFormButton =\n      this.link.accessServiceProtocol === 'ogcFeatures' ||\n      this.link.accessServiceProtocol === 'wfs' ||\n      this.link.accessServiceProtocol === 'GPFDL'\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    this.currentlyActive =\n      changes.currentLink.currentValue === this.link ? true : false\n  }\n\n  openRecordApiFormPanel() {\n    if (this.displayApiFormButton) {\n      this.currentlyActive = !this.currentlyActive\n      this.openRecordApiForm.emit(this.currentlyActive ? this.link : undefined)\n    }\n  }\n}\n","<div\n  class=\"group flex flex-col justify-between h-40 pt-5 pb-6 px-7 rounded filter overflow-hidden cursor-default\"\n>\n  <div\n    class=\"font-title font-medium text-21 text-black text-ellipsis overflow-hidden break-words pb-5 h-[4.5rem]\"\n  >\n    {{ link.name || link.description }}\n  </div>\n  <div class=\"\">\n    <div class=\"flex flex-row justify-between\">\n      <span\n        *ngIf=\"link.accessServiceProtocol !== 'GPFDL'\"\n        class=\"bg-primary-opacity-50 uppercase inline-flex items-center justify-center px-2 py-1 text-13 font-medium leading-none text-white rounded text-primary-lightest group-hover:bg-primary transition-colors\"\n        [ngClass]=\"{\n          '!bg-primary': currentlyActive,\n        }\"\n        >{{ link.accessServiceProtocol }}</span\n      >\n      <span\n        *ngIf=\"link.accessServiceProtocol === 'GPFDL'\"\n        class=\"bg-primary-opacity-50 uppercase inline-flex items-center justify-center px-2 py-1 text-13 font-medium leading-none text-white rounded text-primary-lightest group-hover:bg-primary transition-colors\"\n        [ngClass]=\"{\n          '!bg-primary': currentlyActive,\n        }\"\n        translate\n      >\n        record.metadata.api.gpfdl</span\n      >\n      <div class=\"flex flex-row gap-2 items-center\">\n        <gn-ui-copy-text-button\n          [text]=\"link.url\"\n          [tooltipText]=\"'tooltip.url.copy' | translate\"\n          [displayText]=\"false\"\n        ></gn-ui-copy-text-button>\n        <button\n          *ngIf=\"displayApiFormButton\"\n          type=\"button\"\n          [ngClass]=\"{\n            'py-2 px-4 rounded-r-md bg-gray-400 hover:bg-gray-600 focus:bg-gray-800 text-white':\n              displayText,\n          }\"\n          [matTooltip]=\"\n            !currentlyActive\n              ? ('record.metadata.api.form.openForm' | translate)\n              : ('record.metadata.api.form.closeForm' | translate)\n          \"\n          matTooltipPosition=\"above\"\n          (click)=\"openRecordApiFormPanel()\"\n        >\n          <ng-icon\n            class=\"pointer-events-none align-middle card-icon\"\n            name=\"matMoreHoriz\"\n            [ngClass]=\"{\n              'text-secondary opacity-100': currentlyActive,\n            }\"\n          ></ng-icon>\n        </button>\n      </div>\n    </div>\n  </div>\n</div>\n"]}
81
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"api-card.component.js","sourceRoot":"","sources":["../../../../../../../../libs/ui/elements/src/lib/api-card/api-card.component.ts","../../../../../../../../libs/ui/elements/src/lib/api-card/api-card.component.html"],"names":[],"mappings":"AACA,OAAO,EACL,uBAAuB,EACvB,SAAS,EACT,YAAY,EACZ,KAAK,EAGL,MAAM,GAEP,MAAM,eAAe,CAAA;AACtB,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAA;AAC9C,OAAO,EAAE,uBAAuB,EAAE,MAAM,sCAAsC,CAAA;AAC9E,OAAO,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAA;AACrD,OAAO,EAAE,gBAAgB,EAAE,MAAM,2BAA2B,CAAA;AAC5D,OAAO,EAAE,MAAM,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAA;AACrD,OAAO,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAA;;;;;AAuBnD,MAAM,OAAO,gBAAgB;IAnB7B;QAuBmB,iBAAY,GAA6B;YACxD,CAAC,EAAE,iCAAiC;YACpC,CAAC,EAAE,iCAAiC;YACpC,CAAC,EAAE,2BAA2B;YAC9B,EAAE,EAAE,kCAAkC;SACvC,CAAA;QASD,cAAS,GAAG,EAAE,CAAA;QAEd,oBAAe,GAAG,KAAK,CAAA;QACb,sBAAiB,GACzB,IAAI,YAAY,EAA8B,CAAA;KA0BjD;IArCC,IAAa,IAAI,CAAC,KAAe;QAC/B,IAAI,CAAC,KAAK,GAAG,KAAK,CAAA;QAClB,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,CAAA;IAC3C,CAAC;IACD,IAAI,IAAI;QACN,OAAO,IAAI,CAAC,KAAK,CAAA;IACnB,CAAC;IAOD,IAAI,aAAa;QACf,OAAO,IAAI,CAAC,IAAI,CAAC,qBAAqB,KAAK,KAAK;YAC9C,CAAC,CAAC,sCAAsC;YACxC,CAAC,CAAC,sCAAsC,CAAA;IAC5C,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,oBAAoB;YACvB,IAAI,CAAC,IAAI,CAAC,qBAAqB,KAAK,aAAa;gBACjD,IAAI,CAAC,IAAI,CAAC,qBAAqB,KAAK,KAAK;gBACzC,IAAI,CAAC,IAAI,CAAC,qBAAqB,KAAK,OAAO,CAAA;IAC/C,CAAC;IAED,WAAW,CAAC,OAAsB;QAChC,IAAI,CAAC,eAAe;YAClB,OAAO,CAAC,WAAW,CAAC,YAAY,KAAK,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK,CAAA;IACjE,CAAC;IAED,sBAAsB;QACpB,IAAI,IAAI,CAAC,oBAAoB,EAAE,CAAC;YAC9B,IAAI,CAAC,eAAe,GAAG,CAAC,IAAI,CAAC,eAAe,CAAA;YAC5C,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,SAAS,CAAC,CAAA;QAC3E,CAAC;IACH,CAAC;+GA/CU,gBAAgB;mGAAhB,gBAAgB,wNCvC7B,64FAuFA,yDD5DI,YAAY,wYACZ,uBAAuB,0HACvB,eAAe,kOACf,gBAAgB,6TAChB,MAAM,kGAEO;YACb,YAAY,CAAC;gBACX,eAAe;aAChB,CAAC;SACH;;4FAEU,gBAAgB;kBAnB5B,SAAS;+BACE,gBAAgB,mBAGT,uBAAuB,CAAC,MAAM,cACnC,IAAI,WACP;wBACP,YAAY;wBACZ,uBAAuB;wBACvB,eAAe;wBACf,gBAAgB;wBAChB,MAAM;qBACP,iBACc;wBACb,YAAY,CAAC;4BACX,eAAe;yBAChB,CAAC;qBACH;8BAIQ,IAAI;sBAAZ,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBAQO,IAAI;sBAAhB,KAAK;gBAUI,iBAAiB;sBAA1B,MAAM","sourcesContent":["import { DatasetServiceDistribution } from '../../../../../../libs/common/domain/src/lib/model/record'\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnInit,\n  Output,\n  SimpleChanges,\n} from '@angular/core'\nimport { CommonModule } from '@angular/common'\nimport { CopyTextButtonComponent } from '../../../../../../libs/ui/inputs/src'\nimport { TranslateModule } from '@ngx-translate/core'\nimport { MatTooltipModule } from '@angular/material/tooltip'\nimport { NgIcon, provideIcons } from '@ng-icons/core'\nimport { iconoirSettings } from '@ng-icons/iconoir'\n\ntype CardSize = 'L' | 'M' | 'S' | 'XS'\n\n@Component({\n  selector: 'gn-ui-api-card',\n  templateUrl: './api-card.component.html',\n  styleUrls: ['./api-card.component.css'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true,\n  imports: [\n    CommonModule,\n    CopyTextButtonComponent,\n    TranslateModule,\n    MatTooltipModule,\n    NgIcon,\n  ],\n  viewProviders: [\n    provideIcons({\n      iconoirSettings,\n    }),\n  ],\n})\nexport class ApiCardComponent implements OnInit, OnChanges {\n  private _size: 'L' | 'M' | 'S' | 'XS'\n  @Input() link: DatasetServiceDistribution\n  @Input() currentLink: DatasetServiceDistribution\n  private readonly sizeClassMap: Record<CardSize, string> = {\n    L: 'gn-ui-card-l py-2 px-5 flex-row',\n    M: 'gn-ui-card-m py-2 px-5 flex-row',\n    S: 'gn-ui-card-s p-4 flex-col',\n    XS: 'gn-ui-card-xs py-2 px-5 flex-row',\n  }\n\n  @Input() set size(value: CardSize) {\n    this._size = value\n    this.cardClass = this.sizeClassMap[value]\n  }\n  get size(): 'L' | 'M' | 'S' | 'XS' {\n    return this._size\n  }\n  cardClass = ''\n  displayApiFormButton: boolean\n  currentlyActive = false\n  @Output() openRecordApiForm: EventEmitter<DatasetServiceDistribution> =\n    new EventEmitter<DatasetServiceDistribution>()\n\n  get generatedText() {\n    return this.link.accessServiceProtocol === 'wfs'\n      ? 'datahub.search.filter.generatedByWfs'\n      : 'datahub.search.filter.generatedByAPI'\n  }\n\n  ngOnInit() {\n    this.displayApiFormButton =\n      this.link.accessServiceProtocol === 'ogcFeatures' ||\n      this.link.accessServiceProtocol === 'wfs' ||\n      this.link.accessServiceProtocol === 'GPFDL'\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    this.currentlyActive =\n      changes.currentLink.currentValue === this.link ? true : false\n  }\n\n  openRecordApiFormPanel() {\n    if (this.displayApiFormButton) {\n      this.currentlyActive = !this.currentlyActive\n      this.openRecordApiForm.emit(this.currentlyActive ? this.link : undefined)\n    }\n  }\n}\n","<div\n  class=\"group flex justify-between rounded filter overflow-hidden\"\n  [ngClass]=\"cardClass\"\n>\n  <ng-container *ngIf=\"size !== 'S'\">\n    <div>\n      <ng-container *ngTemplateOutlet=\"content\"></ng-container>\n    </div>\n    <div class=\"flex items-center\">\n      <ng-container *ngTemplateOutlet=\"buttons\"></ng-container>\n    </div>\n  </ng-container>\n  <ng-container *ngIf=\"size === 'S'\">\n    <ng-container *ngTemplateOutlet=\"content\"></ng-container>\n  </ng-container>\n</div>\n\n<ng-template #buttons>\n  <div class=\"flex flex-row gap-2\">\n    <gn-ui-copy-text-button\n      [text]=\"link.url\"\n      [tooltipText]=\"'tooltip.url.copy' | translate\"\n      [displayText]=\"false\"\n      class=\"border border-gray-300 rounded-lg pt-1 px-2 h-[34px]\"\n    ></gn-ui-copy-text-button>\n    <button\n      *ngIf=\"displayApiFormButton\"\n      type=\"button\"\n      class=\"gn-ui-card-icon\"\n      [ngClass]=\"{\n        'py-2 px-4 rounded-r-md bg-gray-400 hover:bg-gray-600 focus:bg-gray-800 text-white':\n          displayText,\n      }\"\n      [matTooltip]=\"\n        !currentlyActive\n          ? ('record.metadata.api.form.openForm' | translate)\n          : ('record.metadata.api.form.closeForm' | translate)\n      \"\n      matTooltipPosition=\"above\"\n      (click)=\"openRecordApiFormPanel()\"\n    >\n      <ng-icon\n        class=\"pointer-events-none align-middle card-icon\"\n        name=\"iconoirSettings\"\n        [ngClass]=\"{\n          'text-secondary opacity-100': currentlyActive,\n        }\"\n      ></ng-icon>\n    </button>\n  </div>\n</ng-template>\n\n<ng-template #content>\n  <div>\n    <div class=\"gn-ui-card-title\">\n      {{ link.description || link.name }}\n    </div>\n    <div class=\"gn-ui-card-detail\">\n      {{ link.name }}\n    </div>\n  </div>\n  <div class=\"flex flex-row justify-between\">\n    <div class=\"flex flex-row gap-2.5 items-center pt-1\">\n      <span\n        *ngIf=\"link.accessServiceProtocol !== 'GPFDL'\"\n        class=\"bg-primary-opacity-50 uppercase inline-flex items-center justify-center px-2 py-1 text-13 font-medium leading-none text-white rounded text-primary-lightest group-hover:bg-primary transition-colors\"\n        [ngClass]=\"{\n          '!bg-primary': currentlyActive,\n        }\"\n        >{{ link.accessServiceProtocol }}</span\n      >\n      <span\n        *ngIf=\"link.accessServiceProtocol === 'GPFDL'\"\n        class=\"bg-primary-opacity-50 uppercase inline-flex items-center justify-center px-2 py-1 text-13 font-medium leading-none text-white rounded text-primary-lightest group-hover:bg-primary transition-colors\"\n        [ngClass]=\"{\n          '!bg-primary': currentlyActive,\n        }\"\n        translate\n      >\n        record.metadata.api.gpfdl</span\n      >\n    </div>\n    <div *ngIf=\"size === 'S'\">\n      <ng-container *ngTemplateOutlet=\"buttons\"></ng-container>\n    </div>\n  </div>\n</ng-template>\n"]}
@@ -2,21 +2,35 @@ import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output, } from
2
2
  import { TranslateModule } from '@ngx-translate/core';
3
3
  import { CommonModule } from '@angular/common';
4
4
  import { NgIcon, provideIcons } from '@ng-icons/core';
5
- import { matCloudDownloadOutline } from '@ng-icons/material-icons/outline';
5
+ import { iconoirDownload } from '@ng-icons/iconoir';
6
6
  import * as i0 from "@angular/core";
7
7
  import * as i1 from "@angular/common";
8
8
  import * as i2 from "@ngx-translate/core";
9
9
  export class DownloadItemComponent {
10
10
  constructor() {
11
+ this.sizeClassMap = {
12
+ L: 'gn-ui-card-l py-2 px-5',
13
+ M: 'gn-ui-card-m py-2 px-5',
14
+ S: 'gn-ui-card-s p-4',
15
+ XS: 'gn-ui-card-xs py-2 px-5',
16
+ };
17
+ this.cardClass = '';
11
18
  this.exportUrl = new EventEmitter();
12
19
  }
20
+ set size(value) {
21
+ this._size = value;
22
+ this.cardClass = this.sizeClassMap[value];
23
+ }
24
+ get size() {
25
+ return this._size;
26
+ }
13
27
  openUrl() {
14
28
  this.exportUrl.emit(this.link.url.toString());
15
29
  }
16
30
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DownloadItemComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
17
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: DownloadItemComponent, isStandalone: true, selector: "gn-ui-download-item", inputs: { link: "link", color: "color", format: "format", isFromApi: "isFromApi" }, outputs: { exportUrl: "exportUrl" }, ngImport: i0, template: "<a\n href=\"{{ link.url }}\"\n target=\"_blank\"\n class=\"group flex justify-between card-shadow px-6 py-5 cursor-pointer\"\n rel=\"noopener\"\n>\n <div class=\"grow-1 w-full overflow-hidden\">\n <div\n class=\"text-21 text-black truncate font-title w-11/12\"\n [title]=\"link.description || link.name\"\n >\n {{ link.description || link.name }}\n </div>\n <div class=\"pt-1\">\n <span\n class=\"inline-flex items-center justify-center px-2 py-1 text-13 font-medium leading-none text-white rounded transition-opacity opacity-70 group-hover:opacity-100\"\n [style.background-color]=\"color\"\n data-cy=\"download-format\"\n >{{ format || ('downloads.format.unknown' | translate) }}</span\n >\n <span\n class=\"pl-2 inline-flex items-center text-gray-800 text-sm\"\n *ngIf=\"isFromApi\"\n translate=\"\"\n >datahub.search.filter.generatedByAPI</span\n >\n </div>\n </div>\n <div class=\"shrink-1 w-14 flex flex-col justify-center items-center\">\n <ng-icon\n class=\"!w-8 !h-8 card-icon text-3xl\"\n name=\"matCloudDownloadOutline\"\n >\n </ng-icon>\n </div>\n</a>\n", styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i2.TranslatePipe, name: "translate" }, { kind: "directive", type: i2.TranslateDirective, selector: "[translate],[ngx-translate]", inputs: ["translate", "translateParams"] }, { kind: "component", type: NgIcon, selector: "ng-icon", inputs: ["name", "svg", "size", "strokeWidth", "color"] }], viewProviders: [
31
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: DownloadItemComponent, isStandalone: true, selector: "gn-ui-download-item", inputs: { link: "link", color: "color", format: "format", isFromApi: "isFromApi", size: "size" }, outputs: { exportUrl: "exportUrl" }, ngImport: i0, template: "<a\n href=\"{{ link.url }}\"\n target=\"_blank\"\n class=\"group flex flex-row justify-between card-shadow cursor-pointer rounded overflow-hidden\"\n rel=\"noopener\"\n [ngClass]=\"cardClass\"\n>\n <div class=\"flex flex-col justify-between\">\n <div class=\"gn-ui-card-title\" [title]=\"link.description || link.name\">\n {{ link.description || link.name }}\n </div>\n <div class=\"gn-ui-card-detail\">\n {{ link.name }}\n </div>\n <div class=\"flex flex-row gap-2 items-center pt-1\">\n <span\n class=\"inline-flex items-center justify-center px-2 py-1 text-13 font-medium leading-none text-white rounded transition-opacity opacity-70 group-hover:opacity-100\"\n [style.background-color]=\"color\"\n data-cy=\"download-format\"\n >{{ format || ('downloads.format.unknown' | translate) }}</span\n >\n <span class=\"text-gray-800 text-xs\" *ngIf=\"isFromApi\" translate=\"\"\n >datahub.search.filter.generatedByAPI</span\n >\n </div>\n </div>\n <div class=\"flex\" [ngClass]=\"size === 'S' ? 'items-end' : 'items-center'\">\n <div class=\"gn-ui-card-icon\">\n <ng-icon\n class=\"inline-block card-icon align-middle\"\n name=\"iconoirDownload\"\n >\n </ng-icon>\n </div>\n </div>\n</a>\n", styles: [""], 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: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i2.TranslatePipe, name: "translate" }, { kind: "directive", type: i2.TranslateDirective, selector: "[translate],[ngx-translate]", inputs: ["translate", "translateParams"] }, { kind: "component", type: NgIcon, selector: "ng-icon", inputs: ["name", "svg", "size", "strokeWidth", "color"] }], viewProviders: [
18
32
  provideIcons({
19
- matCloudDownloadOutline,
33
+ iconoirDownload,
20
34
  }),
21
35
  ], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
22
36
  }
@@ -24,9 +38,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
24
38
  type: Component,
25
39
  args: [{ selector: 'gn-ui-download-item', changeDetection: ChangeDetectionStrategy.OnPush, imports: [CommonModule, TranslateModule, NgIcon], standalone: true, viewProviders: [
26
40
  provideIcons({
27
- matCloudDownloadOutline,
41
+ iconoirDownload,
28
42
  }),
29
- ], template: "<a\n href=\"{{ link.url }}\"\n target=\"_blank\"\n class=\"group flex justify-between card-shadow px-6 py-5 cursor-pointer\"\n rel=\"noopener\"\n>\n <div class=\"grow-1 w-full overflow-hidden\">\n <div\n class=\"text-21 text-black truncate font-title w-11/12\"\n [title]=\"link.description || link.name\"\n >\n {{ link.description || link.name }}\n </div>\n <div class=\"pt-1\">\n <span\n class=\"inline-flex items-center justify-center px-2 py-1 text-13 font-medium leading-none text-white rounded transition-opacity opacity-70 group-hover:opacity-100\"\n [style.background-color]=\"color\"\n data-cy=\"download-format\"\n >{{ format || ('downloads.format.unknown' | translate) }}</span\n >\n <span\n class=\"pl-2 inline-flex items-center text-gray-800 text-sm\"\n *ngIf=\"isFromApi\"\n translate=\"\"\n >datahub.search.filter.generatedByAPI</span\n >\n </div>\n </div>\n <div class=\"shrink-1 w-14 flex flex-col justify-center items-center\">\n <ng-icon\n class=\"!w-8 !h-8 card-icon text-3xl\"\n name=\"matCloudDownloadOutline\"\n >\n </ng-icon>\n </div>\n</a>\n" }]
43
+ ], template: "<a\n href=\"{{ link.url }}\"\n target=\"_blank\"\n class=\"group flex flex-row justify-between card-shadow cursor-pointer rounded overflow-hidden\"\n rel=\"noopener\"\n [ngClass]=\"cardClass\"\n>\n <div class=\"flex flex-col justify-between\">\n <div class=\"gn-ui-card-title\" [title]=\"link.description || link.name\">\n {{ link.description || link.name }}\n </div>\n <div class=\"gn-ui-card-detail\">\n {{ link.name }}\n </div>\n <div class=\"flex flex-row gap-2 items-center pt-1\">\n <span\n class=\"inline-flex items-center justify-center px-2 py-1 text-13 font-medium leading-none text-white rounded transition-opacity opacity-70 group-hover:opacity-100\"\n [style.background-color]=\"color\"\n data-cy=\"download-format\"\n >{{ format || ('downloads.format.unknown' | translate) }}</span\n >\n <span class=\"text-gray-800 text-xs\" *ngIf=\"isFromApi\" translate=\"\"\n >datahub.search.filter.generatedByAPI</span\n >\n </div>\n </div>\n <div class=\"flex\" [ngClass]=\"size === 'S' ? 'items-end' : 'items-center'\">\n <div class=\"gn-ui-card-icon\">\n <ng-icon\n class=\"inline-block card-icon align-middle\"\n name=\"iconoirDownload\"\n >\n </ng-icon>\n </div>\n </div>\n</a>\n" }]
30
44
  }], propDecorators: { link: [{
31
45
  type: Input
32
46
  }], color: [{
@@ -35,7 +49,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
35
49
  type: Input
36
50
  }], isFromApi: [{
37
51
  type: Input
52
+ }], size: [{
53
+ type: Input
38
54
  }], exportUrl: [{
39
55
  type: Output
40
56
  }] } });
41
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZG93bmxvYWQtaXRlbS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL3VpL2VsZW1lbnRzL3NyYy9saWIvZG93bmxvYWQtaXRlbS9kb3dubG9hZC1pdGVtLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvdWkvZWxlbWVudHMvc3JjL2xpYi9kb3dubG9hZC1pdGVtL2Rvd25sb2FkLWl0ZW0uY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUNMLHVCQUF1QixFQUN2QixTQUFTLEVBQ1QsWUFBWSxFQUNaLEtBQUssRUFDTCxNQUFNLEdBQ1AsTUFBTSxlQUFlLENBQUE7QUFFdEIsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLHFCQUFxQixDQUFBO0FBQ3JELE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQTtBQUM5QyxPQUFPLEVBQUUsTUFBTSxFQUFFLFlBQVksRUFBRSxNQUFNLGdCQUFnQixDQUFBO0FBQ3JELE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxNQUFNLGtDQUFrQyxDQUFBOzs7O0FBZTFFLE1BQU0sT0FBTyxxQkFBcUI7SUFibEM7UUFrQlksY0FBUyxHQUFHLElBQUksWUFBWSxFQUFVLENBQUE7S0FLakQ7SUFIQyxPQUFPO1FBQ0wsSUFBSSxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsUUFBUSxFQUFFLENBQUMsQ0FBQTtJQUMvQyxDQUFDOytHQVRVLHFCQUFxQjttR0FBckIscUJBQXFCLHdNQzFCbEMsZ3JDQW9DQSx5RERsQlksWUFBWSxrSUFBRSxlQUFlLG1PQUFFLE1BQU0sa0dBRWhDO1lBQ2IsWUFBWSxDQUFDO2dCQUNYLHVCQUF1QjthQUN4QixDQUFDO1NBQ0g7OzRGQUVVLHFCQUFxQjtrQkFiakMsU0FBUzsrQkFDRSxxQkFBcUIsbUJBR2QsdUJBQXVCLENBQUMsTUFBTSxXQUN0QyxDQUFDLFlBQVksRUFBRSxlQUFlLEVBQUUsTUFBTSxDQUFDLGNBQ3BDLElBQUksaUJBQ0Q7d0JBQ2IsWUFBWSxDQUFDOzRCQUNYLHVCQUF1Qjt5QkFDeEIsQ0FBQztxQkFDSDs4QkFHUSxJQUFJO3NCQUFaLEtBQUs7Z0JBQ0csS0FBSztzQkFBYixLQUFLO2dCQUNHLE1BQU07c0JBQWQsS0FBSztnQkFDRyxTQUFTO3NCQUFqQixLQUFLO2dCQUNJLFNBQVM7c0JBQWxCLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSxcbiAgQ29tcG9uZW50LFxuICBFdmVudEVtaXR0ZXIsXG4gIElucHV0LFxuICBPdXRwdXQsXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnXG5pbXBvcnQgeyBEYXRhc2V0T25saW5lUmVzb3VyY2UgfSBmcm9tICcuLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbW1vbi9kb21haW4vc3JjL2xpYi9tb2RlbC9yZWNvcmQnXG5pbXBvcnQgeyBUcmFuc2xhdGVNb2R1bGUgfSBmcm9tICdAbmd4LXRyYW5zbGF0ZS9jb3JlJ1xuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJ1xuaW1wb3J0IHsgTmdJY29uLCBwcm92aWRlSWNvbnMgfSBmcm9tICdAbmctaWNvbnMvY29yZSdcbmltcG9ydCB7IG1hdENsb3VkRG93bmxvYWRPdXRsaW5lIH0gZnJvbSAnQG5nLWljb25zL21hdGVyaWFsLWljb25zL291dGxpbmUnXG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2duLXVpLWRvd25sb2FkLWl0ZW0nLFxuICB0ZW1wbGF0ZVVybDogJy4vZG93bmxvYWQtaXRlbS5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlVXJsczogWycuL2Rvd25sb2FkLWl0ZW0uY29tcG9uZW50LmNzcyddLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbiAgaW1wb3J0czogW0NvbW1vbk1vZHVsZSwgVHJhbnNsYXRlTW9kdWxlLCBOZ0ljb25dLFxuICBzdGFuZGFsb25lOiB0cnVlLFxuICB2aWV3UHJvdmlkZXJzOiBbXG4gICAgcHJvdmlkZUljb25zKHtcbiAgICAgIG1hdENsb3VkRG93bmxvYWRPdXRsaW5lLFxuICAgIH0pLFxuICBdLFxufSlcbmV4cG9ydCBjbGFzcyBEb3dubG9hZEl0ZW1Db21wb25lbnQge1xuICBASW5wdXQoKSBsaW5rOiBEYXRhc2V0T25saW5lUmVzb3VyY2VcbiAgQElucHV0KCkgY29sb3I6IHN0cmluZ1xuICBASW5wdXQoKSBmb3JtYXQ6IHN0cmluZ1xuICBASW5wdXQoKSBpc0Zyb21BcGk6IGJvb2xlYW5cbiAgQE91dHB1dCgpIGV4cG9ydFVybCA9IG5ldyBFdmVudEVtaXR0ZXI8c3RyaW5nPigpXG5cbiAgb3BlblVybCgpIHtcbiAgICB0aGlzLmV4cG9ydFVybC5lbWl0KHRoaXMubGluay51cmwudG9TdHJpbmcoKSlcbiAgfVxufVxuIiwiPGFcbiAgaHJlZj1cInt7IGxpbmsudXJsIH19XCJcbiAgdGFyZ2V0PVwiX2JsYW5rXCJcbiAgY2xhc3M9XCJncm91cCBmbGV4IGp1c3RpZnktYmV0d2VlbiBjYXJkLXNoYWRvdyBweC02IHB5LTUgY3Vyc29yLXBvaW50ZXJcIlxuICByZWw9XCJub29wZW5lclwiXG4+XG4gIDxkaXYgY2xhc3M9XCJncm93LTEgdy1mdWxsIG92ZXJmbG93LWhpZGRlblwiPlxuICAgIDxkaXZcbiAgICAgIGNsYXNzPVwidGV4dC0yMSB0ZXh0LWJsYWNrIHRydW5jYXRlIGZvbnQtdGl0bGUgdy0xMS8xMlwiXG4gICAgICBbdGl0bGVdPVwibGluay5kZXNjcmlwdGlvbiB8fCBsaW5rLm5hbWVcIlxuICAgID5cbiAgICAgIHt7IGxpbmsuZGVzY3JpcHRpb24gfHwgbGluay5uYW1lIH19XG4gICAgPC9kaXY+XG4gICAgPGRpdiBjbGFzcz1cInB0LTFcIj5cbiAgICAgIDxzcGFuXG4gICAgICAgIGNsYXNzPVwiaW5saW5lLWZsZXggaXRlbXMtY2VudGVyIGp1c3RpZnktY2VudGVyIHB4LTIgcHktMSB0ZXh0LTEzIGZvbnQtbWVkaXVtIGxlYWRpbmctbm9uZSB0ZXh0LXdoaXRlIHJvdW5kZWQgdHJhbnNpdGlvbi1vcGFjaXR5IG9wYWNpdHktNzAgZ3JvdXAtaG92ZXI6b3BhY2l0eS0xMDBcIlxuICAgICAgICBbc3R5bGUuYmFja2dyb3VuZC1jb2xvcl09XCJjb2xvclwiXG4gICAgICAgIGRhdGEtY3k9XCJkb3dubG9hZC1mb3JtYXRcIlxuICAgICAgICA+e3sgZm9ybWF0IHx8ICgnZG93bmxvYWRzLmZvcm1hdC51bmtub3duJyB8IHRyYW5zbGF0ZSkgfX08L3NwYW5cbiAgICAgID5cbiAgICAgIDxzcGFuXG4gICAgICAgIGNsYXNzPVwicGwtMiBpbmxpbmUtZmxleCBpdGVtcy1jZW50ZXIgdGV4dC1ncmF5LTgwMCB0ZXh0LXNtXCJcbiAgICAgICAgKm5nSWY9XCJpc0Zyb21BcGlcIlxuICAgICAgICB0cmFuc2xhdGU9XCJcIlxuICAgICAgICA+ZGF0YWh1Yi5zZWFyY2guZmlsdGVyLmdlbmVyYXRlZEJ5QVBJPC9zcGFuXG4gICAgICA+XG4gICAgPC9kaXY+XG4gIDwvZGl2PlxuICA8ZGl2IGNsYXNzPVwic2hyaW5rLTEgdy0xNCBmbGV4IGZsZXgtY29sIGp1c3RpZnktY2VudGVyIGl0ZW1zLWNlbnRlclwiPlxuICAgIDxuZy1pY29uXG4gICAgICBjbGFzcz1cIiF3LTggIWgtOCBjYXJkLWljb24gdGV4dC0zeGxcIlxuICAgICAgbmFtZT1cIm1hdENsb3VkRG93bmxvYWRPdXRsaW5lXCJcbiAgICA+XG4gICAgPC9uZy1pY29uPlxuICA8L2Rpdj5cbjwvYT5cbiJdfQ==
57
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZG93bmxvYWQtaXRlbS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL3VpL2VsZW1lbnRzL3NyYy9saWIvZG93bmxvYWQtaXRlbS9kb3dubG9hZC1pdGVtLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvdWkvZWxlbWVudHMvc3JjL2xpYi9kb3dubG9hZC1pdGVtL2Rvd25sb2FkLWl0ZW0uY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUNMLHVCQUF1QixFQUN2QixTQUFTLEVBQ1QsWUFBWSxFQUNaLEtBQUssRUFDTCxNQUFNLEdBQ1AsTUFBTSxlQUFlLENBQUE7QUFFdEIsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLHFCQUFxQixDQUFBO0FBQ3JELE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQTtBQUM5QyxPQUFPLEVBQUUsTUFBTSxFQUFFLFlBQVksRUFBRSxNQUFNLGdCQUFnQixDQUFBO0FBQ3JELE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQTs7OztBQWlCbkQsTUFBTSxPQUFPLHFCQUFxQjtJQWJsQztRQW1CbUIsaUJBQVksR0FBNkI7WUFDeEQsQ0FBQyxFQUFFLHdCQUF3QjtZQUMzQixDQUFDLEVBQUUsd0JBQXdCO1lBQzNCLENBQUMsRUFBRSxrQkFBa0I7WUFDckIsRUFBRSxFQUFFLHlCQUF5QjtTQUM5QixDQUFBO1FBU0QsY0FBUyxHQUFHLEVBQUUsQ0FBQTtRQUNKLGNBQVMsR0FBRyxJQUFJLFlBQVksRUFBVSxDQUFBO0tBS2pEO0lBYkMsSUFBYSxJQUFJLENBQUMsS0FBZTtRQUMvQixJQUFJLENBQUMsS0FBSyxHQUFHLEtBQUssQ0FBQTtRQUNsQixJQUFJLENBQUMsU0FBUyxHQUFHLElBQUksQ0FBQyxZQUFZLENBQUMsS0FBSyxDQUFDLENBQUE7SUFDM0MsQ0FBQztJQUNELElBQUksSUFBSTtRQUNOLE9BQU8sSUFBSSxDQUFDLEtBQUssQ0FBQTtJQUNuQixDQUFDO0lBSUQsT0FBTztRQUNMLElBQUksQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLFFBQVEsRUFBRSxDQUFDLENBQUE7SUFDL0MsQ0FBQzsrR0F6QlUscUJBQXFCO21HQUFyQixxQkFBcUIsc05DNUJsQyxteUNBb0NBLHlERGhCWSxZQUFZLGdPQUFFLGVBQWUsbU9BQUUsTUFBTSxrR0FFaEM7WUFDYixZQUFZLENBQUM7Z0JBQ1gsZUFBZTthQUNoQixDQUFDO1NBQ0g7OzRGQUVVLHFCQUFxQjtrQkFiakMsU0FBUzsrQkFDRSxxQkFBcUIsbUJBR2QsdUJBQXVCLENBQUMsTUFBTSxXQUN0QyxDQUFDLFlBQVksRUFBRSxlQUFlLEVBQUUsTUFBTSxDQUFDLGNBQ3BDLElBQUksaUJBQ0Q7d0JBQ2IsWUFBWSxDQUFDOzRCQUNYLGVBQWU7eUJBQ2hCLENBQUM7cUJBQ0g7OEJBSVEsSUFBSTtzQkFBWixLQUFLO2dCQUNHLEtBQUs7c0JBQWIsS0FBSztnQkFDRyxNQUFNO3NCQUFkLEtBQUs7Z0JBQ0csU0FBUztzQkFBakIsS0FBSztnQkFRTyxJQUFJO3NCQUFoQixLQUFLO2dCQVFJLFNBQVM7c0JBQWxCLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSxcbiAgQ29tcG9uZW50LFxuICBFdmVudEVtaXR0ZXIsXG4gIElucHV0LFxuICBPdXRwdXQsXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnXG5pbXBvcnQgeyBEYXRhc2V0T25saW5lUmVzb3VyY2UgfSBmcm9tICcuLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbW1vbi9kb21haW4vc3JjL2xpYi9tb2RlbC9yZWNvcmQnXG5pbXBvcnQgeyBUcmFuc2xhdGVNb2R1bGUgfSBmcm9tICdAbmd4LXRyYW5zbGF0ZS9jb3JlJ1xuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJ1xuaW1wb3J0IHsgTmdJY29uLCBwcm92aWRlSWNvbnMgfSBmcm9tICdAbmctaWNvbnMvY29yZSdcbmltcG9ydCB7IGljb25vaXJEb3dubG9hZCB9IGZyb20gJ0BuZy1pY29ucy9pY29ub2lyJ1xuXG50eXBlIENhcmRTaXplID0gJ0wnIHwgJ00nIHwgJ1MnIHwgJ1hTJ1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdnbi11aS1kb3dubG9hZC1pdGVtJyxcbiAgdGVtcGxhdGVVcmw6ICcuL2Rvd25sb2FkLWl0ZW0uY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi9kb3dubG9hZC1pdGVtLmNvbXBvbmVudC5jc3MnXSxcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG4gIGltcG9ydHM6IFtDb21tb25Nb2R1bGUsIFRyYW5zbGF0ZU1vZHVsZSwgTmdJY29uXSxcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgdmlld1Byb3ZpZGVyczogW1xuICAgIHByb3ZpZGVJY29ucyh7XG4gICAgICBpY29ub2lyRG93bmxvYWQsXG4gICAgfSksXG4gIF0sXG59KVxuZXhwb3J0IGNsYXNzIERvd25sb2FkSXRlbUNvbXBvbmVudCB7XG4gIHByaXZhdGUgX3NpemU6ICdMJyB8ICdNJyB8ICdTJyB8ICdYUydcbiAgQElucHV0KCkgbGluazogRGF0YXNldE9ubGluZVJlc291cmNlXG4gIEBJbnB1dCgpIGNvbG9yOiBzdHJpbmdcbiAgQElucHV0KCkgZm9ybWF0OiBzdHJpbmdcbiAgQElucHV0KCkgaXNGcm9tQXBpOiBib29sZWFuXG4gIHByaXZhdGUgcmVhZG9ubHkgc2l6ZUNsYXNzTWFwOiBSZWNvcmQ8Q2FyZFNpemUsIHN0cmluZz4gPSB7XG4gICAgTDogJ2duLXVpLWNhcmQtbCBweS0yIHB4LTUnLFxuICAgIE06ICdnbi11aS1jYXJkLW0gcHktMiBweC01JyxcbiAgICBTOiAnZ24tdWktY2FyZC1zIHAtNCcsXG4gICAgWFM6ICdnbi11aS1jYXJkLXhzIHB5LTIgcHgtNScsXG4gIH1cblxuICBASW5wdXQoKSBzZXQgc2l6ZSh2YWx1ZTogQ2FyZFNpemUpIHtcbiAgICB0aGlzLl9zaXplID0gdmFsdWVcbiAgICB0aGlzLmNhcmRDbGFzcyA9IHRoaXMuc2l6ZUNsYXNzTWFwW3ZhbHVlXVxuICB9XG4gIGdldCBzaXplKCk6ICdMJyB8ICdNJyB8ICdTJyB8ICdYUycge1xuICAgIHJldHVybiB0aGlzLl9zaXplXG4gIH1cbiAgY2FyZENsYXNzID0gJydcbiAgQE91dHB1dCgpIGV4cG9ydFVybCA9IG5ldyBFdmVudEVtaXR0ZXI8c3RyaW5nPigpXG5cbiAgb3BlblVybCgpIHtcbiAgICB0aGlzLmV4cG9ydFVybC5lbWl0KHRoaXMubGluay51cmwudG9TdHJpbmcoKSlcbiAgfVxufVxuIiwiPGFcbiAgaHJlZj1cInt7IGxpbmsudXJsIH19XCJcbiAgdGFyZ2V0PVwiX2JsYW5rXCJcbiAgY2xhc3M9XCJncm91cCBmbGV4IGZsZXgtcm93IGp1c3RpZnktYmV0d2VlbiBjYXJkLXNoYWRvdyBjdXJzb3ItcG9pbnRlciByb3VuZGVkIG92ZXJmbG93LWhpZGRlblwiXG4gIHJlbD1cIm5vb3BlbmVyXCJcbiAgW25nQ2xhc3NdPVwiY2FyZENsYXNzXCJcbj5cbiAgPGRpdiBjbGFzcz1cImZsZXggZmxleC1jb2wganVzdGlmeS1iZXR3ZWVuXCI+XG4gICAgPGRpdiBjbGFzcz1cImduLXVpLWNhcmQtdGl0bGVcIiBbdGl0bGVdPVwibGluay5kZXNjcmlwdGlvbiB8fCBsaW5rLm5hbWVcIj5cbiAgICAgIHt7IGxpbmsuZGVzY3JpcHRpb24gfHwgbGluay5uYW1lIH19XG4gICAgPC9kaXY+XG4gICAgPGRpdiBjbGFzcz1cImduLXVpLWNhcmQtZGV0YWlsXCI+XG4gICAgICB7eyBsaW5rLm5hbWUgfX1cbiAgICA8L2Rpdj5cbiAgICA8ZGl2IGNsYXNzPVwiZmxleCBmbGV4LXJvdyBnYXAtMiBpdGVtcy1jZW50ZXIgcHQtMVwiPlxuICAgICAgPHNwYW5cbiAgICAgICAgY2xhc3M9XCJpbmxpbmUtZmxleCBpdGVtcy1jZW50ZXIganVzdGlmeS1jZW50ZXIgcHgtMiBweS0xIHRleHQtMTMgZm9udC1tZWRpdW0gbGVhZGluZy1ub25lIHRleHQtd2hpdGUgcm91bmRlZCB0cmFuc2l0aW9uLW9wYWNpdHkgb3BhY2l0eS03MCBncm91cC1ob3ZlcjpvcGFjaXR5LTEwMFwiXG4gICAgICAgIFtzdHlsZS5iYWNrZ3JvdW5kLWNvbG9yXT1cImNvbG9yXCJcbiAgICAgICAgZGF0YS1jeT1cImRvd25sb2FkLWZvcm1hdFwiXG4gICAgICAgID57eyBmb3JtYXQgfHwgKCdkb3dubG9hZHMuZm9ybWF0LnVua25vd24nIHwgdHJhbnNsYXRlKSB9fTwvc3BhblxuICAgICAgPlxuICAgICAgPHNwYW4gY2xhc3M9XCJ0ZXh0LWdyYXktODAwIHRleHQteHNcIiAqbmdJZj1cImlzRnJvbUFwaVwiIHRyYW5zbGF0ZT1cIlwiXG4gICAgICAgID5kYXRhaHViLnNlYXJjaC5maWx0ZXIuZ2VuZXJhdGVkQnlBUEk8L3NwYW5cbiAgICAgID5cbiAgICA8L2Rpdj5cbiAgPC9kaXY+XG4gIDxkaXYgY2xhc3M9XCJmbGV4XCIgW25nQ2xhc3NdPVwic2l6ZSA9PT0gJ1MnID8gJ2l0ZW1zLWVuZCcgOiAnaXRlbXMtY2VudGVyJ1wiPlxuICAgIDxkaXYgY2xhc3M9XCJnbi11aS1jYXJkLWljb25cIj5cbiAgICAgIDxuZy1pY29uXG4gICAgICAgIGNsYXNzPVwiaW5saW5lLWJsb2NrIGNhcmQtaWNvbiBhbGlnbi1taWRkbGVcIlxuICAgICAgICBuYW1lPVwiaWNvbm9pckRvd25sb2FkXCJcbiAgICAgID5cbiAgICAgIDwvbmctaWNvbj5cbiAgICA8L2Rpdj5cbiAgPC9kaXY+XG48L2E+XG4iXX0=
@@ -94,7 +94,7 @@ export class DownloadsListComponent {
94
94
  link.accessServiceProtocol === 'ogcFeatures'));
95
95
  }
96
96
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DownloadsListComponent, deps: [{ token: i1.TranslateService }], target: i0.ɵɵFactoryTarget.Component }); }
97
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: DownloadsListComponent, isStandalone: true, selector: "gn-ui-downloads-list", inputs: { links: "links" }, ngImport: i0, template: "<div\n class=\"flex flex-wrap justify-between mt-8 mb-6 sm:mt-12 sm:mb-2\"\n *ngIf=\"links && links.length > 0\"\n>\n <p\n class=\"font-title text-[28px] text-title font-medium mr-4 pb-4 text-center sm:text-left\"\n translate\n >\n record.metadata.download\n </p>\n <div\n class=\"flex flex-wrap justify-start sm:justify-end sm:pb-4\"\n data-cy=\"download-format-filters\"\n >\n <gn-ui-button\n class=\"m-1 format-filter\"\n [extraClass]=\"\n '!px-[12px] !py-[8px] !text-[15px]' +\n (isFilterActive(format) ? ' opacity-100' : ' opacity-50')\n \"\n (buttonClick)=\"toggleFilterFormat(format)\"\n [attr.data-format]=\"format\"\n *ngFor=\"let format of visibleFormats\"\n >\n {{ getFilterFormatTitle(format) }}\n </gn-ui-button>\n </div>\n</div>\n<div class=\"mb-2 sm:mb-3\" *ngFor=\"let link of filteredLinks\">\n <gn-ui-download-item\n [link]=\"link\"\n [color]=\"getLinkColor(link)\"\n [format]=\"getLinkFormat(link)\"\n [isFromApi]=\"isFromApi(link)\"\n ></gn-ui-download-item>\n</div>\n", styles: [""], 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: "component", type: ButtonComponent, selector: "gn-ui-button", inputs: ["type", "disabled", "extraClass"], outputs: ["buttonClick"] }, { kind: "component", type: DownloadItemComponent, selector: "gn-ui-download-item", inputs: ["link", "color", "format", "isFromApi"], outputs: ["exportUrl"] }, { kind: "ngmodule", type: TranslateModule }, { kind: "directive", type: i1.TranslateDirective, selector: "[translate],[ngx-translate]", inputs: ["translate", "translateParams"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
97
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: DownloadsListComponent, isStandalone: true, selector: "gn-ui-downloads-list", inputs: { links: "links" }, ngImport: i0, template: "<div\n class=\"flex flex-wrap justify-between items-center pb-4\"\n *ngIf=\"links && links.length > 0\"\n>\n <div\n class=\"font-title text-xl text-title font-medium mr-4 text-center sm:text-left\"\n translate\n >\n record.metadata.download\n </div>\n <div\n class=\"flex flex-wrap justify-start sm:justify-end\"\n data-cy=\"download-format-filters\"\n >\n <gn-ui-button\n class=\"m-1 format-filter\"\n [extraClass]=\"\n '!px-[12px] !py-[8px] !text-[15px]' +\n (isFilterActive(format) ? ' opacity-100' : ' opacity-60')\n \"\n (buttonClick)=\"toggleFilterFormat(format)\"\n [attr.data-format]=\"format\"\n *ngFor=\"let format of visibleFormats\"\n >\n {{ getFilterFormatTitle(format) }}\n </gn-ui-button>\n </div>\n</div>\n<div class=\"mb-2 sm:mb-3\" *ngFor=\"let link of filteredLinks\">\n <gn-ui-download-item\n size=\"L\"\n [link]=\"link\"\n [color]=\"getLinkColor(link)\"\n [format]=\"getLinkFormat(link)\"\n [isFromApi]=\"isFromApi(link)\"\n ></gn-ui-download-item>\n</div>\n", styles: [""], 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: "component", type: ButtonComponent, selector: "gn-ui-button", inputs: ["type", "disabled", "extraClass"], outputs: ["buttonClick"] }, { kind: "component", type: DownloadItemComponent, selector: "gn-ui-download-item", inputs: ["link", "color", "format", "isFromApi", "size"], outputs: ["exportUrl"] }, { kind: "ngmodule", type: TranslateModule }, { kind: "directive", type: i1.TranslateDirective, selector: "[translate],[ngx-translate]", inputs: ["translate", "translateParams"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
98
98
  }
99
99
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DownloadsListComponent, decorators: [{
100
100
  type: Component,
@@ -103,8 +103,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
103
103
  ButtonComponent,
104
104
  DownloadItemComponent,
105
105
  TranslateModule,
106
- ], template: "<div\n class=\"flex flex-wrap justify-between mt-8 mb-6 sm:mt-12 sm:mb-2\"\n *ngIf=\"links && links.length > 0\"\n>\n <p\n class=\"font-title text-[28px] text-title font-medium mr-4 pb-4 text-center sm:text-left\"\n translate\n >\n record.metadata.download\n </p>\n <div\n class=\"flex flex-wrap justify-start sm:justify-end sm:pb-4\"\n data-cy=\"download-format-filters\"\n >\n <gn-ui-button\n class=\"m-1 format-filter\"\n [extraClass]=\"\n '!px-[12px] !py-[8px] !text-[15px]' +\n (isFilterActive(format) ? ' opacity-100' : ' opacity-50')\n \"\n (buttonClick)=\"toggleFilterFormat(format)\"\n [attr.data-format]=\"format\"\n *ngFor=\"let format of visibleFormats\"\n >\n {{ getFilterFormatTitle(format) }}\n </gn-ui-button>\n </div>\n</div>\n<div class=\"mb-2 sm:mb-3\" *ngFor=\"let link of filteredLinks\">\n <gn-ui-download-item\n [link]=\"link\"\n [color]=\"getLinkColor(link)\"\n [format]=\"getLinkFormat(link)\"\n [isFromApi]=\"isFromApi(link)\"\n ></gn-ui-download-item>\n</div>\n" }]
106
+ ], template: "<div\n class=\"flex flex-wrap justify-between items-center pb-4\"\n *ngIf=\"links && links.length > 0\"\n>\n <div\n class=\"font-title text-xl text-title font-medium mr-4 text-center sm:text-left\"\n translate\n >\n record.metadata.download\n </div>\n <div\n class=\"flex flex-wrap justify-start sm:justify-end\"\n data-cy=\"download-format-filters\"\n >\n <gn-ui-button\n class=\"m-1 format-filter\"\n [extraClass]=\"\n '!px-[12px] !py-[8px] !text-[15px]' +\n (isFilterActive(format) ? ' opacity-100' : ' opacity-60')\n \"\n (buttonClick)=\"toggleFilterFormat(format)\"\n [attr.data-format]=\"format\"\n *ngFor=\"let format of visibleFormats\"\n >\n {{ getFilterFormatTitle(format) }}\n </gn-ui-button>\n </div>\n</div>\n<div class=\"mb-2 sm:mb-3\" *ngFor=\"let link of filteredLinks\">\n <gn-ui-download-item\n size=\"L\"\n [link]=\"link\"\n [color]=\"getLinkColor(link)\"\n [format]=\"getLinkFormat(link)\"\n [isFromApi]=\"isFromApi(link)\"\n ></gn-ui-download-item>\n</div>\n" }]
107
107
  }], ctorParameters: () => [{ type: i1.TranslateService }], propDecorators: { links: [{
108
108
  type: Input
109
109
  }] } });
110
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"downloads-list.component.js","sourceRoot":"","sources":["../../../../../../../../libs/ui/elements/src/lib/downloads-list/downloads-list.component.ts","../../../../../../../../libs/ui/elements/src/lib/downloads-list/downloads-list.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, Input } from '@angular/core'\nimport { TranslateModule, TranslateService } from '@ngx-translate/core'\nimport { marker } from '@biesbjerg/ngx-translate-extract-marker'\nimport { getBadgeColor, getFileFormat } from '../../../../../../libs/util/shared/src'\nimport { DatasetDownloadDistribution } from '../../../../../../libs/common/domain/src/lib/model/record'\nimport { CommonModule } from '@angular/common'\nimport { ButtonComponent } from '../../../../../../libs/ui/inputs/src'\nimport { DownloadItemComponent } from '../download-item/download-item.component'\n\nmarker('datahub.search.filter.all')\nmarker('datahub.search.filter.others')\n\nconst FILTER_FORMATS = ['all', 'csv', 'excel', 'json', 'shp', 'others'] as const\ntype FilterFormat = (typeof FILTER_FORMATS)[number]\n\n@Component({\n  selector: 'gn-ui-downloads-list',\n  templateUrl: './downloads-list.component.html',\n  styleUrls: ['./downloads-list.component.css'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true,\n  imports: [\n    CommonModule,\n    ButtonComponent,\n    DownloadItemComponent,\n    TranslateModule,\n  ],\n})\nexport class DownloadsListComponent {\n  constructor(private translateService: TranslateService) {}\n\n  @Input() links: DatasetDownloadDistribution[]\n\n  activeFilterFormats: FilterFormat[] = ['all']\n\n  private removeDuplicateFormats(\n    links: DatasetDownloadDistribution[]\n  ): DatasetDownloadDistribution[] {\n    const preferredLinks = new Map<string, DatasetDownloadDistribution>()\n\n    links.forEach((link) => {\n      const format = getFileFormat(link)\n      const withoutNameSpace = (link.name || link.description || '').replace(\n        /^.*?:/,\n        ''\n      )\n      const uniqueKey = `${format}-${withoutNameSpace}`\n      if (!preferredLinks.has(uniqueKey)) {\n        preferredLinks.set(uniqueKey, link)\n      } else {\n        const existingLink = preferredLinks.get(uniqueKey)\n        if (\n          link.accessServiceProtocol === 'ogcFeatures' &&\n          existingLink?.accessServiceProtocol !== 'ogcFeatures'\n        ) {\n          preferredLinks.set(uniqueKey, link)\n        }\n      }\n    })\n\n    return Array.from(preferredLinks.values())\n  }\n\n  get filteredLinks(): DatasetDownloadDistribution[] {\n    const filteredByFormat = this.links.filter((link) =>\n      this.activeFilterFormats.some((format) =>\n        this.isLinkOfFormat(link, format)\n      )\n    )\n    return this.removeDuplicateFormats(filteredByFormat)\n  }\n\n  get visibleFormats(): FilterFormat[] {\n    return FILTER_FORMATS.filter((format) =>\n      this.links.some((link) => this.isLinkOfFormat(link, format))\n    )\n  }\n\n  toggleFilterFormat(format: FilterFormat): void {\n    if (format === 'all') {\n      this.activeFilterFormats = ['all']\n      return\n    }\n    if (this.isFilterActive(format)) {\n      this.activeFilterFormats = this.activeFilterFormats.filter(\n        (f: string) => format !== f\n      )\n    } else {\n      this.activeFilterFormats = [\n        ...this.activeFilterFormats.filter((f) => f !== 'all'),\n        format,\n      ]\n    }\n    if (this.activeFilterFormats.length === 0) {\n      this.activeFilterFormats = ['all']\n    }\n  }\n\n  isFilterActive(filter: FilterFormat): boolean {\n    return this.activeFilterFormats.includes(filter)\n  }\n\n  getFilterFormatTitle(format: FilterFormat) {\n    if (format === 'all' || format === 'others') {\n      return this.translateService.instant(`datahub.search.filter.${format}`)\n    }\n    return format\n  }\n\n  isLinkOfFormat(\n    link: DatasetDownloadDistribution,\n    format: FilterFormat\n  ): boolean {\n    if (format === 'all') {\n      return true\n    }\n    if (getFileFormat(link) === null) {\n      return format === 'others'\n    }\n    if (format === 'others') {\n      const knownFormats = FILTER_FORMATS.filter(\n        (format) => format !== 'all' && format !== 'others'\n      )\n      return knownFormats.every(\n        (knownFormat) => !getFileFormat(link).includes(knownFormat)\n      )\n    }\n    return getFileFormat(link).includes(format)\n  }\n\n  getLinkFormat(link: DatasetDownloadDistribution) {\n    return getFileFormat(link)\n  }\n\n  getLinkColor(link: DatasetDownloadDistribution) {\n    return getBadgeColor(getFileFormat(link))\n  }\n\n  isFromApi(link: DatasetDownloadDistribution) {\n    return (\n      link.type === 'download' &&\n      (link.accessServiceProtocol === 'wfs' ||\n        link.accessServiceProtocol === 'ogcFeatures')\n    )\n  }\n}\n","<div\n  class=\"flex flex-wrap justify-between mt-8 mb-6 sm:mt-12 sm:mb-2\"\n  *ngIf=\"links && links.length > 0\"\n>\n  <p\n    class=\"font-title text-[28px] text-title font-medium mr-4 pb-4 text-center sm:text-left\"\n    translate\n  >\n    record.metadata.download\n  </p>\n  <div\n    class=\"flex flex-wrap justify-start sm:justify-end sm:pb-4\"\n    data-cy=\"download-format-filters\"\n  >\n    <gn-ui-button\n      class=\"m-1 format-filter\"\n      [extraClass]=\"\n        '!px-[12px] !py-[8px] !text-[15px]' +\n        (isFilterActive(format) ? ' opacity-100' : ' opacity-50')\n      \"\n      (buttonClick)=\"toggleFilterFormat(format)\"\n      [attr.data-format]=\"format\"\n      *ngFor=\"let format of visibleFormats\"\n    >\n      {{ getFilterFormatTitle(format) }}\n    </gn-ui-button>\n  </div>\n</div>\n<div class=\"mb-2 sm:mb-3\" *ngFor=\"let link of filteredLinks\">\n  <gn-ui-download-item\n    [link]=\"link\"\n    [color]=\"getLinkColor(link)\"\n    [format]=\"getLinkFormat(link)\"\n    [isFromApi]=\"isFromApi(link)\"\n  ></gn-ui-download-item>\n</div>\n"]}
110
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"downloads-list.component.js","sourceRoot":"","sources":["../../../../../../../../libs/ui/elements/src/lib/downloads-list/downloads-list.component.ts","../../../../../../../../libs/ui/elements/src/lib/downloads-list/downloads-list.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, Input } from '@angular/core'\nimport { TranslateModule, TranslateService } from '@ngx-translate/core'\nimport { marker } from '@biesbjerg/ngx-translate-extract-marker'\nimport { getBadgeColor, getFileFormat } from '../../../../../../libs/util/shared/src'\nimport { DatasetDownloadDistribution } from '../../../../../../libs/common/domain/src/lib/model/record'\nimport { CommonModule } from '@angular/common'\nimport { ButtonComponent } from '../../../../../../libs/ui/inputs/src'\nimport { DownloadItemComponent } from '../download-item/download-item.component'\n\nmarker('datahub.search.filter.all')\nmarker('datahub.search.filter.others')\n\nconst FILTER_FORMATS = ['all', 'csv', 'excel', 'json', 'shp', 'others'] as const\ntype FilterFormat = (typeof FILTER_FORMATS)[number]\n\n@Component({\n  selector: 'gn-ui-downloads-list',\n  templateUrl: './downloads-list.component.html',\n  styleUrls: ['./downloads-list.component.css'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true,\n  imports: [\n    CommonModule,\n    ButtonComponent,\n    DownloadItemComponent,\n    TranslateModule,\n  ],\n})\nexport class DownloadsListComponent {\n  constructor(private translateService: TranslateService) {}\n\n  @Input() links: DatasetDownloadDistribution[]\n\n  activeFilterFormats: FilterFormat[] = ['all']\n\n  private removeDuplicateFormats(\n    links: DatasetDownloadDistribution[]\n  ): DatasetDownloadDistribution[] {\n    const preferredLinks = new Map<string, DatasetDownloadDistribution>()\n\n    links.forEach((link) => {\n      const format = getFileFormat(link)\n      const withoutNameSpace = (link.name || link.description || '').replace(\n        /^.*?:/,\n        ''\n      )\n      const uniqueKey = `${format}-${withoutNameSpace}`\n      if (!preferredLinks.has(uniqueKey)) {\n        preferredLinks.set(uniqueKey, link)\n      } else {\n        const existingLink = preferredLinks.get(uniqueKey)\n        if (\n          link.accessServiceProtocol === 'ogcFeatures' &&\n          existingLink?.accessServiceProtocol !== 'ogcFeatures'\n        ) {\n          preferredLinks.set(uniqueKey, link)\n        }\n      }\n    })\n\n    return Array.from(preferredLinks.values())\n  }\n\n  get filteredLinks(): DatasetDownloadDistribution[] {\n    const filteredByFormat = this.links.filter((link) =>\n      this.activeFilterFormats.some((format) =>\n        this.isLinkOfFormat(link, format)\n      )\n    )\n    return this.removeDuplicateFormats(filteredByFormat)\n  }\n\n  get visibleFormats(): FilterFormat[] {\n    return FILTER_FORMATS.filter((format) =>\n      this.links.some((link) => this.isLinkOfFormat(link, format))\n    )\n  }\n\n  toggleFilterFormat(format: FilterFormat): void {\n    if (format === 'all') {\n      this.activeFilterFormats = ['all']\n      return\n    }\n    if (this.isFilterActive(format)) {\n      this.activeFilterFormats = this.activeFilterFormats.filter(\n        (f: string) => format !== f\n      )\n    } else {\n      this.activeFilterFormats = [\n        ...this.activeFilterFormats.filter((f) => f !== 'all'),\n        format,\n      ]\n    }\n    if (this.activeFilterFormats.length === 0) {\n      this.activeFilterFormats = ['all']\n    }\n  }\n\n  isFilterActive(filter: FilterFormat): boolean {\n    return this.activeFilterFormats.includes(filter)\n  }\n\n  getFilterFormatTitle(format: FilterFormat) {\n    if (format === 'all' || format === 'others') {\n      return this.translateService.instant(`datahub.search.filter.${format}`)\n    }\n    return format\n  }\n\n  isLinkOfFormat(\n    link: DatasetDownloadDistribution,\n    format: FilterFormat\n  ): boolean {\n    if (format === 'all') {\n      return true\n    }\n    if (getFileFormat(link) === null) {\n      return format === 'others'\n    }\n    if (format === 'others') {\n      const knownFormats = FILTER_FORMATS.filter(\n        (format) => format !== 'all' && format !== 'others'\n      )\n      return knownFormats.every(\n        (knownFormat) => !getFileFormat(link).includes(knownFormat)\n      )\n    }\n    return getFileFormat(link).includes(format)\n  }\n\n  getLinkFormat(link: DatasetDownloadDistribution) {\n    return getFileFormat(link)\n  }\n\n  getLinkColor(link: DatasetDownloadDistribution) {\n    return getBadgeColor(getFileFormat(link))\n  }\n\n  isFromApi(link: DatasetDownloadDistribution) {\n    return (\n      link.type === 'download' &&\n      (link.accessServiceProtocol === 'wfs' ||\n        link.accessServiceProtocol === 'ogcFeatures')\n    )\n  }\n}\n","<div\n  class=\"flex flex-wrap justify-between items-center pb-4\"\n  *ngIf=\"links && links.length > 0\"\n>\n  <div\n    class=\"font-title text-xl text-title font-medium mr-4 text-center sm:text-left\"\n    translate\n  >\n    record.metadata.download\n  </div>\n  <div\n    class=\"flex flex-wrap justify-start sm:justify-end\"\n    data-cy=\"download-format-filters\"\n  >\n    <gn-ui-button\n      class=\"m-1 format-filter\"\n      [extraClass]=\"\n        '!px-[12px] !py-[8px] !text-[15px]' +\n        (isFilterActive(format) ? ' opacity-100' : ' opacity-60')\n      \"\n      (buttonClick)=\"toggleFilterFormat(format)\"\n      [attr.data-format]=\"format\"\n      *ngFor=\"let format of visibleFormats\"\n    >\n      {{ getFilterFormatTitle(format) }}\n    </gn-ui-button>\n  </div>\n</div>\n<div class=\"mb-2 sm:mb-3\" *ngFor=\"let link of filteredLinks\">\n  <gn-ui-download-item\n    size=\"L\"\n    [link]=\"link\"\n    [color]=\"getLinkColor(link)\"\n    [format]=\"getLinkFormat(link)\"\n    [isFromApi]=\"isFromApi(link)\"\n  ></gn-ui-download-item>\n</div>\n"]}