geonetwork-ui 2.4.0-dev.cec60ff1 → 2.4.0-dev.db93b4c4

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 (110) hide show
  1. package/esm2022/libs/api/metadata-converter/src/lib/gn4/atomic-operations.mjs +2 -1
  2. package/esm2022/libs/api/metadata-converter/src/lib/gn4/types/metadata.model.mjs +1 -1
  3. package/esm2022/libs/feature/editor/src/lib/+state/editor.actions.mjs +2 -1
  4. package/esm2022/libs/feature/editor/src/lib/+state/editor.effects.mjs +3 -3
  5. package/esm2022/libs/feature/editor/src/lib/+state/editor.facade.mjs +7 -2
  6. package/esm2022/libs/feature/editor/src/lib/+state/editor.models.mjs +1 -1
  7. package/esm2022/libs/feature/editor/src/lib/+state/editor.reducer.mjs +7 -3
  8. package/esm2022/libs/feature/editor/src/lib/+state/editor.selectors.mjs +16 -6
  9. package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field.component.mjs +3 -3
  10. package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/index.mjs +1 -2
  11. package/esm2022/libs/feature/editor/src/lib/components/record-form/record-form.component.mjs +11 -7
  12. package/esm2022/libs/feature/editor/src/lib/expressions.mjs +1 -1
  13. package/esm2022/libs/feature/editor/src/lib/fields.config.mjs +143 -60
  14. package/esm2022/libs/feature/editor/src/lib/models/editor-config.model.mjs +2 -0
  15. package/esm2022/libs/feature/editor/src/lib/models/index.mjs +2 -1
  16. package/esm2022/libs/feature/editor/src/lib/services/editor.service.mjs +4 -3
  17. package/esm2022/libs/feature/record/src/lib/data-view-permalink/data-view-permalink.component.mjs +42 -23
  18. package/esm2022/libs/feature/record/src/lib/data-view-share/data-view-share.component.mjs +13 -5
  19. package/esm2022/libs/feature/record/src/lib/data-view-web-component/data-view-web-component.component.mjs +49 -15
  20. package/esm2022/libs/ui/elements/src/lib/api-card/api-card.component.mjs +3 -3
  21. package/esm2022/translations/de.json +62 -30
  22. package/esm2022/translations/en.json +34 -2
  23. package/esm2022/translations/es.json +32 -0
  24. package/esm2022/translations/fr.json +35 -3
  25. package/esm2022/translations/it.json +32 -0
  26. package/esm2022/translations/nl.json +32 -0
  27. package/esm2022/translations/pt.json +32 -0
  28. package/fesm2022/geonetwork-ui.mjs +542 -150
  29. package/fesm2022/geonetwork-ui.mjs.map +1 -1
  30. package/libs/api/metadata-converter/src/lib/gn4/atomic-operations.d.ts.map +1 -1
  31. package/libs/api/metadata-converter/src/lib/gn4/types/metadata.model.d.ts +1 -0
  32. package/libs/api/metadata-converter/src/lib/gn4/types/metadata.model.d.ts.map +1 -1
  33. package/libs/feature/editor/src/lib/+state/editor.actions.d.ts +5 -0
  34. package/libs/feature/editor/src/lib/+state/editor.actions.d.ts.map +1 -1
  35. package/libs/feature/editor/src/lib/+state/editor.facade.d.ts +4 -4
  36. package/libs/feature/editor/src/lib/+state/editor.facade.d.ts.map +1 -1
  37. package/libs/feature/editor/src/lib/+state/editor.models.d.ts +8 -0
  38. package/libs/feature/editor/src/lib/+state/editor.models.d.ts.map +1 -1
  39. package/libs/feature/editor/src/lib/+state/editor.reducer.d.ts +4 -3
  40. package/libs/feature/editor/src/lib/+state/editor.reducer.d.ts.map +1 -1
  41. package/libs/feature/editor/src/lib/+state/editor.selectors.d.ts +4 -8
  42. package/libs/feature/editor/src/lib/+state/editor.selectors.d.ts.map +1 -1
  43. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field.component.d.ts +1 -1
  44. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field.component.d.ts.map +1 -1
  45. package/libs/feature/editor/src/lib/components/record-form/form-field/index.d.ts +0 -1
  46. package/libs/feature/editor/src/lib/components/record-form/form-field/index.d.ts.map +1 -1
  47. package/libs/feature/editor/src/lib/components/record-form/record-form.component.d.ts +5 -7
  48. package/libs/feature/editor/src/lib/components/record-form/record-form.component.d.ts.map +1 -1
  49. package/libs/feature/editor/src/lib/expressions.d.ts +1 -1
  50. package/libs/feature/editor/src/lib/expressions.d.ts.map +1 -1
  51. package/libs/feature/editor/src/lib/fields.config.d.ts +38 -2
  52. package/libs/feature/editor/src/lib/fields.config.d.ts.map +1 -1
  53. package/libs/feature/editor/src/lib/models/editor-config.model.d.ts +36 -0
  54. package/libs/feature/editor/src/lib/models/editor-config.model.d.ts.map +1 -0
  55. package/libs/feature/editor/src/lib/models/index.d.ts +1 -0
  56. package/libs/feature/editor/src/lib/models/index.d.ts.map +1 -1
  57. package/libs/feature/editor/src/lib/services/editor.service.d.ts +2 -2
  58. package/libs/feature/editor/src/lib/services/editor.service.d.ts.map +1 -1
  59. package/libs/feature/record/src/lib/data-view-permalink/data-view-permalink.component.d.ts +4 -1
  60. package/libs/feature/record/src/lib/data-view-permalink/data-view-permalink.component.d.ts.map +1 -1
  61. package/libs/feature/record/src/lib/data-view-share/data-view-share.component.d.ts +4 -1
  62. package/libs/feature/record/src/lib/data-view-share/data-view-share.component.d.ts.map +1 -1
  63. package/libs/feature/record/src/lib/data-view-web-component/data-view-web-component.component.d.ts +4 -1
  64. package/libs/feature/record/src/lib/data-view-web-component/data-view-web-component.component.d.ts.map +1 -1
  65. package/package.json +1 -1
  66. package/src/libs/api/metadata-converter/src/lib/gn4/atomic-operations.ts +1 -0
  67. package/src/libs/api/metadata-converter/src/lib/gn4/types/metadata.model.ts +1 -0
  68. package/src/libs/common/fixtures/src/index.ts +2 -0
  69. package/src/libs/common/fixtures/src/lib/editor/editor.fixtures.ts +156 -0
  70. package/src/libs/common/fixtures/src/lib/editor/index.ts +1 -0
  71. package/src/libs/feature/editor/src/lib/+state/editor.actions.ts +5 -0
  72. package/src/libs/feature/editor/src/lib/+state/editor.effects.ts +2 -2
  73. package/src/libs/feature/editor/src/lib/+state/editor.facade.ts +9 -1
  74. package/src/libs/feature/editor/src/lib/+state/editor.models.ts +11 -0
  75. package/src/libs/feature/editor/src/lib/+state/editor.reducer.ts +11 -5
  76. package/src/libs/feature/editor/src/lib/+state/editor.selectors.ts +22 -8
  77. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field.component.html +9 -9
  78. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field.component.ts +2 -1
  79. package/src/libs/feature/editor/src/lib/components/record-form/form-field/index.ts +0 -1
  80. package/src/libs/feature/editor/src/lib/components/record-form/record-form.component.html +51 -11
  81. package/src/libs/feature/editor/src/lib/components/record-form/record-form.component.ts +15 -8
  82. package/src/libs/feature/editor/src/lib/expressions.ts +1 -1
  83. package/src/libs/feature/editor/src/lib/fields.config.ts +175 -61
  84. package/src/libs/feature/editor/src/lib/models/editor-config.model.ts +53 -0
  85. package/src/libs/feature/editor/src/lib/models/index.ts +1 -0
  86. package/src/libs/feature/editor/src/lib/services/editor.service.ts +8 -4
  87. package/src/libs/feature/record/src/lib/data-view-permalink/data-view-permalink.component.ts +36 -19
  88. package/src/libs/feature/record/src/lib/data-view-share/data-view-share.component.html +6 -2
  89. package/src/libs/feature/record/src/lib/data-view-share/data-view-share.component.ts +11 -0
  90. package/src/libs/feature/record/src/lib/data-view-web-component/data-view-web-component.component.ts +59 -12
  91. package/src/libs/ui/elements/src/lib/api-card/api-card.component.html +29 -29
  92. package/src/libs/ui/inputs/src/lib/switch-toggle/switch-toggle.component.css +31 -0
  93. package/src/libs/ui/inputs/src/lib/switch-toggle/switch-toggle.component.html +15 -0
  94. package/src/libs/ui/inputs/src/lib/switch-toggle/switch-toggle.component.ts +38 -0
  95. package/translations/de.json +62 -30
  96. package/translations/en.json +34 -2
  97. package/translations/es.json +32 -0
  98. package/translations/fr.json +35 -3
  99. package/translations/it.json +32 -0
  100. package/translations/nl.json +32 -0
  101. package/translations/pt.json +32 -0
  102. package/translations/sk.json +32 -0
  103. package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field.model.mjs +0 -2
  104. package/esm2022/libs/feature/editor/src/lib/models/fields.model.mjs +0 -2
  105. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field.model.d.ts +0 -26
  106. package/libs/feature/editor/src/lib/components/record-form/form-field/form-field.model.d.ts.map +0 -1
  107. package/libs/feature/editor/src/lib/models/fields.model.d.ts +0 -15
  108. package/libs/feature/editor/src/lib/models/fields.model.d.ts.map +0 -1
  109. package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field.model.ts +0 -43
  110. package/src/libs/feature/editor/src/lib/models/fields.model.ts +0 -29
@@ -0,0 +1,156 @@
1
+ export const EDITOR_CONFIG = () => ({
2
+ pages: [
3
+ {
4
+ labelKey: 'Resource description',
5
+ sections: [EDITOR_SECTION_ABOUT()],
6
+ },
7
+ {
8
+ labelKey: 'Resources',
9
+ sections: [EDITOR_SECTION_CLASSIFICATION()],
10
+ },
11
+ {
12
+ labelKey: 'Access and contact',
13
+ sections: [
14
+ EDITOR_SECTION_USE_AND_ACCESS_CONDITIONS(),
15
+ EDITOR_SECTION_DATA_MANAGER(),
16
+ ],
17
+ },
18
+ ],
19
+ })
20
+
21
+ export const EDITOR_SECTION_ABOUT = () => ({
22
+ labelKey: 'About the resource',
23
+ descriptionKey: 'This section describes the resource.',
24
+ hidden: false,
25
+ fields: [
26
+ EDITOR_FIELD_TITLE(),
27
+ EDITOR_FIELD_ABSTRACT(),
28
+ EDITOR_FIELD_RESOURCE_UPDATED(),
29
+ EDITOR_FIELD_RECORD_UPDATED(),
30
+ EDITOR_FIELD_UPDATE_FREQUENCY(),
31
+ EDITOR_FIELD_TEMPORAL_EXTENTS(),
32
+ ],
33
+ })
34
+
35
+ export const EDITOR_SECTION_DATA_MANAGER = () => ({
36
+ labelKey: 'Data manager',
37
+ descriptionKey: '',
38
+ hidden: false,
39
+ fields: [],
40
+ })
41
+
42
+ export const EDITOR_SECTION_USE_AND_ACCESS_CONDITIONS = () => ({
43
+ labelKey: 'Data manager',
44
+ descriptionKey: '',
45
+ hidden: false,
46
+ fields: [EDITOR_FIELD_LICENSE()],
47
+ })
48
+
49
+ export const EDITOR_SECTION_CLASSIFICATION = () => ({
50
+ labelKey: 'Classification',
51
+ descriptionKey: 'The classification has an impact on the access to the data.',
52
+ hidden: false,
53
+ fields: [EDITOR_FIELD_KEYWORDS(), EDITOR_FIELD_UNIQUE_IDENTIFIER()],
54
+ })
55
+
56
+ export const EDITOR_FIELD_TITLE = () => ({
57
+ model: 'title',
58
+ hidden: false,
59
+ value: 'Accroches vélos MEL',
60
+ formFieldConfig: {
61
+ labelKey: 'editor.record.form.field.title',
62
+ },
63
+ })
64
+
65
+ export const EDITOR_FIELD_ABSTRACT = () => ({
66
+ model: 'abstract',
67
+ hidden: false,
68
+ value: 'Abstract',
69
+ formFieldConfig: {
70
+ labelKey: 'editor.record.form.field.abstract',
71
+ },
72
+ })
73
+
74
+ export const EDITOR_FIELD_RESOURCE_UPDATED = () => ({
75
+ model: 'resourceUpdated',
76
+ hidden: false,
77
+ formFieldConfig: {
78
+ labelKey: 'editor.record.form.field.resourceUpdated',
79
+ },
80
+ })
81
+
82
+ export const EDITOR_FIELD_RECORD_UPDATED = () => ({
83
+ model: 'recordUpdated',
84
+ hidden: false,
85
+ formFieldConfig: {
86
+ labelKey: 'editor.record.form.field.recordUpdated',
87
+ locked: true,
88
+ },
89
+ value: '2024-07-16T05:18:53.000Z',
90
+ onSaveProcess: '${dateNow()}',
91
+ })
92
+
93
+ export const EDITOR_FIELD_UPDATE_FREQUENCY = () => ({
94
+ model: 'updateFrequency',
95
+ hidden: false,
96
+ formFieldConfig: {
97
+ labelKey: 'editor.record.form.field.updateFrequency',
98
+ },
99
+ value: 'unknown',
100
+ })
101
+
102
+ export const EDITOR_FIELD_TEMPORAL_EXTENTS = () => ({
103
+ model: 'temporalExtents',
104
+ hidden: false,
105
+ formFieldConfig: {
106
+ labelKey: 'editor.record.form.field.temporalExtents',
107
+ },
108
+ value: [],
109
+ })
110
+
111
+ export const EDITOR_FIELD_SPATIAL_EXTENTS = () => ({
112
+ model: 'spatialExtents',
113
+ hidden: false,
114
+ formFieldConfig: {
115
+ labelKey: 'editor.record.form.field.spatialExtents',
116
+ },
117
+ })
118
+
119
+ export const EDITOR_FIELD_KEYWORDS = () => ({
120
+ model: 'keywords',
121
+ hidden: false,
122
+ formFieldConfig: {
123
+ labelKey: 'editor.record.form.field.keywords',
124
+ },
125
+ })
126
+
127
+ export const EDITOR_FIELD_UNIQUE_IDENTIFIER = () => ({
128
+ model: 'uniqueIdentifier',
129
+ hidden: false,
130
+ formFieldConfig: {
131
+ labelKey: 'editor.record.form.field.uniqueIdentifier',
132
+ locked: true,
133
+ },
134
+ value: 'accroche_velos',
135
+ })
136
+
137
+ export const EDITOR_FIELD_LICENSE = () => ({
138
+ model: 'licenses',
139
+ hidden: false,
140
+ formFieldConfig: {
141
+ labelKey: 'editor.record.form.field.license',
142
+ locked: true,
143
+ },
144
+ })
145
+
146
+ export const EDITOR_FIELDS = () => [
147
+ EDITOR_FIELD_TITLE(),
148
+ EDITOR_FIELD_ABSTRACT(),
149
+ EDITOR_FIELD_RESOURCE_UPDATED(),
150
+ EDITOR_FIELD_RECORD_UPDATED(),
151
+ EDITOR_FIELD_UPDATE_FREQUENCY(),
152
+ EDITOR_FIELD_TEMPORAL_EXTENTS(),
153
+ EDITOR_FIELD_SPATIAL_EXTENTS(),
154
+ EDITOR_FIELD_KEYWORDS(),
155
+ EDITOR_FIELD_UNIQUE_IDENTIFIER(),
156
+ ]
@@ -0,0 +1 @@
1
+ export * from './editor.fixtures'
@@ -28,3 +28,8 @@ export const saveRecordFailure = createAction(
28
28
  )
29
29
 
30
30
  export const draftSaveSuccess = createAction('[Editor] Draft save success')
31
+
32
+ export const setCurrentPage = createAction(
33
+ '[Editor] Set current page',
34
+ props<{ page: number }>()
35
+ )
@@ -6,9 +6,9 @@ import * as EditorActions from './editor.actions'
6
6
  import { EditorService } from '../services/editor.service'
7
7
  import { Store } from '@ngrx/store'
8
8
  import {
9
+ selectEditorConfig,
9
10
  selectRecord,
10
11
  selectRecordAlreadySavedOnce,
11
- selectRecordFieldsConfig,
12
12
  } from './editor.selectors'
13
13
  import { RecordsRepositoryInterface } from '../../../../../../libs/common/domain/src/lib/repository/records-repository.interface'
14
14
 
@@ -24,7 +24,7 @@ export class EditorEffects {
24
24
  ofType(EditorActions.saveRecord),
25
25
  withLatestFrom(
26
26
  this.store.select(selectRecord),
27
- this.store.select(selectRecordFieldsConfig),
27
+ this.store.select(selectEditorConfig),
28
28
  this.store.select(selectRecordAlreadySavedOnce)
29
29
  ),
30
30
  switchMap(([, record, fieldsConfig, alreadySavedOnce]) =>
@@ -25,8 +25,12 @@ export class EditorFacade {
25
25
  changedSinceSave$ = this.store.pipe(
26
26
  select(EditorSelectors.selectRecordChangedSinceSave)
27
27
  )
28
- recordFields$ = this.store.pipe(select(EditorSelectors.selectRecordFields))
28
+ currentSections$ = this.store.pipe(
29
+ select(EditorSelectors.selectRecordSections)
30
+ )
29
31
  draftSaveSuccess$ = this.actions$.pipe(ofType(EditorActions.draftSaveSuccess))
32
+ currentPage$ = this.store.pipe(select(EditorSelectors.selectCurrentPage))
33
+ editorConfig$ = this.store.pipe(select(EditorSelectors.selectEditorConfig))
30
34
 
31
35
  openRecord(
32
36
  record: CatalogRecord,
@@ -45,4 +49,8 @@ export class EditorFacade {
45
49
  updateRecordField(field: string, value: unknown) {
46
50
  this.store.dispatch(EditorActions.updateRecordField({ field, value }))
47
51
  }
52
+
53
+ setCurrentPage(page: number) {
54
+ this.store.dispatch(EditorActions.setCurrentPage({ page }))
55
+ }
48
56
  }
@@ -1 +1,12 @@
1
+ import { EditorField, EditorFieldValue, EditorSection } from '../models'
2
+
1
3
  export type SaveRecordError = string
4
+
5
+ export interface EditorFieldWithValue {
6
+ config: EditorField
7
+ value: EditorFieldValue
8
+ }
9
+
10
+ export type EditorSectionWithValues = EditorSection & {
11
+ fieldsWithValues: EditorFieldWithValue[]
12
+ }
@@ -2,8 +2,8 @@ import { Action, createReducer, on } from '@ngrx/store'
2
2
  import * as EditorActions from './editor.actions'
3
3
  import { CatalogRecord } from '../../../../../../libs/common/domain/src/lib/model/record'
4
4
  import { SaveRecordError } from './editor.models'
5
- import { EditorFieldsConfig } from '../models/fields.model'
6
- import { DEFAULT_FIELDS } from '../fields.config'
5
+ import { EditorConfig } from '../models'
6
+ import { DEFAULT_CONFIGURATION } from '../fields.config'
7
7
 
8
8
  export const EDITOR_FEATURE_KEY = 'editor'
9
9
 
@@ -13,7 +13,7 @@ export const EDITOR_FEATURE_KEY = 'editor'
13
13
  * @property saving
14
14
  * @property saveError
15
15
  * @property changedSinceSave
16
- * @property fieldsConfig Configuration for the fields in the editor
16
+ * @property editorConfig Configuration for the fields in the editor
17
17
  */
18
18
  export interface EditorState {
19
19
  record: CatalogRecord | null
@@ -22,7 +22,8 @@ export interface EditorState {
22
22
  saving: boolean
23
23
  saveError: SaveRecordError | null
24
24
  changedSinceSave: boolean
25
- fieldsConfig: EditorFieldsConfig
25
+ editorConfig: EditorConfig
26
+ currentPage: number
26
27
  }
27
28
 
28
29
  export interface EditorPartialState {
@@ -36,7 +37,8 @@ export const initialEditorState: EditorState = {
36
37
  saving: false,
37
38
  saveError: null,
38
39
  changedSinceSave: false,
39
- fieldsConfig: DEFAULT_FIELDS,
40
+ editorConfig: DEFAULT_CONFIGURATION,
41
+ currentPage: 0,
40
42
  }
41
43
 
42
44
  const reducer = createReducer(
@@ -77,6 +79,10 @@ const reducer = createReducer(
77
79
  on(EditorActions.markRecordAsChanged, (state) => ({
78
80
  ...state,
79
81
  changedSinceSave: true,
82
+ })),
83
+ on(EditorActions.setCurrentPage, (state, { page }) => ({
84
+ ...state,
85
+ currentPage: page,
80
86
  }))
81
87
  )
82
88
 
@@ -1,5 +1,6 @@
1
1
  import { createFeatureSelector, createSelector } from '@ngrx/store'
2
2
  import { EDITOR_FEATURE_KEY, EditorState } from './editor.reducer'
3
+ import { EditorSectionWithValues } from './editor.models'
3
4
 
4
5
  export const selectEditorState =
5
6
  createFeatureSelector<EditorState>(EDITOR_FEATURE_KEY)
@@ -34,16 +35,29 @@ export const selectRecordAlreadySavedOnce = createSelector(
34
35
  (state: EditorState) => state.alreadySavedOnce
35
36
  )
36
37
 
37
- export const selectRecordFieldsConfig = createSelector(
38
+ export const selectEditorConfig = createSelector(
38
39
  selectEditorState,
39
- (state: EditorState) => state.fieldsConfig
40
+ (state: EditorState) => state.editorConfig
40
41
  )
41
42
 
42
- export const selectRecordFields = createSelector(
43
+ export const selectCurrentPage = createSelector(
43
44
  selectEditorState,
44
- (state: EditorState) =>
45
- state.fieldsConfig.map((fieldConfig) => ({
46
- config: fieldConfig,
47
- value: state.record?.[fieldConfig.model] ?? null,
48
- }))
45
+ (state: EditorState) => state.currentPage
46
+ )
47
+
48
+ export const selectRecordSections = createSelector(
49
+ selectEditorState,
50
+ (state: EditorState) => {
51
+ const currentPage = state.editorConfig.pages[state.currentPage]
52
+ if (!currentPage) {
53
+ return [] as EditorSectionWithValues[]
54
+ }
55
+ return currentPage.sections.map((section) => ({
56
+ ...section,
57
+ fieldsWithValues: section.fields.map((fieldConfig) => ({
58
+ config: fieldConfig,
59
+ value: state.record?.[fieldConfig.model] ?? null,
60
+ })),
61
+ })) as EditorSectionWithValues[]
62
+ }
49
63
  )
@@ -4,8 +4,8 @@
4
4
  </ng-container>
5
5
  <ng-template #withGenericWrapper>
6
6
  <gn-ui-form-field-wrapper
7
- [label]="config.labelKey | translate"
8
- [hint]="config.hintKey | translate"
7
+ [label]="config.labelKey! | translate"
8
+ [hint]="config.hintKey! | translate"
9
9
  >
10
10
  <ng-container *ngTemplateOutlet="fieldContent"></ng-container>
11
11
  </gn-ui-form-field-wrapper>
@@ -15,14 +15,14 @@
15
15
  <ng-template #fieldContent>
16
16
  <ng-container *ngIf="isTitle">
17
17
  <div class="flex justify-between items-center gap-3">
18
- <h2
18
+ <span
19
19
  #titleInput
20
- class="grow text-3xl font-normal"
20
+ class="grow font-title text-3xl font-normal"
21
21
  [gnUiEditableLabel]="true"
22
22
  (editableLabelChanged)="formControl.setValue($event)"
23
23
  >
24
24
  {{ formControl.value }}
25
- </h2>
25
+ </span>
26
26
  <span
27
27
  class="material-symbols-outlined gn-ui-icon-small m-2 cursor-pointer"
28
28
  (click)="focusTitleInput()"
@@ -30,7 +30,7 @@
30
30
  >
31
31
  <span
32
32
  class="material-symbols-outlined gn-ui-icon-small m-2"
33
- [matTooltip]="config.hintKey | translate"
33
+ [matTooltip]="config.hintKey! | translate"
34
34
  matTooltipPosition="above"
35
35
  >
36
36
  help
@@ -41,14 +41,14 @@
41
41
  <gn-ui-form-field-rich
42
42
  class="h-[8rem]"
43
43
  [control]="formControl"
44
- [label]="config.labelKey | translate"
45
- [hint]="config.hintKey | translate"
44
+ [label]="config.labelKey! | translate"
45
+ [hint]="config.hintKey! | translate"
46
46
  ></gn-ui-form-field-rich>
47
47
  </ng-container>
48
48
  <ng-container *ngIf="isLicenses">
49
49
  <gn-ui-form-field-license
50
50
  [control]="formControl"
51
- [label]="config.labelKey | translate"
51
+ [label]="config.labelKey! | translate"
52
52
  ></gn-ui-form-field-license>
53
53
  </ng-container>
54
54
  <ng-container *ngIf="isResourceUpdated">
@@ -25,10 +25,10 @@ import { FormFieldObjectComponent } from './form-field-object/form-field-object.
25
25
  import { FormFieldRichComponent } from './form-field-rich/form-field-rich.component'
26
26
  import { FormFieldSimpleComponent } from './form-field-simple/form-field-simple.component'
27
27
  import { FormFieldSpatialExtentComponent } from './form-field-spatial-extent/form-field-spatial-extent.component'
28
- import { FormFieldConfig } from './form-field.model'
29
28
  import { FormFieldUpdateFrequencyComponent } from './form-field-update-frequency/form-field-update-frequency.component'
30
29
  import { CatalogRecordKeys } from '../../../../../../../../libs/common/domain/src/lib/model/record'
31
30
  import { FormFieldKeywordsComponent } from './form-field-keywords/form-field-keywords.component'
31
+ import { FormFieldConfig } from '../../../models'
32
32
 
33
33
  @Component({
34
34
  selector: 'gn-ui-form-field',
@@ -65,6 +65,7 @@ export class FormFieldComponent {
65
65
  emitEvent: false,
66
66
  })
67
67
  }
68
+
68
69
  @Output() valueChange: Observable<unknown>
69
70
 
70
71
  @ViewChild('titleInput') titleInput: ElementRef
@@ -9,4 +9,3 @@ export * from './form-field-object/form-field-object.component'
9
9
  export * from './form-field-array/form-field-array.component'
10
10
  export * from './form-field-spatial-extent/form-field-spatial-extent.component'
11
11
  export * from './form-field.component'
12
- export * from './form-field.model'
@@ -1,11 +1,51 @@
1
- <div class="flex flex-col gap-6 p-6">
2
- <ng-container *ngFor="let field of fields$ | async; trackBy: fieldTracker">
3
- <gn-ui-form-field
4
- *ngIf="field.config.formFieldConfig && !field.config.hidden"
5
- [model]="field.config.model"
6
- [config]="field.config.formFieldConfig"
7
- [value]="field.value"
8
- (valueChange)="handleFieldValueChange(field, $event)"
9
- ></gn-ui-form-field>
10
- </ng-container>
11
- </div>
1
+ <ng-container>
2
+ <div class="flex flex-col gap-6 p-8">
3
+ <ng-container
4
+ *ngFor="
5
+ let section of facade.currentSections$ | async;
6
+ trackBy: sectionTracker
7
+ "
8
+ >
9
+ <ng-container *ngIf="!section.hidden">
10
+ <div class="flex flex-col gap-8 border p-8 rounded-[8px] shadow">
11
+ <div
12
+ class="flex flex-col gap-2"
13
+ [ngClass]="section.labelKey ? 'mb-4' : 'hidden'"
14
+ >
15
+ <div
16
+ *ngIf="section.labelKey"
17
+ class="text-2xl font-petrona text-secondary"
18
+ translate
19
+ >
20
+ {{ section.labelKey }}
21
+ </div>
22
+ <div
23
+ *ngIf="section.descriptionKey"
24
+ class="text-secondary-lightest"
25
+ translate
26
+ >
27
+ {{ section.descriptionKey }}
28
+ </div>
29
+ </div>
30
+ <ng-container
31
+ *ngFor="
32
+ let field of section.fieldsWithValues;
33
+ trackBy: fieldTracker
34
+ "
35
+ >
36
+ <ng-container *ngIf="!field.config.hidden">
37
+ <gn-ui-form-field
38
+ [model]="field.config.model!"
39
+ [config]="field.config.formFieldConfig"
40
+ [value]="field.value"
41
+ (valueChange)="
42
+ handleFieldValueChange(field.config.model!, $event)
43
+ "
44
+ ></gn-ui-form-field>
45
+ </ng-container>
46
+ </ng-container>
47
+ </div>
48
+ </ng-container>
49
+ </ng-container>
50
+ </div>
51
+ </ng-container>
@@ -1,8 +1,13 @@
1
1
  import { CommonModule } from '@angular/common'
2
2
  import { ChangeDetectionStrategy, Component } from '@angular/core'
3
3
  import { EditorFacade } from '../../+state/editor.facade'
4
- import { EditorFieldState, EditorFieldValue } from '../../models/fields.model'
4
+ import { EditorFieldValue } from '../../models'
5
5
  import { FormFieldComponent } from './form-field'
6
+ import { TranslateModule } from '@ngx-translate/core'
7
+ import {
8
+ EditorFieldWithValue,
9
+ EditorSectionWithValues,
10
+ } from '../../+state/editor.models'
6
11
 
7
12
  @Component({
8
13
  selector: 'gn-ui-record-form',
@@ -10,21 +15,23 @@ import { FormFieldComponent } from './form-field'
10
15
  styleUrls: ['./record-form.component.css'],
11
16
  changeDetection: ChangeDetectionStrategy.OnPush,
12
17
  standalone: true,
13
- imports: [CommonModule, FormFieldComponent],
18
+ imports: [CommonModule, FormFieldComponent, TranslateModule],
14
19
  })
15
20
  export class RecordFormComponent {
16
- fields$ = this.facade.recordFields$
17
-
18
21
  constructor(public facade: EditorFacade) {}
19
22
 
20
- handleFieldValueChange(field: EditorFieldState, newValue: EditorFieldValue) {
21
- if (!field.config.model) {
23
+ handleFieldValueChange(model: string, newValue: EditorFieldValue) {
24
+ if (!model) {
22
25
  return
23
26
  }
24
- this.facade.updateRecordField(field.config.model, newValue)
27
+ this.facade.updateRecordField(model, newValue)
25
28
  }
26
29
 
27
- fieldTracker(index: number, field: EditorFieldState) {
30
+ fieldTracker(index: number, field: EditorFieldWithValue): any {
28
31
  return field.config.model
29
32
  }
33
+
34
+ sectionTracker(index: number, section: EditorSectionWithValues): any {
35
+ return section.labelKey
36
+ }
30
37
  }
@@ -1,4 +1,4 @@
1
- import { EditorFieldState, EditorFieldValue } from './models/fields.model'
1
+ import { EditorFieldState, EditorFieldValue } from './models/'
2
2
 
3
3
  export type ExpressionEvaluator = (field: EditorFieldState) => EditorFieldValue
4
4