@provoly/dashboard 1.3.7 → 1.3.9

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 (201) hide show
  1. package/admin/components/admin-classes/admin-classes-view/admin-attributes-form/admin-attributes-form.component.d.ts +5 -2
  2. package/admin/components/admin-fields/admin-fields-form/admin-fields-form.component.d.ts +47 -18
  3. package/admin/components/admin-fields/admin-fields-select/admin-fields-select.component.d.ts +6 -2
  4. package/admin/components/admin-fields/admin-fields.component.d.ts +4 -1
  5. package/admin/components/admin-fields/store/admin-fields.model.d.ts +1 -1
  6. package/admin/components/admin-fields/store/fields.actions.d.ts +19 -12
  7. package/admin/components/admin-fields/store/fields.effects.d.ts +16 -3
  8. package/admin/i18n/en.translations.d.ts +33 -14
  9. package/admin/i18n/fr.translations.d.ts +33 -14
  10. package/components/checkbox/checkbox.component.d.ts +4 -2
  11. package/components/data-format/data-format.pipe.d.ts +11 -1
  12. package/components/paginator/index.d.ts +5 -0
  13. package/components/paginator/paginator.component.d.ts +19 -0
  14. package/components/paginator/paginator.module.d.ts +10 -0
  15. package/components/paginator/public-api.d.ts +3 -0
  16. package/components/paginator/style/_o-pry-paginator.scss +11 -0
  17. package/components/paginator/style/css.component.d.ts +5 -0
  18. package/dataset/components/dataset-detail/dataset-detail.component.d.ts +5 -8
  19. package/dataset/dataset.module.d.ts +1 -1
  20. package/dataset/i18n/en.translations.d.ts +0 -12
  21. package/dataset/i18n/fr.translations.d.ts +0 -12
  22. package/esm2022/admin/components/admin-abac-rules/components/attribute-condition/attribute-condition.component.mjs +4 -6
  23. package/esm2022/admin/components/admin-classes/admin-classes-customize/symbol/admin-classes-customize-symbol.component.mjs +1 -1
  24. package/esm2022/admin/components/admin-classes/admin-classes-customize/tooltip/admin-classes-customize-tooltip.component.mjs +1 -1
  25. package/esm2022/admin/components/admin-classes/admin-classes-view/admin-attributes-form/admin-attributes-form.component.mjs +10 -12
  26. package/esm2022/admin/components/admin-classes/admin-classes-view/admin-classes-view.component.mjs +6 -5
  27. package/esm2022/admin/components/admin-dataset/admin-select-dataset/admin-select-dataset.component.mjs +2 -2
  28. package/esm2022/admin/components/admin-fields/admin-fields-form/admin-fields-form.component.mjs +142 -63
  29. package/esm2022/admin/components/admin-fields/admin-fields-select/admin-fields-select.component.mjs +7 -8
  30. package/esm2022/admin/components/admin-fields/admin-fields.component.mjs +15 -11
  31. package/esm2022/admin/components/admin-fields/store/admin-fields.model.mjs +1 -1
  32. package/esm2022/admin/components/admin-fields/store/fields.actions.mjs +6 -5
  33. package/esm2022/admin/components/admin-fields/store/fields.effects.mjs +12 -6
  34. package/esm2022/admin/i18n/en.translations.mjs +34 -15
  35. package/esm2022/admin/i18n/fr.translations.mjs +34 -15
  36. package/esm2022/components/checkbox/checkbox.component.mjs +15 -7
  37. package/esm2022/components/data-format/data-format.pipe.mjs +88 -7
  38. package/esm2022/components/paginator/paginator.component.mjs +51 -0
  39. package/esm2022/components/paginator/paginator.module.mjs +20 -0
  40. package/esm2022/components/paginator/provoly-dashboard-components-paginator.mjs +5 -0
  41. package/esm2022/components/paginator/public-api.mjs +4 -0
  42. package/esm2022/components/paginator/style/css.component.mjs +11 -0
  43. package/esm2022/dataset/components/dataset-detail/dataset-detail.component.mjs +16 -26
  44. package/esm2022/dataset/dataset.module.mjs +2 -5
  45. package/esm2022/dataset/i18n/en.translations.mjs +1 -13
  46. package/esm2022/dataset/i18n/fr.translations.mjs +2 -14
  47. package/esm2022/import/components/form/import-form.component.mjs +174 -0
  48. package/esm2022/import/components/list/import-list.component.mjs +73 -0
  49. package/esm2022/import/components/version-modal/version-modal.component.mjs +26 -0
  50. package/esm2022/import/i18n/en.translations.mjs +16 -2
  51. package/esm2022/import/i18n/fr.translations.mjs +16 -2
  52. package/esm2022/import/import-routing.module.mjs +3 -3
  53. package/esm2022/import/import.module.mjs +25 -10
  54. package/esm2022/import/public-api.mjs +4 -2
  55. package/esm2022/import/style/css.component.mjs +2 -2
  56. package/esm2022/lib/core/components/select/select.component.mjs +3 -3
  57. package/esm2022/lib/core/components/share/legacy-share/share.component.mjs +8 -8
  58. package/esm2022/lib/core/components/status-modal/status-modal.component.mjs +48 -0
  59. package/esm2022/lib/core/components/{modal-status/modal-status.module.mjs → status-modal/status-modal.module.mjs} +9 -9
  60. package/esm2022/lib/core/core.module.mjs +5 -5
  61. package/esm2022/lib/core/i18n/en.translations.mjs +39 -6
  62. package/esm2022/lib/core/i18n/fr.translations.mjs +41 -6
  63. package/esm2022/lib/core/model/admin-api.model.mjs +5 -69
  64. package/esm2022/lib/core/model/widget-analytic-manifest.interface.mjs +1 -1
  65. package/esm2022/lib/core/model/widget-table-manifest.interface.mjs +1 -1
  66. package/esm2022/lib/core/public-api.mjs +3 -3
  67. package/esm2022/lib/core/store/class/class.interface.mjs +1 -1
  68. package/esm2022/lib/core/store/class/class.selectors.mjs +2 -2
  69. package/esm2022/lib/core/store/data-source/data-source.actions.mjs +3 -3
  70. package/esm2022/lib/core/store/data-source/data-source.effects.mjs +7 -4
  71. package/esm2022/lib/core/store/data-source/data-source.model.mjs +1 -1
  72. package/esm2022/lib/core/store/data-source/data-source.reducer.mjs +5 -3
  73. package/esm2022/lib/core/store/data-source/data-source.selectors.mjs +3 -11
  74. package/esm2022/lib/core/store/data-source/data-source.service.mjs +23 -5
  75. package/esm2022/lib/core/store/field/field.interface.mjs +1 -3
  76. package/esm2022/lib/core/store/field/field.service.mjs +7 -2
  77. package/esm2022/lib/dashboard/components/context-menu/object-edition/object-edition.component.mjs +3 -3
  78. package/esm2022/lib/dashboard/components/widgets/datasource-selector/datasource-card/datasource-card.component.mjs +3 -11
  79. package/esm2022/lib/dashboard/components/widgets/datasource-selector/datasource-list/datasource-list.component.mjs +2 -2
  80. package/esm2022/lib/dashboard/item-utils.mjs +5 -5
  81. package/esm2022/lib/dashboard/store/dashboard.actions.mjs +1 -4
  82. package/esm2022/lib/dashboard/store/dashboard.effects.mjs +1 -19
  83. package/esm2022/lib/dashboard/store/dashboard.reducers.mjs +1 -26
  84. package/esm2022/lib/dashboard/tooltip/components/default/default.tooltip.component.mjs +3 -3
  85. package/esm2022/lib/dashboard/tooltip/tooltip-factory.service.mjs +3 -2
  86. package/esm2022/search/search-mono-class/components/search-condition/search-condition.component.mjs +4 -4
  87. package/esm2022/search/search-mono-class/components/search-order/search-order.component.mjs +3 -3
  88. package/esm2022/search/search-mono-class/components/search-select-attribute/search-select-attribute.component.mjs +4 -5
  89. package/esm2022/search/search-mono-class/store/search-mono-class.effects.mjs +2 -2
  90. package/esm2022/search/search-mono-class/store/search-mono-class.service.mjs +5 -6
  91. package/esm2022/search/search-multi-class/store/search-multi-class.service.mjs +4 -4
  92. package/esm2022/toolbox/components/filter-settings/filter-settings.component.mjs +3 -3
  93. package/esm2022/toolbox/components/save-view/save-view.component.mjs +3 -3
  94. package/esm2022/tooltips/attribute/attribute-tooltip.component.mjs +17 -19
  95. package/esm2022/tooltips/attribute/attribute-tooltip.module.mjs +5 -4
  96. package/esm2022/widgets/widget-aggregated-chart/component/widget-aggregated-chart.component.mjs +54 -37
  97. package/esm2022/widgets/widget-analytic/component/widget-analytic.component.mjs +4 -16
  98. package/esm2022/widgets/widget-chart/component/widget-chart.component.mjs +9 -9
  99. package/esm2022/widgets/widget-detail/component/widget-detail.component.mjs +5 -5
  100. package/esm2022/widgets/widget-map/component/widget-map.component.mjs +30 -32
  101. package/esm2022/widgets/widget-map/pipe/widget-map-geometry-fields-for.pipe.mjs +2 -5
  102. package/esm2022/widgets/widget-map/utils/cql-utils.class.mjs +2 -2
  103. package/esm2022/widgets/widget-map/utils/widget-map.utils.mjs +6 -10
  104. package/esm2022/widgets/widget-table/component/widget-table.component.mjs +18 -14
  105. package/esm2022/widgets/widget-table/expand-value/expand-value.component.mjs +9 -5
  106. package/esm2022/widgets/widget-table/get-value/get-value.pipe.mjs +2 -2
  107. package/esm2022/widgets/widget-table/public-api.mjs +1 -2
  108. package/esm2022/widgets/widget-table/widget-table.module.mjs +12 -7
  109. package/esm2022/widgets/widget-tile/component/widget-tile.component.mjs +10 -15
  110. package/esm2022/widgets/widget-tile/widget-tile.module.mjs +8 -4
  111. package/esm2022/widgets/widget-vega/component/widget-vega.component.mjs +2 -2
  112. package/fesm2022/provoly-dashboard-admin.mjs +249 -126
  113. package/fesm2022/provoly-dashboard-admin.mjs.map +1 -1
  114. package/fesm2022/provoly-dashboard-components-checkbox.mjs +14 -6
  115. package/fesm2022/provoly-dashboard-components-checkbox.mjs.map +1 -1
  116. package/fesm2022/provoly-dashboard-components-data-format.mjs +88 -7
  117. package/fesm2022/provoly-dashboard-components-data-format.mjs.map +1 -1
  118. package/fesm2022/provoly-dashboard-components-paginator.mjs +82 -0
  119. package/fesm2022/provoly-dashboard-components-paginator.mjs.map +1 -0
  120. package/fesm2022/provoly-dashboard-dataset.mjs +21 -58
  121. package/fesm2022/provoly-dashboard-dataset.mjs.map +1 -1
  122. package/fesm2022/provoly-dashboard-import.mjs +249 -116
  123. package/fesm2022/provoly-dashboard-import.mjs.map +1 -1
  124. package/fesm2022/provoly-dashboard-search.mjs +15 -16
  125. package/fesm2022/provoly-dashboard-search.mjs.map +1 -1
  126. package/fesm2022/provoly-dashboard-toolbox.mjs +4 -4
  127. package/fesm2022/provoly-dashboard-toolbox.mjs.map +1 -1
  128. package/fesm2022/provoly-dashboard-tooltips-attribute.mjs +20 -21
  129. package/fesm2022/provoly-dashboard-tooltips-attribute.mjs.map +1 -1
  130. package/fesm2022/provoly-dashboard-widgets-widget-aggregated-chart.mjs +53 -36
  131. package/fesm2022/provoly-dashboard-widgets-widget-aggregated-chart.mjs.map +1 -1
  132. package/fesm2022/provoly-dashboard-widgets-widget-analytic.mjs +3 -15
  133. package/fesm2022/provoly-dashboard-widgets-widget-analytic.mjs.map +1 -1
  134. package/fesm2022/provoly-dashboard-widgets-widget-chart.mjs +9 -9
  135. package/fesm2022/provoly-dashboard-widgets-widget-chart.mjs.map +1 -1
  136. package/fesm2022/provoly-dashboard-widgets-widget-detail.mjs +4 -4
  137. package/fesm2022/provoly-dashboard-widgets-widget-detail.mjs.map +1 -1
  138. package/fesm2022/provoly-dashboard-widgets-widget-map.mjs +36 -45
  139. package/fesm2022/provoly-dashboard-widgets-widget-map.mjs.map +1 -1
  140. package/fesm2022/provoly-dashboard-widgets-widget-table.mjs +32 -38
  141. package/fesm2022/provoly-dashboard-widgets-widget-table.mjs.map +1 -1
  142. package/fesm2022/provoly-dashboard-widgets-widget-tile.mjs +16 -17
  143. package/fesm2022/provoly-dashboard-widgets-widget-tile.mjs.map +1 -1
  144. package/fesm2022/provoly-dashboard-widgets-widget-vega.mjs +1 -1
  145. package/fesm2022/provoly-dashboard-widgets-widget-vega.mjs.map +1 -1
  146. package/fesm2022/provoly-dashboard.mjs +286 -338
  147. package/fesm2022/provoly-dashboard.mjs.map +1 -1
  148. package/import/components/{import.component.d.ts → form/import-form.component.d.ts} +8 -4
  149. package/import/components/list/import-list.component.d.ts +34 -0
  150. package/import/components/version-modal/version-modal.component.d.ts +13 -0
  151. package/import/i18n/en.translations.d.ts +14 -0
  152. package/import/i18n/fr.translations.d.ts +14 -0
  153. package/import/import.module.d.ts +13 -10
  154. package/import/public-api.d.ts +3 -1
  155. package/import/style/_o-import.scss +50 -6
  156. package/lib/core/components/share/legacy-share/share.component.d.ts +1 -1
  157. package/lib/core/components/{modal-status/modal-status.component.d.ts → status-modal/status-modal.component.d.ts} +10 -6
  158. package/lib/core/components/{modal-status/modal-status.module.d.ts → status-modal/status-modal.module.d.ts} +5 -5
  159. package/lib/core/core.module.d.ts +2 -2
  160. package/lib/core/i18n/en.translations.d.ts +33 -0
  161. package/lib/core/i18n/fr.translations.d.ts +35 -0
  162. package/lib/core/model/admin-api.model.d.ts +6 -8
  163. package/lib/core/model/widget-analytic-manifest.interface.d.ts +0 -3
  164. package/lib/core/model/widget-table-manifest.interface.d.ts +2 -0
  165. package/lib/core/public-api.d.ts +2 -2
  166. package/lib/core/store/class/class.interface.d.ts +2 -1
  167. package/lib/core/store/class/class.selectors.d.ts +10 -10
  168. package/lib/core/store/data-source/data-source.actions.d.ts +21 -1
  169. package/lib/core/store/data-source/data-source.effects.d.ts +11 -1
  170. package/lib/core/store/data-source/data-source.model.d.ts +3 -2
  171. package/lib/core/store/data-source/data-source.reducer.d.ts +1 -0
  172. package/lib/core/store/data-source/data-source.selectors.d.ts +3 -3
  173. package/lib/core/store/data-source/data-source.service.d.ts +11 -2
  174. package/lib/core/store/field/field.interface.d.ts +8 -4
  175. package/lib/core/store/field/field.service.d.ts +1 -0
  176. package/lib/dashboard/components/context-menu/object-edition/object-edition.component.d.ts +1 -1
  177. package/lib/dashboard/components/widgets/datasource-selector/datasource-card/datasource-card.component.d.ts +3 -7
  178. package/lib/dashboard/item-utils.d.ts +1 -1
  179. package/lib/dashboard/store/dashboard.actions.d.ts +0 -11
  180. package/lib/dashboard/store/dashboard.effects.d.ts +0 -3
  181. package/lib/dashboard/tooltip/tooltip-factory.service.d.ts +2 -1
  182. package/package.json +18 -12
  183. package/styles/base/_utils.scss +9 -1
  184. package/styles/components/_a-btn.scss +7 -0
  185. package/styles/components/_a-table.scss +2 -16
  186. package/styles/layout/_o-workspace.scss +1 -0
  187. package/tooltips/attribute/attribute-tooltip.component.d.ts +6 -6
  188. package/tooltips/attribute/attribute-tooltip.module.d.ts +2 -1
  189. package/widgets/widget-aggregated-chart/component/widget-aggregated-chart.component.d.ts +16 -3
  190. package/widgets/widget-analytic/component/widget-analytic.component.d.ts +2 -3
  191. package/widgets/widget-detail/component/widget-detail.component.d.ts +1 -4
  192. package/widgets/widget-table/component/widget-table.component.d.ts +1 -0
  193. package/widgets/widget-table/expand-value/expand-value.component.d.ts +4 -2
  194. package/widgets/widget-table/public-api.d.ts +0 -1
  195. package/widgets/widget-table/widget-table.module.d.ts +9 -8
  196. package/widgets/widget-tile/component/widget-tile.component.d.ts +1 -0
  197. package/widgets/widget-tile/widget-tile.module.d.ts +2 -1
  198. package/esm2022/import/components/import.component.mjs +0 -167
  199. package/esm2022/lib/core/components/modal-status/modal-status.component.mjs +0 -45
  200. package/esm2022/widgets/widget-table/expand-value/format-number.pipe.mjs +0 -24
  201. package/widgets/widget-table/expand-value/format-number.pipe.d.ts +0 -10
@@ -80,7 +80,7 @@ export class AdminSelectDatasetComponent extends SubscriptionnerDirective {
80
80
  moduleAccess: 'admin',
81
81
  pageAccess: 'dataset',
82
82
  actionAccess: 'write',
83
- disabled: versions.filter((v) => v.dataset === dataset.id).length > 0
83
+ disabled: versions.filter((v) => v.dataset.id === dataset.id).length > 0
84
84
  }
85
85
  ]
86
86
  }));
@@ -163,4 +163,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.3", ngImpor
163
163
  type: Inject,
164
164
  args: [PRY_ACCESS_TOKEN]
165
165
  }] }] });
166
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"admin-select-dataset.component.js","sourceRoot":"","sources":["../../../../../../../../projects/provoly/dashboard/admin/components/admin-dataset/admin-select-dataset/admin-select-dataset.component.ts","../../../../../../../../projects/provoly/dashboard/admin/components/admin-dataset/admin-select-dataset/admin-select-dataset.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectorRef, Component, Inject, OnDestroy, OnInit, Optional } from '@angular/core';\nimport { ActivatedRoute, Router } from '@angular/router';\nimport { Store } from '@ngrx/store';\nimport {\n  Associations,\n  DashboardSelectors,\n  Dataset,\n  DataSourceSelectors,\n  MetadataValue,\n  MissingGroupsByEntity,\n  PRY_ACCESS_TOKEN,\n  PryBaseAccess,\n  PryI18nService,\n  PryShareMode,\n  SubscriptionnerDirective\n} from '@provoly/dashboard';\nimport { MetadataActions, MetadataSelectors, MetaEventType } from '@provoly/dashboard/components/metadata-editor';\nimport { BehaviorSubject, combineLatest, map, Observable, of, Subscription, withLatestFrom } from 'rxjs';\nimport { concatLatestFrom } from '@ngrx/operators';\nimport { AdminActions } from '../../../store/admin.actions';\nimport { AdminSelectors } from '../../../store/admin.selectors';\nimport { AdminDatasetActions } from '../store/admin-dataset.actions';\nimport { AdminDatasetSelectors } from '../store/admin-dataset.selectors';\n\ninterface MissingGroups {\n  [key: string]: { groups: string[]; entityName: string };\n}\n\n@Component({\n  selector: 'pry-admin-select-dataset',\n  templateUrl: './admin-select-dataset.component.html'\n})\nexport class AdminSelectDatasetComponent extends SubscriptionnerDirective implements OnInit, OnDestroy {\n  static id = 'AdminSelectDatasetComponent';\n  selectedDataset$: Observable<Dataset | null>;\n  associations$: Observable<Associations | undefined>;\n  sub = new Subscription();\n  currentTypeTranslation = '';\n  datasetMetadata$: Observable<MetadataValue[]>;\n  editable$: Observable<boolean>;\n  accessGroups: string[] = [];\n  selectedDatasetMissingGroups$: Observable<MissingGroupsByEntity | undefined>;\n  missingGroups$: Observable<MissingGroups | undefined>;\n  shareRadioValue$ = new BehaviorSubject<PryShareMode | undefined>(undefined);\n  disableShareButton$ = new BehaviorSubject<boolean>(false);\n\n  constructor(\n    private store: Store<any>,\n    private router: Router,\n    private route: ActivatedRoute,\n    private i18n: PryI18nService,\n    private cdr: ChangeDetectorRef,\n    @Optional() @Inject(PRY_ACCESS_TOKEN) protected access: PryBaseAccess\n  ) {\n    super();\n    this.store.dispatch(MetadataActions.loadMetadata());\n    this.selectedDataset$ = this.store.select(AdminDatasetSelectors.selectedDataset);\n    this.datasetMetadata$ = this.store.select(AdminDatasetSelectors.selectedDatasetMetadata);\n    this.associations$ = this.store.select(AdminSelectors.selectedAssociation);\n    this.editable$ = this.store.select(MetadataSelectors.editable);\n    this.selectedDatasetMissingGroups$ = this.store.select(AdminDatasetSelectors.selectedDatasetMissingGroups);\n    this.missingGroups$ = this.selectedDatasetMissingGroups$.pipe(\n      withLatestFrom(this.store.select(DashboardSelectors.manifestsList)),\n      map(([conflict, manifests]) => {\n        const result: { [key: string]: { groups: string[]; entityName: string } } = {};\n        Object.keys(conflict ?? {}).forEach((entityId) => {\n          result[entityId] = {\n            groups: conflict?.[entityId] ?? [],\n            entityName: manifests.find((m) => m.id === entityId)?.name ?? entityId\n          };\n        });\n        return Object.keys(result).length > 0 ? result : undefined;\n      })\n    );\n  }\n\n  ngOnInit(): void {\n    this.subscriptions.add(\n      combineLatest([this.selectedDataset$, this.store.select(DataSourceSelectors.datasetVersions)])\n        .pipe(concatLatestFrom(([dataset, versions]) => (dataset ? this.canModify$(dataset) : of(false))))\n        .subscribe(([[dataset, versions], canModify]) => {\n          if (dataset) {\n            this.accessGroups = dataset.groups ?? [];\n            const editPath = this.router.createUrlTree(['.', 'dataset', 'edit', dataset.id], {\n              relativeTo: this.route\n            });\n            if (canModify) {\n              this.store.dispatch(\n                AdminActions.mainActions({\n                  actions: [\n                    {\n                      action: AdminActions.routeTo({ path: editPath.toString() }),\n                      label: 'edit',\n                      icon: 'edit',\n                      moduleAccess: 'admin',\n                      pageAccess: 'dataset',\n                      actionAccess: 'write'\n                    },\n                    {\n                      action: AdminDatasetActions.confirmDatasetDeletion({\n                        name: dataset.id,\n                        route: this.router.createUrlTree(['.', 'dataset'], { relativeTo: this.route }).toString(),\n                        addRoute: this.router\n                          .createUrlTree(['.', 'dataset', 'new'], { relativeTo: this.route })\n                          .toString()\n                      }),\n                      label: 'delete',\n                      icon: 'delete',\n                      moduleAccess: 'admin',\n                      pageAccess: 'dataset',\n                      actionAccess: 'write',\n                      disabled: versions.filter((v) => v.dataset === dataset.id).length > 0\n                    }\n                  ]\n                })\n              );\n            } else {\n              this.store.dispatch(\n                AdminActions.mainActions({\n                  actions: []\n                })\n              );\n            }\n          }\n        })\n    );\n  }\n\n  closePanel() {\n    const path = this.router.createUrlTree(['.', 'dataset', 'new'], { relativeTo: this.route });\n    this.store.dispatch(AdminDatasetActions.unselectDataset());\n    this.store.dispatch(AdminActions.togglePanel({ panelOpen: false }));\n    this.store.dispatch(\n      AdminActions.mainActions({\n        actions: [\n          {\n            action: AdminActions.routeTo({ path: path.toString() }),\n            label: 'add',\n            icon: 'add_column',\n            moduleAccess: 'admin',\n            pageAccess: 'metadata_rules',\n            actionAccess: 'write'\n          }\n        ]\n      })\n    );\n  }\n\n  removeMetadata(metadata: MetaEventType) {\n    this.store.dispatch(\n      MetadataActions.deleteDatasetMetadata({ datasetId: metadata.id, metadataId: metadata.metadataId })\n    );\n  }\n\n  addDatasetMetadata(metadata: MetaEventType) {\n    this.store.dispatch(\n      MetadataActions.addDatasetMetadata({\n        datasetId: metadata.id,\n        metadataId: metadata.metadataId,\n        value: metadata.value\n      })\n    );\n  }\n\n  share(dataset: Dataset) {\n    this.store.dispatch(AdminDatasetActions.update({ dataset: { ...dataset, groups: this.accessGroups }, route: '' }));\n  }\n\n  getGroupLabel(groupName: string) {\n    const i18nBase = '@pry.components.chipsSelector.share.groups.';\n    const label = this.i18n.instant(i18nBase + groupName, undefined, false);\n    return label.startsWith(i18nBase) ? groupName : label;\n  }\n\n  changeGroup($event: string[]) {\n    this.accessGroups = $event;\n    this.updateDisableButtonValue();\n    this.store.dispatch(AdminDatasetActions.setMissingGroups({ missingGroups: undefined }));\n  }\n\n  updateGroups($event: PryShareMode) {\n    this.shareRadioValue$.next($event);\n    this.updateDisableButtonValue();\n  }\n\n  updateDisableButtonValue() {\n    if (this.shareRadioValue$.getValue() === PryShareMode.GROUPS && this.accessGroups.length === 0) {\n      this.disableShareButton$.next(true);\n    } else {\n      if (this.disableShareButton$.getValue()) {\n        this.disableShareButton$.next(false);\n      }\n    }\n    this.cdr.detectChanges();\n  }\n\n  canModify$(dataset: Dataset) {\n    return this.access ? this.access.canModifyDataset(dataset) : of(false);\n  }\n}\n","<div\n  *ngIf=\"selectedDataset$ | async as dataset\"\n  [id]=\"'panel-dataset-' + dataset.id\"\n  [attr.aria-labelledby]=\"'button-dataset-' + dataset.id\"\n  class=\"o-panel o-pry-admin-dataset-select\"\n>\n  <div class=\"o-panel__header\">\n    <button type=\"button\" class=\"a-btn a-btn--icon-only\" (click)=\"closePanel()\">\n      <span class=\"u-visually-hidden\">{{ '@pry.action.closePanel' | i18n }}</span>\n      <pry-icon iconSvg=\"close\"></pry-icon>\n    </button>\n\n    <h3 class=\"a-h3\">\n      {{ '@pry.admin.dataset.datasetDetails' | i18n }}\n    </h3>\n  </div>\n\n  <pry-tab-group translationStringBase=\"@pry.admin.\">\n    <pry-tab [templateRef]=\"datasetDetails\" name=\"dataset.details\"></pry-tab>\n    <pry-tab [templateRef]=\"datasetMetadata\" name=\"metadata.title\"></pry-tab>\n    <pry-tab [templateRef]=\"datasetAssociations\" name=\"classes.associations\"></pry-tab>\n    <pry-tab *ngIf=\"canModify$(dataset) | async\" [templateRef]=\"shareDataset\" name=\"share\"></pry-tab>\n  </pry-tab-group>\n\n  <ng-template #datasetDetails>\n    <div class=\"u-display-flex -column -gap-20\">\n      <div>\n        <h4 class=\"a-h4\">{{ '@pry.dataset.name' | i18n }}</h4>\n        <span>{{ dataset.name }}</span>\n      </div>\n      <div>\n        <h4 class=\"a-h4\">{{ '@pry.dataset.description' | i18n }}</h4>\n        @if (dataset.description) {\n          <span>{{ dataset.description }}</span>\n        } @else {\n          <span class=\"-italic\">{{ '@pry.dataset.noDescription' | i18n }}</span>\n        }\n      </div>\n      <div>\n        <h4 class=\"a-h4\">{{ '@pry.admin.customize.name' | i18n }}</h4>\n        <span>{{ dataset.oClass | translateId: { type: 'class', output: 'name' } | async }}</span>\n      </div>\n      <div>\n        <h4 class=\"a-h4\">{{ '@pry.admin.dataset.type' | i18n }}</h4>\n        <span>{{ '@pry.admin.dataset.' + dataset.type | i18n }}</span>\n      </div>\n      <div>\n        <h4 class=\"a-h4\">{{ '@pry.dataset.tags' | i18n }}</h4>\n        @if (dataset.categories && dataset.categories.length > 0) {\n          <div class=\"u-display-flex\">\n            @for (category of dataset.categories; track category.id) {\n              <span class=\"a-chip -md\">{{ category.name }}</span>\n            }\n          </div>\n        } @else {\n          <span class=\"-italic\">{{ '@pry.dataset.noTags' | i18n }}</span>\n        }\n      </div>\n    </div>\n  </ng-template>\n\n  <ng-template #datasetMetadata>\n    <pry-metadata-editor\n      [targetId]=\"(selectedDataset$ | async)?.id ?? ''\"\n      [isModification]=\"(editable$ | async) ?? false\"\n      [metadata]=\"(datasetMetadata$ | async) ?? []\"\n      (removeMeta)=\"removeMetadata($event)\"\n      (addMeta)=\"addDatasetMetadata($event)\"\n      [type]=\"'meta'\"\n    ></pry-metadata-editor>\n  </ng-template>\n\n  <ng-template #datasetAssociations>\n    <div *ngIf=\"associations$ | async as associations\" class=\"o-tabs__panels__item__content\">\n      <h4 class=\"a-h4\">{{ '@pry.admin.classes.associations' | i18n }}</h4>\n      <pry-association [associations]=\"associations\"></pry-association>\n    </div>\n  </ng-template>\n\n  <ng-template #shareDataset>\n    <div class=\"o-pry-admin-dataset-select__share\">\n      <pry-group-share\n        [ngModel]=\"dataset.groups\"\n        (ngModelChange)=\"changeGroup($event)\"\n        (radioValueChange)=\"updateGroups($event)\"\n      ></pry-group-share>\n      <button\n        type=\"submit\"\n        class=\"a-btn a-btn--primary u-self-end\"\n        #submit\n        (click)=\"share(dataset)\"\n        [disabled]=\"disableShareButton$ | async\"\n      >\n        {{ '@pry.admin.validate' | i18n }}\n      </button>\n      @if (selectedDatasetMissingGroups$ | async) {\n        <h4 class=\"a-h4\">{{ '@pry.admin.dataset.success' | i18n }}</h4>\n      }\n      @if (missingGroups$ | async; as missingGroups) {\n        <div class=\"u-display-flex -column\">\n          <span>{{ '@pry.admin.dataset.conflict' | i18n }}</span>\n          @for (missing of missingGroups | keyvalue; track missing.key) {\n            <div>\n              {{ '@pry.admin.dataset.entities.dashboard' | i18n }} <strong>{{ missing.value.entityName }}</strong>\n              <div class=\"u-display-flex\">\n                @for (group of missing.value.groups; track group) {\n                  <span class=\"a-chip\">{{ getGroupLabel(group) }}</span>\n                }\n              </div>\n            </div>\n          }\n        </div>\n      }\n    </div>\n  </ng-template>\n</div>\n"]}
166
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"admin-select-dataset.component.js","sourceRoot":"","sources":["../../../../../../../../projects/provoly/dashboard/admin/components/admin-dataset/admin-select-dataset/admin-select-dataset.component.ts","../../../../../../../../projects/provoly/dashboard/admin/components/admin-dataset/admin-select-dataset/admin-select-dataset.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectorRef, Component, Inject, OnDestroy, OnInit, Optional } from '@angular/core';\nimport { ActivatedRoute, Router } from '@angular/router';\nimport { Store } from '@ngrx/store';\nimport {\n  Associations,\n  DashboardSelectors,\n  Dataset,\n  DataSourceSelectors,\n  MetadataValue,\n  MissingGroupsByEntity,\n  PRY_ACCESS_TOKEN,\n  PryBaseAccess,\n  PryI18nService,\n  PryShareMode,\n  SubscriptionnerDirective\n} from '@provoly/dashboard';\nimport { MetadataActions, MetadataSelectors, MetaEventType } from '@provoly/dashboard/components/metadata-editor';\nimport { BehaviorSubject, combineLatest, map, Observable, of, Subscription, withLatestFrom } from 'rxjs';\nimport { concatLatestFrom } from '@ngrx/operators';\nimport { AdminActions } from '../../../store/admin.actions';\nimport { AdminSelectors } from '../../../store/admin.selectors';\nimport { AdminDatasetActions } from '../store/admin-dataset.actions';\nimport { AdminDatasetSelectors } from '../store/admin-dataset.selectors';\n\ninterface MissingGroups {\n  [key: string]: { groups: string[]; entityName: string };\n}\n\n@Component({\n  selector: 'pry-admin-select-dataset',\n  templateUrl: './admin-select-dataset.component.html'\n})\nexport class AdminSelectDatasetComponent extends SubscriptionnerDirective implements OnInit, OnDestroy {\n  static id = 'AdminSelectDatasetComponent';\n  selectedDataset$: Observable<Dataset | null>;\n  associations$: Observable<Associations | undefined>;\n  sub = new Subscription();\n  currentTypeTranslation = '';\n  datasetMetadata$: Observable<MetadataValue[]>;\n  editable$: Observable<boolean>;\n  accessGroups: string[] = [];\n  selectedDatasetMissingGroups$: Observable<MissingGroupsByEntity | undefined>;\n  missingGroups$: Observable<MissingGroups | undefined>;\n  shareRadioValue$ = new BehaviorSubject<PryShareMode | undefined>(undefined);\n  disableShareButton$ = new BehaviorSubject<boolean>(false);\n\n  constructor(\n    private store: Store<any>,\n    private router: Router,\n    private route: ActivatedRoute,\n    private i18n: PryI18nService,\n    private cdr: ChangeDetectorRef,\n    @Optional() @Inject(PRY_ACCESS_TOKEN) protected access: PryBaseAccess\n  ) {\n    super();\n    this.store.dispatch(MetadataActions.loadMetadata());\n    this.selectedDataset$ = this.store.select(AdminDatasetSelectors.selectedDataset);\n    this.datasetMetadata$ = this.store.select(AdminDatasetSelectors.selectedDatasetMetadata);\n    this.associations$ = this.store.select(AdminSelectors.selectedAssociation);\n    this.editable$ = this.store.select(MetadataSelectors.editable);\n    this.selectedDatasetMissingGroups$ = this.store.select(AdminDatasetSelectors.selectedDatasetMissingGroups);\n    this.missingGroups$ = this.selectedDatasetMissingGroups$.pipe(\n      withLatestFrom(this.store.select(DashboardSelectors.manifestsList)),\n      map(([conflict, manifests]) => {\n        const result: { [key: string]: { groups: string[]; entityName: string } } = {};\n        Object.keys(conflict ?? {}).forEach((entityId) => {\n          result[entityId] = {\n            groups: conflict?.[entityId] ?? [],\n            entityName: manifests.find((m) => m.id === entityId)?.name ?? entityId\n          };\n        });\n        return Object.keys(result).length > 0 ? result : undefined;\n      })\n    );\n  }\n\n  ngOnInit(): void {\n    this.subscriptions.add(\n      combineLatest([this.selectedDataset$, this.store.select(DataSourceSelectors.datasetVersions)])\n        .pipe(concatLatestFrom(([dataset, versions]) => (dataset ? this.canModify$(dataset) : of(false))))\n        .subscribe(([[dataset, versions], canModify]) => {\n          if (dataset) {\n            this.accessGroups = dataset.groups ?? [];\n            const editPath = this.router.createUrlTree(['.', 'dataset', 'edit', dataset.id], {\n              relativeTo: this.route\n            });\n            if (canModify) {\n              this.store.dispatch(\n                AdminActions.mainActions({\n                  actions: [\n                    {\n                      action: AdminActions.routeTo({ path: editPath.toString() }),\n                      label: 'edit',\n                      icon: 'edit',\n                      moduleAccess: 'admin',\n                      pageAccess: 'dataset',\n                      actionAccess: 'write'\n                    },\n                    {\n                      action: AdminDatasetActions.confirmDatasetDeletion({\n                        name: dataset.id,\n                        route: this.router.createUrlTree(['.', 'dataset'], { relativeTo: this.route }).toString(),\n                        addRoute: this.router\n                          .createUrlTree(['.', 'dataset', 'new'], { relativeTo: this.route })\n                          .toString()\n                      }),\n                      label: 'delete',\n                      icon: 'delete',\n                      moduleAccess: 'admin',\n                      pageAccess: 'dataset',\n                      actionAccess: 'write',\n                      disabled: versions.filter((v) => v.dataset.id === dataset.id).length > 0\n                    }\n                  ]\n                })\n              );\n            } else {\n              this.store.dispatch(\n                AdminActions.mainActions({\n                  actions: []\n                })\n              );\n            }\n          }\n        })\n    );\n  }\n\n  closePanel() {\n    const path = this.router.createUrlTree(['.', 'dataset', 'new'], { relativeTo: this.route });\n    this.store.dispatch(AdminDatasetActions.unselectDataset());\n    this.store.dispatch(AdminActions.togglePanel({ panelOpen: false }));\n    this.store.dispatch(\n      AdminActions.mainActions({\n        actions: [\n          {\n            action: AdminActions.routeTo({ path: path.toString() }),\n            label: 'add',\n            icon: 'add_column',\n            moduleAccess: 'admin',\n            pageAccess: 'metadata_rules',\n            actionAccess: 'write'\n          }\n        ]\n      })\n    );\n  }\n\n  removeMetadata(metadata: MetaEventType) {\n    this.store.dispatch(\n      MetadataActions.deleteDatasetMetadata({ datasetId: metadata.id, metadataId: metadata.metadataId })\n    );\n  }\n\n  addDatasetMetadata(metadata: MetaEventType) {\n    this.store.dispatch(\n      MetadataActions.addDatasetMetadata({\n        datasetId: metadata.id,\n        metadataId: metadata.metadataId,\n        value: metadata.value\n      })\n    );\n  }\n\n  share(dataset: Dataset) {\n    this.store.dispatch(AdminDatasetActions.update({ dataset: { ...dataset, groups: this.accessGroups }, route: '' }));\n  }\n\n  getGroupLabel(groupName: string) {\n    const i18nBase = '@pry.components.chipsSelector.share.groups.';\n    const label = this.i18n.instant(i18nBase + groupName, undefined, false);\n    return label.startsWith(i18nBase) ? groupName : label;\n  }\n\n  changeGroup($event: string[]) {\n    this.accessGroups = $event;\n    this.updateDisableButtonValue();\n    this.store.dispatch(AdminDatasetActions.setMissingGroups({ missingGroups: undefined }));\n  }\n\n  updateGroups($event: PryShareMode) {\n    this.shareRadioValue$.next($event);\n    this.updateDisableButtonValue();\n  }\n\n  updateDisableButtonValue() {\n    if (this.shareRadioValue$.getValue() === PryShareMode.GROUPS && this.accessGroups.length === 0) {\n      this.disableShareButton$.next(true);\n    } else {\n      if (this.disableShareButton$.getValue()) {\n        this.disableShareButton$.next(false);\n      }\n    }\n    this.cdr.detectChanges();\n  }\n\n  canModify$(dataset: Dataset) {\n    return this.access ? this.access.canModifyDataset(dataset) : of(false);\n  }\n}\n","<div\n  *ngIf=\"selectedDataset$ | async as dataset\"\n  [id]=\"'panel-dataset-' + dataset.id\"\n  [attr.aria-labelledby]=\"'button-dataset-' + dataset.id\"\n  class=\"o-panel o-pry-admin-dataset-select\"\n>\n  <div class=\"o-panel__header\">\n    <button type=\"button\" class=\"a-btn a-btn--icon-only\" (click)=\"closePanel()\">\n      <span class=\"u-visually-hidden\">{{ '@pry.action.closePanel' | i18n }}</span>\n      <pry-icon iconSvg=\"close\"></pry-icon>\n    </button>\n\n    <h3 class=\"a-h3\">\n      {{ '@pry.admin.dataset.datasetDetails' | i18n }}\n    </h3>\n  </div>\n\n  <pry-tab-group translationStringBase=\"@pry.admin.\">\n    <pry-tab [templateRef]=\"datasetDetails\" name=\"dataset.details\"></pry-tab>\n    <pry-tab [templateRef]=\"datasetMetadata\" name=\"metadata.title\"></pry-tab>\n    <pry-tab [templateRef]=\"datasetAssociations\" name=\"classes.associations\"></pry-tab>\n    <pry-tab *ngIf=\"canModify$(dataset) | async\" [templateRef]=\"shareDataset\" name=\"share\"></pry-tab>\n  </pry-tab-group>\n\n  <ng-template #datasetDetails>\n    <div class=\"u-display-flex -column -gap-20\">\n      <div>\n        <h4 class=\"a-h4\">{{ '@pry.dataset.name' | i18n }}</h4>\n        <span>{{ dataset.name }}</span>\n      </div>\n      <div>\n        <h4 class=\"a-h4\">{{ '@pry.dataset.description' | i18n }}</h4>\n        @if (dataset.description) {\n          <span>{{ dataset.description }}</span>\n        } @else {\n          <span class=\"-italic\">{{ '@pry.dataset.noDescription' | i18n }}</span>\n        }\n      </div>\n      <div>\n        <h4 class=\"a-h4\">{{ '@pry.admin.customize.name' | i18n }}</h4>\n        <span>{{ dataset.oClass | translateId: { type: 'class', output: 'name' } | async }}</span>\n      </div>\n      <div>\n        <h4 class=\"a-h4\">{{ '@pry.admin.dataset.type' | i18n }}</h4>\n        <span>{{ '@pry.admin.dataset.' + dataset.type | i18n }}</span>\n      </div>\n      <div>\n        <h4 class=\"a-h4\">{{ '@pry.dataset.tags' | i18n }}</h4>\n        @if (dataset.categories && dataset.categories.length > 0) {\n          <div class=\"u-display-flex\">\n            @for (category of dataset.categories; track category.id) {\n              <span class=\"a-chip -md\">{{ category.name }}</span>\n            }\n          </div>\n        } @else {\n          <span class=\"-italic\">{{ '@pry.dataset.noTags' | i18n }}</span>\n        }\n      </div>\n    </div>\n  </ng-template>\n\n  <ng-template #datasetMetadata>\n    <pry-metadata-editor\n      [targetId]=\"(selectedDataset$ | async)?.id ?? ''\"\n      [isModification]=\"(editable$ | async) ?? false\"\n      [metadata]=\"(datasetMetadata$ | async) ?? []\"\n      (removeMeta)=\"removeMetadata($event)\"\n      (addMeta)=\"addDatasetMetadata($event)\"\n      [type]=\"'meta'\"\n    ></pry-metadata-editor>\n  </ng-template>\n\n  <ng-template #datasetAssociations>\n    <div *ngIf=\"associations$ | async as associations\" class=\"o-tabs__panels__item__content\">\n      <h4 class=\"a-h4\">{{ '@pry.admin.classes.associations' | i18n }}</h4>\n      <pry-association [associations]=\"associations\"></pry-association>\n    </div>\n  </ng-template>\n\n  <ng-template #shareDataset>\n    <div class=\"o-pry-admin-dataset-select__share\">\n      <pry-group-share\n        [ngModel]=\"dataset.groups\"\n        (ngModelChange)=\"changeGroup($event)\"\n        (radioValueChange)=\"updateGroups($event)\"\n      ></pry-group-share>\n      <button\n        type=\"submit\"\n        class=\"a-btn a-btn--primary u-self-end\"\n        #submit\n        (click)=\"share(dataset)\"\n        [disabled]=\"disableShareButton$ | async\"\n      >\n        {{ '@pry.admin.validate' | i18n }}\n      </button>\n      @if (selectedDatasetMissingGroups$ | async) {\n        <h4 class=\"a-h4\">{{ '@pry.admin.dataset.success' | i18n }}</h4>\n      }\n      @if (missingGroups$ | async; as missingGroups) {\n        <div class=\"u-display-flex -column\">\n          <span>{{ '@pry.admin.dataset.conflict' | i18n }}</span>\n          @for (missing of missingGroups | keyvalue; track missing.key) {\n            <div>\n              {{ '@pry.admin.dataset.entities.dashboard' | i18n }} <strong>{{ missing.value.entityName }}</strong>\n              <div class=\"u-display-flex\">\n                @for (group of missing.value.groups; track group) {\n                  <span class=\"a-chip\">{{ getGroupLabel(group) }}</span>\n                }\n              </div>\n            </div>\n          }\n        </div>\n      }\n    </div>\n  </ng-template>\n</div>\n"]}
@@ -1,115 +1,194 @@
1
1
  import { Component, Input } from '@angular/core';
2
- import { FormControl, Validators } from '@angular/forms';
3
- import { FIELD_OPTIONS, FieldActions, FieldSelectors, GeometricFieldTypes } from '@provoly/dashboard';
4
- import { combineLatest, map, startWith, Subscription } from 'rxjs';
2
+ import { FormControl, FormGroup, Validators } from '@angular/forms';
3
+ import { FIELD_I18N, FieldActions, FieldSelectors, FieldType, GeometricFieldTypes, SubscriptionnerDirective } from '@provoly/dashboard';
4
+ import { combineLatest, map } from 'rxjs';
5
5
  import { v4 as uuid } from 'uuid';
6
6
  import { noWhitespaceValidator } from '../../../components/admin.component';
7
7
  import { AdminActions } from '../../../store/admin.actions';
8
8
  import { FieldsActions } from '../store/fields.actions';
9
- import { distinctUntilChanged } from 'rxjs/operators';
9
+ import { dateFormatOptions } from '@provoly/dashboard/components/data-format';
10
10
  import * as i0 from "@angular/core";
11
11
  import * as i1 from "@ngrx/store";
12
12
  import * as i2 from "@angular/router";
13
- import * as i3 from "@angular/forms";
14
- import * as i4 from "@provoly/dashboard";
15
- import * as i5 from "@angular/common";
13
+ import * as i3 from "@provoly/dashboard";
14
+ import * as i4 from "@angular/common";
15
+ import * as i5 from "@angular/forms";
16
+ import * as i6 from "@provoly/dashboard/components/checkbox";
16
17
  export const CRS_OPTIONS = [
17
18
  { label: 'WGS84 (EPSG:4326)', code: 'EPSG:4326' },
18
19
  { label: 'Lambert93 (EPSG: 2154)', code: 'EPSG:2154' }
19
20
  ];
20
- export class AdminFieldsFormComponent {
21
- constructor(store, router, route, formBuilder, i18nService) {
21
+ export class AdminFieldsFormComponent extends SubscriptionnerDirective {
22
+ constructor(store, router, route, i18n) {
23
+ super();
22
24
  this.store = store;
23
25
  this.router = router;
24
26
  this.route = route;
25
- this.formBuilder = formBuilder;
26
- this.i18nService = i18nService;
27
- this.sub = new Subscription();
28
- this.isSubmitted = false;
29
- this.fieldTypeTranslations = [];
27
+ this.i18n = i18n;
28
+ this.dateFormats = Object.keys(dateFormatOptions.value);
30
29
  this.CRS_OPTIONS = CRS_OPTIONS;
31
- this.fieldTypeTranslations = FIELD_OPTIONS.map((translate) => ({
32
- varType: translate.varType,
33
- translation: this.i18nService.instant(translate.translation),
34
- description: this.i18nService.instant(translate.description)
35
- }));
36
- this.fieldTypeTranslations.sort((a, b) => a['translation'].localeCompare(b['translation']));
30
+ this.FieldType = FieldType;
31
+ this.FIELD_I18N = FIELD_I18N;
37
32
  this.store.dispatch(FieldActions.load());
38
- this.goBackPath = this.router.createUrlTree(['..'], { relativeTo: this.route }).toString();
39
- this.goBackPathEdit = this.router.createUrlTree(['../..'], { relativeTo: this.route }).toString();
40
- this.fieldForm = this.formBuilder.group({
41
- id: [uuid()],
42
- name: ['', [Validators.required, Validators.minLength(3), Validators.maxLength(100), noWhitespaceValidator]],
43
- type: [this.fieldTypeTranslations[0]['varType']]
44
- });
45
- }
46
- ngOnInit() {
47
33
  this.fieldNames$ = this.store
48
34
  .select(FieldSelectors.fields)
49
35
  .pipe(map((fields) => fields.map((field) => field.name.toLowerCase())));
50
- this.nameAlreadyExists$ = combineLatest([
51
- this.fieldForm.get('name')?.valueChanges,
52
- this.fieldNames$
53
- ]).pipe(map(([value, fieldNames]) => fieldNames.includes(value.toLowerCase()) && value != this.currentField?.name));
54
- this.sub.add(this.nameAlreadyExists$.subscribe((value) => {
36
+ this.fieldTypes = Object.values(FieldType)
37
+ .filter((type) => type !== FieldType.GEOMETRYCOLLECTION)
38
+ .sort((a, b) => {
39
+ const [labelA, labelB] = [this.i18n.instant(FIELD_I18N.label + a), this.i18n.instant(FIELD_I18N.label + b)];
40
+ return labelA.localeCompare(labelB);
41
+ });
42
+ this.form = new FormGroup({
43
+ name: new FormControl('', {
44
+ validators: [Validators.required, Validators.minLength(3), Validators.maxLength(100), noWhitespaceValidator],
45
+ nonNullable: true
46
+ }),
47
+ type: new FormControl(this.fieldTypes[0], { nonNullable: true }),
48
+ formatOptions: new FormGroup({})
49
+ });
50
+ this.subscriptions.add(this.type?.valueChanges.subscribe((type) => this.setFormatOptionControls(type)));
51
+ this.form.patchValue({ type: this.fieldTypes[0] });
52
+ this.nameAlreadyExists$ = combineLatest([this.name.valueChanges, this.fieldNames$]).pipe(map(([value, fieldNames]) => fieldNames.includes(value.toLowerCase()) && value != this.currentField?.name));
53
+ this.subscriptions.add(this.nameAlreadyExists$.subscribe((value) => {
55
54
  if (value) {
56
- this.fieldForm.controls['name'].setErrors({ 'same-name': true });
55
+ this.name?.setErrors({ 'same-name': true });
57
56
  }
58
57
  return value;
59
58
  }));
59
+ this.goBackPath = this.router.createUrlTree(['..'], { relativeTo: this.route }).toString();
60
+ this.goBackPathEdit = this.router.createUrlTree(['../..'], { relativeTo: this.route }).toString();
61
+ }
62
+ ngOnInit() {
60
63
  if (this.currentField) {
61
- this.fieldForm.patchValue({
62
- id: this.currentField.id,
64
+ this.form.patchValue({
63
65
  name: this.currentField.name,
64
66
  type: this.currentField.type
65
67
  });
66
- this.fieldForm.controls['type'].disable();
68
+ this.type.disable();
67
69
  if (this.isGeographicType) {
68
- this.fieldForm.addControl('crs', new FormControl(this.currentField.crs, [Validators.required]));
69
- this.fieldForm.controls['crs'].disable();
70
+ this.form.addControl('crs', new FormControl(this.currentField.crs, { validators: [Validators.required], nonNullable: true }));
71
+ this.crs?.disable();
70
72
  }
73
+ this.setFormatOptionValues();
71
74
  }
72
- this.selectedFieldTypeDescription$ = this.fieldForm.get('type')?.valueChanges.pipe(startWith(this.currentField?.type ?? this.fieldTypeTranslations[0]['varType']), distinctUntilChanged(), map((selectedType) => this.fieldTypeTranslations.find((translation) => translation['varType'] === selectedType)?.['description'] ??
73
- ''));
74
- this.fieldForm.get('type').valueChanges.subscribe((type) => {
75
+ this.subscriptions.add(this.type.valueChanges.subscribe((type) => {
75
76
  if (this.isGeographicType) {
76
- this.fieldForm.addControl('crs', new FormControl(CRS_OPTIONS[0].code, [Validators.required]));
77
+ this.form.addControl('crs', new FormControl(CRS_OPTIONS[0].code, { validators: [Validators.required], nonNullable: true }));
77
78
  }
78
79
  else {
79
- this.fieldForm.removeControl('crs');
80
+ this.form.removeControl('crs');
80
81
  }
81
- });
82
+ }));
82
83
  }
83
- get isGeographicType() {
84
- return GeometricFieldTypes.includes(this.fieldForm.get('type')?.value);
84
+ get name() {
85
+ return this.form.get('name');
86
+ }
87
+ get type() {
88
+ return this.form.get('type');
85
89
  }
86
- ngOnDestroy() {
87
- this.sub.unsubscribe();
90
+ get crs() {
91
+ return this.form.get('crs');
92
+ }
93
+ get formatOptions() {
94
+ return this.form.get('formatOptions');
95
+ }
96
+ get isGeographicType() {
97
+ return GeometricFieldTypes.includes(this.type?.value);
88
98
  }
89
99
  goBack() {
90
100
  this.store.dispatch(AdminActions.routeTo({ path: this.getPath(), params: undefined }));
91
101
  }
92
- addField() {
93
- this.fieldForm.patchValue({
94
- name: this.fieldForm.value.name.trim()
102
+ getFormValue() {
103
+ return {
104
+ name: this.name.value,
105
+ type: this.type.value,
106
+ crs: this.crs?.value,
107
+ unit: this.formatOptions?.value.unit ?? undefined,
108
+ decimalPrecision: this.formatOptions?.value.decimalPrecision ?? undefined,
109
+ isLocaleFormat: this.formatOptions?.value.isLocaleFormat ?? undefined,
110
+ format: this.formatOptions?.value.dateFormat ?? undefined
111
+ };
112
+ }
113
+ submit() {
114
+ this.form.patchValue({
115
+ name: this.name?.value?.trim()
95
116
  });
96
- this.isSubmitted = true;
97
- if (this.fieldForm.valid) {
98
- this.isSubmitted = false;
99
- let fieldToSave = this.fieldForm.getRawValue();
100
- this.store.dispatch(FieldsActions.saveField({ field: fieldToSave, route: this.getPath() }));
117
+ if (this.form.valid) {
118
+ this.currentField ? this.updateField() : this.saveField();
119
+ }
120
+ }
121
+ saveField() {
122
+ this.store.dispatch(FieldsActions.saveField({
123
+ field: { id: uuid(), ...this.getFormValue() },
124
+ route: this.getPath()
125
+ }));
126
+ }
127
+ updateField() {
128
+ this.store.dispatch(FieldsActions.updateField({
129
+ field: { id: this.currentField.id, ...this.getFormValue() },
130
+ route: this.getPath()
131
+ }));
132
+ }
133
+ setFormatOptionControls(type) {
134
+ switch (type) {
135
+ case FieldType.INTEGER:
136
+ case FieldType.LONG:
137
+ this.formatOptions?.addControl('isLocaleFormat', new FormControl(true));
138
+ this.formatOptions?.setControl('unit', new FormControl(null));
139
+ this.formatOptions?.removeControl('decimalPrecision');
140
+ this.formatOptions?.removeControl('dateFormat');
141
+ break;
142
+ case FieldType.DECIMAL:
143
+ this.formatOptions?.addControl('isLocaleFormat', new FormControl(true));
144
+ this.formatOptions?.setControl('unit', new FormControl(null));
145
+ this.formatOptions?.setControl('decimalPrecision', new FormControl(2));
146
+ this.formatOptions?.removeControl('dateFormat');
147
+ break;
148
+ case FieldType.INSTANT:
149
+ this.formatOptions?.removeControl('isLocaleFormat');
150
+ this.formatOptions?.removeControl('unit');
151
+ this.formatOptions?.removeControl('decimalPrecision');
152
+ this.formatOptions?.setControl('dateFormat', new FormControl(null));
153
+ break;
154
+ default:
155
+ this.form.removeControl('formatOptions');
156
+ break;
157
+ }
158
+ }
159
+ setFormatOptionValues() {
160
+ switch (this.currentField?.type) {
161
+ case FieldType.INTEGER:
162
+ case FieldType.LONG:
163
+ this.formatOptions?.patchValue({
164
+ isLocaleFormat: this.currentField?.isLocaleFormat,
165
+ unit: this.currentField?.unit
166
+ });
167
+ break;
168
+ case FieldType.DECIMAL:
169
+ this.formatOptions?.patchValue({
170
+ isLocaleFormat: this.currentField?.isLocaleFormat,
171
+ unit: this.currentField?.unit,
172
+ decimalPrecision: this.currentField?.decimalPrecision
173
+ });
174
+ break;
175
+ case FieldType.INSTANT:
176
+ this.formatOptions?.patchValue({ dateFormat: this.currentField?.format });
177
+ break;
178
+ default:
179
+ break;
101
180
  }
102
181
  }
103
182
  getPath() {
104
183
  return this.currentField ? this.goBackPathEdit : this.goBackPath;
105
184
  }
106
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.3", ngImport: i0, type: AdminFieldsFormComponent, deps: [{ token: i1.Store }, { token: i2.Router }, { token: i2.ActivatedRoute }, { token: i3.UntypedFormBuilder }, { token: i4.PryI18nService }], target: i0.ɵɵFactoryTarget.Component }); }
107
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.1.3", type: AdminFieldsFormComponent, selector: "pry-admin-fields-form", inputs: { currentField: "currentField" }, ngImport: i0, template: "<div>\n <form class=\"o-form\" [formGroup]=\"fieldForm\" (ngSubmit)=\"addField()\">\n <div class=\"m-form-label-field -width-sm\">\n <label id=\"name-label\" for=\"field_name\" class=\"a-label\">\n {{ '@pry.admin.fields.name' | i18n }} *\n <span class=\"u-visually-hidden\">({{ '@pry.admin.required' | i18n }})</span>\n </label>\n <input\n id=\"field_name\"\n type=\"text\"\n class=\"a-form-field\"\n formControlName=\"name\"\n [attr.aria-labelledby]=\"isSubmitted && fieldForm.get('name')?.invalid ? 'name-label name-error' : 'name-label'\"\n [attr.aria-invalid]=\"isSubmitted && fieldForm.get('name')?.invalid\"\n required\n />\n <label\n *ngIf=\"isSubmitted && fieldForm.get('name')?.invalid\"\n id=\"name-error\"\n for=\"field_name\"\n class=\"a-label a-label--help -error\"\n >\n <span *ngIf=\"fieldForm.get('name')?.hasError('same-name')\">{{ '@pry.admin.exists' | i18n }}</span>\n <span *ngIf=\"fieldForm.get('name')?.hasError('required')\">{{ '@pry.admin.required' | i18n }}</span>\n <span *ngIf=\"fieldForm.get('name')?.hasError('minlength')\">{{\n '@pry.admin.minLength' | i18n : { len: 3 }\n }}</span>\n <span *ngIf=\"fieldForm.get('name')?.hasError('maxlength')\">{{\n '@pry.admin.maxLength' | i18n : { len: 100 }\n }}</span>\n <span *ngIf=\"fieldForm.get('name')?.hasError('whitespace') && !fieldForm.get('name')?.hasError('minlength')\">{{\n '@pry.admin.noWhitespace' | i18n\n }}</span>\n </label>\n </div>\n\n <div class=\"m-form-label-field -width-sm\">\n <label class=\"a-label\">\n {{ '@pry.admin.fields.type' | i18n }} *\n <span class=\"u-visually-hidden\">({{ '@pry.admin.required' | i18n }})</span>\n </label>\n <div class=\"u-display-flex\">\n <pry-select\n class=\"-width-sm\"\n formControlName=\"type\"\n [items]=\"fieldTypeTranslations\"\n bindValue=\"varType\"\n bindLabel=\"translation\"\n [isForm]=\"true\"\n ></pry-select>\n <div\n *ngIf=\"selectedFieldTypeDescription$ | async as description\"\n class=\"m-info-icon a-tooltip -tooltip-width-lg u-self-center -flex-shrink-0\"\n [attr.data-tooltip]=\"description\"\n data-tooltip-position=\"right\"\n >\n <span>i</span>\n </div>\n </div>\n </div>\n\n <div class=\"m-form-label-field -width-sm\" *ngIf=\"isGeographicType\">\n <label class=\"a-label\">\n {{ '@pry.admin.fields.crs' | i18n }} *\n <span class=\"u-visually-hidden\">({{ '@pry.admin.required' | i18n }})</span>\n </label>\n <div class=\"u-display-flex\">\n <pry-select\n class=\"-width-sm\"\n formControlName=\"crs\"\n [items]=\"CRS_OPTIONS\"\n bindValue=\"code\"\n bindLabel=\"label\"\n [isForm]=\"true\"\n id=\"crs\"\n ></pry-select>\n </div>\n <label\n *ngIf=\"isSubmitted && fieldForm.get('crs') && fieldForm.get('crs')?.invalid\"\n id=\"crs-error\"\n for=\"crs\"\n class=\"a-label a-label--help -error\"\n >\n <span *ngIf=\"fieldForm.get('name')?.hasError('required')\">{{ '@pry.admin.required' | i18n }}</span>\n </label>\n </div>\n\n <div class=\"m-btn-group -width-sm\">\n <button\n type=\"button\"\n class=\"a-btn a-btn--secondary\"\n (click)=\"goBack()\"\n [innerHTML]=\"'@pry.admin.cancel' | i18n\"\n ></button>\n <button\n class=\"a-btn a-btn--primary\"\n type=\"submit\"\n [innerHTML]=\"(currentField ? '@pry.admin.edit' : '@pry.admin.create') | i18n\"\n ></button>\n </div>\n </form>\n</div>\n", dependencies: [{ kind: "directive", type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i3.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i3.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i3.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i3.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "component", type: i4.PrySelectComponent, selector: "pry-select", inputs: ["items", "clearable", "multiple", "closeOnSelect", "placeholder", "isForm", "required", "name", "readonly", "autocomplete", "alwaysShowAutosuggestedValues", "externalAutocompleteService", "bindValue", "bindLabel", "iconSize", "bindIcon", "template", "i18nPrefix", "bindClasses", "loading", "elementRef"], outputs: ["searched", "cleared", "clicked"] }, { kind: "pipe", type: i5.AsyncPipe, name: "async" }, { kind: "pipe", type: i4.I18nPipe, name: "i18n" }] }); }
185
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.3", ngImport: i0, type: AdminFieldsFormComponent, deps: [{ token: i1.Store }, { token: i2.Router }, { token: i2.ActivatedRoute }, { token: i3.PryI18nService }], target: i0.ɵɵFactoryTarget.Component }); }
186
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.1.3", type: AdminFieldsFormComponent, selector: "pry-admin-fields-form", inputs: { currentField: "currentField" }, usesInheritance: true, ngImport: i0, template: "<div>\n <form class=\"o-form\" [formGroup]=\"form\" (ngSubmit)=\"submit()\">\n <div class=\"m-form-label-field -width-sm\">\n <label id=\"name-label\" for=\"field_name\" class=\"a-label\">\n {{ '@pry.admin.fields.name' | i18n }} *\n <span class=\"u-visually-hidden\">({{ '@pry.admin.required' | i18n }})</span>\n </label>\n <input\n id=\"field_name\"\n type=\"text\"\n class=\"a-form-field\"\n formControlName=\"name\"\n [attr.aria-labelledby]=\"name?.dirty && name?.invalid ? 'name-label name-error' : 'name-label'\"\n [attr.aria-invalid]=\"name?.dirty && name?.invalid\"\n />\n @if (name?.dirty && name?.invalid) {\n <label id=\"name-error\" for=\"field_name\" class=\"a-label a-label--help -error\">\n @if (name?.hasError('same-name')) {\n <span>{{ '@pry.admin.exists' | i18n }}</span>\n }\n @if (name?.hasError('required')) {\n <span>{{ '@pry.admin.required' | i18n }}</span>\n }\n @if (name?.hasError('minlength')) {\n <span>{{ '@pry.admin.minLength' | i18n: { len: 3 } }}</span>\n }\n @if (name?.hasError('maxlength')) {\n <span>{{ '@pry.admin.maxLength' | i18n: { len: 100 } }}</span>\n }\n @if (name?.hasError('whitespace') && !name?.hasError('minlength')) {\n <span>{{ '@pry.admin.noWhitespace' | i18n }}</span>\n }\n </label>\n }\n </div>\n\n <div class=\"m-form-label-field -width-sm\">\n <label class=\"a-label\" for=\"field_type\">\n {{ '@pry.admin.fields.type' | i18n }} *\n <span class=\"u-visually-hidden\">({{ '@pry.admin.required' | i18n }})</span>\n </label>\n <div class=\"u-display-flex\">\n <pry-select\n id=\"field_type\"\n class=\"u-flex-grow-1\"\n formControlName=\"type\"\n [items]=\"fieldTypes\"\n [i18nPrefix]=\"FIELD_I18N.label\"\n [isForm]=\"true\"\n ></pry-select>\n <div\n class=\"m-info-icon a-tooltip -tooltip-width-lg u-self-center u-flex-shrink-0\"\n [attr.data-tooltip]=\"FIELD_I18N.information + this.type?.value | i18n\"\n data-tooltip-position=\"right\"\n >\n <span>i</span>\n </div>\n </div>\n </div>\n\n @if (isGeographicType) {\n <div class=\"m-form-label-field -width-sm\">\n <label class=\"a-label\" for=\"crs\">\n {{ '@pry.admin.fields.crs' | i18n }} *\n <span class=\"u-visually-hidden\">({{ '@pry.admin.required' | i18n }})</span>\n </label>\n <div class=\"u-display-flex\">\n <pry-select\n class=\"-width-sm\"\n formControlName=\"crs\"\n [items]=\"CRS_OPTIONS\"\n bindValue=\"code\"\n bindLabel=\"label\"\n [isForm]=\"true\"\n id=\"crs\"\n ></pry-select>\n </div>\n @if (crs?.dirty && crs?.invalid) {\n <label id=\"crs-error\" for=\"crs\" class=\"a-label a-label--help -error\">\n @if (crs?.hasError('required')) {\n <span>{{ '@pry.admin.required' | i18n }}</span>\n }\n </label>\n }\n </div>\n }\n\n @if (formatOptions) {\n <div formGroupName=\"formatOptions\">\n <h3 class=\"a-h3\">{{ '@pry.admin.fields.formatOptions.title' | i18n }}</h3>\n @if (type?.value === FieldType.INTEGER || type?.value === FieldType.LONG || type?.value === FieldType.DECIMAL) {\n <ng-container *ngTemplateOutlet=\"numberFormatOptions\"></ng-container>\n } @else if (type?.value === FieldType.INSTANT) {\n <ng-container *ngTemplateOutlet=\"dateFormatOptions\"></ng-container>\n }\n\n <ng-template #numberFormatOptions>\n @if (type?.value === FieldType.DECIMAL) {\n <div class=\"m-form-label-field -width-sm\">\n <label class=\"a-label\" for=\"field_format_comma\">{{\n '@pry.admin.fields.formatOptions.decimalPrecision' | i18n\n }}</label>\n <input formControlName=\"decimalPrecision\" id=\"field_format_comma\" type=\"number\" class=\"a-form-field\" />\n </div>\n }\n <div class=\"m-form-label-field -width-sm\">\n <pry-checkbox\n formControlName=\"isLocaleFormat\"\n inputId=\"field_format_locale_number_format\"\n [inhibit]=\"false\"\n >\n {{ '@pry.admin.fields.formatOptions.isLocaleFormat' | i18n }}\n </pry-checkbox>\n </div>\n <div class=\"m-form-label-field -width-sm\">\n <label class=\"a-label\" for=\"field_format_unit\">{{ '@pry.admin.fields.formatOptions.unit' | i18n }}</label>\n <input formControlName=\"unit\" id=\"field_format_unit\" type=\"text\" class=\"a-form-field\" />\n </div>\n </ng-template>\n\n <ng-template #dateFormatOptions>\n <div class=\"m-form-label-field -width-sm\">\n <label class=\"a-label\" for=\"field_format_date\">{{\n '@pry.admin.fields.formatOptions.dateFormat' | i18n\n }}</label>\n <pry-select\n formControlName=\"dateFormat\"\n id=\"field_format_date\"\n [items]=\"dateFormats\"\n [isForm]=\"true\"\n i18nPrefix=\"@pry.admin.fields.formatOptions.dateFormatOptions.\"\n [clearable]=\"true\"\n ></pry-select>\n </div>\n </ng-template>\n </div>\n }\n\n <div class=\"m-btn-group -width-sm\">\n <button\n type=\"button\"\n class=\"a-btn a-btn--secondary\"\n (click)=\"goBack()\"\n [innerHTML]=\"'@pry.admin.cancel' | i18n\"\n ></button>\n <button\n class=\"a-btn a-btn--primary\"\n type=\"submit\"\n [innerHTML]=\"(currentField ? '@pry.admin.edit' : '@pry.admin.create') | i18n\"\n ></button>\n </div>\n </form>\n</div>\n", dependencies: [{ kind: "directive", type: i4.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i5.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i5.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i5.NumberValueAccessor, selector: "input[type=number][formControlName],input[type=number][formControl],input[type=number][ngModel]" }, { kind: "directive", type: i5.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i5.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i5.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i5.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "directive", type: i5.FormGroupName, selector: "[formGroupName]", inputs: ["formGroupName"] }, { kind: "component", type: i6.PryCheckboxComponent, selector: "pry-checkbox", inputs: ["circle", "name", "inputId", "inhibit"] }, { kind: "component", type: i3.PrySelectComponent, selector: "pry-select", inputs: ["items", "clearable", "multiple", "closeOnSelect", "placeholder", "isForm", "required", "name", "readonly", "autocomplete", "alwaysShowAutosuggestedValues", "externalAutocompleteService", "bindValue", "bindLabel", "iconSize", "bindIcon", "template", "i18nPrefix", "bindClasses", "loading", "elementRef"], outputs: ["searched", "cleared", "clicked"] }, { kind: "pipe", type: i3.I18nPipe, name: "i18n" }] }); }
108
187
  }
109
188
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.3", ngImport: i0, type: AdminFieldsFormComponent, decorators: [{
110
189
  type: Component,
111
- args: [{ selector: 'pry-admin-fields-form', template: "<div>\n <form class=\"o-form\" [formGroup]=\"fieldForm\" (ngSubmit)=\"addField()\">\n <div class=\"m-form-label-field -width-sm\">\n <label id=\"name-label\" for=\"field_name\" class=\"a-label\">\n {{ '@pry.admin.fields.name' | i18n }} *\n <span class=\"u-visually-hidden\">({{ '@pry.admin.required' | i18n }})</span>\n </label>\n <input\n id=\"field_name\"\n type=\"text\"\n class=\"a-form-field\"\n formControlName=\"name\"\n [attr.aria-labelledby]=\"isSubmitted && fieldForm.get('name')?.invalid ? 'name-label name-error' : 'name-label'\"\n [attr.aria-invalid]=\"isSubmitted && fieldForm.get('name')?.invalid\"\n required\n />\n <label\n *ngIf=\"isSubmitted && fieldForm.get('name')?.invalid\"\n id=\"name-error\"\n for=\"field_name\"\n class=\"a-label a-label--help -error\"\n >\n <span *ngIf=\"fieldForm.get('name')?.hasError('same-name')\">{{ '@pry.admin.exists' | i18n }}</span>\n <span *ngIf=\"fieldForm.get('name')?.hasError('required')\">{{ '@pry.admin.required' | i18n }}</span>\n <span *ngIf=\"fieldForm.get('name')?.hasError('minlength')\">{{\n '@pry.admin.minLength' | i18n : { len: 3 }\n }}</span>\n <span *ngIf=\"fieldForm.get('name')?.hasError('maxlength')\">{{\n '@pry.admin.maxLength' | i18n : { len: 100 }\n }}</span>\n <span *ngIf=\"fieldForm.get('name')?.hasError('whitespace') && !fieldForm.get('name')?.hasError('minlength')\">{{\n '@pry.admin.noWhitespace' | i18n\n }}</span>\n </label>\n </div>\n\n <div class=\"m-form-label-field -width-sm\">\n <label class=\"a-label\">\n {{ '@pry.admin.fields.type' | i18n }} *\n <span class=\"u-visually-hidden\">({{ '@pry.admin.required' | i18n }})</span>\n </label>\n <div class=\"u-display-flex\">\n <pry-select\n class=\"-width-sm\"\n formControlName=\"type\"\n [items]=\"fieldTypeTranslations\"\n bindValue=\"varType\"\n bindLabel=\"translation\"\n [isForm]=\"true\"\n ></pry-select>\n <div\n *ngIf=\"selectedFieldTypeDescription$ | async as description\"\n class=\"m-info-icon a-tooltip -tooltip-width-lg u-self-center -flex-shrink-0\"\n [attr.data-tooltip]=\"description\"\n data-tooltip-position=\"right\"\n >\n <span>i</span>\n </div>\n </div>\n </div>\n\n <div class=\"m-form-label-field -width-sm\" *ngIf=\"isGeographicType\">\n <label class=\"a-label\">\n {{ '@pry.admin.fields.crs' | i18n }} *\n <span class=\"u-visually-hidden\">({{ '@pry.admin.required' | i18n }})</span>\n </label>\n <div class=\"u-display-flex\">\n <pry-select\n class=\"-width-sm\"\n formControlName=\"crs\"\n [items]=\"CRS_OPTIONS\"\n bindValue=\"code\"\n bindLabel=\"label\"\n [isForm]=\"true\"\n id=\"crs\"\n ></pry-select>\n </div>\n <label\n *ngIf=\"isSubmitted && fieldForm.get('crs') && fieldForm.get('crs')?.invalid\"\n id=\"crs-error\"\n for=\"crs\"\n class=\"a-label a-label--help -error\"\n >\n <span *ngIf=\"fieldForm.get('name')?.hasError('required')\">{{ '@pry.admin.required' | i18n }}</span>\n </label>\n </div>\n\n <div class=\"m-btn-group -width-sm\">\n <button\n type=\"button\"\n class=\"a-btn a-btn--secondary\"\n (click)=\"goBack()\"\n [innerHTML]=\"'@pry.admin.cancel' | i18n\"\n ></button>\n <button\n class=\"a-btn a-btn--primary\"\n type=\"submit\"\n [innerHTML]=\"(currentField ? '@pry.admin.edit' : '@pry.admin.create') | i18n\"\n ></button>\n </div>\n </form>\n</div>\n" }]
112
- }], ctorParameters: () => [{ type: i1.Store }, { type: i2.Router }, { type: i2.ActivatedRoute }, { type: i3.UntypedFormBuilder }, { type: i4.PryI18nService }], propDecorators: { currentField: [{
190
+ args: [{ selector: 'pry-admin-fields-form', template: "<div>\n <form class=\"o-form\" [formGroup]=\"form\" (ngSubmit)=\"submit()\">\n <div class=\"m-form-label-field -width-sm\">\n <label id=\"name-label\" for=\"field_name\" class=\"a-label\">\n {{ '@pry.admin.fields.name' | i18n }} *\n <span class=\"u-visually-hidden\">({{ '@pry.admin.required' | i18n }})</span>\n </label>\n <input\n id=\"field_name\"\n type=\"text\"\n class=\"a-form-field\"\n formControlName=\"name\"\n [attr.aria-labelledby]=\"name?.dirty && name?.invalid ? 'name-label name-error' : 'name-label'\"\n [attr.aria-invalid]=\"name?.dirty && name?.invalid\"\n />\n @if (name?.dirty && name?.invalid) {\n <label id=\"name-error\" for=\"field_name\" class=\"a-label a-label--help -error\">\n @if (name?.hasError('same-name')) {\n <span>{{ '@pry.admin.exists' | i18n }}</span>\n }\n @if (name?.hasError('required')) {\n <span>{{ '@pry.admin.required' | i18n }}</span>\n }\n @if (name?.hasError('minlength')) {\n <span>{{ '@pry.admin.minLength' | i18n: { len: 3 } }}</span>\n }\n @if (name?.hasError('maxlength')) {\n <span>{{ '@pry.admin.maxLength' | i18n: { len: 100 } }}</span>\n }\n @if (name?.hasError('whitespace') && !name?.hasError('minlength')) {\n <span>{{ '@pry.admin.noWhitespace' | i18n }}</span>\n }\n </label>\n }\n </div>\n\n <div class=\"m-form-label-field -width-sm\">\n <label class=\"a-label\" for=\"field_type\">\n {{ '@pry.admin.fields.type' | i18n }} *\n <span class=\"u-visually-hidden\">({{ '@pry.admin.required' | i18n }})</span>\n </label>\n <div class=\"u-display-flex\">\n <pry-select\n id=\"field_type\"\n class=\"u-flex-grow-1\"\n formControlName=\"type\"\n [items]=\"fieldTypes\"\n [i18nPrefix]=\"FIELD_I18N.label\"\n [isForm]=\"true\"\n ></pry-select>\n <div\n class=\"m-info-icon a-tooltip -tooltip-width-lg u-self-center u-flex-shrink-0\"\n [attr.data-tooltip]=\"FIELD_I18N.information + this.type?.value | i18n\"\n data-tooltip-position=\"right\"\n >\n <span>i</span>\n </div>\n </div>\n </div>\n\n @if (isGeographicType) {\n <div class=\"m-form-label-field -width-sm\">\n <label class=\"a-label\" for=\"crs\">\n {{ '@pry.admin.fields.crs' | i18n }} *\n <span class=\"u-visually-hidden\">({{ '@pry.admin.required' | i18n }})</span>\n </label>\n <div class=\"u-display-flex\">\n <pry-select\n class=\"-width-sm\"\n formControlName=\"crs\"\n [items]=\"CRS_OPTIONS\"\n bindValue=\"code\"\n bindLabel=\"label\"\n [isForm]=\"true\"\n id=\"crs\"\n ></pry-select>\n </div>\n @if (crs?.dirty && crs?.invalid) {\n <label id=\"crs-error\" for=\"crs\" class=\"a-label a-label--help -error\">\n @if (crs?.hasError('required')) {\n <span>{{ '@pry.admin.required' | i18n }}</span>\n }\n </label>\n }\n </div>\n }\n\n @if (formatOptions) {\n <div formGroupName=\"formatOptions\">\n <h3 class=\"a-h3\">{{ '@pry.admin.fields.formatOptions.title' | i18n }}</h3>\n @if (type?.value === FieldType.INTEGER || type?.value === FieldType.LONG || type?.value === FieldType.DECIMAL) {\n <ng-container *ngTemplateOutlet=\"numberFormatOptions\"></ng-container>\n } @else if (type?.value === FieldType.INSTANT) {\n <ng-container *ngTemplateOutlet=\"dateFormatOptions\"></ng-container>\n }\n\n <ng-template #numberFormatOptions>\n @if (type?.value === FieldType.DECIMAL) {\n <div class=\"m-form-label-field -width-sm\">\n <label class=\"a-label\" for=\"field_format_comma\">{{\n '@pry.admin.fields.formatOptions.decimalPrecision' | i18n\n }}</label>\n <input formControlName=\"decimalPrecision\" id=\"field_format_comma\" type=\"number\" class=\"a-form-field\" />\n </div>\n }\n <div class=\"m-form-label-field -width-sm\">\n <pry-checkbox\n formControlName=\"isLocaleFormat\"\n inputId=\"field_format_locale_number_format\"\n [inhibit]=\"false\"\n >\n {{ '@pry.admin.fields.formatOptions.isLocaleFormat' | i18n }}\n </pry-checkbox>\n </div>\n <div class=\"m-form-label-field -width-sm\">\n <label class=\"a-label\" for=\"field_format_unit\">{{ '@pry.admin.fields.formatOptions.unit' | i18n }}</label>\n <input formControlName=\"unit\" id=\"field_format_unit\" type=\"text\" class=\"a-form-field\" />\n </div>\n </ng-template>\n\n <ng-template #dateFormatOptions>\n <div class=\"m-form-label-field -width-sm\">\n <label class=\"a-label\" for=\"field_format_date\">{{\n '@pry.admin.fields.formatOptions.dateFormat' | i18n\n }}</label>\n <pry-select\n formControlName=\"dateFormat\"\n id=\"field_format_date\"\n [items]=\"dateFormats\"\n [isForm]=\"true\"\n i18nPrefix=\"@pry.admin.fields.formatOptions.dateFormatOptions.\"\n [clearable]=\"true\"\n ></pry-select>\n </div>\n </ng-template>\n </div>\n }\n\n <div class=\"m-btn-group -width-sm\">\n <button\n type=\"button\"\n class=\"a-btn a-btn--secondary\"\n (click)=\"goBack()\"\n [innerHTML]=\"'@pry.admin.cancel' | i18n\"\n ></button>\n <button\n class=\"a-btn a-btn--primary\"\n type=\"submit\"\n [innerHTML]=\"(currentField ? '@pry.admin.edit' : '@pry.admin.create') | i18n\"\n ></button>\n </div>\n </form>\n</div>\n" }]
191
+ }], ctorParameters: () => [{ type: i1.Store }, { type: i2.Router }, { type: i2.ActivatedRoute }, { type: i3.PryI18nService }], propDecorators: { currentField: [{
113
192
  type: Input
114
193
  }] } });
115
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"admin-fields-form.component.js","sourceRoot":"","sources":["../../../../../../../../projects/provoly/dashboard/admin/components/admin-fields/admin-fields-form/admin-fields-form.component.ts","../../../../../../../../projects/provoly/dashboard/admin/components/admin-fields/admin-fields-form/admin-fields-form.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnDestroy, OnInit } from '@angular/core';\nimport { FormControl, UntypedFormBuilder, UntypedFormGroup, Validators } from '@angular/forms';\nimport { ActivatedRoute, Router } from '@angular/router';\nimport { Store } from '@ngrx/store';\nimport {\n  Field,\n  FIELD_OPTIONS,\n  FieldActions,\n  FieldSelectors,\n  GeometricFieldTypes,\n  PryI18nService\n} from '@provoly/dashboard';\nimport { combineLatest, map, Observable, startWith, Subscription } from 'rxjs';\nimport { v4 as uuid } from 'uuid';\nimport { noWhitespaceValidator } from '../../../components/admin.component';\nimport { AdminActions } from '../../../store/admin.actions';\nimport { FieldsActions } from '../store/fields.actions';\nimport { distinctUntilChanged } from 'rxjs/operators';\n\nexport const CRS_OPTIONS = [\n  { label: 'WGS84 (EPSG:4326)', code: 'EPSG:4326' },\n  { label: 'Lambert93 (EPSG: 2154)', code: 'EPSG:2154' }\n];\n\n@Component({\n  selector: 'pry-admin-fields-form',\n  templateUrl: './admin-fields-form.component.html'\n})\nexport class AdminFieldsFormComponent implements OnInit, OnDestroy {\n  fieldNames$?: Observable<string[]>;\n  nameAlreadyExists$?: Observable<boolean>;\n  sub = new Subscription();\n\n  fieldForm: UntypedFormGroup;\n  goBackPath: string;\n  goBackPathEdit: string;\n  isSubmitted = false;\n  fieldTypeTranslations: { [key: string]: string }[] = [];\n  selectedFieldTypeDescription$?: Observable<string>;\n  @Input() currentField?: Field;\n\n  constructor(\n    private store: Store<any>,\n    private router: Router,\n    private route: ActivatedRoute,\n    private formBuilder: UntypedFormBuilder,\n    private i18nService: PryI18nService\n  ) {\n    this.fieldTypeTranslations = FIELD_OPTIONS.map((translate) => ({\n      varType: translate.varType,\n      translation: this.i18nService.instant(translate.translation),\n      description: this.i18nService.instant(translate.description)\n    }));\n    this.fieldTypeTranslations.sort((a, b) => a['translation'].localeCompare(b['translation']));\n    this.store.dispatch(FieldActions.load());\n    this.goBackPath = this.router.createUrlTree(['..'], { relativeTo: this.route }).toString();\n    this.goBackPathEdit = this.router.createUrlTree(['../..'], { relativeTo: this.route }).toString();\n    this.fieldForm = this.formBuilder.group({\n      id: [uuid()],\n      name: ['', [Validators.required, Validators.minLength(3), Validators.maxLength(100), noWhitespaceValidator]],\n      type: [this.fieldTypeTranslations[0]['varType']]\n    });\n  }\n\n  ngOnInit(): void {\n    this.fieldNames$ = this.store\n      .select(FieldSelectors.fields)\n      .pipe(map((fields: Field[]) => fields.map((field: Field) => field.name.toLowerCase())));\n\n    this.nameAlreadyExists$ = combineLatest([\n      this.fieldForm.get('name')?.valueChanges as Observable<string>,\n      this.fieldNames$\n    ]).pipe(map(([value, fieldNames]) => fieldNames.includes(value.toLowerCase()) && value != this.currentField?.name));\n    this.sub.add(\n      this.nameAlreadyExists$.subscribe((value) => {\n        if (value) {\n          this.fieldForm.controls['name'].setErrors({ 'same-name': true });\n        }\n        return value;\n      })\n    );\n\n    if (this.currentField) {\n      this.fieldForm.patchValue({\n        id: this.currentField.id,\n        name: this.currentField.name,\n        type: this.currentField.type\n      });\n      this.fieldForm.controls['type'].disable();\n      if (this.isGeographicType) {\n        this.fieldForm.addControl('crs', new FormControl(this.currentField.crs, [Validators.required]));\n        this.fieldForm.controls['crs'].disable();\n      }\n    }\n\n    this.selectedFieldTypeDescription$ = this.fieldForm.get('type')?.valueChanges.pipe(\n      startWith(this.currentField?.type ?? this.fieldTypeTranslations[0]['varType']),\n      distinctUntilChanged(),\n      map(\n        (selectedType: string) =>\n          this.fieldTypeTranslations.find((translation) => translation['varType'] === selectedType)?.['description'] ??\n          ''\n      )\n    );\n\n    this.fieldForm.get('type')!.valueChanges.subscribe((type) => {\n      if (this.isGeographicType) {\n        this.fieldForm.addControl('crs', new FormControl(CRS_OPTIONS[0].code, [Validators.required]));\n      } else {\n        this.fieldForm.removeControl('crs');\n      }\n    });\n  }\n\n  get isGeographicType() {\n    return GeometricFieldTypes.includes(this.fieldForm.get('type')?.value);\n  }\n\n  ngOnDestroy() {\n    this.sub.unsubscribe();\n  }\n\n  goBack() {\n    this.store.dispatch(AdminActions.routeTo({ path: this.getPath(), params: undefined }));\n  }\n\n  addField() {\n    this.fieldForm.patchValue({\n      name: this.fieldForm.value.name.trim()\n    });\n    this.isSubmitted = true;\n    if (this.fieldForm.valid) {\n      this.isSubmitted = false;\n      let fieldToSave = this.fieldForm.getRawValue() as Field;\n      this.store.dispatch(FieldsActions.saveField({ field: fieldToSave, route: this.getPath() }));\n    }\n  }\n\n  private getPath() {\n    return this.currentField ? this.goBackPathEdit : this.goBackPath;\n  }\n\n  protected readonly CRS_OPTIONS = CRS_OPTIONS;\n}\n","<div>\n  <form class=\"o-form\" [formGroup]=\"fieldForm\" (ngSubmit)=\"addField()\">\n    <div class=\"m-form-label-field -width-sm\">\n      <label id=\"name-label\" for=\"field_name\" class=\"a-label\">\n        {{ '@pry.admin.fields.name' | i18n }} *\n        <span class=\"u-visually-hidden\">({{ '@pry.admin.required' | i18n }})</span>\n      </label>\n      <input\n        id=\"field_name\"\n        type=\"text\"\n        class=\"a-form-field\"\n        formControlName=\"name\"\n        [attr.aria-labelledby]=\"isSubmitted && fieldForm.get('name')?.invalid ? 'name-label name-error' : 'name-label'\"\n        [attr.aria-invalid]=\"isSubmitted && fieldForm.get('name')?.invalid\"\n        required\n      />\n      <label\n        *ngIf=\"isSubmitted && fieldForm.get('name')?.invalid\"\n        id=\"name-error\"\n        for=\"field_name\"\n        class=\"a-label a-label--help -error\"\n      >\n        <span *ngIf=\"fieldForm.get('name')?.hasError('same-name')\">{{ '@pry.admin.exists' | i18n }}</span>\n        <span *ngIf=\"fieldForm.get('name')?.hasError('required')\">{{ '@pry.admin.required' | i18n }}</span>\n        <span *ngIf=\"fieldForm.get('name')?.hasError('minlength')\">{{\n          '@pry.admin.minLength' | i18n : { len: 3 }\n        }}</span>\n        <span *ngIf=\"fieldForm.get('name')?.hasError('maxlength')\">{{\n          '@pry.admin.maxLength' | i18n : { len: 100 }\n        }}</span>\n        <span *ngIf=\"fieldForm.get('name')?.hasError('whitespace') && !fieldForm.get('name')?.hasError('minlength')\">{{\n          '@pry.admin.noWhitespace' | i18n\n        }}</span>\n      </label>\n    </div>\n\n    <div class=\"m-form-label-field -width-sm\">\n      <label class=\"a-label\">\n        {{ '@pry.admin.fields.type' | i18n }} *\n        <span class=\"u-visually-hidden\">({{ '@pry.admin.required' | i18n }})</span>\n      </label>\n      <div class=\"u-display-flex\">\n        <pry-select\n          class=\"-width-sm\"\n          formControlName=\"type\"\n          [items]=\"fieldTypeTranslations\"\n          bindValue=\"varType\"\n          bindLabel=\"translation\"\n          [isForm]=\"true\"\n        ></pry-select>\n        <div\n          *ngIf=\"selectedFieldTypeDescription$ | async as description\"\n          class=\"m-info-icon a-tooltip -tooltip-width-lg u-self-center -flex-shrink-0\"\n          [attr.data-tooltip]=\"description\"\n          data-tooltip-position=\"right\"\n        >\n          <span>i</span>\n        </div>\n      </div>\n    </div>\n\n    <div class=\"m-form-label-field -width-sm\" *ngIf=\"isGeographicType\">\n      <label class=\"a-label\">\n        {{ '@pry.admin.fields.crs' | i18n }} *\n        <span class=\"u-visually-hidden\">({{ '@pry.admin.required' | i18n }})</span>\n      </label>\n      <div class=\"u-display-flex\">\n        <pry-select\n          class=\"-width-sm\"\n          formControlName=\"crs\"\n          [items]=\"CRS_OPTIONS\"\n          bindValue=\"code\"\n          bindLabel=\"label\"\n          [isForm]=\"true\"\n          id=\"crs\"\n        ></pry-select>\n      </div>\n      <label\n        *ngIf=\"isSubmitted && fieldForm.get('crs') && fieldForm.get('crs')?.invalid\"\n        id=\"crs-error\"\n        for=\"crs\"\n        class=\"a-label a-label--help -error\"\n      >\n        <span *ngIf=\"fieldForm.get('name')?.hasError('required')\">{{ '@pry.admin.required' | i18n }}</span>\n      </label>\n    </div>\n\n    <div class=\"m-btn-group -width-sm\">\n      <button\n        type=\"button\"\n        class=\"a-btn a-btn--secondary\"\n        (click)=\"goBack()\"\n        [innerHTML]=\"'@pry.admin.cancel' | i18n\"\n      ></button>\n      <button\n        class=\"a-btn a-btn--primary\"\n        type=\"submit\"\n        [innerHTML]=\"(currentField ? '@pry.admin.edit' : '@pry.admin.create') | i18n\"\n      ></button>\n    </div>\n  </form>\n</div>\n"]}
194
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"admin-fields-form.component.js","sourceRoot":"","sources":["../../../../../../../../projects/provoly/dashboard/admin/components/admin-fields/admin-fields-form/admin-fields-form.component.ts","../../../../../../../../projects/provoly/dashboard/admin/components/admin-fields/admin-fields-form/admin-fields-form.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,KAAK,EAAqB,MAAM,eAAe,CAAC;AACpE,OAAO,EAAmB,WAAW,EAAE,SAAS,EAAE,UAAU,EAAE,MAAM,gBAAgB,CAAC;AAGrF,OAAO,EACL,UAAU,EAEV,YAAY,EACZ,cAAc,EACd,SAAS,EACT,mBAAmB,EAEnB,wBAAwB,EACzB,MAAM,oBAAoB,CAAC;AAC5B,OAAO,EAAE,aAAa,EAAE,GAAG,EAAc,MAAM,MAAM,CAAC;AACtD,OAAO,EAAE,EAAE,IAAI,IAAI,EAAE,MAAM,MAAM,CAAC;AAClC,OAAO,EAAE,qBAAqB,EAAE,MAAM,qCAAqC,CAAC;AAC5E,OAAO,EAAE,YAAY,EAAE,MAAM,8BAA8B,CAAC;AAC5D,OAAO,EAAE,aAAa,EAAE,MAAM,yBAAyB,CAAC;AACxD,OAAO,EAAE,iBAAiB,EAAE,MAAM,2CAA2C,CAAC;;;;;;;;AAE9E,MAAM,CAAC,MAAM,WAAW,GAAG;IACzB,EAAE,KAAK,EAAE,mBAAmB,EAAE,IAAI,EAAE,WAAW,EAAE;IACjD,EAAE,KAAK,EAAE,wBAAwB,EAAE,IAAI,EAAE,WAAW,EAAE;CACvD,CAAC;AAoBF,MAAM,OAAO,wBAAyB,SAAQ,wBAAwB;IAapE,YACU,KAAiB,EACjB,MAAc,EACd,KAAqB,EACrB,IAAoB;QAE5B,KAAK,EAAE,CAAC;QALA,UAAK,GAAL,KAAK,CAAY;QACjB,WAAM,GAAN,MAAM,CAAQ;QACd,UAAK,GAAL,KAAK,CAAgB;QACrB,SAAI,GAAJ,IAAI,CAAgB;QAT9B,gBAAW,GAAG,MAAM,CAAC,IAAI,CAAC,iBAAiB,CAAC,KAAK,CAAC,CAAC;QAyMhC,gBAAW,GAAG,WAAW,CAAC;QAC1B,cAAS,GAAG,SAAS,CAAC;QACtB,eAAU,GAAG,UAAU,CAAC;QA/LzC,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,YAAY,CAAC,IAAI,EAAE,CAAC,CAAC;QAEzC,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,KAAK;aAC1B,MAAM,CAAC,cAAc,CAAC,MAAM,CAAC;aAC7B,IAAI,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC,CAAC,CAAC,CAAC;QAE1E,IAAI,CAAC,UAAU,GAAG,MAAM,CAAC,MAAM,CAAC,SAAS,CAAC;aACvC,MAAM,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,KAAK,SAAS,CAAC,kBAAkB,CAAC;aACvD,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE;YACb,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,KAAK,GAAG,CAAC,CAAC,EAAE,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,KAAK,GAAG,CAAC,CAAC,CAAC,CAAC;YAC5G,OAAO,MAAM,CAAC,aAAa,CAAC,MAAM,CAAC,CAAC;QACtC,CAAC,CAAC,CAAC;QAEL,IAAI,CAAC,IAAI,GAAG,IAAI,SAAS,CAAY;YACnC,IAAI,EAAE,IAAI,WAAW,CAAC,EAAE,EAAE;gBACxB,UAAU,EAAE,CAAC,UAAU,CAAC,QAAQ,EAAE,UAAU,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,UAAU,CAAC,SAAS,CAAC,GAAG,CAAC,EAAE,qBAAqB,CAAC;gBAC5G,WAAW,EAAE,IAAI;aAClB,CAAC;YACF,IAAI,EAAE,IAAI,WAAW,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,EAAE,EAAE,WAAW,EAAE,IAAI,EAAE,CAAC;YAChE,aAAa,EAAE,IAAI,SAAS,CAAC,EAAE,CAAC;SACjC,CAAC,CAAC;QAEH,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,EAAE,YAAY,CAAC,SAAS,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,uBAAuB,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QACxG,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,EAAE,IAAI,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;QAEnD,IAAI,CAAC,kBAAkB,GAAG,aAAa,CAAC,CAAC,IAAI,CAAC,IAAK,CAAC,YAAY,EAAE,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,IAAI,CACvF,GAAG,CAAC,CAAC,CAAC,KAAK,EAAE,UAAU,CAAC,EAAE,EAAE,CAAC,UAAU,CAAC,QAAQ,CAAC,KAAK,CAAC,WAAW,EAAE,CAAC,IAAI,KAAK,IAAI,IAAI,CAAC,YAAY,EAAE,IAAI,CAAC,CAC3G,CAAC;QACF,IAAI,CAAC,aAAa,CAAC,GAAG,CACpB,IAAI,CAAC,kBAAkB,CAAC,SAAS,CAAC,CAAC,KAAK,EAAE,EAAE;YAC1C,IAAI,KAAK,EAAE,CAAC;gBACV,IAAI,CAAC,IAAI,EAAE,SAAS,CAAC,EAAE,WAAW,EAAE,IAAI,EAAE,CAAC,CAAC;YAC9C,CAAC;YACD,OAAO,KAAK,CAAC;QACf,CAAC,CAAC,CACH,CAAC;QAEF,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,MAAM,CAAC,aAAa,CAAC,CAAC,IAAI,CAAC,EAAE,EAAE,UAAU,EAAE,IAAI,CAAC,KAAK,EAAE,CAAC,CAAC,QAAQ,EAAE,CAAC;QAC3F,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,MAAM,CAAC,aAAa,CAAC,CAAC,OAAO,CAAC,EAAE,EAAE,UAAU,EAAE,IAAI,CAAC,KAAK,EAAE,CAAC,CAAC,QAAQ,EAAE,CAAC;IACpG,CAAC;IAED,QAAQ;QACN,IAAI,IAAI,CAAC,YAAY,EAAE,CAAC;YACtB,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC;gBACnB,IAAI,EAAE,IAAI,CAAC,YAAY,CAAC,IAAI;gBAC5B,IAAI,EAAE,IAAI,CAAC,YAAY,CAAC,IAAI;aAC7B,CAAC,CAAC;YACH,IAAI,CAAC,IAAK,CAAC,OAAO,EAAE,CAAC;YACrB,IAAI,IAAI,CAAC,gBAAgB,EAAE,CAAC;gBAC1B,IAAI,CAAC,IAAI,CAAC,UAAU,CAClB,KAAK,EACL,IAAI,WAAW,CAAC,IAAI,CAAC,YAAY,CAAC,GAAG,EAAE,EAAE,UAAU,EAAE,CAAC,UAAU,CAAC,QAAQ,CAAC,EAAE,WAAW,EAAE,IAAI,EAAE,CAAC,CACjG,CAAC;gBACF,IAAI,CAAC,GAAG,EAAE,OAAO,EAAE,CAAC;YACtB,CAAC;YACD,IAAI,CAAC,qBAAqB,EAAE,CAAC;QAC/B,CAAC;QACD,IAAI,CAAC,aAAa,CAAC,GAAG,CACpB,IAAI,CAAC,IAAK,CAAC,YAAY,CAAC,SAAS,CAAC,CAAC,IAAI,EAAE,EAAE;YACzC,IAAI,IAAI,CAAC,gBAAgB,EAAE,CAAC;gBAC1B,IAAI,CAAC,IAAI,CAAC,UAAU,CAClB,KAAK,EACL,IAAI,WAAW,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,IAAI,EAAE,EAAE,UAAU,EAAE,CAAC,UAAU,CAAC,QAAQ,CAAC,EAAE,WAAW,EAAE,IAAI,EAAE,CAAC,CAC/F,CAAC;YACJ,CAAC;iBAAM,CAAC;gBACN,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;YACjC,CAAC;QACH,CAAC,CAAC,CACH,CAAC;IACJ,CAAC;IAED,IAAI,IAAI;QACN,OAAO,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;IAC/B,CAAC;IAED,IAAI,IAAI;QACN,OAAO,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;IAC/B,CAAC;IAED,IAAI,GAAG;QACL,OAAO,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;IAC9B,CAAC;IAED,IAAI,aAAa;QACf,OAAO,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,eAAe,CAAiC,CAAC;IACxE,CAAC;IAED,IAAI,gBAAgB;QAClB,OAAO,mBAAmB,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,EAAE,KAAe,CAAC,CAAC;IAClE,CAAC;IAED,MAAM;QACJ,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,YAAY,CAAC,OAAO,CAAC,EAAE,IAAI,EAAE,IAAI,CAAC,OAAO,EAAE,EAAE,MAAM,EAAE,SAAS,EAAE,CAAC,CAAC,CAAC;IACzF,CAAC;IAED,YAAY;QACV,OAAO;YACL,IAAI,EAAE,IAAI,CAAC,IAAK,CAAC,KAAK;YACtB,IAAI,EAAE,IAAI,CAAC,IAAK,CAAC,KAAK;YACtB,GAAG,EAAE,IAAI,CAAC,GAAG,EAAE,KAAK;YACpB,IAAI,EAAE,IAAI,CAAC,aAAa,EAAE,KAAK,CAAC,IAAI,IAAI,SAAS;YACjD,gBAAgB,EAAE,IAAI,CAAC,aAAa,EAAE,KAAK,CAAC,gBAAgB,IAAI,SAAS;YACzE,cAAc,EAAE,IAAI,CAAC,aAAa,EAAE,KAAK,CAAC,cAAc,IAAI,SAAS;YACrE,MAAM,EAAE,IAAI,CAAC,aAAa,EAAE,KAAK,CAAC,UAAU,IAAI,SAAS;SAC1D,CAAC;IACJ,CAAC;IAED,MAAM;QACJ,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC;YACnB,IAAI,EAAE,IAAI,CAAC,IAAI,EAAE,KAAK,EAAE,IAAI,EAAE;SAC/B,CAAC,CAAC;QACH,IAAI,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC;YACpB,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,EAAE,CAAC;QAC5D,CAAC;IACH,CAAC;IAED,SAAS;QACP,IAAI,CAAC,KAAK,CAAC,QAAQ,CACjB,aAAa,CAAC,SAAS,CAAC;YACtB,KAAK,EAAE,EAAE,EAAE,EAAE,IAAI,EAAE,EAAE,GAAG,IAAI,CAAC,YAAY,EAAE,EAAE;YAC7C,KAAK,EAAE,IAAI,CAAC,OAAO,EAAE;SACtB,CAAC,CACH,CAAC;IACJ,CAAC;IAED,WAAW;QACT,IAAI,CAAC,KAAK,CAAC,QAAQ,CACjB,aAAa,CAAC,WAAW,CAAC;YACxB,KAAK,EAAE,EAAE,EAAE,EAAE,IAAI,CAAC,YAAa,CAAC,EAAE,EAAE,GAAG,IAAI,CAAC,YAAY,EAAE,EAAE;YAC5D,KAAK,EAAE,IAAI,CAAC,OAAO,EAAE;SACtB,CAAC,CACH,CAAC;IACJ,CAAC;IAED,uBAAuB,CAAC,IAAsB;QAC5C,QAAQ,IAAI,EAAE,CAAC;YACb,KAAK,SAAS,CAAC,OAAO,CAAC;YACvB,KAAK,SAAS,CAAC,IAAI;gBACjB,IAAI,CAAC,aAAa,EAAE,UAAU,CAAC,gBAAgB,EAAE,IAAI,WAAW,CAAC,IAAI,CAAC,CAAC,CAAC;gBACxE,IAAI,CAAC,aAAa,EAAE,UAAU,CAAC,MAAM,EAAE,IAAI,WAAW,CAAC,IAAI,CAAC,CAAC,CAAC;gBAC9D,IAAI,CAAC,aAAa,EAAE,aAAa,CAAC,kBAAkB,CAAC,CAAC;gBACtD,IAAI,CAAC,aAAa,EAAE,aAAa,CAAC,YAAY,CAAC,CAAC;gBAChD,MAAM;YACR,KAAK,SAAS,CAAC,OAAO;gBACpB,IAAI,CAAC,aAAa,EAAE,UAAU,CAAC,gBAAgB,EAAE,IAAI,WAAW,CAAC,IAAI,CAAC,CAAC,CAAC;gBACxE,IAAI,CAAC,aAAa,EAAE,UAAU,CAAC,MAAM,EAAE,IAAI,WAAW,CAAC,IAAI,CAAC,CAAC,CAAC;gBAC9D,IAAI,CAAC,aAAa,EAAE,UAAU,CAAC,kBAAkB,EAAE,IAAI,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC;gBACvE,IAAI,CAAC,aAAa,EAAE,aAAa,CAAC,YAAY,CAAC,CAAC;gBAChD,MAAM;YACR,KAAK,SAAS,CAAC,OAAO;gBACpB,IAAI,CAAC,aAAa,EAAE,aAAa,CAAC,gBAAgB,CAAC,CAAC;gBACpD,IAAI,CAAC,aAAa,EAAE,aAAa,CAAC,MAAM,CAAC,CAAC;gBAC1C,IAAI,CAAC,aAAa,EAAE,aAAa,CAAC,kBAAkB,CAAC,CAAC;gBACtD,IAAI,CAAC,aAAa,EAAE,UAAU,CAAC,YAAY,EAAE,IAAI,WAAW,CAAC,IAAI,CAAC,CAAC,CAAC;gBACpE,MAAM;YACR;gBACE,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,eAAe,CAAC,CAAC;gBACzC,MAAM;QACV,CAAC;IACH,CAAC;IAED,qBAAqB;QACnB,QAAQ,IAAI,CAAC,YAAY,EAAE,IAAI,EAAE,CAAC;YAChC,KAAK,SAAS,CAAC,OAAO,CAAC;YACvB,KAAK,SAAS,CAAC,IAAI;gBACjB,IAAI,CAAC,aAAa,EAAE,UAAU,CAAC;oBAC7B,cAAc,EAAE,IAAI,CAAC,YAAY,EAAE,cAAc;oBACjD,IAAI,EAAE,IAAI,CAAC,YAAY,EAAE,IAAI;iBAC9B,CAAC,CAAC;gBACH,MAAM;YACR,KAAK,SAAS,CAAC,OAAO;gBACpB,IAAI,CAAC,aAAa,EAAE,UAAU,CAAC;oBAC7B,cAAc,EAAE,IAAI,CAAC,YAAY,EAAE,cAAc;oBACjD,IAAI,EAAE,IAAI,CAAC,YAAY,EAAE,IAAI;oBAC7B,gBAAgB,EAAE,IAAI,CAAC,YAAY,EAAE,gBAAgB;iBACtD,CAAC,CAAC;gBACH,MAAM;YACR,KAAK,SAAS,CAAC,OAAO;gBACpB,IAAI,CAAC,aAAa,EAAE,UAAU,CAAC,EAAE,UAAU,EAAE,IAAI,CAAC,YAAY,EAAE,MAAM,EAAE,CAAC,CAAC;gBAC1E,MAAM;YACR;gBACE,MAAM;QACV,CAAC;IACH,CAAC;IAEO,OAAO;QACb,OAAO,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC;IACnE,CAAC;8GA/MU,wBAAwB;kGAAxB,wBAAwB,8HC5CrC,u8LAyJA;;2FD7Ga,wBAAwB;kBAJpC,SAAS;+BACE,uBAAuB;yJAIxB,YAAY;sBAApB,KAAK","sourcesContent":["import { Component, Input, OnDestroy, OnInit } from '@angular/core';\nimport { AbstractControl, FormControl, FormGroup, Validators } from '@angular/forms';\nimport { ActivatedRoute, Router } from '@angular/router';\nimport { Store } from '@ngrx/store';\nimport {\n  FIELD_I18N,\n  Field,\n  FieldActions,\n  FieldSelectors,\n  FieldType,\n  GeometricFieldTypes,\n  PryI18nService,\n  SubscriptionnerDirective\n} from '@provoly/dashboard';\nimport { combineLatest, map, Observable } from 'rxjs';\nimport { v4 as uuid } from 'uuid';\nimport { noWhitespaceValidator } from '../../../components/admin.component';\nimport { AdminActions } from '../../../store/admin.actions';\nimport { FieldsActions } from '../store/fields.actions';\nimport { dateFormatOptions } from '@provoly/dashboard/components/data-format';\n\nexport const CRS_OPTIONS = [\n  { label: 'WGS84 (EPSG:4326)', code: 'EPSG:4326' },\n  { label: 'Lambert93 (EPSG: 2154)', code: 'EPSG:2154' }\n];\n\ninterface FieldForm {\n  name: FormControl<string>;\n  type: FormControl<FieldType>;\n  crs?: FormControl<string | undefined>;\n  formatOptions?: FormGroup<FormatOptionsForm>;\n}\n\ninterface FormatOptionsForm {\n  isLocaleFormat?: FormControl<boolean | null>;\n  unit?: FormControl<string | null>;\n  decimalPrecision?: FormControl<number | null>;\n  dateFormat?: FormControl<string | null>;\n}\n\n@Component({\n  selector: 'pry-admin-fields-form',\n  templateUrl: './admin-fields-form.component.html'\n})\nexport class AdminFieldsFormComponent extends SubscriptionnerDirective implements OnInit, OnDestroy {\n  @Input() currentField?: Field;\n\n  form: FormGroup<FieldForm>;\n  fieldTypes: FieldType[];\n  fieldNames$: Observable<string[]>;\n  nameAlreadyExists$?: Observable<boolean>;\n\n  dateFormats = Object.keys(dateFormatOptions.value);\n\n  goBackPath: string;\n  goBackPathEdit: string;\n\n  constructor(\n    private store: Store<any>,\n    private router: Router,\n    private route: ActivatedRoute,\n    private i18n: PryI18nService\n  ) {\n    super();\n    this.store.dispatch(FieldActions.load());\n\n    this.fieldNames$ = this.store\n      .select(FieldSelectors.fields)\n      .pipe(map((fields) => fields.map((field) => field.name.toLowerCase())));\n\n    this.fieldTypes = Object.values(FieldType)\n      .filter((type) => type !== FieldType.GEOMETRYCOLLECTION)\n      .sort((a, b) => {\n        const [labelA, labelB] = [this.i18n.instant(FIELD_I18N.label + a), this.i18n.instant(FIELD_I18N.label + b)];\n        return labelA.localeCompare(labelB);\n      });\n\n    this.form = new FormGroup<FieldForm>({\n      name: new FormControl('', {\n        validators: [Validators.required, Validators.minLength(3), Validators.maxLength(100), noWhitespaceValidator],\n        nonNullable: true\n      }),\n      type: new FormControl(this.fieldTypes[0], { nonNullable: true }),\n      formatOptions: new FormGroup({})\n    });\n\n    this.subscriptions.add(this.type?.valueChanges.subscribe((type) => this.setFormatOptionControls(type)));\n    this.form.patchValue({ type: this.fieldTypes[0] });\n\n    this.nameAlreadyExists$ = combineLatest([this.name!.valueChanges, this.fieldNames$]).pipe(\n      map(([value, fieldNames]) => fieldNames.includes(value.toLowerCase()) && value != this.currentField?.name)\n    );\n    this.subscriptions.add(\n      this.nameAlreadyExists$.subscribe((value) => {\n        if (value) {\n          this.name?.setErrors({ 'same-name': true });\n        }\n        return value;\n      })\n    );\n\n    this.goBackPath = this.router.createUrlTree(['..'], { relativeTo: this.route }).toString();\n    this.goBackPathEdit = this.router.createUrlTree(['../..'], { relativeTo: this.route }).toString();\n  }\n\n  ngOnInit(): void {\n    if (this.currentField) {\n      this.form.patchValue({\n        name: this.currentField.name,\n        type: this.currentField.type\n      });\n      this.type!.disable();\n      if (this.isGeographicType) {\n        this.form.addControl<'crs'>(\n          'crs',\n          new FormControl(this.currentField.crs, { validators: [Validators.required], nonNullable: true })\n        );\n        this.crs?.disable();\n      }\n      this.setFormatOptionValues();\n    }\n    this.subscriptions.add(\n      this.type!.valueChanges.subscribe((type) => {\n        if (this.isGeographicType) {\n          this.form.addControl(\n            'crs',\n            new FormControl(CRS_OPTIONS[0].code, { validators: [Validators.required], nonNullable: true })\n          );\n        } else {\n          this.form.removeControl('crs');\n        }\n      })\n    );\n  }\n\n  get name(): AbstractControl<string> | null {\n    return this.form.get('name');\n  }\n\n  get type(): AbstractControl<FieldType> | null {\n    return this.form.get('type');\n  }\n\n  get crs(): AbstractControl<string | undefined> | null {\n    return this.form.get('crs');\n  }\n\n  get formatOptions(): FormGroup<FormatOptionsForm> | null {\n    return this.form.get('formatOptions') as FormGroup<FormatOptionsForm>;\n  }\n\n  get isGeographicType(): boolean {\n    return GeometricFieldTypes.includes(this.type?.value as string);\n  }\n\n  goBack() {\n    this.store.dispatch(AdminActions.routeTo({ path: this.getPath(), params: undefined }));\n  }\n\n  getFormValue() {\n    return {\n      name: this.name!.value,\n      type: this.type!.value,\n      crs: this.crs?.value,\n      unit: this.formatOptions?.value.unit ?? undefined,\n      decimalPrecision: this.formatOptions?.value.decimalPrecision ?? undefined,\n      isLocaleFormat: this.formatOptions?.value.isLocaleFormat ?? undefined,\n      format: this.formatOptions?.value.dateFormat ?? undefined\n    };\n  }\n\n  submit() {\n    this.form.patchValue({\n      name: this.name?.value?.trim()\n    });\n    if (this.form.valid) {\n      this.currentField ? this.updateField() : this.saveField();\n    }\n  }\n\n  saveField() {\n    this.store.dispatch(\n      FieldsActions.saveField({\n        field: { id: uuid(), ...this.getFormValue() },\n        route: this.getPath()\n      })\n    );\n  }\n\n  updateField() {\n    this.store.dispatch(\n      FieldsActions.updateField({\n        field: { id: this.currentField!.id, ...this.getFormValue() },\n        route: this.getPath()\n      })\n    );\n  }\n\n  setFormatOptionControls(type: FieldType | null) {\n    switch (type) {\n      case FieldType.INTEGER:\n      case FieldType.LONG:\n        this.formatOptions?.addControl('isLocaleFormat', new FormControl(true));\n        this.formatOptions?.setControl('unit', new FormControl(null));\n        this.formatOptions?.removeControl('decimalPrecision');\n        this.formatOptions?.removeControl('dateFormat');\n        break;\n      case FieldType.DECIMAL:\n        this.formatOptions?.addControl('isLocaleFormat', new FormControl(true));\n        this.formatOptions?.setControl('unit', new FormControl(null));\n        this.formatOptions?.setControl('decimalPrecision', new FormControl(2));\n        this.formatOptions?.removeControl('dateFormat');\n        break;\n      case FieldType.INSTANT:\n        this.formatOptions?.removeControl('isLocaleFormat');\n        this.formatOptions?.removeControl('unit');\n        this.formatOptions?.removeControl('decimalPrecision');\n        this.formatOptions?.setControl('dateFormat', new FormControl(null));\n        break;\n      default:\n        this.form.removeControl('formatOptions');\n        break;\n    }\n  }\n\n  setFormatOptionValues() {\n    switch (this.currentField?.type) {\n      case FieldType.INTEGER:\n      case FieldType.LONG:\n        this.formatOptions?.patchValue({\n          isLocaleFormat: this.currentField?.isLocaleFormat,\n          unit: this.currentField?.unit\n        });\n        break;\n      case FieldType.DECIMAL:\n        this.formatOptions?.patchValue({\n          isLocaleFormat: this.currentField?.isLocaleFormat,\n          unit: this.currentField?.unit,\n          decimalPrecision: this.currentField?.decimalPrecision\n        });\n        break;\n      case FieldType.INSTANT:\n        this.formatOptions?.patchValue({ dateFormat: this.currentField?.format });\n        break;\n      default:\n        break;\n    }\n  }\n\n  private getPath() {\n    return this.currentField ? this.goBackPathEdit : this.goBackPath;\n  }\n\n  protected readonly CRS_OPTIONS = CRS_OPTIONS;\n  protected readonly FieldType = FieldType;\n  protected readonly FIELD_I18N = FIELD_I18N;\n}\n","<div>\n  <form class=\"o-form\" [formGroup]=\"form\" (ngSubmit)=\"submit()\">\n    <div class=\"m-form-label-field -width-sm\">\n      <label id=\"name-label\" for=\"field_name\" class=\"a-label\">\n        {{ '@pry.admin.fields.name' | i18n }} *\n        <span class=\"u-visually-hidden\">({{ '@pry.admin.required' | i18n }})</span>\n      </label>\n      <input\n        id=\"field_name\"\n        type=\"text\"\n        class=\"a-form-field\"\n        formControlName=\"name\"\n        [attr.aria-labelledby]=\"name?.dirty && name?.invalid ? 'name-label name-error' : 'name-label'\"\n        [attr.aria-invalid]=\"name?.dirty && name?.invalid\"\n      />\n      @if (name?.dirty && name?.invalid) {\n        <label id=\"name-error\" for=\"field_name\" class=\"a-label a-label--help -error\">\n          @if (name?.hasError('same-name')) {\n            <span>{{ '@pry.admin.exists' | i18n }}</span>\n          }\n          @if (name?.hasError('required')) {\n            <span>{{ '@pry.admin.required' | i18n }}</span>\n          }\n          @if (name?.hasError('minlength')) {\n            <span>{{ '@pry.admin.minLength' | i18n: { len: 3 } }}</span>\n          }\n          @if (name?.hasError('maxlength')) {\n            <span>{{ '@pry.admin.maxLength' | i18n: { len: 100 } }}</span>\n          }\n          @if (name?.hasError('whitespace') && !name?.hasError('minlength')) {\n            <span>{{ '@pry.admin.noWhitespace' | i18n }}</span>\n          }\n        </label>\n      }\n    </div>\n\n    <div class=\"m-form-label-field -width-sm\">\n      <label class=\"a-label\" for=\"field_type\">\n        {{ '@pry.admin.fields.type' | i18n }} *\n        <span class=\"u-visually-hidden\">({{ '@pry.admin.required' | i18n }})</span>\n      </label>\n      <div class=\"u-display-flex\">\n        <pry-select\n          id=\"field_type\"\n          class=\"u-flex-grow-1\"\n          formControlName=\"type\"\n          [items]=\"fieldTypes\"\n          [i18nPrefix]=\"FIELD_I18N.label\"\n          [isForm]=\"true\"\n        ></pry-select>\n        <div\n          class=\"m-info-icon a-tooltip -tooltip-width-lg u-self-center u-flex-shrink-0\"\n          [attr.data-tooltip]=\"FIELD_I18N.information + this.type?.value | i18n\"\n          data-tooltip-position=\"right\"\n        >\n          <span>i</span>\n        </div>\n      </div>\n    </div>\n\n    @if (isGeographicType) {\n      <div class=\"m-form-label-field -width-sm\">\n        <label class=\"a-label\" for=\"crs\">\n          {{ '@pry.admin.fields.crs' | i18n }} *\n          <span class=\"u-visually-hidden\">({{ '@pry.admin.required' | i18n }})</span>\n        </label>\n        <div class=\"u-display-flex\">\n          <pry-select\n            class=\"-width-sm\"\n            formControlName=\"crs\"\n            [items]=\"CRS_OPTIONS\"\n            bindValue=\"code\"\n            bindLabel=\"label\"\n            [isForm]=\"true\"\n            id=\"crs\"\n          ></pry-select>\n        </div>\n        @if (crs?.dirty && crs?.invalid) {\n          <label id=\"crs-error\" for=\"crs\" class=\"a-label a-label--help -error\">\n            @if (crs?.hasError('required')) {\n              <span>{{ '@pry.admin.required' | i18n }}</span>\n            }\n          </label>\n        }\n      </div>\n    }\n\n    @if (formatOptions) {\n      <div formGroupName=\"formatOptions\">\n        <h3 class=\"a-h3\">{{ '@pry.admin.fields.formatOptions.title' | i18n }}</h3>\n        @if (type?.value === FieldType.INTEGER || type?.value === FieldType.LONG || type?.value === FieldType.DECIMAL) {\n          <ng-container *ngTemplateOutlet=\"numberFormatOptions\"></ng-container>\n        } @else if (type?.value === FieldType.INSTANT) {\n          <ng-container *ngTemplateOutlet=\"dateFormatOptions\"></ng-container>\n        }\n\n        <ng-template #numberFormatOptions>\n          @if (type?.value === FieldType.DECIMAL) {\n            <div class=\"m-form-label-field -width-sm\">\n              <label class=\"a-label\" for=\"field_format_comma\">{{\n                '@pry.admin.fields.formatOptions.decimalPrecision' | i18n\n              }}</label>\n              <input formControlName=\"decimalPrecision\" id=\"field_format_comma\" type=\"number\" class=\"a-form-field\" />\n            </div>\n          }\n          <div class=\"m-form-label-field -width-sm\">\n            <pry-checkbox\n              formControlName=\"isLocaleFormat\"\n              inputId=\"field_format_locale_number_format\"\n              [inhibit]=\"false\"\n            >\n              {{ '@pry.admin.fields.formatOptions.isLocaleFormat' | i18n }}\n            </pry-checkbox>\n          </div>\n          <div class=\"m-form-label-field -width-sm\">\n            <label class=\"a-label\" for=\"field_format_unit\">{{ '@pry.admin.fields.formatOptions.unit' | i18n }}</label>\n            <input formControlName=\"unit\" id=\"field_format_unit\" type=\"text\" class=\"a-form-field\" />\n          </div>\n        </ng-template>\n\n        <ng-template #dateFormatOptions>\n          <div class=\"m-form-label-field -width-sm\">\n            <label class=\"a-label\" for=\"field_format_date\">{{\n              '@pry.admin.fields.formatOptions.dateFormat' | i18n\n            }}</label>\n            <pry-select\n              formControlName=\"dateFormat\"\n              id=\"field_format_date\"\n              [items]=\"dateFormats\"\n              [isForm]=\"true\"\n              i18nPrefix=\"@pry.admin.fields.formatOptions.dateFormatOptions.\"\n              [clearable]=\"true\"\n            ></pry-select>\n          </div>\n        </ng-template>\n      </div>\n    }\n\n    <div class=\"m-btn-group -width-sm\">\n      <button\n        type=\"button\"\n        class=\"a-btn a-btn--secondary\"\n        (click)=\"goBack()\"\n        [innerHTML]=\"'@pry.admin.cancel' | i18n\"\n      ></button>\n      <button\n        class=\"a-btn a-btn--primary\"\n        type=\"submit\"\n        [innerHTML]=\"(currentField ? '@pry.admin.edit' : '@pry.admin.create') | i18n\"\n      ></button>\n    </div>\n  </form>\n</div>\n"]}