geonetwork-ui 2.4.0-dev.8f04e899 → 2.4.0-dev.9121e5f4

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 (172) hide show
  1. package/esm2022/libs/api/repository/src/lib/gn4/gn4-repository.mjs +10 -1
  2. package/esm2022/libs/api/repository/src/lib/gn4/organizations/organizations-from-groups.service.mjs +2 -1
  3. package/esm2022/libs/api/repository/src/lib/gn4/organizations/organizations-from-metadata.service.mjs +3 -1
  4. package/esm2022/libs/api/repository/src/lib/gn4/platform/gn4-platform.mapper.mjs +2 -2
  5. package/esm2022/libs/api/repository/src/lib/gn4/platform/gn4-platform.service.mjs +9 -5
  6. package/esm2022/libs/common/domain/src/lib/model/record/organization.model.mjs +1 -1
  7. package/esm2022/libs/common/domain/src/lib/platform.service.interface.mjs +1 -1
  8. package/esm2022/libs/common/domain/src/lib/repository/records-repository.interface.mjs +1 -1
  9. package/esm2022/libs/data-access/gn4/src/openapi/model/user.api.model.mjs +1 -1
  10. package/esm2022/libs/feature/catalog/src/index.mjs +2 -1
  11. package/esm2022/libs/feature/catalog/src/lib/feature-catalog.module.mjs +1 -1
  12. package/esm2022/libs/feature/catalog/src/lib/organisations/organisations.component.mjs +6 -6
  13. package/esm2022/libs/feature/catalog/src/lib/organization-url.token.mjs +4 -0
  14. package/esm2022/libs/feature/catalog/src/lib/records/records.service.mjs +4 -6
  15. package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-keywords/form-field-keywords.component.mjs +4 -2
  16. package/esm2022/libs/feature/record/src/lib/state/mdview.facade.mjs +8 -12
  17. package/esm2022/libs/feature/router/src/lib/default/constants.mjs +2 -1
  18. package/esm2022/libs/feature/router/src/lib/default/router.config.mjs +1 -1
  19. package/esm2022/libs/feature/router/src/lib/default/router.service.mjs +9 -2
  20. package/esm2022/libs/feature/router/src/lib/default/state/router.facade.mjs +8 -1
  21. package/esm2022/libs/feature/search/src/index.mjs +2 -2
  22. package/esm2022/libs/feature/search/src/lib/results-table/results-table-container.component.mjs +49 -0
  23. package/esm2022/libs/feature/search/src/lib/state/search.facade.mjs +3 -2
  24. package/esm2022/libs/feature/search/src/lib/state/selectors.mjs +4 -1
  25. package/esm2022/libs/ui/catalog/src/lib/organisation-preview/organisation-preview.component.mjs +5 -5
  26. package/esm2022/libs/ui/catalog/src/lib/ui-catalog.module.mjs +5 -2
  27. package/esm2022/libs/ui/dataviz/src/lib/figure/figure.component.mjs +5 -8
  28. package/esm2022/libs/ui/elements/src/index.mjs +1 -2
  29. package/esm2022/libs/ui/elements/src/lib/error/error.component.mjs +5 -3
  30. package/esm2022/libs/ui/elements/src/lib/metadata-info/metadata-info.component.mjs +4 -4
  31. package/esm2022/libs/ui/elements/src/lib/related-record-card/related-record-card.component.mjs +24 -5
  32. package/esm2022/libs/ui/elements/src/lib/ui-elements.module.mjs +7 -9
  33. package/esm2022/libs/ui/layout/src/index.mjs +2 -1
  34. package/esm2022/libs/ui/layout/src/lib/max-lines/max-lines.component.mjs +71 -0
  35. package/esm2022/libs/ui/layout/src/lib/ui-layout.module.mjs +1 -1
  36. package/esm2022/libs/ui/search/src/index.mjs +2 -1
  37. package/esm2022/libs/ui/search/src/lib/results-table/results-table.component.mjs +120 -0
  38. package/esm2022/translations/de.json +27 -4
  39. package/esm2022/translations/en.json +30 -4
  40. package/esm2022/translations/es.json +27 -4
  41. package/esm2022/translations/fr.json +31 -5
  42. package/esm2022/translations/it.json +27 -4
  43. package/esm2022/translations/nl.json +27 -4
  44. package/esm2022/translations/pt.json +27 -4
  45. package/fesm2022/geonetwork-ui.mjs +478 -228
  46. package/fesm2022/geonetwork-ui.mjs.map +1 -1
  47. package/libs/api/repository/src/lib/gn4/gn4-repository.d.ts +1 -0
  48. package/libs/api/repository/src/lib/gn4/gn4-repository.d.ts.map +1 -1
  49. package/libs/api/repository/src/lib/gn4/organizations/organizations-from-groups.service.d.ts.map +1 -1
  50. package/libs/api/repository/src/lib/gn4/organizations/organizations-from-metadata.service.d.ts.map +1 -1
  51. package/libs/api/repository/src/lib/gn4/platform/gn4-platform.service.d.ts +2 -1
  52. package/libs/api/repository/src/lib/gn4/platform/gn4-platform.service.d.ts.map +1 -1
  53. package/libs/common/domain/src/lib/model/record/organization.model.d.ts +1 -0
  54. package/libs/common/domain/src/lib/model/record/organization.model.d.ts.map +1 -1
  55. package/libs/common/domain/src/lib/platform.service.interface.d.ts +2 -1
  56. package/libs/common/domain/src/lib/platform.service.interface.d.ts.map +1 -1
  57. package/libs/common/domain/src/lib/repository/records-repository.interface.d.ts +2 -0
  58. package/libs/common/domain/src/lib/repository/records-repository.interface.d.ts.map +1 -1
  59. package/libs/data-access/gn4/src/openapi/model/user.api.model.d.ts +1 -1
  60. package/libs/feature/catalog/src/index.d.ts +1 -0
  61. package/libs/feature/catalog/src/index.d.ts.map +1 -1
  62. package/libs/feature/catalog/src/lib/feature-catalog.module.d.ts.map +1 -1
  63. package/libs/feature/catalog/src/lib/organisations/organisations.component.d.ts.map +1 -1
  64. package/libs/feature/catalog/src/lib/organization-url.token.d.ts +3 -0
  65. package/libs/feature/catalog/src/lib/organization-url.token.d.ts.map +1 -0
  66. package/libs/feature/catalog/src/lib/records/records.service.d.ts.map +1 -1
  67. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-keywords/form-field-keywords.component.d.ts.map +1 -1
  68. package/libs/feature/record/src/lib/state/mdview.facade.d.ts.map +1 -1
  69. package/libs/feature/router/src/lib/default/constants.d.ts +1 -0
  70. package/libs/feature/router/src/lib/default/constants.d.ts.map +1 -1
  71. package/libs/feature/router/src/lib/default/router.config.d.ts +1 -0
  72. package/libs/feature/router/src/lib/default/router.config.d.ts.map +1 -1
  73. package/libs/feature/router/src/lib/default/router.service.d.ts +1 -0
  74. package/libs/feature/router/src/lib/default/router.service.d.ts.map +1 -1
  75. package/libs/feature/router/src/lib/default/state/router.facade.d.ts +1 -0
  76. package/libs/feature/router/src/lib/default/state/router.facade.d.ts.map +1 -1
  77. package/libs/feature/search/src/index.d.ts +1 -1
  78. package/libs/feature/search/src/index.d.ts.map +1 -1
  79. package/libs/feature/search/src/lib/results-table/results-table-container.component.d.ts +25 -0
  80. package/libs/feature/search/src/lib/results-table/results-table-container.component.d.ts.map +1 -0
  81. package/libs/feature/search/src/lib/state/search.facade.d.ts +1 -0
  82. package/libs/feature/search/src/lib/state/search.facade.d.ts.map +1 -1
  83. package/libs/feature/search/src/lib/state/selectors.d.ts +1 -0
  84. package/libs/feature/search/src/lib/state/selectors.d.ts.map +1 -1
  85. package/libs/ui/catalog/src/lib/organisation-preview/organisation-preview.component.d.ts +2 -2
  86. package/libs/ui/catalog/src/lib/ui-catalog.module.d.ts +2 -1
  87. package/libs/ui/catalog/src/lib/ui-catalog.module.d.ts.map +1 -1
  88. package/libs/ui/dataviz/src/lib/figure/figure.component.d.ts +1 -2
  89. package/libs/ui/dataviz/src/lib/figure/figure.component.d.ts.map +1 -1
  90. package/libs/ui/elements/src/index.d.ts +0 -1
  91. package/libs/ui/elements/src/index.d.ts.map +1 -1
  92. package/libs/ui/elements/src/lib/error/error.component.d.ts +3 -1
  93. package/libs/ui/elements/src/lib/error/error.component.d.ts.map +1 -1
  94. package/libs/ui/elements/src/lib/related-record-card/related-record-card.component.d.ts +5 -1
  95. package/libs/ui/elements/src/lib/related-record-card/related-record-card.component.d.ts.map +1 -1
  96. package/libs/ui/elements/src/lib/ui-elements.module.d.ts +19 -19
  97. package/libs/ui/elements/src/lib/ui-elements.module.d.ts.map +1 -1
  98. package/libs/ui/layout/src/index.d.ts +1 -0
  99. package/libs/ui/layout/src/index.d.ts.map +1 -1
  100. package/libs/ui/{elements → layout}/src/lib/max-lines/max-lines.component.d.ts +2 -2
  101. package/libs/ui/layout/src/lib/max-lines/max-lines.component.d.ts.map +1 -0
  102. package/libs/ui/layout/src/lib/ui-layout.module.d.ts.map +1 -1
  103. package/libs/ui/search/src/index.d.ts +1 -0
  104. package/libs/ui/search/src/index.d.ts.map +1 -1
  105. package/libs/ui/search/src/lib/results-table/results-table.component.d.ts +30 -0
  106. package/libs/ui/search/src/lib/results-table/results-table.component.d.ts.map +1 -0
  107. package/package.json +1 -1
  108. package/src/libs/api/repository/src/lib/gn4/gn4-repository.ts +14 -0
  109. package/src/libs/api/repository/src/lib/gn4/organizations/organizations-from-groups.service.ts +1 -0
  110. package/src/libs/api/repository/src/lib/gn4/organizations/organizations-from-metadata.service.ts +3 -1
  111. package/src/libs/api/repository/src/lib/gn4/platform/gn4-platform.mapper.ts +1 -1
  112. package/src/libs/api/repository/src/lib/gn4/platform/gn4-platform.service.ts +26 -15
  113. package/src/libs/common/domain/src/lib/model/record/organization.model.ts +1 -0
  114. package/src/libs/common/domain/src/lib/platform.service.interface.ts +5 -1
  115. package/src/libs/common/domain/src/lib/repository/records-repository.interface.ts +3 -0
  116. package/src/libs/common/fixtures/src/lib/organisations.fixture.ts +28 -0
  117. package/src/libs/common/fixtures/src/lib/records.fixtures.ts +8 -0
  118. package/src/libs/data-access/datafeeder/src/openapi/model/datasetMetadata.api.model.ts +4 -0
  119. package/src/libs/data-access/datafeeder/src/openapi/model/datasetUploadStatus.api.model.ts +2 -0
  120. package/src/libs/data-access/gn4/src/openapi/model/user.api.model.ts +1 -1
  121. package/src/libs/feature/catalog/src/index.ts +1 -0
  122. package/src/libs/feature/catalog/src/lib/feature-catalog.module.ts +0 -1
  123. package/src/libs/feature/catalog/src/lib/organisations/organisations.component.html +1 -1
  124. package/src/libs/feature/catalog/src/lib/organisations/organisations.component.ts +2 -2
  125. package/src/libs/feature/catalog/src/lib/organization-url.token.ts +6 -0
  126. package/src/libs/feature/catalog/src/lib/records/records.service.ts +6 -8
  127. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-keywords/form-field-keywords.component.ts +8 -6
  128. package/src/libs/feature/record/src/lib/state/mdview.facade.ts +42 -31
  129. package/src/libs/feature/router/src/lib/default/constants.ts +1 -0
  130. package/src/libs/feature/router/src/lib/default/router.config.ts +1 -0
  131. package/src/libs/feature/router/src/lib/default/router.service.ts +13 -1
  132. package/src/libs/feature/router/src/lib/default/state/router.facade.ts +9 -1
  133. package/src/libs/feature/search/src/index.ts +1 -1
  134. package/src/libs/feature/search/src/lib/results-table/results-table-container.component.html +9 -0
  135. package/src/libs/feature/search/src/lib/results-table/results-table-container.component.ts +49 -0
  136. package/src/libs/feature/search/src/lib/state/search.facade.ts +5 -0
  137. package/src/libs/feature/search/src/lib/state/selectors.ts +7 -0
  138. package/src/libs/ui/catalog/src/lib/organisation-preview/organisation-preview.component.html +8 -6
  139. package/src/libs/ui/catalog/src/lib/organisation-preview/organisation-preview.component.ts +2 -2
  140. package/src/libs/ui/catalog/src/lib/ui-catalog.module.ts +2 -0
  141. package/src/libs/ui/dataviz/src/lib/figure/figure.component.html +11 -3
  142. package/src/libs/ui/dataviz/src/lib/figure/figure.component.ts +3 -7
  143. package/src/libs/ui/elements/src/index.ts +0 -1
  144. package/src/libs/ui/elements/src/lib/error/error.component.html +30 -6
  145. package/src/libs/ui/elements/src/lib/error/error.component.ts +2 -0
  146. package/src/libs/ui/elements/src/lib/related-record-card/related-record-card.component.html +1 -1
  147. package/src/libs/ui/elements/src/lib/related-record-card/related-record-card.component.ts +22 -1
  148. package/src/libs/ui/elements/src/lib/ui-elements.module.ts +2 -4
  149. package/src/libs/ui/layout/src/index.ts +1 -0
  150. package/src/libs/ui/{elements → layout}/src/lib/max-lines/max-lines.component.html +1 -0
  151. package/src/libs/ui/{elements → layout}/src/lib/max-lines/max-lines.component.ts +9 -5
  152. package/src/libs/ui/layout/src/lib/ui-layout.module.ts +0 -1
  153. package/src/libs/ui/search/src/index.ts +1 -0
  154. package/src/libs/ui/search/src/lib/results-table/results-table.component.css +0 -0
  155. package/src/libs/{feature → ui}/search/src/lib/results-table/results-table.component.html +8 -8
  156. package/src/libs/ui/search/src/lib/results-table/results-table.component.ts +138 -0
  157. package/translations/de.json +27 -4
  158. package/translations/en.json +30 -4
  159. package/translations/es.json +27 -4
  160. package/translations/fr.json +31 -5
  161. package/translations/it.json +27 -4
  162. package/translations/nl.json +27 -4
  163. package/translations/pt.json +27 -4
  164. package/translations/sk.json +28 -5
  165. package/esm2022/libs/feature/search/src/lib/results-table/results-table.component.mjs +0 -136
  166. package/esm2022/libs/ui/elements/src/lib/max-lines/max-lines.component.mjs +0 -69
  167. package/libs/feature/search/src/lib/results-table/results-table.component.d.ts +0 -36
  168. package/libs/feature/search/src/lib/results-table/results-table.component.d.ts.map +0 -1
  169. package/libs/ui/elements/src/lib/max-lines/max-lines.component.d.ts.map +0 -1
  170. package/src/libs/feature/search/src/lib/results-table/results-table.component.ts +0 -171
  171. /package/src/libs/feature/search/src/lib/results-table/{results-table.component.css → results-table-container.component.css} +0 -0
  172. /package/src/libs/ui/{elements → layout}/src/lib/max-lines/max-lines.component.css +0 -0
@@ -21,4 +21,4 @@ export * from './lib/results-hits-number/results-hits.container.component'
21
21
  export * from './lib/results-layout/results-layout.component'
22
22
  export * from './lib/sort-by/sort-by.component'
23
23
  export * from './lib/state/container/search-state.container.directive'
24
- export * from './lib/results-table/results-table.component'
24
+ export * from './lib/results-table/results-table-container.component'
@@ -0,0 +1,9 @@
1
+ <gn-ui-results-table
2
+ [records]="records$ | async"
3
+ [recordHasDraft]="hasDraft"
4
+ [selectedRecordsIdentifiers]="selectedRecords$ | async"
5
+ [sortOrder]="sortBy$ | async"
6
+ (recordClick)="handleRecordClick($event)"
7
+ (recordsSelectedChange)="handleRecordsSelectedChange($event[0], $event[1])"
8
+ (sortByChange)="handleSortByChange($event[0], $event[1])"
9
+ ></gn-ui-results-table>
@@ -0,0 +1,49 @@
1
+ import { Component, EventEmitter, Output } from '@angular/core'
2
+ import { CatalogRecord } from '../../../../../../libs/common/domain/src/lib/model/record'
3
+ import { SearchFacade } from '../state/search.facade'
4
+ import { SelectionService } from '../../../../../../libs/api/repository/src'
5
+ import { SearchService } from '../utils/service/search.service'
6
+ import { RecordsRepositoryInterface } from '../../../../../../libs/common/domain/src/lib/repository/records-repository.interface'
7
+ import { ResultsTableComponent } from '../../../../../../libs/ui/search/src'
8
+ import { CommonModule } from '@angular/common'
9
+
10
+ @Component({
11
+ selector: 'gn-ui-results-table-container',
12
+ templateUrl: './results-table-container.component.html',
13
+ styleUrls: ['./results-table-container.component.css'],
14
+ standalone: true,
15
+ imports: [CommonModule, ResultsTableComponent],
16
+ })
17
+ export class ResultsTableContainerComponent {
18
+ @Output() recordClick = new EventEmitter<CatalogRecord>()
19
+
20
+ records$ = this.searchFacade.results$
21
+ selectedRecords$ = this.selectionService.selectedRecordsIdentifiers$
22
+ sortBy$ = this.searchFacade.sortBy$
23
+
24
+ hasDraft = (record: CatalogRecord): boolean =>
25
+ this.recordsRepository.recordHasDraft(record.uniqueIdentifier)
26
+
27
+ constructor(
28
+ private searchFacade: SearchFacade,
29
+ private searchService: SearchService,
30
+ private selectionService: SelectionService,
31
+ private recordsRepository: RecordsRepositoryInterface
32
+ ) {}
33
+
34
+ handleRecordClick(item: unknown) {
35
+ this.recordClick.emit(item as CatalogRecord)
36
+ }
37
+
38
+ handleSortByChange(col: string, order: 'asc' | 'desc') {
39
+ this.searchService.setSortBy([order, col])
40
+ }
41
+
42
+ handleRecordsSelectedChange(records: CatalogRecord[], selected: boolean) {
43
+ if (!selected) {
44
+ this.selectionService.deselectRecords(records)
45
+ } else {
46
+ this.selectionService.selectRecords(records)
47
+ }
48
+ }
49
+ }
@@ -37,6 +37,7 @@ import {
37
37
  getSearchResultsLoading,
38
38
  getSearchSortBy,
39
39
  getSpatialFilterEnabled,
40
+ isBeginningOfResults,
40
41
  isEndOfResults,
41
42
  totalPages,
42
43
  } from './selectors'
@@ -58,6 +59,7 @@ export class SearchFacade {
58
59
  layout$: Observable<string>
59
60
  sortBy$: Observable<SortByField>
60
61
  isLoading$: Observable<boolean>
62
+ isBeginningOfResults$: Observable<boolean>
61
63
  isEndOfResults$: Observable<boolean>
62
64
  totalPages$: Observable<number>
63
65
  currentPage$: Observable<number>
@@ -98,6 +100,9 @@ export class SearchFacade {
98
100
  this.isLoading$ = this.store.pipe(select(getSearchResultsLoading, searchId))
99
101
  this.searchFilters$ = this.store.pipe(select(getSearchFilters, searchId))
100
102
  this.resultsHits$ = this.store.pipe(select(getSearchResultsHits, searchId))
103
+ this.isBeginningOfResults$ = this.store.pipe(
104
+ select(isBeginningOfResults, searchId)
105
+ )
101
106
  this.isEndOfResults$ = this.store.pipe(select(isEndOfResults, searchId))
102
107
  this.totalPages$ = this.store.pipe(select(totalPages, searchId))
103
108
  this.currentPage$ = this.store.pipe(select(currentPage, searchId))
@@ -50,6 +50,13 @@ export const getSearchResultsHits = createSelector(
50
50
  (state: SearchStateSearch) => state.results.count
51
51
  )
52
52
 
53
+ export const isBeginningOfResults = createSelector(
54
+ getSearchStateSearch,
55
+ (state: SearchStateSearch) => {
56
+ return state.params.currentPage === 0
57
+ }
58
+ )
59
+
53
60
  export const isEndOfResults = createSelector(
54
61
  getSearchStateSearch,
55
62
  (state: SearchStateSearch) => {
@@ -1,14 +1,14 @@
1
1
  <a href (click)="clickOrganisation($event)" [attr.href]="organisationUrl">
2
2
  <div
3
3
  class="group cursor-pointer rounded-lg h-full flex flex-col"
4
- [title]="organisation.name"
4
+ [title]="organization.name"
5
5
  >
6
6
  <div
7
7
  class="shrink-0 bg-gray-100 rounded-lg overflow-hidden w-full border border-gray-300 h-36"
8
8
  >
9
9
  <gn-ui-thumbnail
10
10
  class="relative h-full w-full"
11
- [thumbnailUrl]="organisation.logoUrl"
11
+ [thumbnailUrl]="organization.logoUrl"
12
12
  [fit]="'contain'"
13
13
  >
14
14
  </gn-ui-thumbnail>
@@ -18,22 +18,24 @@
18
18
  class="shrink-0 mb-3 mt-5 font-title text-21 text-title group-hover:text-primary line-clamp-2 sm:mt-2 transition-colors"
19
19
  data-cy="organizationName"
20
20
  >
21
- {{ organisation.name }}</span
21
+ {{ organization.name }}</span
22
22
  >
23
23
  <p
24
24
  class="abstract mt-4 mb-5 sm:mb-2 sm:mt-0 grow shrink-1 overflow-hidden"
25
25
  data-cy="organizationDesc"
26
26
  >
27
- {{ organisation.description }}
27
+ {{ organization.description }}
28
28
  </p>
29
29
  <div class="shrink-0 text-primary opacity-50 flex leading-6">
30
30
  <mat-icon class="material-symbols-outlined text-primary opacity-50 mr-1"
31
31
  >folder_open
32
32
  </mat-icon>
33
33
  <span class="mx-1" data-cy="organizationRecordsCount">{{
34
- organisation.recordCount
34
+ organization.recordCount
35
35
  }}</span>
36
- <span translate>record.metadata.publications</span>
36
+ <span translate [translateParams]="{ count: organization.recordCount }"
37
+ >record.metadata.publications</span
38
+ >
37
39
  </div>
38
40
  </div>
39
41
  </div>
@@ -14,12 +14,12 @@ import { Organization } from '../../../../../../libs/common/domain/src/lib/model
14
14
  changeDetection: ChangeDetectionStrategy.OnPush,
15
15
  })
16
16
  export class OrganisationPreviewComponent {
17
- @Input() organisation: Organization
17
+ @Input() organization: Organization
18
18
  @Input() organisationUrl: string
19
19
  @Output() clickedOrganisation = new EventEmitter<Organization>()
20
20
 
21
21
  clickOrganisation(event: Event) {
22
22
  event.preventDefault()
23
- this.clickedOrganisation.emit(this.organisation)
23
+ this.clickedOrganisation.emit(this.organization)
24
24
  }
25
25
  }
@@ -9,6 +9,7 @@ import { OrganisationsFilterComponent } from './organisations-filter/organisatio
9
9
  import { UiInputsModule } from '../../../../../libs/ui/inputs/src'
10
10
  import { LanguageSwitcherComponent } from './language-switcher/language-switcher.component'
11
11
  import { OrganisationsResultComponent } from './organisations-result/organisations-result.component'
12
+ import { RouterLink } from '@angular/router'
12
13
 
13
14
  @NgModule({
14
15
  declarations: [
@@ -24,6 +25,7 @@ import { OrganisationsResultComponent } from './organisations-result/organisatio
24
25
  UiElementsModule,
25
26
  UiInputsModule,
26
27
  MatIconModule,
28
+ RouterLink,
27
29
  ],
28
30
  exports: [
29
31
  CatalogTitleComponent,
@@ -1,7 +1,13 @@
1
1
  <div
2
- translate
3
2
  class="flex flex-row justify-start items-center overflow-hidden"
4
- [title]="hoverTitle"
3
+ data-test="figureTitle"
4
+ [title]="
5
+ figure.toString() +
6
+ ' ' +
7
+ unit +
8
+ ' ' +
9
+ (title | translate: { count: figure })
10
+ "
5
11
  >
6
12
  <mat-icon
7
13
  class="material-symbols-outlined {{ bgClass }} {{
@@ -13,7 +19,9 @@
13
19
  </mat-icon>
14
20
  <div class="shrink overflow-hidden">
15
21
  <div class="figure-block text-[1.5em] text-black">
16
- <span class="figure font-medium mr-[0.3em]">{{ figure }}</span>
22
+ <span class="figure font-medium mr-[0.3em]" data-test="figure">{{
23
+ figure
24
+ }}</span>
17
25
  <span class="unit text-[0.665em]">{{ unit }}</span>
18
26
  </div>
19
27
  <div translate class="title truncate" [translateParams]="{ count: figure }">
@@ -1,4 +1,4 @@
1
- import { Component, ChangeDetectionStrategy, Input } from '@angular/core'
1
+ import { ChangeDetectionStrategy, Component, Input } from '@angular/core'
2
2
 
3
3
  @Component({
4
4
  selector: 'gn-ui-figure',
@@ -10,17 +10,13 @@ export class FigureComponent {
10
10
  @Input() icon!: string
11
11
  @Input() title!: string
12
12
  @Input() figure!: string | number
13
- @Input() unit?: string
13
+ @Input() unit = ''
14
14
  @Input() color: 'primary' | 'secondary' = 'primary'
15
15
 
16
- get hoverTitle() {
17
- return `${this.figure.toString()} ${this.unit || ''}
18
- ${this.title}`
19
- }
20
-
21
16
  get textClass() {
22
17
  return this.color === 'primary' ? 'text-primary' : 'text-secondary'
23
18
  }
19
+
24
20
  get bgClass() {
25
21
  return this.color === 'primary' ? 'bg-primary-white' : 'bg-secondary-white'
26
22
  }
@@ -8,7 +8,6 @@ export * from './lib/image-overlay-preview/image-overlay-preview.component'
8
8
  export * from './lib/link-card/link-card.component'
9
9
  export * from './lib/markdown-editor/markdown-editor.component'
10
10
  export * from './lib/markdown-parser/markdown-parser.component'
11
- export * from './lib/max-lines/max-lines.component'
12
11
  export * from './lib/metadata-catalog/metadata-catalog.component'
13
12
  export * from './lib/metadata-contact/metadata-contact.component'
14
13
  export * from './lib/metadata-info/metadata-info.component'
@@ -8,11 +8,11 @@
8
8
  <div class="relative opacity-40">
9
9
  <mat-icon class="material-symbols-outlined face">face</mat-icon>
10
10
  <mat-icon class="material-symbols-outlined question-mark1"
11
- >question_mark</mat-icon
12
- >
11
+ >question_mark
12
+ </mat-icon>
13
13
  <mat-icon class="material-symbols-outlined question-mark2"
14
- >question_mark</mat-icon
15
- >
14
+ >question_mark
15
+ </mat-icon>
16
16
  </div>
17
17
  <div translate>search.error.couldNotReachApi</div>
18
18
  </div>
@@ -32,6 +32,15 @@
32
32
  <div translate>search.error.receivedError</div>
33
33
  <div *ngIf="error">{{ error }}</div>
34
34
  </div>
35
+ <div *ngIf="type === types.ORGANIZATION_HAS_NO_DATASET">
36
+ <div class="relative opacity-40">
37
+ <mat-icon class="material-symbols-outlined computer">computer</mat-icon>
38
+ <mat-icon class="material-symbols-outlined computer-question-mark"
39
+ >question_mark
40
+ </mat-icon>
41
+ </div>
42
+ <div translate>search.error.organizationHasNoDataset</div>
43
+ </div>
35
44
  <div
36
45
  *ngIf="type === types.RECORD_NOT_FOUND"
37
46
  data-test="record-not-found-error"
@@ -39,12 +48,27 @@
39
48
  <div class="relative opacity-40">
40
49
  <mat-icon class="material-symbols-outlined computer">computer</mat-icon>
41
50
  <mat-icon class="material-symbols-outlined computer-question-mark"
42
- >question_mark</mat-icon
43
- >
51
+ >question_mark
52
+ </mat-icon>
44
53
  </div>
45
54
  <div translate [translateParams]="{ id: recordId }">
46
55
  search.error.recordNotFound
47
56
  </div>
48
57
  <div *ngIf="error">{{ error }}</div>
49
58
  </div>
59
+ <div
60
+ *ngIf="type === types.ORGANIZATION_NOT_FOUND"
61
+ data-test="org-not-found-error"
62
+ >
63
+ <div class="relative opacity-40">
64
+ <mat-icon class="material-symbols-outlined computer">computer</mat-icon>
65
+ <mat-icon class="material-symbols-outlined computer-question-mark"
66
+ >question_mark
67
+ </mat-icon>
68
+ </div>
69
+ <div translate [translateParams]="{ id: recordId }">
70
+ search.error.organizationNotFound
71
+ </div>
72
+ <div *ngIf="error">{{ error }}</div>
73
+ </div>
50
74
  </div>
@@ -5,6 +5,8 @@ export enum ErrorType {
5
5
  RECEIVED_ERROR,
6
6
  RECORD_NOT_FOUND,
7
7
  DATASET_HAS_NO_LINK,
8
+ ORGANIZATION_HAS_NO_DATASET,
9
+ ORGANIZATION_NOT_FOUND,
8
10
  }
9
11
 
10
12
  @Component({
@@ -1,5 +1,5 @@
1
1
  <a
2
- class="w-72 h-96 overflow-hidden rounded-lg bg-white cursor-pointer block hover:-translate-y-2 duration-[180ms]"
2
+ [class]="classList"
3
3
  [routerLink]="['/dataset', record.uniqueIdentifier]"
4
4
  target="_blank"
5
5
  >
@@ -1,4 +1,4 @@
1
- import { Component, ChangeDetectionStrategy, Input } from '@angular/core'
1
+ import { ChangeDetectionStrategy, Component, Input } from '@angular/core'
2
2
  import { CatalogRecord } from '../../../../../../libs/common/domain/src/lib/model/record'
3
3
 
4
4
  @Component({
@@ -8,5 +8,26 @@ import { CatalogRecord } from '../../../../../../libs/common/domain/src/lib/mode
8
8
  changeDetection: ChangeDetectionStrategy.OnPush,
9
9
  })
10
10
  export class RelatedRecordCardComponent {
11
+ private readonly baseClasses: string
12
+
11
13
  @Input() record: CatalogRecord
14
+ @Input() extraClass = ''
15
+
16
+ constructor() {
17
+ this.baseClasses = [
18
+ 'w-72',
19
+ 'h-96',
20
+ 'overflow-hidden',
21
+ 'rounded-lg',
22
+ 'bg-white',
23
+ 'cursor-pointer',
24
+ 'block',
25
+ 'hover:-translate-y-2 ',
26
+ 'duration-[180ms]',
27
+ ].join(' ')
28
+ }
29
+
30
+ get classList() {
31
+ return `${this.baseClasses} ${this.extraClass}`
32
+ }
12
33
  }
@@ -10,7 +10,7 @@ import { DownloadItemComponent } from './download-item/download-item.component'
10
10
  import { DownloadsListComponent } from './downloads-list/downloads-list.component'
11
11
  import { ApiCardComponent } from './api-card/api-card.component'
12
12
  import { UiWidgetsModule } from '../../../../../libs/ui/widgets/src'
13
- import { UiLayoutModule } from '../../../../../libs/ui/layout/src'
13
+ import { MaxLinesComponent, UiLayoutModule } from '../../../../../libs/ui/layout/src'
14
14
  import { TranslateModule } from '@ngx-translate/core'
15
15
  import { RelatedRecordCardComponent } from './related-record-card/related-record-card.component'
16
16
  import { MetadataContactComponent } from './metadata-contact/metadata-contact.component'
@@ -26,7 +26,6 @@ import { AvatarComponent } from './avatar/avatar.component'
26
26
  import { UserPreviewComponent } from './user-preview/user-preview.component'
27
27
  import { GnUiLinkifyDirective } from './metadata-info/linkify.directive'
28
28
  import { PaginationButtonsComponent } from './pagination-buttons/pagination-buttons.component'
29
- import { MaxLinesComponent } from './max-lines/max-lines.component'
30
29
  import { RecordApiFormComponent } from './record-api-form/record-api-form.component'
31
30
  import { MarkdownParserComponent } from './markdown-parser/markdown-parser.component'
32
31
  import { ImageOverlayPreviewComponent } from './image-overlay-preview/image-overlay-preview.component'
@@ -50,6 +49,7 @@ import { TimeSincePipe } from './user-feedback-item/time-since.pipe'
50
49
  ThumbnailComponent,
51
50
  TimeSincePipe,
52
51
  BadgeComponent,
52
+ MaxLinesComponent,
53
53
  ],
54
54
  declarations: [
55
55
  MetadataInfoComponent,
@@ -68,7 +68,6 @@ import { TimeSincePipe } from './user-feedback-item/time-since.pipe'
68
68
  UserPreviewComponent,
69
69
  GnUiLinkifyDirective,
70
70
  PaginationButtonsComponent,
71
- MaxLinesComponent,
72
71
  RecordApiFormComponent,
73
72
  UserFeedbackItemComponent,
74
73
  ImageOverlayPreviewComponent,
@@ -90,7 +89,6 @@ import { TimeSincePipe } from './user-feedback-item/time-since.pipe'
90
89
  AvatarComponent,
91
90
  UserPreviewComponent,
92
91
  PaginationButtonsComponent,
93
- MaxLinesComponent,
94
92
  RecordApiFormComponent,
95
93
  MarkdownParserComponent,
96
94
  UserFeedbackItemComponent,
@@ -3,6 +3,7 @@ export * from './lib/carousel/carousel.component'
3
3
  export * from './lib/expandable-panel-button/expandable-panel-button.component'
4
4
  export * from './lib/expandable-panel/expandable-panel.component'
5
5
  export * from './lib/form-field-wrapper/form-field-wrapper.component'
6
+ export * from './lib/max-lines/max-lines.component'
6
7
  export * from './lib/interactive-table/interactive-table-column/interactive-table-column.component'
7
8
  export * from './lib/interactive-table/interactive-table.component'
8
9
  export * from './lib/sticky-header/sticky-header.component'
@@ -14,6 +14,7 @@
14
14
  *ngIf="showToggleButton"
15
15
  (click)="toggleDisplay()"
16
16
  class="text-secondary cursor-pointer pt-2.5"
17
+ data-cy="readMoreButton"
17
18
  >
18
19
  {{ (isExpanded ? 'ui.readLess' : 'ui.readMore') | translate }}
19
20
  </div>
@@ -1,19 +1,23 @@
1
1
  import {
2
+ AfterViewInit,
3
+ ChangeDetectionStrategy,
4
+ ChangeDetectorRef,
2
5
  Component,
3
- Input,
4
6
  ElementRef,
5
- ChangeDetectionStrategy,
6
- AfterViewInit,
7
- ViewChild,
7
+ Input,
8
8
  OnDestroy,
9
- ChangeDetectorRef,
9
+ ViewChild,
10
10
  } from '@angular/core'
11
+ import { CommonModule } from '@angular/common'
12
+ import { TranslateModule } from '@ngx-translate/core'
11
13
 
12
14
  @Component({
13
15
  selector: 'gn-ui-max-lines',
14
16
  templateUrl: './max-lines.component.html',
15
17
  styleUrls: ['./max-lines.component.css'],
16
18
  changeDetection: ChangeDetectionStrategy.OnPush,
19
+ standalone: true,
20
+ imports: [CommonModule, TranslateModule],
17
21
  })
18
22
  export class MaxLinesComponent implements AfterViewInit, OnDestroy {
19
23
  @Input() maxLines = 6
@@ -6,7 +6,6 @@ import { StickyHeaderComponent } from './sticky-header/sticky-header.component'
6
6
  import { AnchorLinkDirective } from './anchor-link/anchor-link.directive'
7
7
  import { ExpandablePanelButtonComponent } from './expandable-panel-button/expandable-panel-button.component'
8
8
  import { MatIconModule } from '@angular/material/icon'
9
- import { CarouselComponent } from './carousel/carousel.component'
10
9
 
11
10
  @NgModule({
12
11
  imports: [CommonModule, MatIconModule, TranslateModule.forChild()],
@@ -17,3 +17,4 @@ export * from './lib/record-preview-title/record-preview-title.component'
17
17
  export * from './lib/record-metric/record-metric.component'
18
18
  export * from './lib/results-list-item/results-list-item.component'
19
19
  export * from './lib/results-hits-number/results-hits-number.component'
20
+ export * from './lib/results-table/results-table.component'
@@ -1,13 +1,13 @@
1
1
  <gn-ui-interactive-table
2
- [items]="records$ | async"
2
+ [items]="records"
3
3
  (itemClick)="handleRecordClick($event)"
4
4
  >
5
5
  <!-- SELECTED COLUMN -->
6
6
  <gn-ui-interactive-table-column>
7
7
  <ng-template #header>
8
8
  <gn-ui-checkbox
9
- [checked]="isAllSelected() | async"
10
- [indeterminate]="isSomeSelected() | async"
9
+ [checked]="isAllSelected()"
10
+ [indeterminate]="isSomeSelected()"
11
11
  (changed)="toggleSelectAll()"
12
12
  type="default"
13
13
  class="-m-2 mr-3"
@@ -16,7 +16,7 @@
16
16
  </ng-template>
17
17
  <ng-template #cell let-item>
18
18
  <gn-ui-checkbox
19
- [checked]="isChecked(item) | async"
19
+ [checked]="isChecked(item)"
20
20
  (changed)="handleRecordSelectedChange($event, item)"
21
21
  class="-m-2"
22
22
  type="default"
@@ -27,7 +27,7 @@
27
27
  <!-- TITLE COLUMN -->
28
28
  <gn-ui-interactive-table-column
29
29
  [sortable]="true"
30
- [activeSort]="isSortedBy('resourceTitleObject.default.keyword') | async"
30
+ [activeSort]="isSortedBy('resourceTitleObject.default.keyword')"
31
31
  (sortChange)="setSortBy('resourceTitleObject.default.keyword', $event)"
32
32
  >
33
33
  <ng-template #header>
@@ -37,7 +37,7 @@
37
37
  <div class="flex flex-row items-center gap-2 max-w-full">
38
38
  <span class="overflow-hidden text-ellipsis">{{ item.title }}</span>
39
39
  <gn-ui-badge
40
- *ngIf="hasDraft(item)"
40
+ *ngIf="recordHasDraft(item)"
41
41
  [style.--gn-ui-badge-padding]="'0.4em 0.6em'"
42
42
  [style.--gn-ui-badge-text-color]="'#3d2006'"
43
43
  [style.--gn-ui-badge-background-color]="'#ffbc7b'"
@@ -85,7 +85,7 @@
85
85
  <!-- OWNER COLUMN -->
86
86
  <gn-ui-interactive-table-column
87
87
  [sortable]="true"
88
- [activeSort]="isSortedBy('recordOwner') | async"
88
+ [activeSort]="isSortedBy('recordOwner')"
89
89
  (sortChange)="setSortBy('recordOwner', $event)"
90
90
  >
91
91
  <ng-template #header>
@@ -110,7 +110,7 @@
110
110
  <!-- UPDATE DATE COLUMN -->
111
111
  <gn-ui-interactive-table-column
112
112
  [sortable]="true"
113
- [activeSort]="isSortedBy('changeDate') | async"
113
+ [activeSort]="isSortedBy('changeDate')"
114
114
  (sortChange)="setSortBy('changeDate', $event)"
115
115
  >
116
116
  <ng-template #header>