geonetwork-ui 2.3.0-dev.139106e0 → 2.3.0-dev.287bf00c

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 (166) hide show
  1. package/esm2022/libs/api/repository/src/lib/gn4/auth/avatar.service.interface.mjs +1 -1
  2. package/esm2022/libs/api/repository/src/lib/gn4/auth/gravatar.service.mjs +12 -1
  3. package/esm2022/libs/api/repository/src/lib/gn4/platform/gn4-platform.mapper.mjs +36 -3
  4. package/esm2022/libs/api/repository/src/lib/gn4/platform/gn4-platform.service.mjs +19 -7
  5. package/esm2022/libs/common/domain/src/lib/model/record/index.mjs +2 -1
  6. package/esm2022/libs/common/domain/src/lib/model/record/user-feedbacks.model.mjs +2 -0
  7. package/esm2022/libs/common/domain/src/lib/model/user/index.mjs +2 -0
  8. package/esm2022/libs/common/domain/src/lib/platform.service.interface.mjs +1 -1
  9. package/esm2022/libs/feature/dataviz/src/lib/service/data.service.mjs +53 -2
  10. package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-license/form-field-license.component.mjs +64 -0
  11. package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-resource-updated/form-field-resource-updated.component.mjs +15 -0
  12. package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field.component.mjs +20 -6
  13. package/esm2022/libs/feature/editor/src/lib/components/wizard-field/wizard-field.component.mjs +1 -1
  14. package/esm2022/libs/feature/editor/src/lib/fields.config.mjs +16 -1
  15. package/esm2022/libs/feature/map/src/lib/add-layer-from-ogc-api/add-layer-from-ogc-api.component.mjs +1 -1
  16. package/esm2022/libs/feature/map/src/lib/add-layer-from-wfs/add-layer-from-wfs.component.mjs +1 -1
  17. package/esm2022/libs/feature/map/src/lib/add-layer-from-wms/add-layer-from-wms.component.mjs +1 -1
  18. package/esm2022/libs/feature/record/src/lib/feature-record.module.mjs +4 -4
  19. package/esm2022/libs/feature/record/src/lib/map-view/map-view.component.mjs +3 -2
  20. package/esm2022/libs/feature/record/src/lib/state/mdview.actions.mjs +22 -4
  21. package/esm2022/libs/feature/record/src/lib/state/mdview.effects.mjs +37 -10
  22. package/esm2022/libs/feature/record/src/lib/state/mdview.facade.mjs +22 -7
  23. package/esm2022/libs/feature/record/src/lib/state/mdview.reducer.mjs +52 -17
  24. package/esm2022/libs/feature/record/src/lib/state/mdview.selectors.mjs +18 -3
  25. package/esm2022/libs/feature/router/src/lib/default/state/router.effects.mjs +2 -2
  26. package/esm2022/libs/ui/elements/src/lib/markdown-editor/markdown-editor.component.mjs +2 -2
  27. package/esm2022/libs/ui/elements/src/lib/record-api-form/record-api-form.component.mjs +34 -7
  28. package/esm2022/libs/ui/elements/src/lib/ui-elements.module.mjs +10 -2
  29. package/esm2022/libs/ui/elements/src/lib/user-feedback-item/time-since.pipe.mjs +59 -0
  30. package/esm2022/libs/ui/elements/src/lib/user-feedback-item/user-feedback-item.component.mjs +62 -0
  31. package/esm2022/libs/ui/inputs/src/index.mjs +15 -15
  32. package/esm2022/libs/ui/inputs/src/lib/date-picker/date-picker.component.mjs +22 -0
  33. package/esm2022/libs/ui/inputs/src/lib/date-range-picker/date-range-picker.component.mjs +7 -5
  34. package/esm2022/libs/ui/inputs/src/lib/dropdown-selector/dropdown-selector.component.mjs +17 -8
  35. package/esm2022/libs/ui/inputs/src/lib/text-area/text-area.component.mjs +27 -4
  36. package/esm2022/libs/ui/inputs/src/lib/text-input/text-input.component.mjs +19 -3
  37. package/esm2022/libs/ui/inputs/src/lib/ui-inputs.module.mjs +11 -9
  38. package/esm2022/libs/util/shared/src/lib/links/link-classifier.service.mjs +2 -2
  39. package/esm2022/libs/util/shared/src/lib/links/link-utils.mjs +22 -1
  40. package/esm2022/translations/de.json +26 -0
  41. package/esm2022/translations/en.json +26 -0
  42. package/esm2022/translations/es.json +26 -0
  43. package/esm2022/translations/fr.json +26 -0
  44. package/esm2022/translations/it.json +26 -0
  45. package/esm2022/translations/nl.json +26 -0
  46. package/esm2022/translations/pt.json +26 -0
  47. package/fesm2022/geonetwork-ui.mjs +1436 -717
  48. package/fesm2022/geonetwork-ui.mjs.map +1 -1
  49. package/libs/api/repository/src/lib/gn4/auth/avatar.service.interface.d.ts +1 -0
  50. package/libs/api/repository/src/lib/gn4/auth/avatar.service.interface.d.ts.map +1 -1
  51. package/libs/api/repository/src/lib/gn4/auth/gravatar.service.d.ts +1 -0
  52. package/libs/api/repository/src/lib/gn4/auth/gravatar.service.d.ts.map +1 -1
  53. package/libs/api/repository/src/lib/gn4/platform/gn4-platform.mapper.d.ts +6 -2
  54. package/libs/api/repository/src/lib/gn4/platform/gn4-platform.mapper.d.ts.map +1 -1
  55. package/libs/api/repository/src/lib/gn4/platform/gn4-platform.service.d.ts +9 -6
  56. package/libs/api/repository/src/lib/gn4/platform/gn4-platform.service.d.ts.map +1 -1
  57. package/libs/common/domain/src/lib/model/record/index.d.ts +1 -0
  58. package/libs/common/domain/src/lib/model/record/index.d.ts.map +1 -1
  59. package/libs/common/domain/src/lib/model/record/user-feedbacks.model.d.ts +15 -0
  60. package/libs/common/domain/src/lib/model/record/user-feedbacks.model.d.ts.map +1 -0
  61. package/libs/common/domain/src/lib/model/user/index.d.ts +2 -0
  62. package/libs/common/domain/src/lib/model/user/index.d.ts.map +1 -0
  63. package/libs/common/domain/src/lib/platform.service.interface.d.ts +3 -0
  64. package/libs/common/domain/src/lib/platform.service.interface.d.ts.map +1 -1
  65. package/libs/feature/dataviz/src/lib/service/data.service.d.ts +3 -1
  66. package/libs/feature/dataviz/src/lib/service/data.service.d.ts.map +1 -1
  67. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-license/form-field-license.component.d.ts +39 -0
  68. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-license/form-field-license.component.d.ts.map +1 -0
  69. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-resource-updated/form-field-resource-updated.component.d.ts +8 -0
  70. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-resource-updated/form-field-resource-updated.component.d.ts.map +1 -0
  71. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field.component.d.ts +4 -1
  72. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field.component.d.ts.map +1 -1
  73. package/libs/feature/editor/src/lib/fields.config.d.ts.map +1 -1
  74. package/libs/feature/record/src/lib/feature-record.module.d.ts.map +1 -1
  75. package/libs/feature/record/src/lib/map-view/map-view.component.d.ts.map +1 -1
  76. package/libs/feature/record/src/lib/state/mdview.actions.d.ts +40 -6
  77. package/libs/feature/record/src/lib/state/mdview.actions.d.ts.map +1 -1
  78. package/libs/feature/record/src/lib/state/mdview.effects.d.ts +24 -4
  79. package/libs/feature/record/src/lib/state/mdview.effects.d.ts.map +1 -1
  80. package/libs/feature/record/src/lib/state/mdview.facade.d.ts +14 -4
  81. package/libs/feature/record/src/lib/state/mdview.facade.d.ts.map +1 -1
  82. package/libs/feature/record/src/lib/state/mdview.reducer.d.ts +8 -5
  83. package/libs/feature/record/src/lib/state/mdview.reducer.d.ts.map +1 -1
  84. package/libs/feature/record/src/lib/state/mdview.selectors.d.ts +12 -9
  85. package/libs/feature/record/src/lib/state/mdview.selectors.d.ts.map +1 -1
  86. package/libs/ui/elements/src/lib/downloads-list/downloads-list.component.d.ts +1 -1
  87. package/libs/ui/elements/src/lib/record-api-form/record-api-form.component.d.ts +4 -2
  88. package/libs/ui/elements/src/lib/record-api-form/record-api-form.component.d.ts.map +1 -1
  89. package/libs/ui/elements/src/lib/ui-elements.module.d.ts +16 -14
  90. package/libs/ui/elements/src/lib/ui-elements.module.d.ts.map +1 -1
  91. package/libs/ui/elements/src/lib/user-feedback-item/time-since.pipe.d.ts +11 -0
  92. package/libs/ui/elements/src/lib/user-feedback-item/time-since.pipe.d.ts.map +1 -0
  93. package/libs/ui/elements/src/lib/user-feedback-item/user-feedback-item.component.d.ts +22 -0
  94. package/libs/ui/elements/src/lib/user-feedback-item/user-feedback-item.component.d.ts.map +1 -0
  95. package/libs/ui/inputs/src/index.d.ts +14 -14
  96. package/libs/ui/inputs/src/index.d.ts.map +1 -1
  97. package/libs/ui/inputs/src/lib/date-picker/date-picker.component.d.ts +9 -0
  98. package/libs/ui/inputs/src/lib/date-picker/date-picker.component.d.ts.map +1 -0
  99. package/libs/ui/inputs/src/lib/date-range-picker/date-range-picker.component.d.ts +1 -1
  100. package/libs/ui/inputs/src/lib/date-range-picker/date-range-picker.component.d.ts.map +1 -1
  101. package/libs/ui/inputs/src/lib/dropdown-selector/dropdown-selector.component.d.ts +1 -1
  102. package/libs/ui/inputs/src/lib/dropdown-selector/dropdown-selector.component.d.ts.map +1 -1
  103. package/libs/ui/inputs/src/lib/text-area/text-area.component.d.ts +7 -1
  104. package/libs/ui/inputs/src/lib/text-area/text-area.component.d.ts.map +1 -1
  105. package/libs/ui/inputs/src/lib/text-input/text-input.component.d.ts +4 -1
  106. package/libs/ui/inputs/src/lib/text-input/text-input.component.d.ts.map +1 -1
  107. package/libs/ui/inputs/src/lib/ui-inputs.module.d.ts +35 -35
  108. package/libs/util/shared/src/lib/links/link-utils.d.ts +18 -0
  109. package/libs/util/shared/src/lib/links/link-utils.d.ts.map +1 -1
  110. package/package.json +1 -1
  111. package/src/libs/api/repository/src/lib/gn4/auth/avatar.service.interface.ts +1 -0
  112. package/src/libs/api/repository/src/lib/gn4/auth/gravatar.service.ts +12 -1
  113. package/src/libs/api/repository/src/lib/gn4/platform/gn4-platform.mapper.ts +51 -1
  114. package/src/libs/api/repository/src/lib/gn4/platform/gn4-platform.service.ts +34 -7
  115. package/src/libs/common/domain/src/lib/model/record/index.ts +1 -0
  116. package/src/libs/common/domain/src/lib/model/record/user-feedbacks.model.ts +15 -0
  117. package/src/libs/common/domain/src/lib/platform.service.interface.ts +3 -0
  118. package/src/libs/common/fixtures/src/index.ts +8 -6
  119. package/src/libs/common/fixtures/src/lib/records.fixtures.ts +3 -3
  120. package/src/libs/common/fixtures/src/lib/user-feedbacks.fixtures.ts +83 -0
  121. package/src/libs/feature/dataviz/src/lib/service/data.service.ts +68 -1
  122. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-license/form-field-license.component.css +0 -0
  123. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-license/form-field-license.component.html +8 -0
  124. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-license/form-field-license.component.ts +64 -0
  125. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-resource-updated/form-field-resource-updated.component.css +0 -0
  126. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-resource-updated/form-field-resource-updated.component.html +4 -0
  127. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-resource-updated/form-field-resource-updated.component.ts +15 -0
  128. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field.component.html +33 -33
  129. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field.component.ts +16 -0
  130. package/src/libs/feature/editor/src/lib/fields.config.ts +15 -0
  131. package/src/libs/feature/record/src/lib/feature-record.module.ts +5 -2
  132. package/src/libs/feature/record/src/lib/map-view/map-view.component.ts +2 -1
  133. package/src/libs/feature/record/src/lib/state/mdview.actions.ts +51 -6
  134. package/src/libs/feature/record/src/lib/state/mdview.effects.ts +82 -7
  135. package/src/libs/feature/record/src/lib/state/mdview.facade.ts +49 -8
  136. package/src/libs/feature/record/src/lib/state/mdview.reducer.ts +81 -24
  137. package/src/libs/feature/record/src/lib/state/mdview.selectors.ts +40 -10
  138. package/src/libs/feature/router/src/lib/default/state/router.effects.ts +2 -2
  139. package/src/libs/ui/elements/src/lib/record-api-form/record-api-form.component.html +1 -1
  140. package/src/libs/ui/elements/src/lib/record-api-form/record-api-form.component.ts +40 -4
  141. package/src/libs/ui/elements/src/lib/ui-elements.module.ts +5 -0
  142. package/src/libs/ui/elements/src/lib/user-feedback-item/time-since.pipe.ts +54 -0
  143. package/src/libs/ui/elements/src/lib/user-feedback-item/user-feedback-item.component.css +0 -0
  144. package/src/libs/ui/elements/src/lib/user-feedback-item/user-feedback-item.component.html +75 -0
  145. package/src/libs/ui/elements/src/lib/user-feedback-item/user-feedback-item.component.ts +63 -0
  146. package/src/libs/ui/inputs/src/index.ts +14 -14
  147. package/src/libs/ui/inputs/src/lib/date-picker/date-picker.component.css +3 -0
  148. package/src/libs/ui/inputs/src/lib/date-picker/date-picker.component.html +11 -0
  149. package/src/libs/ui/inputs/src/lib/date-picker/date-picker.component.ts +16 -0
  150. package/src/libs/ui/inputs/src/lib/date-range-picker/date-range-picker.component.ts +8 -1
  151. package/src/libs/ui/inputs/src/lib/dropdown-selector/dropdown-selector.component.ts +13 -0
  152. package/src/libs/ui/inputs/src/lib/text-area/text-area.component.html +2 -1
  153. package/src/libs/ui/inputs/src/lib/text-area/text-area.component.ts +29 -0
  154. package/src/libs/ui/inputs/src/lib/text-input/text-input.component.html +1 -1
  155. package/src/libs/ui/inputs/src/lib/text-input/text-input.component.ts +16 -1
  156. package/src/libs/ui/inputs/src/lib/ui-inputs.module.ts +2 -2
  157. package/src/libs/util/shared/src/lib/links/link-classifier.service.ts +1 -1
  158. package/src/libs/util/shared/src/lib/links/link-utils.ts +21 -0
  159. package/translations/de.json +26 -0
  160. package/translations/en.json +26 -0
  161. package/translations/es.json +26 -0
  162. package/translations/fr.json +26 -0
  163. package/translations/it.json +26 -0
  164. package/translations/nl.json +26 -0
  165. package/translations/pt.json +26 -0
  166. package/translations/sk.json +26 -0
@@ -31,6 +31,8 @@ import { MaxLinesComponent } from './max-lines/max-lines.component'
31
31
  import { RecordApiFormComponent } from './record-api-form/record-api-form.component'
32
32
  import { MarkdownParserComponent } from './markdown-parser/markdown-parser.component'
33
33
  import { ImageOverlayPreviewComponent } from './image-overlay-preview/image-overlay-preview.component'
34
+ import { UserFeedbackItemComponent } from './user-feedback-item/user-feedback-item.component'
35
+ import { TimeSincePipe } from './user-feedback-item/time-since.pipe'
34
36
 
35
37
  @NgModule({
36
38
  imports: [
@@ -47,6 +49,7 @@ import { ImageOverlayPreviewComponent } from './image-overlay-preview/image-over
47
49
  NgOptimizedImage,
48
50
  MarkdownParserComponent,
49
51
  ThumbnailComponent,
52
+ TimeSincePipe,
50
53
  ],
51
54
  declarations: [
52
55
  MetadataInfoComponent,
@@ -68,6 +71,7 @@ import { ImageOverlayPreviewComponent } from './image-overlay-preview/image-over
68
71
  PaginationButtonsComponent,
69
72
  MaxLinesComponent,
70
73
  RecordApiFormComponent,
74
+ UserFeedbackItemComponent,
71
75
  ImageOverlayPreviewComponent,
72
76
  ],
73
77
  exports: [
@@ -91,6 +95,7 @@ import { ImageOverlayPreviewComponent } from './image-overlay-preview/image-over
91
95
  MaxLinesComponent,
92
96
  RecordApiFormComponent,
93
97
  MarkdownParserComponent,
98
+ UserFeedbackItemComponent,
94
99
  ImageOverlayPreviewComponent,
95
100
  ],
96
101
  })
@@ -0,0 +1,54 @@
1
+ import { Pipe, PipeTransform } from '@angular/core'
2
+ import { TranslateService } from '@ngx-translate/core'
3
+ import { formatDistance } from 'date-fns'
4
+ import { de, enUS, es, fr, it, nl, pt, sk } from 'date-fns/locale'
5
+
6
+ @Pipe({
7
+ name: 'timeSince',
8
+ standalone: true,
9
+ })
10
+ export class TimeSincePipe implements PipeTransform {
11
+ constructor(private translate: TranslateService) {}
12
+
13
+ transform(value: Date): string {
14
+ if (isNaN(value.getTime())) {
15
+ throw new Error('Invalid Date')
16
+ }
17
+
18
+ const maintenant = new Date()
19
+ let locale: Locale
20
+
21
+ switch (this.translate.currentLang) {
22
+ case 'fr':
23
+ locale = fr
24
+ break
25
+ case 'de':
26
+ locale = de
27
+ break
28
+ case 'es':
29
+ locale = es
30
+ break
31
+ case 'it':
32
+ locale = it
33
+ break
34
+ case 'nl':
35
+ locale = nl
36
+ break
37
+ case 'pt':
38
+ locale = pt
39
+ break
40
+ case 'sk':
41
+ locale = sk
42
+ break
43
+ case 'en':
44
+ default:
45
+ locale = enUS
46
+ break
47
+ }
48
+
49
+ return formatDistance(value, maintenant, {
50
+ addSuffix: true,
51
+ locale: locale,
52
+ })
53
+ }
54
+ }
@@ -0,0 +1,75 @@
1
+ <div
2
+ *ngIf="userFeedbackParent.published"
3
+ class="flex flex-col bg-white rounded w-full"
4
+ [ngClass]="[isAnAnswer ? 'ps-4 ' : 'p-4']"
5
+ >
6
+ <div class="flex flex-row">
7
+ <div class="avatar">
8
+ <img
9
+ class="rounded-full"
10
+ [src]="userFeedbackParent.avatarUrl"
11
+ alt="avatar"
12
+ />
13
+ </div>
14
+ <div class="p-4 flex flex-col">
15
+ <span>{{ userFeedbackParent.authorName }}</span>
16
+ <span> {{ userFeedbackParent.date | timeSince }}</span>
17
+ </div>
18
+ </div>
19
+ <div data-cy="commentText" class="mt-4 whitespace-pre-line">
20
+ {{ userFeedbackParent.comment }}
21
+ </div>
22
+ <div
23
+ class="w-full"
24
+ *ngFor="let userFeedBacksAnswer of userFeedBacksAnswers; let last = last"
25
+ >
26
+ <hr class="-mx-4 my-6" />
27
+ <gn-ui-user-feedback-item
28
+ [userFeedbackParent]="userFeedBacksAnswer"
29
+ [isLastComment]="last"
30
+ ></gn-ui-user-feedback-item>
31
+ </div>
32
+
33
+ <div *ngIf="isActiveUserEditor" class="mt-2 flex flex-col">
34
+ <hr class="-mx-4 my-4" />
35
+ <div
36
+ id="new-comment-buttons"
37
+ class="flex flex-row gap-2 items-center justify-end"
38
+ >
39
+ <gn-ui-text-area
40
+ [disabled]="isAddUserFeedbackLoading"
41
+ [(value)]="newAnswer"
42
+ (valueChange)="onNewAnswerValueChange()"
43
+ (keyup.control.enter)="publishNewAnswer()"
44
+ [placeholder]="
45
+ 'record.metadata.userFeedbacks.newAnswer.placeholder' | translate
46
+ "
47
+ class="grow"
48
+ extraClass="bg-transparent border-0 placeholder-primary-darker text-primary-darker h-9"
49
+ ></gn-ui-text-area>
50
+ <div *ngIf="!isAnswerEmpty" class="flex flex-row justify-end">
51
+ <gn-ui-button
52
+ [disabled]="isAddUserFeedbackLoading"
53
+ [type]="'outline'"
54
+ (buttonClick)="publishNewAnswer()"
55
+ [title]="
56
+ 'record.metadata.userFeedbacks.newAnswer.buttonTitle' | translate
57
+ "
58
+ extraClass="!p-[0.5em] text-primary-darker border-primary-darker h-9"
59
+ >
60
+ <mat-icon
61
+ class="material-symbols-outlined"
62
+ *ngIf="!isAddUserFeedbackLoading"
63
+ >
64
+ send
65
+ </mat-icon>
66
+ <ng-container *ngIf="isAddUserFeedbackLoading">
67
+ <div class="flex justify-center w-full">
68
+ <gn-ui-spinning-loader></gn-ui-spinning-loader>
69
+ </div>
70
+ </ng-container>
71
+ </gn-ui-button>
72
+ </div>
73
+ </div>
74
+ </div>
75
+ </div>
@@ -0,0 +1,63 @@
1
+ import {
2
+ ChangeDetectionStrategy,
3
+ Component,
4
+ EventEmitter,
5
+ Input,
6
+ OnInit,
7
+ Output,
8
+ } from '@angular/core'
9
+ import {
10
+ UserFeedback,
11
+ UserFeedbackViewModel,
12
+ } from '../../../../../../libs/common/domain/src/lib/model/record'
13
+ import { UserModel } from '../../../../../../libs/common/domain/src/lib/model/user'
14
+
15
+ @Component({
16
+ selector: 'gn-ui-user-feedback-item',
17
+ templateUrl: './user-feedback-item.component.html',
18
+ styleUrls: ['./user-feedback-item.component.css'],
19
+ changeDetection: ChangeDetectionStrategy.OnPush,
20
+ })
21
+ export class UserFeedbackItemComponent implements OnInit {
22
+ @Input() userFeedbackParent: UserFeedbackViewModel
23
+ @Input() userFeedBacksAnswers: UserFeedbackViewModel[]
24
+ @Input() isActiveUserEditor: boolean
25
+ @Input() activeUser: UserModel
26
+ @Input() isLastComment: boolean
27
+ @Input() isAddUserFeedbackLoading: boolean
28
+
29
+ @Output() newUserFeedbackAnswer = new EventEmitter<UserFeedback>()
30
+
31
+ isAnAnswer = false
32
+ newAnswer = ''
33
+ isAnswerEmpty = true
34
+
35
+ ngOnInit(): void {
36
+ this.isAnAnswer = !!this.userFeedbackParent.parentUuid
37
+ }
38
+
39
+ onNewAnswerValueChange() {
40
+ this.isAnswerEmpty = this.newAnswer.length === 0
41
+ }
42
+
43
+ publishNewAnswer() {
44
+ if (this.newAnswer.trim() === '') return
45
+
46
+ const newAnswer: UserFeedback = {
47
+ ...this.userFeedbackParent,
48
+ uuid: undefined,
49
+ published: true,
50
+ comment: this.newAnswer,
51
+ parentUuid: this.userFeedbackParent.uuid,
52
+ authorUserId: this.activeUser?.id,
53
+ authorEmail: this.activeUser?.email,
54
+ date: new Date(),
55
+ authorName: `${this.activeUser?.name} ${this.activeUser?.surname}`,
56
+ }
57
+
58
+ this.newUserFeedbackAnswer.emit(newAnswer)
59
+
60
+ this.newAnswer = ''
61
+ this.onNewAnswerValueChange()
62
+ }
63
+ }
@@ -1,21 +1,21 @@
1
- export * from './lib/dropdown-selector/dropdown-selector.component'
2
- export * from './lib/dropdown-selector/dropdown-selector.model'
3
- export * from './lib/dropdown-multiselect/dropdown-multiselect.component'
4
- export * from './lib/dropdown-multiselect/dropdown-multiselect.model'
5
- export * from './lib/text-input/text-input.component'
6
- export * from './lib/chips-input/chips-input.component'
7
- export * from './lib/text-area/text-area.component'
8
1
  export * from './lib/autocomplete/autocomplete.component'
9
- export * from './lib/star-toggle/star-toggle.component'
10
2
  export * from './lib/button/button.component'
11
- export * from './lib/viewport-intersector/viewport-intersector.component'
12
3
  export * from './lib/check-toggle/check-toggle.component'
13
- export * from './lib/ui-inputs.module'
4
+ export * from './lib/checkbox/checkbox.component'
5
+ export * from './lib/chips-input/chips-input.component'
14
6
  export * from './lib/copy-text-button/copy-text-button.component'
7
+ export * from './lib/date-picker/date-picker.component'
8
+ export * from './lib/date-range-picker/date-range-picker.component'
15
9
  export * from './lib/drag-and-drop-file-input/drag-and-drop-file-input.component'
10
+ export * from './lib/dropdown-multiselect/dropdown-multiselect.component'
11
+ export * from './lib/dropdown-multiselect/dropdown-multiselect.model'
12
+ export * from './lib/dropdown-selector/dropdown-selector.component'
13
+ export * from './lib/dropdown-selector/dropdown-selector.model'
14
+ export * from './lib/editable-label/editable-label.directive'
16
15
  export * from './lib/navigation-button/navigation-button.component'
17
- export * from './lib/viewport-intersector/viewport-intersector.component'
18
- export * from './lib/checkbox/checkbox.component'
19
16
  export * from './lib/search-input/search-input.component'
20
- export * from './lib/date-range-picker/date-range-picker.component'
21
- export * from './lib/editable-label/editable-label.directive'
17
+ export * from './lib/star-toggle/star-toggle.component'
18
+ export * from './lib/text-area/text-area.component'
19
+ export * from './lib/text-input/text-input.component'
20
+ export * from './lib/ui-inputs.module'
21
+ export * from './lib/viewport-intersector/viewport-intersector.component'
@@ -0,0 +1,3 @@
1
+ mat-datepicker-toggle {
2
+ @apply text-primary;
3
+ }
@@ -0,0 +1,11 @@
1
+ <div
2
+ class="flex items-center justify-between pl-3 rounded-lg border border-gray-300 bg-white"
3
+ >
4
+ <input
5
+ [matDatepicker]="picker"
6
+ [value]="date"
7
+ (dateChange)="dateChange.emit($event.value)"
8
+ />
9
+ <mat-datepicker-toggle matIconSuffix [for]="picker"></mat-datepicker-toggle>
10
+ </div>
11
+ <mat-datepicker #picker></mat-datepicker>
@@ -0,0 +1,16 @@
1
+ import { Component, EventEmitter, Input, Output } from '@angular/core'
2
+ import { MatNativeDateModule } from '@angular/material/core'
3
+ import { MatDatepickerModule } from '@angular/material/datepicker'
4
+ import { MatIconModule } from '@angular/material/icon'
5
+
6
+ @Component({
7
+ selector: 'gn-ui-date-picker',
8
+ templateUrl: './date-picker.component.html',
9
+ styleUrls: ['./date-picker.component.css'],
10
+ standalone: true,
11
+ imports: [MatIconModule, MatNativeDateModule, MatDatepickerModule],
12
+ })
13
+ export class DatePickerComponent {
14
+ @Input() date: Date
15
+ @Output() dateChange = new EventEmitter<Date>()
16
+ }
@@ -1,10 +1,17 @@
1
1
  import { Component } from '@angular/core'
2
- import { MatDatepickerInputEvent } from '@angular/material/datepicker'
2
+ import { MatNativeDateModule } from '@angular/material/core'
3
+ import {
4
+ MatDatepickerInputEvent,
5
+ MatDatepickerModule,
6
+ } from '@angular/material/datepicker'
7
+ import { MatIconModule } from '@angular/material/icon'
3
8
 
4
9
  @Component({
5
10
  selector: 'gn-ui-date-range-picker',
6
11
  templateUrl: './date-range-picker.component.html',
7
12
  styleUrls: ['./date-range-picker.component.css'],
13
+ standalone: true,
14
+ imports: [MatIconModule, MatNativeDateModule, MatDatepickerModule],
8
15
  })
9
16
  export class DateRangePickerComponent {
10
17
  startDate: Date
@@ -2,6 +2,7 @@ import {
2
2
  CdkConnectedOverlay,
3
3
  CdkOverlayOrigin,
4
4
  ConnectedPosition,
5
+ OverlayModule,
5
6
  } from '@angular/cdk/overlay'
6
7
  import {
7
8
  ChangeDetectionStrategy,
@@ -17,6 +18,10 @@ import {
17
18
  } from '@angular/core'
18
19
  import { firstValueFrom } from 'rxjs'
19
20
  import { DropdownChoice } from './dropdown-selector.model'
21
+ import { CommonModule } from '@angular/common'
22
+ import { TranslateModule } from '@ngx-translate/core'
23
+ import { MatIconModule } from '@angular/material/icon'
24
+ import { ButtonComponent } from '../button/button.component'
20
25
 
21
26
  const DEFAULT_ROW_NUMBERS = 6
22
27
 
@@ -25,6 +30,14 @@ const DEFAULT_ROW_NUMBERS = 6
25
30
  templateUrl: './dropdown-selector.component.html',
26
31
  styleUrls: ['./dropdown-selector.component.css'],
27
32
  changeDetection: ChangeDetectionStrategy.OnPush,
33
+ standalone: true,
34
+ imports: [
35
+ CommonModule,
36
+ ButtonComponent,
37
+ OverlayModule,
38
+ MatIconModule,
39
+ TranslateModule,
40
+ ],
28
41
  })
29
42
  export class DropdownSelectorComponent implements OnInit {
30
43
  @Input() title: string
@@ -2,11 +2,12 @@
2
2
  <textarea
3
3
  #input
4
4
  name="textArea"
5
+ [disabled]="disabled"
5
6
  [placeholder]="placeholder"
6
7
  [value]="value"
7
8
  (change)="handleChange($event)"
8
9
  (input)="handleChange($event)"
9
- class="w-full pt-2 pl-2 resize-none border border-gray-800 rounded italic leading-tight focus:outline-none focus:bg-background focus:border-primary"
10
+ [class]="classList"
10
11
  [attr.required]="required || null"
11
12
  ></textarea>
12
13
  </div>
@@ -15,7 +15,12 @@ import { distinctUntilChanged } from 'rxjs/operators'
15
15
  standalone: true,
16
16
  })
17
17
  export class TextAreaComponent implements AfterViewInit {
18
+ private readonly baseClasses: string
19
+ private readonly disabledClasses: string
20
+
18
21
  @Input() value = ''
22
+ @Input() disabled = false
23
+ @Input() extraClass = ''
19
24
  @Input() placeholder: string
20
25
  @Input() required = false
21
26
 
@@ -24,6 +29,30 @@ export class TextAreaComponent implements AfterViewInit {
24
29
 
25
30
  @ViewChild('input') input
26
31
 
32
+ constructor() {
33
+ this.baseClasses = [
34
+ 'w-full',
35
+ 'pt-2',
36
+ 'pl-2',
37
+ 'resize-none',
38
+ 'border',
39
+ 'border-gray-800',
40
+ 'rounded italic',
41
+ 'leading-tight',
42
+ 'focus:outline-none',
43
+ 'focus:bg-background',
44
+ 'focus:border-primary',
45
+ ].join(' ')
46
+
47
+ this.disabledClasses = ['cursor-not-allowed'].join(' ')
48
+ }
49
+
50
+ get classList() {
51
+ return `${this.baseClasses} ${this.extraClass} ${
52
+ this.disabled ? this.disabledClasses : ''
53
+ }`
54
+ }
55
+
27
56
  ngAfterViewInit() {
28
57
  this.checkRequired(this.input.nativeElement.value)
29
58
  }
@@ -1,6 +1,6 @@
1
1
  <input
2
2
  #input
3
- class="appearance-none border border-gray-300 rounded w-full p-2 text-gray-700 leading-tight focus:outline-none focus:border-primary"
3
+ [class]="classList"
4
4
  type="text"
5
5
  [value]="value"
6
6
  (change)="handleChange($event)"
@@ -14,14 +14,29 @@ import { Subject } from 'rxjs'
14
14
  styleUrls: ['./text-input.component.css'],
15
15
  })
16
16
  export class TextInputComponent implements AfterViewInit {
17
+ private readonly baseClass = [
18
+ 'appearance-none',
19
+ 'border border-gray-300',
20
+ 'rounded w-full',
21
+ 'p-2',
22
+ 'text-gray-700',
23
+ 'leading-tight',
24
+ 'focus:outline-none',
25
+ 'focus:border-primary',
26
+ ].join(' ')
27
+
17
28
  @Input() value = ''
29
+ @Input() extraClass = ''
18
30
  @Input() hint: string
19
31
  @Input() required = false
20
32
  rawChange = new Subject<string>()
21
33
  @Output() valueChange = this.rawChange.pipe(distinctUntilChanged())
22
-
23
34
  @ViewChild('input') input
24
35
 
36
+ get classList() {
37
+ return `${this.baseClass} ${this.extraClass}`
38
+ }
39
+
25
40
  ngAfterViewInit() {
26
41
  this.checkRequired(this.input.nativeElement.value)
27
42
  }
@@ -36,7 +36,6 @@ import { ImageInputComponent } from './image-input/image-input.component'
36
36
 
37
37
  @NgModule({
38
38
  declarations: [
39
- DropdownSelectorComponent,
40
39
  AutocompleteComponent,
41
40
  TextInputComponent,
42
41
  DragAndDropFileInputComponent,
@@ -49,7 +48,6 @@ import { ImageInputComponent } from './image-input/image-input.component'
49
48
  CopyTextButtonComponent,
50
49
  CheckboxComponent,
51
50
  SearchInputComponent,
52
- DateRangePickerComponent,
53
51
  ],
54
52
  imports: [
55
53
  CommonModule,
@@ -73,6 +71,8 @@ import { ImageInputComponent } from './image-input/image-input.component'
73
71
  TextAreaComponent,
74
72
  ButtonComponent,
75
73
  ImageInputComponent,
74
+ DropdownSelectorComponent,
75
+ DateRangePickerComponent,
76
76
  ],
77
77
  exports: [
78
78
  DropdownSelectorComponent,
@@ -26,7 +26,7 @@ export class LinkClassifierService {
26
26
  case 'wmts':
27
27
  return [LinkUsage.API, LinkUsage.MAP_API]
28
28
  case 'ogcFeatures':
29
- return [LinkUsage.API]
29
+ return [LinkUsage.API, LinkUsage.DOWNLOAD, LinkUsage.GEODATA]
30
30
  default:
31
31
  return [LinkUsage.UNKNOWN]
32
32
  }
@@ -94,6 +94,27 @@ export const FORMATS = {
94
94
  color: '#de630b',
95
95
  mimeTypes: ['application/x-dxf', 'image/x-dxf'],
96
96
  },
97
+ html: {
98
+ extensions: ['html', 'htm'],
99
+ priority: 12,
100
+ color: '#f2bb3a',
101
+ mimeTypes: ['text/html'],
102
+ },
103
+ fgb: {
104
+ extensions: ['fgb', 'flatgeobuf'],
105
+ priority: 13,
106
+ color: '#f2bb3a',
107
+ mimeTypes: ['application/flatgeobuf'],
108
+ },
109
+ jsonfg: {
110
+ extensions: ['jsonfg', 'jsonfgc'],
111
+ priority: 14,
112
+ color: '#f2bb3a',
113
+ mimeTypes: [
114
+ 'application/vnd.ogc.fg+json',
115
+ 'application/vnd.ogc.fg+json;compatibility=geojson',
116
+ ],
117
+ },
97
118
  } as const
98
119
 
99
120
  export type FileFormat = keyof typeof FORMATS
@@ -1,4 +1,5 @@
1
1
  {
2
+ "button.login": "",
2
3
  "catalog.figures.datasets": "{count, plural, =0{Datensätze} one{Datensatz} other{Datensätze}}",
3
4
  "catalog.figures.organisations": "{count, plural, =0{Organisationen} one{Organisation} other{Organisationen}}",
4
5
  "chart.aggregation.average": "Durchschnitt",
@@ -144,6 +145,17 @@
144
145
  "downloads.format.unknown": "unbekannt",
145
146
  "downloads.wfs.featuretype.not.found": "Der Layer wurde nicht gefunden",
146
147
  "dropFile": "Datei ablegen",
148
+ "editor.record.form.license": "Lizenz",
149
+ "editor.record.form.license.cc-by": "",
150
+ "editor.record.form.license.cc-by-sa": "",
151
+ "editor.record.form.license.cc-zero": "",
152
+ "editor.record.form.license.etalab": "",
153
+ "editor.record.form.license.etalab-v2": "",
154
+ "editor.record.form.license.odbl": "",
155
+ "editor.record.form.license.odc-by": "",
156
+ "editor.record.form.license.pddl": "",
157
+ "editor.record.form.license.unknown": "Unbekannt oder nicht vorhanden",
158
+ "editor.record.form.resourceUpdated": "",
147
159
  "editor.record.loadError.body": "",
148
160
  "editor.record.loadError.closeMessage": "",
149
161
  "editor.record.loadError.title": "",
@@ -278,6 +290,14 @@
278
290
  "record.metadata.quality.updateFrequency.failed": "Aktualisierungsfrequenz nicht angegeben",
279
291
  "record.metadata.quality.updateFrequency.success": "Aktualisierungsfrequenz angegeben",
280
292
  "record.metadata.related": "Ähnliche Datensätze",
293
+ "record.metadata.userFeedbacks": "",
294
+ "record.metadata.userFeedbacks.anonymousUser": "",
295
+ "record.metadata.userFeedbacks.sortSelector.label": "",
296
+ "record.metadata.userFeedbacks.sortSelector.choices.newestFirst": "",
297
+ "record.metadata.userFeedbacks.sortSelector.choices.oldestFirst": "",
298
+ "record.metadata.userFeedbacks.newComment.placeholder": "",
299
+ "record.metadata.userFeedbacks.newAnswer.placeholder": "",
300
+ "record.metadata.userFeedbacks.newAnswer.buttonTitle": "",
281
301
  "record.metadata.sheet": "Weitere Informationen verfügbar unter:",
282
302
  "record.metadata.status": "Status",
283
303
  "record.metadata.technical": "Technische Informationen",
@@ -351,6 +371,12 @@
351
371
  "table.loading.data": "Daten werden geladen...",
352
372
  "table.object.count": "Objekte in diesem Datensatz",
353
373
  "table.select.data": "Datenquelle",
374
+ "timeSincePipe.lessThanAMinute": "",
375
+ "timeSincePipe.minutesAgo": "",
376
+ "timeSincePipe.hoursAgo": "",
377
+ "timeSincePipe.daysAgo": "",
378
+ "timeSincePipe.monthsAgo": "",
379
+ "timeSincePipe.yearsAgo": "",
354
380
  "tooltip.html.copy": "HTML kopieren",
355
381
  "tooltip.id.copy": "Eindeutige Kennung kopieren",
356
382
  "tooltip.url.copy": "URL kopieren",
@@ -1,4 +1,5 @@
1
1
  {
2
+ "button.login": "Log in",
2
3
  "catalog.figures.datasets": "{count, plural, =0{datasets} one{dataset} other{datasets}}",
3
4
  "catalog.figures.organisations": "{count, plural, =0{organisations} one{organisation} other{organisations}}",
4
5
  "chart.aggregation.average": "average",
@@ -144,6 +145,17 @@
144
145
  "downloads.format.unknown": "unknown",
145
146
  "downloads.wfs.featuretype.not.found": "The layer was not found",
146
147
  "dropFile": "drop file",
148
+ "editor.record.form.license": "License",
149
+ "editor.record.form.license.cc-by": "Creative Commons CC-BY",
150
+ "editor.record.form.license.cc-by-sa": "Creative Commons CC-BY-SA",
151
+ "editor.record.form.license.cc-zero": "Creative Commons CC-0",
152
+ "editor.record.form.license.etalab": "Open Licence (Etalab)",
153
+ "editor.record.form.license.etalab-v2": "Open Licence v2.0 (Etalab)",
154
+ "editor.record.form.license.odbl": "Open Data Commons ODbL",
155
+ "editor.record.form.license.odc-by": "Open Data Commons ODC-By",
156
+ "editor.record.form.license.pddl": "Open Data Commons PDDL",
157
+ "editor.record.form.license.unknown": "Unknown or absent",
158
+ "editor.record.form.resourceUpdated": "Last update date",
147
159
  "editor.record.loadError.body": "The record could not be loaded:",
148
160
  "editor.record.loadError.closeMessage": "Understood",
149
161
  "editor.record.loadError.title": "Error loading record",
@@ -278,6 +290,14 @@
278
290
  "record.metadata.quality.updateFrequency.failed": "Update frequency is not specified",
279
291
  "record.metadata.quality.updateFrequency.success": "Update frequency is specified",
280
292
  "record.metadata.related": "Related records",
293
+ "record.metadata.userFeedbacks": "Questions / Answers",
294
+ "record.metadata.userFeedbacks.anonymousUser": "In order to leave a comment, please log in.",
295
+ "record.metadata.userFeedbacks.sortSelector.label": "Sort by ...",
296
+ "record.metadata.userFeedbacks.sortSelector.choices.newestFirst": "Newest comments first",
297
+ "record.metadata.userFeedbacks.sortSelector.choices.oldestFirst": "Oldest comments first",
298
+ "record.metadata.userFeedbacks.newComment.placeholder": "Write your comment here...",
299
+ "record.metadata.userFeedbacks.newAnswer.placeholder": "Answer...",
300
+ "record.metadata.userFeedbacks.newAnswer.buttonTitle": "Publish",
281
301
  "record.metadata.sheet": "Original metadata",
282
302
  "record.metadata.status": "Status",
283
303
  "record.metadata.technical": "Technical information",
@@ -351,6 +371,12 @@
351
371
  "table.loading.data": "Loading data...",
352
372
  "table.object.count": "objects in this dataset",
353
373
  "table.select.data": "Data source",
374
+ "timeSincePipe.lessThanAMinute": "Less than a minute ago",
375
+ "timeSincePipe.minutesAgo": "{value} minute{s} ago",
376
+ "timeSincePipe.hoursAgo": "{value} hour{s} ago",
377
+ "timeSincePipe.daysAgo": "{value} day{s} ago",
378
+ "timeSincePipe.monthsAgo": "{value} month{s} ago",
379
+ "timeSincePipe.yearsAgo": "{value} year{s} ago",
354
380
  "tooltip.html.copy": "Copy HTML",
355
381
  "tooltip.id.copy": "Copy unique identifier",
356
382
  "tooltip.url.copy": "Copy URL",