@provoly/dashboard 0.13.7 → 0.13.8

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 (112) hide show
  1. package/admin/components/admin-dataset/admin-select-dataset/admin-select-dataset.component.d.ts +4 -4
  2. package/admin/components/admin-dataset/store/admin-dataset.actions.d.ts +3 -3
  3. package/esm2022/admin/components/admin-classes/admin-classes-customize/tooltip/admin-classes-customize-tooltip.component.mjs +3 -3
  4. package/esm2022/admin/components/admin-dataset/admin-select-dataset/admin-select-dataset.component.mjs +2 -2
  5. package/esm2022/admin/components/admin-dataset/store/admin-dataset.actions.mjs +1 -1
  6. package/esm2022/lib/core/components/overlay/dialog-confirm.component.mjs +5 -12
  7. package/esm2022/lib/core/components/overlay/overlay.module.mjs +5 -4
  8. package/esm2022/lib/core/components/select/select.component.mjs +2 -2
  9. package/esm2022/lib/core/components/share/share.component.mjs +3 -3
  10. package/esm2022/lib/core/model/admin-api.model.mjs +1 -1
  11. package/esm2022/lib/core/model/dataset.interface.mjs +1 -1
  12. package/esm2022/lib/core/model/display-options.interface.mjs +4 -2
  13. package/esm2022/lib/core/model/manifest.interface.mjs +1 -1
  14. package/esm2022/lib/core/store/config/config.actions.mjs +2 -1
  15. package/esm2022/lib/core/store/config/config.effects.mjs +25 -4
  16. package/esm2022/lib/core/store/data-source/data-source.actions.mjs +1 -1
  17. package/esm2022/lib/core/store/data-source/data-source.effects.mjs +1 -1
  18. package/esm2022/lib/core/store/data-source/data-source.model.mjs +1 -1
  19. package/esm2022/lib/core/store/data-source/data-source.reducer.mjs +1 -1
  20. package/esm2022/lib/core/store/data-source/data-source.service.mjs +1 -1
  21. package/esm2022/lib/dashboard/components/context-menu/context-menu.component.mjs +3 -7
  22. package/esm2022/lib/dashboard/components/widgets/datasource-selector/datasource-selector.component.mjs +1 -1
  23. package/esm2022/lib/dashboard/components/widgets/settings/settings.component.mjs +6 -3
  24. package/esm2022/lib/dashboard/public-api.mjs +2 -1
  25. package/esm2022/lib/dashboard/store/dashboard.actions.mjs +2 -3
  26. package/esm2022/lib/dashboard/store/dashboard.effects.mjs +25 -11
  27. package/esm2022/lib/dashboard/store/dashboard.reducers.mjs +2 -11
  28. package/esm2022/lib/dashboard/store/dashboard.selectors.mjs +3 -5
  29. package/esm2022/lib/dashboard/store/manifest-utils.class.mjs +11 -0
  30. package/esm2022/lib/dashboard/store/manifest.service.mjs +3 -10
  31. package/esm2022/lib/dashboard/tooltip/components/default/default.tooltip.component.mjs +5 -4
  32. package/esm2022/pipeline/components/pipeline-list/pipeline-list.component.mjs +5 -8
  33. package/esm2022/presentation/components/presentation.component.mjs +5 -42
  34. package/esm2022/presentation/presentation.module.mjs +8 -4
  35. package/esm2022/restitution/components/restitution-catalog/restitution-catalog.component.mjs +9 -65
  36. package/esm2022/search/components/save-query/save-query.component.mjs +5 -8
  37. package/esm2022/toolbox/components/filter-settings/filter-settings.component.mjs +3 -3
  38. package/esm2022/toolbox/components/refresh-datasets/refresh-datasets.component.mjs +3 -3
  39. package/esm2022/toolbox/components/select-grid-layout/select-grid-layout.component.mjs +5 -16
  40. package/esm2022/toolbox/toolbox.module.mjs +8 -4
  41. package/esm2022/tooltips/attribute/attribute-tooltip.component.mjs +3 -3
  42. package/esm2022/widgets/widget-chart/component/widget-chart.component.mjs +3 -3
  43. package/esm2022/widgets/widget-map/component/widget-map.component.mjs +46 -23
  44. package/esm2022/widgets/widget-map/i18n/en.translations.mjs +4 -2
  45. package/esm2022/widgets/widget-map/i18n/fr.translations.mjs +4 -2
  46. package/esm2022/widgets/widget-map/interaction/interaction-manager.class.mjs +4 -23
  47. package/esm2022/widgets/widget-tile/component/widget-tile.component.mjs +3 -3
  48. package/fesm2022/provoly-dashboard-admin.mjs +2 -2
  49. package/fesm2022/provoly-dashboard-admin.mjs.map +1 -1
  50. package/fesm2022/provoly-dashboard-pipeline.mjs +4 -7
  51. package/fesm2022/provoly-dashboard-pipeline.mjs.map +1 -1
  52. package/fesm2022/provoly-dashboard-presentation.mjs +11 -44
  53. package/fesm2022/provoly-dashboard-presentation.mjs.map +1 -1
  54. package/fesm2022/provoly-dashboard-restitution.mjs +9 -65
  55. package/fesm2022/provoly-dashboard-restitution.mjs.map +1 -1
  56. package/fesm2022/provoly-dashboard-search.mjs +4 -7
  57. package/fesm2022/provoly-dashboard-search.mjs.map +1 -1
  58. package/fesm2022/provoly-dashboard-toolbox.mjs +14 -21
  59. package/fesm2022/provoly-dashboard-toolbox.mjs.map +1 -1
  60. package/fesm2022/provoly-dashboard-tooltips-attribute.mjs +2 -2
  61. package/fesm2022/provoly-dashboard-tooltips-attribute.mjs.map +1 -1
  62. package/fesm2022/provoly-dashboard-widgets-widget-chart.mjs +2 -2
  63. package/fesm2022/provoly-dashboard-widgets-widget-chart.mjs.map +1 -1
  64. package/fesm2022/provoly-dashboard-widgets-widget-map.mjs +57 -111
  65. package/fesm2022/provoly-dashboard-widgets-widget-map.mjs.map +1 -1
  66. package/fesm2022/provoly-dashboard-widgets-widget-tile.mjs +2 -2
  67. package/fesm2022/provoly-dashboard-widgets-widget-tile.mjs.map +1 -1
  68. package/fesm2022/provoly-dashboard.mjs +153 -135
  69. package/fesm2022/provoly-dashboard.mjs.map +1 -1
  70. package/lib/core/components/overlay/overlay.module.d.ts +2 -1
  71. package/lib/core/model/admin-api.model.d.ts +1 -1
  72. package/lib/core/model/dataset.interface.d.ts +0 -10
  73. package/lib/core/model/display-options.interface.d.ts +1 -0
  74. package/lib/core/model/manifest.interface.d.ts +2 -0
  75. package/lib/core/store/config/config.actions.d.ts +5 -0
  76. package/lib/core/store/config/config.effects.d.ts +6 -1
  77. package/lib/core/store/data-source/data-source.actions.d.ts +2 -2
  78. package/lib/core/store/data-source/data-source.effects.d.ts +2 -3
  79. package/lib/core/store/data-source/data-source.model.d.ts +11 -3
  80. package/lib/core/store/data-source/data-source.reducer.d.ts +2 -2
  81. package/lib/core/store/data-source/data-source.selectors.d.ts +5 -5
  82. package/lib/core/store/data-source/data-source.service.d.ts +4 -4
  83. package/lib/dashboard/components/context-menu/context-menu.component.d.ts +0 -1
  84. package/lib/dashboard/components/widgets/datasource-selector/datasource-selector.component.d.ts +1 -2
  85. package/lib/dashboard/components/widgets/settings/settings.component.d.ts +1 -0
  86. package/lib/dashboard/public-api.d.ts +1 -0
  87. package/lib/dashboard/store/dashboard.actions.d.ts +6 -17
  88. package/lib/dashboard/store/dashboard.effects.d.ts +6 -7
  89. package/lib/dashboard/store/dashboard.reducers.d.ts +1 -5
  90. package/lib/dashboard/store/dashboard.selectors.d.ts +0 -57
  91. package/lib/dashboard/store/manifest-utils.class.d.ts +4 -0
  92. package/lib/dashboard/store/manifest.service.d.ts +0 -1
  93. package/package.json +31 -31
  94. package/pipeline/components/pipeline-list/pipeline-list.component.d.ts +1 -2
  95. package/presentation/components/presentation.component.d.ts +0 -5
  96. package/presentation/presentation.module.d.ts +2 -1
  97. package/restitution/components/restitution-catalog/restitution-catalog.component.d.ts +4 -15
  98. package/schematics/ng-update/version-0-13/index.js +18 -1
  99. package/schematics/ng-update/version-0-13/index.js.map +1 -1
  100. package/schematics/ng-update/version-0-13/index.spec.js +8 -1
  101. package/schematics/ng-update/version-0-13/index.spec.js.map +1 -1
  102. package/search/components/save-query/save-query.component.d.ts +1 -2
  103. package/styles/components/_m-tooltip.scss +18 -2
  104. package/styles-theme/components-theme/_m-tooltip.theme.scss +0 -12
  105. package/toolbox/components/select-grid-layout/select-grid-layout.component.d.ts +0 -4
  106. package/toolbox/toolbox.module.d.ts +2 -1
  107. package/widgets/widget-map/component/widget-map.component.d.ts +8 -3
  108. package/widgets/widget-map/i18n/en.translations.d.ts +2 -0
  109. package/widgets/widget-map/i18n/fr.translations.d.ts +2 -0
  110. package/widgets/widget-map/interaction/interaction-manager.class.d.ts +3 -5
  111. package/esm2022/widgets/widget-map/search-bar/search-bar.control.mjs +0 -66
  112. package/widgets/widget-map/search-bar/search-bar.control.d.ts +0 -27
@@ -73,9 +73,11 @@ export const enTranslations = {
73
73
  export: 'Export map',
74
74
  import: 'Import layer',
75
75
  legend: 'Legend of layer {{layer}}',
76
- legendNotProvided: 'Legend not provided by server'
76
+ legendNotProvided: 'Legend not provided by server',
77
+ selectLayers: 'Select layers',
78
+ legends: 'Display legend'
77
79
  }
78
80
  }
79
81
  }
80
82
  };
81
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZW4udHJhbnNsYXRpb25zLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvcHJvdm9seS9kYXNoYm9hcmQvd2lkZ2V0cy93aWRnZXQtbWFwL2kxOG4vZW4udHJhbnNsYXRpb25zLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE1BQU0sQ0FBQyxNQUFNLGNBQWMsR0FBRztJQUM1QixNQUFNLEVBQUU7UUFDTixNQUFNLEVBQUU7WUFDTixHQUFHLEVBQUU7Z0JBQ0gsV0FBVyxFQUFFLGVBQWU7Z0JBQzVCLFlBQVksRUFBRSxpQkFBaUI7Z0JBQy9CLEtBQUssRUFBRSxXQUFXO2dCQUNsQixPQUFPLEVBQUUsV0FBVztnQkFDcEIsR0FBRyxFQUFFLFVBQVU7Z0JBQ2YsUUFBUSxFQUFFLFdBQVc7Z0JBQ3JCLEtBQUssRUFBRSxtQkFBbUI7Z0JBQzFCLFlBQVksRUFBRSxlQUFlO2dCQUM3QixVQUFVLEVBQUUsYUFBYTtnQkFDekIsU0FBUyxFQUFFO29CQUNULEtBQUssRUFBRSxNQUFNO29CQUNiLE9BQU8sRUFBRSxTQUFTO29CQUNsQixNQUFNLEVBQUUsYUFBYTtvQkFDckIsUUFBUSxFQUFFLE9BQU87b0JBQ2pCLE1BQU0sRUFBRSxhQUFhO29CQUNyQixPQUFPLEVBQUUsWUFBWTtvQkFDckIsR0FBRyxFQUFFLFNBQVM7b0JBQ2QsSUFBSSxFQUFFLFVBQVU7b0JBQ2hCLFlBQVksRUFBRSxlQUFlO29CQUM3QixVQUFVLEVBQUUsYUFBYTtvQkFDekIsVUFBVSxFQUFFLGFBQWE7b0JBQ3pCLEtBQUssRUFBRSxRQUFRO29CQUNmLElBQUksRUFBRSxPQUFPO29CQUNiLFNBQVMsRUFBRSxxQkFBcUI7b0JBQ2hDLFlBQVksRUFBRSxhQUFhO29CQUMzQixlQUFlLEVBQUUsZ0JBQWdCO2lCQUNsQztnQkFDRCxPQUFPLEVBQUU7b0JBQ1AsS0FBSyxFQUFFLE9BQU87b0JBQ2QsS0FBSyxFQUFFLE9BQU87b0JBQ2QsS0FBSyxFQUFFLGtCQUFrQjtpQkFDMUI7Z0JBQ0QsSUFBSSxFQUFFLG9CQUFvQjtnQkFDMUIsWUFBWSxFQUFFLG1CQUFtQjtnQkFDakMsVUFBVSxFQUFFLG9CQUFvQjtnQkFDaEMsR0FBRyxFQUFFO29CQUNILEdBQUcsRUFBRSxhQUFhO29CQUNsQixVQUFVLEVBQUUsaUJBQWlCO29CQUM3QixVQUFVLEVBQUUsT0FBTztvQkFDbkIsS0FBSyxFQUFFLE9BQU87b0JBQ2QsU0FBUyxFQUFFLFdBQVc7aUJBQ3ZCO2dCQUNELFdBQVcsRUFBRSxjQUFjO2dCQUMzQixhQUFhLEVBQUUsb0NBQW9DO2dCQUNuRCxpQkFBaUIsRUFBRTtvQkFDakIsSUFBSSxFQUFFLG1CQUFtQjtvQkFDekIsR0FBRyxFQUFFLG1CQUFtQjtvQkFDeEIsR0FBRyxFQUFFLG9CQUFvQjtpQkFDMUI7Z0JBQ0Qsa0JBQWtCLEVBQUUsb0JBQW9CO2dCQUN4QyxPQUFPLEVBQUUsNEJBQTRCO2dCQUNyQyxTQUFTLEVBQUUsZUFBZTtnQkFDMUIsV0FBVyxFQUFFLDZCQUE2QjtnQkFDMUMsUUFBUSxFQUFFLDZCQUE2QjtnQkFDdkMsV0FBVyxFQUFFLDZGQUE2RjtnQkFDMUcsbUJBQW1CLEVBQUUseUNBQXlDO2dCQUM5RCxTQUFTLEVBQUUsV0FBVztnQkFDdEIsZUFBZSxFQUFFLGtCQUFrQjtnQkFDbkMsT0FBTyxFQUFFLFNBQVM7Z0JBQ2xCLE9BQU8sRUFBRSxTQUFTO2dCQUNsQixhQUFhLEVBQUUsYUFBYTtnQkFDNUIsTUFBTSxFQUFFLFFBQVE7Z0JBQ2hCLFFBQVEsRUFBRSxVQUFVO2dCQUNwQixJQUFJLEVBQUUsV0FBVztnQkFDakIsS0FBSyxFQUFFLGlCQUFpQjtnQkFDeEIsU0FBUyxFQUFFLHFCQUFxQjtnQkFDaEMsS0FBSyxFQUFFLGlCQUFpQjtnQkFDeEIsSUFBSSxFQUFFLGdCQUFnQjtnQkFDdEIsTUFBTSxFQUFFLFlBQVk7Z0JBQ3BCLE1BQU0sRUFBRSxjQUFjO2dCQUN0QixNQUFNLEVBQUUsMkJBQTJCO2dCQUNuQyxpQkFBaUIsRUFBRSwrQkFBK0I7YUFDbkQ7U0FDRjtLQUNGO0NBQ0YsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBjb25zdCBlblRyYW5zbGF0aW9ucyA9IHtcbiAgJ0BwcnknOiB7XG4gICAgd2lkZ2V0OiB7XG4gICAgICBtYXA6IHtcbiAgICAgICAgYXR0cmlidXRpb246ICdMYXllciBjcmVkaXRzJyxcbiAgICAgICAgYXR0cmlidXRpb25zOiAnRGlzcGxheSBjcmVkaXRzJyxcbiAgICAgICAgc3R5bGU6ICdNYXAgc3R5bGUnLFxuICAgICAgICBub1N0eWxlOiAnRW1wdHkgbWFwJyxcbiAgICAgICAgZml0OiAnRml0IGRhdGEnLFxuICAgICAgICBhZGRMYXllcjogJ0FkZCBsYXllcicsXG4gICAgICAgIGxheWVyOiAnTGF5ZXIgbsKwe3tpbmRleH19JyxcbiAgICAgICAgbGF5ZXJPcHRpb25zOiAnTGF5ZXIgb3B0aW9ucycsXG4gICAgICAgIGxheWVyVGl0bGU6ICdMYXllciBMYWJlbCcsXG4gICAgICAgIGxheWVyVHlwZToge1xuICAgICAgICAgIHRpdGxlOiAnVHlwZScsXG4gICAgICAgICAgaGVhdG1hcDogJ0hlYXRtYXAnLFxuICAgICAgICAgIGJ1YmJsZTogJ0J1YmJsZXMgbWFwJyxcbiAgICAgICAgICByZWxhdGlvbjogJ0xpbmtzJyxcbiAgICAgICAgICBtYXJrZXI6ICdNYXJrZXJzIG1hcCcsXG4gICAgICAgICAgcG9seWdvbjogJ1NoYXBlcyBtYXAnLFxuICAgICAgICAgIHdtczogJ1dNUyBBUEknLFxuICAgICAgICAgIHdtdHM6ICdXTVRTIEFQSScsXG4gICAgICAgICAgZmVhdHVyZWxheWVyOiAnRmVhdHVyZSBsYXllcicsXG4gICAgICAgICAgdmVjdG9ydGlsZTogJ1ZlY3RvciB0aWxlJyxcbiAgICAgICAgICByYXN0ZXJ0aWxlOiAnUmFzdGVyIHRpbGUnLFxuICAgICAgICAgIHBvaW50OiAnUG9pbnRzJyxcbiAgICAgICAgICBsaW5lOiAnTGluZXMnLFxuICAgICAgICAgIGdlb3NlcnZlcjogJ0dlb3NlcnZlciAoe3trZXl9fSknLFxuICAgICAgICAgICdtdWx0aS1saW5lJzogJ011bHRpLWxpbmVzJyxcbiAgICAgICAgICAnbXVsdGktcG9seWdvbic6ICdNdWx0aS1wb2x5Z29ucydcbiAgICAgICAgfSxcbiAgICAgICAgdG9vbHRpcDoge1xuICAgICAgICAgIGhvdmVyOiAnSG92ZXInLFxuICAgICAgICAgIGNsaWNrOiAnQ2xpY2snLFxuICAgICAgICAgIHRpdGxlOiAnT3BlbmluZyB0b29sdGlwcydcbiAgICAgICAgfSxcbiAgICAgICAgdGlsZTogJ1RpbGUgbGF5ZXIgb3B0aW9ucycsXG4gICAgICAgIGxvY2F0aW9uQXR0cjogJ1BsYWNlbWVudCBvcHRpb25zJyxcbiAgICAgICAgY2x1c3RlcmluZzogJ0NsdXN0ZXJpbmcgb3B0aW9ucycsXG4gICAgICAgIHdtczoge1xuICAgICAgICAgIHVybDogJ1NlcnZpY2UgVXJsJyxcbiAgICAgICAgICBwYXJhbUxheWVyOiAnRGF0YSBpZGVudGlmaWVyJyxcbiAgICAgICAgICBwYXJhbVRpbGVkOiAnVGlsZWQnLFxuICAgICAgICAgIHN0eWxlOiAnU3R5bGUnLFxuICAgICAgICAgIG1hdHJpeFNldDogJ21hdHJpeFNldCdcbiAgICAgICAgfSxcbiAgICAgICAgZGVsZXRlTGF5ZXI6ICdEZWxldGUgbGF5ZXInLFxuICAgICAgICBsb2NhdGlvbkFycmF5OiAnTGF0IGFuZCBMbmcgaW4gc2VwYXJhdGUgcHJvcGVydGllcycsXG4gICAgICAgIGxvY2F0aW9uQXR0cmlidXRlOiB7XG4gICAgICAgICAgYm90aDogJ0xvY2F0aW9uIHByb3BlcnR5JyxcbiAgICAgICAgICBsYXQ6ICdMYXRpdHVkZSBwcm9wZXJ0eScsXG4gICAgICAgICAgbG5nOiAnTG9uZ2l0dWRlIHByb3BlcnR5J1xuICAgICAgICB9LFxuICAgICAgICBpbnRlbnNpdHlBdHRyaWJ1dGU6ICdJbnRlbnNpdHkgcHJvcGVydHknLFxuICAgICAgICBjbGFzc2VzOiAnQ2xhc3NlcyBkaXNwbGF5ZWQgaW4gbGF5ZXInLFxuICAgICAgICByZWxhdGlvbnM6ICdEaXNwbGF5IGxpbmtzJyxcbiAgICAgICAgaW1wb3J0U3RhcnQ6ICdJbXBvcnQgZmlsZSB7e2ZpbGVuYW1lfX0uLi4nLFxuICAgICAgICBpbXBvcnRPazogJ0ZpbGUge3tmaWxlbmFtZX19IGltcG9ydGVkLicsXG4gICAgICAgIGltcG9ydEVycm9yOiAnQ2Fubm90IHJlYWQgZm9ybWF0IHdpdGggZXh0ZW5zaW9uIHt7ZXh0ZW5zaW9ufX0uIEF1dGhvcml6ZWQgdHlwZXMgYXJlIHt7YXV0aG9yaXplZEZvcm1hdHN9fScsXG4gICAgICAgIGltcG9ydE5vdEZvdW5kSW5aaXA6ICdObyBmaWxlIHt7ZXh0ZW5zaW9ufX0gZm91bmQgaW4gYXJjaGl2ZS4nLFxuICAgICAgICBjbHVzdGVyZWQ6ICdDbHVzdGVyZWQnLFxuICAgICAgICBjbHVzdGVyRGlzdGFuY2U6ICdDbHVzdGVyIGRpc3RhbmNlJyxcbiAgICAgICAgb3BhY2l0eTogJ09wYWNpdHknLFxuICAgICAgICBhZGRyZXNzOiAnQWRkcmVzcycsXG4gICAgICAgIGFkZHJlc3NDb29yZHM6ICdDb29yZGluYXRlcycsXG4gICAgICAgIGFjdGl2ZTogJ0FjdGl2ZScsXG4gICAgICAgIGluYWN0aXZlOiAnSW5hY3RpdmUnLFxuICAgICAgICBtb3ZlOiAnTW92ZSBtb2RlJyxcbiAgICAgICAgbGFzc286ICdMYXNzbyBzZWxlY3Rpb24nLFxuICAgICAgICByZWN0YW5nbGU6ICdSZWN0YW5nbGUgc2VsZWN0aW9uJyxcbiAgICAgICAgY2xpY2s6ICdDbGljayBzZWxlY3Rpb24nLFxuICAgICAgICB6b29tOiAnWm9vbSBzZWxlY3Rpb24nLFxuICAgICAgICBleHBvcnQ6ICdFeHBvcnQgbWFwJyxcbiAgICAgICAgaW1wb3J0OiAnSW1wb3J0IGxheWVyJyxcbiAgICAgICAgbGVnZW5kOiAnTGVnZW5kIG9mIGxheWVyIHt7bGF5ZXJ9fScsXG4gICAgICAgIGxlZ2VuZE5vdFByb3ZpZGVkOiAnTGVnZW5kIG5vdCBwcm92aWRlZCBieSBzZXJ2ZXInXG4gICAgICB9XG4gICAgfVxuICB9XG59O1xuIl19
83
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZW4udHJhbnNsYXRpb25zLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvcHJvdm9seS9kYXNoYm9hcmQvd2lkZ2V0cy93aWRnZXQtbWFwL2kxOG4vZW4udHJhbnNsYXRpb25zLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE1BQU0sQ0FBQyxNQUFNLGNBQWMsR0FBRztJQUM1QixNQUFNLEVBQUU7UUFDTixNQUFNLEVBQUU7WUFDTixHQUFHLEVBQUU7Z0JBQ0gsV0FBVyxFQUFFLGVBQWU7Z0JBQzVCLFlBQVksRUFBRSxpQkFBaUI7Z0JBQy9CLEtBQUssRUFBRSxXQUFXO2dCQUNsQixPQUFPLEVBQUUsV0FBVztnQkFDcEIsR0FBRyxFQUFFLFVBQVU7Z0JBQ2YsUUFBUSxFQUFFLFdBQVc7Z0JBQ3JCLEtBQUssRUFBRSxtQkFBbUI7Z0JBQzFCLFlBQVksRUFBRSxlQUFlO2dCQUM3QixVQUFVLEVBQUUsYUFBYTtnQkFDekIsU0FBUyxFQUFFO29CQUNULEtBQUssRUFBRSxNQUFNO29CQUNiLE9BQU8sRUFBRSxTQUFTO29CQUNsQixNQUFNLEVBQUUsYUFBYTtvQkFDckIsUUFBUSxFQUFFLE9BQU87b0JBQ2pCLE1BQU0sRUFBRSxhQUFhO29CQUNyQixPQUFPLEVBQUUsWUFBWTtvQkFDckIsR0FBRyxFQUFFLFNBQVM7b0JBQ2QsSUFBSSxFQUFFLFVBQVU7b0JBQ2hCLFlBQVksRUFBRSxlQUFlO29CQUM3QixVQUFVLEVBQUUsYUFBYTtvQkFDekIsVUFBVSxFQUFFLGFBQWE7b0JBQ3pCLEtBQUssRUFBRSxRQUFRO29CQUNmLElBQUksRUFBRSxPQUFPO29CQUNiLFNBQVMsRUFBRSxxQkFBcUI7b0JBQ2hDLFlBQVksRUFBRSxhQUFhO29CQUMzQixlQUFlLEVBQUUsZ0JBQWdCO2lCQUNsQztnQkFDRCxPQUFPLEVBQUU7b0JBQ1AsS0FBSyxFQUFFLE9BQU87b0JBQ2QsS0FBSyxFQUFFLE9BQU87b0JBQ2QsS0FBSyxFQUFFLGtCQUFrQjtpQkFDMUI7Z0JBQ0QsSUFBSSxFQUFFLG9CQUFvQjtnQkFDMUIsWUFBWSxFQUFFLG1CQUFtQjtnQkFDakMsVUFBVSxFQUFFLG9CQUFvQjtnQkFDaEMsR0FBRyxFQUFFO29CQUNILEdBQUcsRUFBRSxhQUFhO29CQUNsQixVQUFVLEVBQUUsaUJBQWlCO29CQUM3QixVQUFVLEVBQUUsT0FBTztvQkFDbkIsS0FBSyxFQUFFLE9BQU87b0JBQ2QsU0FBUyxFQUFFLFdBQVc7aUJBQ3ZCO2dCQUNELFdBQVcsRUFBRSxjQUFjO2dCQUMzQixhQUFhLEVBQUUsb0NBQW9DO2dCQUNuRCxpQkFBaUIsRUFBRTtvQkFDakIsSUFBSSxFQUFFLG1CQUFtQjtvQkFDekIsR0FBRyxFQUFFLG1CQUFtQjtvQkFDeEIsR0FBRyxFQUFFLG9CQUFvQjtpQkFDMUI7Z0JBQ0Qsa0JBQWtCLEVBQUUsb0JBQW9CO2dCQUN4QyxPQUFPLEVBQUUsNEJBQTRCO2dCQUNyQyxTQUFTLEVBQUUsZUFBZTtnQkFDMUIsV0FBVyxFQUFFLDZCQUE2QjtnQkFDMUMsUUFBUSxFQUFFLDZCQUE2QjtnQkFDdkMsV0FBVyxFQUFFLDZGQUE2RjtnQkFDMUcsbUJBQW1CLEVBQUUseUNBQXlDO2dCQUM5RCxTQUFTLEVBQUUsV0FBVztnQkFDdEIsZUFBZSxFQUFFLGtCQUFrQjtnQkFDbkMsT0FBTyxFQUFFLFNBQVM7Z0JBQ2xCLE9BQU8sRUFBRSxTQUFTO2dCQUNsQixhQUFhLEVBQUUsYUFBYTtnQkFDNUIsTUFBTSxFQUFFLFFBQVE7Z0JBQ2hCLFFBQVEsRUFBRSxVQUFVO2dCQUNwQixJQUFJLEVBQUUsV0FBVztnQkFDakIsS0FBSyxFQUFFLGlCQUFpQjtnQkFDeEIsU0FBUyxFQUFFLHFCQUFxQjtnQkFDaEMsS0FBSyxFQUFFLGlCQUFpQjtnQkFDeEIsSUFBSSxFQUFFLGdCQUFnQjtnQkFDdEIsTUFBTSxFQUFFLFlBQVk7Z0JBQ3BCLE1BQU0sRUFBRSxjQUFjO2dCQUN0QixNQUFNLEVBQUUsMkJBQTJCO2dCQUNuQyxpQkFBaUIsRUFBRSwrQkFBK0I7Z0JBQ2xELFlBQVksRUFBRSxlQUFlO2dCQUM3QixPQUFPLEVBQUUsZ0JBQWdCO2FBQzFCO1NBQ0Y7S0FDRjtDQUNGLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgY29uc3QgZW5UcmFuc2xhdGlvbnMgPSB7XG4gICdAcHJ5Jzoge1xuICAgIHdpZGdldDoge1xuICAgICAgbWFwOiB7XG4gICAgICAgIGF0dHJpYnV0aW9uOiAnTGF5ZXIgY3JlZGl0cycsXG4gICAgICAgIGF0dHJpYnV0aW9uczogJ0Rpc3BsYXkgY3JlZGl0cycsXG4gICAgICAgIHN0eWxlOiAnTWFwIHN0eWxlJyxcbiAgICAgICAgbm9TdHlsZTogJ0VtcHR5IG1hcCcsXG4gICAgICAgIGZpdDogJ0ZpdCBkYXRhJyxcbiAgICAgICAgYWRkTGF5ZXI6ICdBZGQgbGF5ZXInLFxuICAgICAgICBsYXllcjogJ0xheWVyIG7CsHt7aW5kZXh9fScsXG4gICAgICAgIGxheWVyT3B0aW9uczogJ0xheWVyIG9wdGlvbnMnLFxuICAgICAgICBsYXllclRpdGxlOiAnTGF5ZXIgTGFiZWwnLFxuICAgICAgICBsYXllclR5cGU6IHtcbiAgICAgICAgICB0aXRsZTogJ1R5cGUnLFxuICAgICAgICAgIGhlYXRtYXA6ICdIZWF0bWFwJyxcbiAgICAgICAgICBidWJibGU6ICdCdWJibGVzIG1hcCcsXG4gICAgICAgICAgcmVsYXRpb246ICdMaW5rcycsXG4gICAgICAgICAgbWFya2VyOiAnTWFya2VycyBtYXAnLFxuICAgICAgICAgIHBvbHlnb246ICdTaGFwZXMgbWFwJyxcbiAgICAgICAgICB3bXM6ICdXTVMgQVBJJyxcbiAgICAgICAgICB3bXRzOiAnV01UUyBBUEknLFxuICAgICAgICAgIGZlYXR1cmVsYXllcjogJ0ZlYXR1cmUgbGF5ZXInLFxuICAgICAgICAgIHZlY3RvcnRpbGU6ICdWZWN0b3IgdGlsZScsXG4gICAgICAgICAgcmFzdGVydGlsZTogJ1Jhc3RlciB0aWxlJyxcbiAgICAgICAgICBwb2ludDogJ1BvaW50cycsXG4gICAgICAgICAgbGluZTogJ0xpbmVzJyxcbiAgICAgICAgICBnZW9zZXJ2ZXI6ICdHZW9zZXJ2ZXIgKHt7a2V5fX0pJyxcbiAgICAgICAgICAnbXVsdGktbGluZSc6ICdNdWx0aS1saW5lcycsXG4gICAgICAgICAgJ211bHRpLXBvbHlnb24nOiAnTXVsdGktcG9seWdvbnMnXG4gICAgICAgIH0sXG4gICAgICAgIHRvb2x0aXA6IHtcbiAgICAgICAgICBob3ZlcjogJ0hvdmVyJyxcbiAgICAgICAgICBjbGljazogJ0NsaWNrJyxcbiAgICAgICAgICB0aXRsZTogJ09wZW5pbmcgdG9vbHRpcHMnXG4gICAgICAgIH0sXG4gICAgICAgIHRpbGU6ICdUaWxlIGxheWVyIG9wdGlvbnMnLFxuICAgICAgICBsb2NhdGlvbkF0dHI6ICdQbGFjZW1lbnQgb3B0aW9ucycsXG4gICAgICAgIGNsdXN0ZXJpbmc6ICdDbHVzdGVyaW5nIG9wdGlvbnMnLFxuICAgICAgICB3bXM6IHtcbiAgICAgICAgICB1cmw6ICdTZXJ2aWNlIFVybCcsXG4gICAgICAgICAgcGFyYW1MYXllcjogJ0RhdGEgaWRlbnRpZmllcicsXG4gICAgICAgICAgcGFyYW1UaWxlZDogJ1RpbGVkJyxcbiAgICAgICAgICBzdHlsZTogJ1N0eWxlJyxcbiAgICAgICAgICBtYXRyaXhTZXQ6ICdtYXRyaXhTZXQnXG4gICAgICAgIH0sXG4gICAgICAgIGRlbGV0ZUxheWVyOiAnRGVsZXRlIGxheWVyJyxcbiAgICAgICAgbG9jYXRpb25BcnJheTogJ0xhdCBhbmQgTG5nIGluIHNlcGFyYXRlIHByb3BlcnRpZXMnLFxuICAgICAgICBsb2NhdGlvbkF0dHJpYnV0ZToge1xuICAgICAgICAgIGJvdGg6ICdMb2NhdGlvbiBwcm9wZXJ0eScsXG4gICAgICAgICAgbGF0OiAnTGF0aXR1ZGUgcHJvcGVydHknLFxuICAgICAgICAgIGxuZzogJ0xvbmdpdHVkZSBwcm9wZXJ0eSdcbiAgICAgICAgfSxcbiAgICAgICAgaW50ZW5zaXR5QXR0cmlidXRlOiAnSW50ZW5zaXR5IHByb3BlcnR5JyxcbiAgICAgICAgY2xhc3NlczogJ0NsYXNzZXMgZGlzcGxheWVkIGluIGxheWVyJyxcbiAgICAgICAgcmVsYXRpb25zOiAnRGlzcGxheSBsaW5rcycsXG4gICAgICAgIGltcG9ydFN0YXJ0OiAnSW1wb3J0IGZpbGUge3tmaWxlbmFtZX19Li4uJyxcbiAgICAgICAgaW1wb3J0T2s6ICdGaWxlIHt7ZmlsZW5hbWV9fSBpbXBvcnRlZC4nLFxuICAgICAgICBpbXBvcnRFcnJvcjogJ0Nhbm5vdCByZWFkIGZvcm1hdCB3aXRoIGV4dGVuc2lvbiB7e2V4dGVuc2lvbn19LiBBdXRob3JpemVkIHR5cGVzIGFyZSB7e2F1dGhvcml6ZWRGb3JtYXRzfX0nLFxuICAgICAgICBpbXBvcnROb3RGb3VuZEluWmlwOiAnTm8gZmlsZSB7e2V4dGVuc2lvbn19IGZvdW5kIGluIGFyY2hpdmUuJyxcbiAgICAgICAgY2x1c3RlcmVkOiAnQ2x1c3RlcmVkJyxcbiAgICAgICAgY2x1c3RlckRpc3RhbmNlOiAnQ2x1c3RlciBkaXN0YW5jZScsXG4gICAgICAgIG9wYWNpdHk6ICdPcGFjaXR5JyxcbiAgICAgICAgYWRkcmVzczogJ0FkZHJlc3MnLFxuICAgICAgICBhZGRyZXNzQ29vcmRzOiAnQ29vcmRpbmF0ZXMnLFxuICAgICAgICBhY3RpdmU6ICdBY3RpdmUnLFxuICAgICAgICBpbmFjdGl2ZTogJ0luYWN0aXZlJyxcbiAgICAgICAgbW92ZTogJ01vdmUgbW9kZScsXG4gICAgICAgIGxhc3NvOiAnTGFzc28gc2VsZWN0aW9uJyxcbiAgICAgICAgcmVjdGFuZ2xlOiAnUmVjdGFuZ2xlIHNlbGVjdGlvbicsXG4gICAgICAgIGNsaWNrOiAnQ2xpY2sgc2VsZWN0aW9uJyxcbiAgICAgICAgem9vbTogJ1pvb20gc2VsZWN0aW9uJyxcbiAgICAgICAgZXhwb3J0OiAnRXhwb3J0IG1hcCcsXG4gICAgICAgIGltcG9ydDogJ0ltcG9ydCBsYXllcicsXG4gICAgICAgIGxlZ2VuZDogJ0xlZ2VuZCBvZiBsYXllciB7e2xheWVyfX0nLFxuICAgICAgICBsZWdlbmROb3RQcm92aWRlZDogJ0xlZ2VuZCBub3QgcHJvdmlkZWQgYnkgc2VydmVyJyxcbiAgICAgICAgc2VsZWN0TGF5ZXJzOiAnU2VsZWN0IGxheWVycycsXG4gICAgICAgIGxlZ2VuZHM6ICdEaXNwbGF5IGxlZ2VuZCdcbiAgICAgIH1cbiAgICB9XG4gIH1cbn07XG4iXX0=
@@ -73,9 +73,11 @@ export const frTranslations = {
73
73
  export: 'Exporter la carte',
74
74
  import: 'Importer une couche',
75
75
  legend: 'Légende de la couche {{layer}}',
76
- legendNotProvided: 'Légende non fournie par le serveur'
76
+ legendNotProvided: 'Légende non fournie par le serveur',
77
+ selectLayers: 'Sélectionner les couches',
78
+ legends: 'Afficher la légende'
77
79
  }
78
80
  }
79
81
  }
80
82
  };
81
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZnIudHJhbnNsYXRpb25zLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvcHJvdm9seS9kYXNoYm9hcmQvd2lkZ2V0cy93aWRnZXQtbWFwL2kxOG4vZnIudHJhbnNsYXRpb25zLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE1BQU0sQ0FBQyxNQUFNLGNBQWMsR0FBRztJQUM1QixNQUFNLEVBQUU7UUFDTixNQUFNLEVBQUU7WUFDTixHQUFHLEVBQUU7Z0JBQ0gsV0FBVyxFQUFFLHlCQUF5QjtnQkFDdEMsWUFBWSxFQUFFLHNCQUFzQjtnQkFDcEMsS0FBSyxFQUFFLHdCQUF3QjtnQkFDL0IsT0FBTyxFQUFFLHFCQUFxQjtnQkFDOUIsR0FBRyxFQUFFLCtCQUErQjtnQkFDcEMsUUFBUSxFQUFFLG9CQUFvQjtnQkFDOUIsS0FBSyxFQUFFLG9CQUFvQjtnQkFDM0IsWUFBWSxFQUFFLHNCQUFzQjtnQkFDcEMsVUFBVSxFQUFFLHNCQUFzQjtnQkFDbEMsU0FBUyxFQUFFO29CQUNULEtBQUssRUFBRSxNQUFNO29CQUNiLE9BQU8sRUFBRSxTQUFTO29CQUNsQixRQUFRLEVBQUUsV0FBVztvQkFDckIsTUFBTSxFQUFFLFFBQVE7b0JBQ2hCLE1BQU0sRUFBRSxXQUFXO29CQUNuQixPQUFPLEVBQUUsUUFBUTtvQkFDakIsR0FBRyxFQUFFLGFBQWE7b0JBQ2xCLElBQUksRUFBRSxjQUFjO29CQUNwQixZQUFZLEVBQUUsZUFBZTtvQkFDN0IsVUFBVSxFQUFFLGFBQWE7b0JBQ3pCLFVBQVUsRUFBRSxhQUFhO29CQUN6QixLQUFLLEVBQUUsUUFBUTtvQkFDZixJQUFJLEVBQUUsUUFBUTtvQkFDZCxTQUFTLEVBQUUscUJBQXFCO29CQUNoQyxZQUFZLEVBQUUsY0FBYztvQkFDNUIsZUFBZSxFQUFFLGdCQUFnQjtpQkFDbEM7Z0JBQ0QsT0FBTyxFQUFFO29CQUNQLEtBQUssRUFBRSxRQUFRO29CQUNmLEtBQUssRUFBRSxNQUFNO29CQUNiLEtBQUssRUFBRSx3QkFBd0I7aUJBQ2hDO2dCQUNELElBQUksRUFBRSx3QkFBd0I7Z0JBQzlCLFlBQVksRUFBRSwyQkFBMkI7Z0JBQ3pDLFVBQVUsRUFBRSx5QkFBeUI7Z0JBQ3JDLEdBQUcsRUFBRTtvQkFDSCxHQUFHLEVBQUUsZ0JBQWdCO29CQUNyQixVQUFVLEVBQUUseUJBQXlCO29CQUNyQyxVQUFVLEVBQUUsc0JBQXNCO29CQUNsQyxLQUFLLEVBQUUsT0FBTztvQkFDZCxTQUFTLEVBQUUsV0FBVztpQkFDdkI7Z0JBQ0QsV0FBVyxFQUFFLHFCQUFxQjtnQkFDbEMsYUFBYSxFQUFFLGdDQUFnQztnQkFDL0MsaUJBQWlCLEVBQUU7b0JBQ2pCLElBQUksRUFBRSwyQkFBMkI7b0JBQ2pDLEdBQUcsRUFBRSwwQkFBMEI7b0JBQy9CLEdBQUcsRUFBRSwyQkFBMkI7aUJBQ2pDO2dCQUNELGtCQUFrQixFQUFFLDBCQUEwQjtnQkFDOUMsT0FBTyxFQUFFLHFDQUFxQztnQkFDOUMsU0FBUyxFQUFFLHdCQUF3QjtnQkFDbkMsV0FBVyxFQUFFLHdDQUF3QztnQkFDckQsUUFBUSxFQUFFLCtCQUErQjtnQkFDekMsV0FBVyxFQUFFLDRGQUE0RjtnQkFDekcsbUJBQW1CLEVBQUUsb0RBQW9EO2dCQUN6RSxTQUFTLEVBQUUsY0FBYztnQkFDekIsZUFBZSxFQUFFLDBCQUEwQjtnQkFDM0MsT0FBTyxFQUFFLFNBQVM7Z0JBQ2xCLE9BQU8sRUFBRSxTQUFTO2dCQUNsQixhQUFhLEVBQUUsYUFBYTtnQkFDNUIsTUFBTSxFQUFFLFFBQVE7Z0JBQ2hCLFFBQVEsRUFBRSxVQUFVO2dCQUNwQixJQUFJLEVBQUUsa0JBQWtCO2dCQUN4QixLQUFLLEVBQUUscUJBQXFCO2dCQUM1QixTQUFTLEVBQUUseUJBQXlCO2dCQUNwQyxLQUFLLEVBQUUsdUJBQXVCO2dCQUM5QixJQUFJLEVBQUUsb0JBQW9CO2dCQUMxQixNQUFNLEVBQUUsbUJBQW1CO2dCQUMzQixNQUFNLEVBQUUscUJBQXFCO2dCQUM3QixNQUFNLEVBQUUsZ0NBQWdDO2dCQUN4QyxpQkFBaUIsRUFBRSxvQ0FBb0M7YUFDeEQ7U0FDRjtLQUNGO0NBQ0YsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBjb25zdCBmclRyYW5zbGF0aW9ucyA9IHtcbiAgJ0BwcnknOiB7XG4gICAgd2lkZ2V0OiB7XG4gICAgICBtYXA6IHtcbiAgICAgICAgYXR0cmlidXRpb246ICdDcsOpZGl0cyBkZSBjZXR0ZSBjb3VjaGUnLFxuICAgICAgICBhdHRyaWJ1dGlvbnM6ICdBZmZpY2hlciBsZXMgY3LDqWRpdHMnLFxuICAgICAgICBzdHlsZTogJ1N0eWxlIGR1IGZvbmQgZGUgY2FydGUnLFxuICAgICAgICBub1N0eWxlOiAnQXVjdW4gZm9uZCBkZSBjYXJ0ZScsXG4gICAgICAgIGZpdDogJ0FkYXB0ZXIgbGEgdGFpbGxlIGF1eCBkb25uw6llcycsXG4gICAgICAgIGFkZExheWVyOiAnQWpvdXRlciB1bmUgY291Y2hlJyxcbiAgICAgICAgbGF5ZXI6ICdDb3VjaGUgbsKwe3tpbmRleH19JyxcbiAgICAgICAgbGF5ZXJPcHRpb25zOiAnT3B0aW9ucyBkZSBsYSBjb3VjaGUnLFxuICAgICAgICBsYXllclRpdGxlOiAnTGliZWxsw6kgZGUgbGEgY291Y2hlJyxcbiAgICAgICAgbGF5ZXJUeXBlOiB7XG4gICAgICAgICAgdGl0bGU6ICdUeXBlJyxcbiAgICAgICAgICBoZWF0bWFwOiAnQ2hhbGV1cicsXG4gICAgICAgICAgcmVsYXRpb246ICdSZWxhdGlvbnMnLFxuICAgICAgICAgIGJ1YmJsZTogJ0J1bGxlcycsXG4gICAgICAgICAgbWFya2VyOiAnTWFycXVldXJzJyxcbiAgICAgICAgICBwb2x5Z29uOiAnRm9ybWVzJyxcbiAgICAgICAgICB3bXM6ICdTZXJ2aWNlIFdNUycsXG4gICAgICAgICAgd210czogJ1NlcnZpY2UgV01UUycsXG4gICAgICAgICAgZmVhdHVyZWxheWVyOiAnRmVhdHVyZSBsYXllcicsXG4gICAgICAgICAgdmVjdG9ydGlsZTogJ1ZlY3RvciB0aWxlJyxcbiAgICAgICAgICByYXN0ZXJ0aWxlOiAnUmFzdGVyIHRpbGUnLFxuICAgICAgICAgIHBvaW50OiAnUG9pbnRzJyxcbiAgICAgICAgICBsaW5lOiAnTGlnbmVzJyxcbiAgICAgICAgICBnZW9zZXJ2ZXI6ICdHZW9zZXJ2ZXIgKHt7a2V5fX0pJyxcbiAgICAgICAgICAnbXVsdGktbGluZSc6ICdNdWx0aS1saWduZXMnLFxuICAgICAgICAgICdtdWx0aS1wb2x5Z29uJzogJ011bHRpLXBvbHlnb25lJ1xuICAgICAgICB9LFxuICAgICAgICB0b29sdGlwOiB7XG4gICAgICAgICAgaG92ZXI6ICdTdXJ2b2wnLFxuICAgICAgICAgIGNsaWNrOiAnQ2xpYycsXG4gICAgICAgICAgdGl0bGU6ICdPdXZlcnR1cmUgZGVzIHRvb2x0aXBzJ1xuICAgICAgICB9LFxuICAgICAgICB0aWxlOiAnT3B0aW9uIGRlIGNvdWNoZSB0dWlsZScsXG4gICAgICAgIGxvY2F0aW9uQXR0cjogJ09wdGlvbnMgZGUgcG9zaXRpb25uZW1lbnQnLFxuICAgICAgICBjbHVzdGVyaW5nOiAnT3B0aW9ucyBkZSByZWdyb3VwZW1lbnQnLFxuICAgICAgICB3bXM6IHtcbiAgICAgICAgICB1cmw6ICdVcmwgZHUgc2VydmljZScsXG4gICAgICAgICAgcGFyYW1MYXllcjogJ0lkZW50aWZpYW50IGRlIGRvbm5uw6llcycsXG4gICAgICAgICAgcGFyYW1UaWxlZDogJ1NvdXMgZm9ybWUgZGUgdHVpbGVzJyxcbiAgICAgICAgICBzdHlsZTogJ1N0eWxlJyxcbiAgICAgICAgICBtYXRyaXhTZXQ6ICdtYXRyaXhTZXQnXG4gICAgICAgIH0sXG4gICAgICAgIGRlbGV0ZUxheWVyOiAnU3VwcHJpbWVyIGxhIGNvdWNoZScsXG4gICAgICAgIGxvY2F0aW9uQXJyYXk6ICdMYXRpdHVkZSBldCBMb25naXR1ZGUgc8OpcGFyw6llcycsXG4gICAgICAgIGxvY2F0aW9uQXR0cmlidXRlOiB7XG4gICAgICAgICAgYm90aDogJ1Byb3ByacOpdMOpIGRlcyBjb29yZG9ubsOpZXMnLFxuICAgICAgICAgIGxhdDogJ1Byb3ByacOpdMOpIGRlIGxhIGxhdGl0dWRlJyxcbiAgICAgICAgICBsbmc6ICdQcm9wcmnDqXTDqSBkZSBsYSBsb25naXR1ZGUnXG4gICAgICAgIH0sXG4gICAgICAgIGludGVuc2l0eUF0dHJpYnV0ZTogXCJQcm9wcmnDqXTDqSBkZSBsJ2ludGVuc2l0w6lcIixcbiAgICAgICAgY2xhc3NlczogJ0NsYXNzZXMgYWZmaWNow6llcyBkYW5zIGNldHRlIGNvdWNoZScsXG4gICAgICAgIHJlbGF0aW9uczogJ0FmZmljaGVyIGxlcyByZWxhdGlvbnMnLFxuICAgICAgICBpbXBvcnRTdGFydDogJ0ltcG9ydGF0aW9uIGR1IGZpY2hpZXIge3tmaWxlbmFtZX19Li4uJyxcbiAgICAgICAgaW1wb3J0T2s6ICdGaWNoaWVyIHt7ZmlsZW5hbWV9fSBpbXBvcnTDqS4nLFxuICAgICAgICBpbXBvcnRFcnJvcjogXCJMJ2V4dGVuc2lvbiB7e2V4dGVuc2lvbn19IG4nZXN0IHBhcyByZWNvbm51ZS4gVm91cyBwb3V2ZXogdXRpbGlzZXI6IHt7YXV0aG9yaXplZEZvcm1hdHN9fS5cIixcbiAgICAgICAgaW1wb3J0Tm90Rm91bmRJblppcDogXCJBdWN1biBmaWNoaWVyIHt7ZXh0ZW5zaW9ufX0gdHJvdXbDqSBkYW5zIGwnYXJjaGl2ZS5cIixcbiAgICAgICAgY2x1c3RlcmVkOiAnUmVncm91cGVtZW50JyxcbiAgICAgICAgY2x1c3RlckRpc3RhbmNlOiAnRGlzdGFuY2UgZGUgcmVncm91cGVtZW50JyxcbiAgICAgICAgb3BhY2l0eTogJ09wYWNpdMOpJyxcbiAgICAgICAgYWRkcmVzczogJ0FkcmVzc2UnLFxuICAgICAgICBhZGRyZXNzQ29vcmRzOiAnQ29vcmRvbm7DqWVzJyxcbiAgICAgICAgYWN0aXZlOiAnQWN0aXZlJyxcbiAgICAgICAgaW5hY3RpdmU6ICdJbmFjdGl2ZScsXG4gICAgICAgIG1vdmU6ICdNb2RlIGTDqXBsYWNlbWVudCcsXG4gICAgICAgIGxhc3NvOiAnU8OpbGVjdGlvbiBwYXIgbGFzc28nLFxuICAgICAgICByZWN0YW5nbGU6ICdTw6lsZWN0aW9uIHBhciByZWN0YW5nbGUnLFxuICAgICAgICBjbGljazogJ1PDqWxlY3Rpb25uZXIgcGFyIGNsaWMnLFxuICAgICAgICB6b29tOiAnWm9vbSBwYXIgcmVjdGFuZ2xlJyxcbiAgICAgICAgZXhwb3J0OiAnRXhwb3J0ZXIgbGEgY2FydGUnLFxuICAgICAgICBpbXBvcnQ6ICdJbXBvcnRlciB1bmUgY291Y2hlJyxcbiAgICAgICAgbGVnZW5kOiAnTMOpZ2VuZGUgZGUgbGEgY291Y2hlIHt7bGF5ZXJ9fScsXG4gICAgICAgIGxlZ2VuZE5vdFByb3ZpZGVkOiAnTMOpZ2VuZGUgbm9uIGZvdXJuaWUgcGFyIGxlIHNlcnZldXInXG4gICAgICB9XG4gICAgfVxuICB9XG59O1xuIl19
83
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZnIudHJhbnNsYXRpb25zLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvcHJvdm9seS9kYXNoYm9hcmQvd2lkZ2V0cy93aWRnZXQtbWFwL2kxOG4vZnIudHJhbnNsYXRpb25zLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE1BQU0sQ0FBQyxNQUFNLGNBQWMsR0FBRztJQUM1QixNQUFNLEVBQUU7UUFDTixNQUFNLEVBQUU7WUFDTixHQUFHLEVBQUU7Z0JBQ0gsV0FBVyxFQUFFLHlCQUF5QjtnQkFDdEMsWUFBWSxFQUFFLHNCQUFzQjtnQkFDcEMsS0FBSyxFQUFFLHdCQUF3QjtnQkFDL0IsT0FBTyxFQUFFLHFCQUFxQjtnQkFDOUIsR0FBRyxFQUFFLCtCQUErQjtnQkFDcEMsUUFBUSxFQUFFLG9CQUFvQjtnQkFDOUIsS0FBSyxFQUFFLG9CQUFvQjtnQkFDM0IsWUFBWSxFQUFFLHNCQUFzQjtnQkFDcEMsVUFBVSxFQUFFLHNCQUFzQjtnQkFDbEMsU0FBUyxFQUFFO29CQUNULEtBQUssRUFBRSxNQUFNO29CQUNiLE9BQU8sRUFBRSxTQUFTO29CQUNsQixRQUFRLEVBQUUsV0FBVztvQkFDckIsTUFBTSxFQUFFLFFBQVE7b0JBQ2hCLE1BQU0sRUFBRSxXQUFXO29CQUNuQixPQUFPLEVBQUUsUUFBUTtvQkFDakIsR0FBRyxFQUFFLGFBQWE7b0JBQ2xCLElBQUksRUFBRSxjQUFjO29CQUNwQixZQUFZLEVBQUUsZUFBZTtvQkFDN0IsVUFBVSxFQUFFLGFBQWE7b0JBQ3pCLFVBQVUsRUFBRSxhQUFhO29CQUN6QixLQUFLLEVBQUUsUUFBUTtvQkFDZixJQUFJLEVBQUUsUUFBUTtvQkFDZCxTQUFTLEVBQUUscUJBQXFCO29CQUNoQyxZQUFZLEVBQUUsY0FBYztvQkFDNUIsZUFBZSxFQUFFLGdCQUFnQjtpQkFDbEM7Z0JBQ0QsT0FBTyxFQUFFO29CQUNQLEtBQUssRUFBRSxRQUFRO29CQUNmLEtBQUssRUFBRSxNQUFNO29CQUNiLEtBQUssRUFBRSx3QkFBd0I7aUJBQ2hDO2dCQUNELElBQUksRUFBRSx3QkFBd0I7Z0JBQzlCLFlBQVksRUFBRSwyQkFBMkI7Z0JBQ3pDLFVBQVUsRUFBRSx5QkFBeUI7Z0JBQ3JDLEdBQUcsRUFBRTtvQkFDSCxHQUFHLEVBQUUsZ0JBQWdCO29CQUNyQixVQUFVLEVBQUUseUJBQXlCO29CQUNyQyxVQUFVLEVBQUUsc0JBQXNCO29CQUNsQyxLQUFLLEVBQUUsT0FBTztvQkFDZCxTQUFTLEVBQUUsV0FBVztpQkFDdkI7Z0JBQ0QsV0FBVyxFQUFFLHFCQUFxQjtnQkFDbEMsYUFBYSxFQUFFLGdDQUFnQztnQkFDL0MsaUJBQWlCLEVBQUU7b0JBQ2pCLElBQUksRUFBRSwyQkFBMkI7b0JBQ2pDLEdBQUcsRUFBRSwwQkFBMEI7b0JBQy9CLEdBQUcsRUFBRSwyQkFBMkI7aUJBQ2pDO2dCQUNELGtCQUFrQixFQUFFLDBCQUEwQjtnQkFDOUMsT0FBTyxFQUFFLHFDQUFxQztnQkFDOUMsU0FBUyxFQUFFLHdCQUF3QjtnQkFDbkMsV0FBVyxFQUFFLHdDQUF3QztnQkFDckQsUUFBUSxFQUFFLCtCQUErQjtnQkFDekMsV0FBVyxFQUFFLDRGQUE0RjtnQkFDekcsbUJBQW1CLEVBQUUsb0RBQW9EO2dCQUN6RSxTQUFTLEVBQUUsY0FBYztnQkFDekIsZUFBZSxFQUFFLDBCQUEwQjtnQkFDM0MsT0FBTyxFQUFFLFNBQVM7Z0JBQ2xCLE9BQU8sRUFBRSxTQUFTO2dCQUNsQixhQUFhLEVBQUUsYUFBYTtnQkFDNUIsTUFBTSxFQUFFLFFBQVE7Z0JBQ2hCLFFBQVEsRUFBRSxVQUFVO2dCQUNwQixJQUFJLEVBQUUsa0JBQWtCO2dCQUN4QixLQUFLLEVBQUUscUJBQXFCO2dCQUM1QixTQUFTLEVBQUUseUJBQXlCO2dCQUNwQyxLQUFLLEVBQUUsdUJBQXVCO2dCQUM5QixJQUFJLEVBQUUsb0JBQW9CO2dCQUMxQixNQUFNLEVBQUUsbUJBQW1CO2dCQUMzQixNQUFNLEVBQUUscUJBQXFCO2dCQUM3QixNQUFNLEVBQUUsZ0NBQWdDO2dCQUN4QyxpQkFBaUIsRUFBRSxvQ0FBb0M7Z0JBQ3ZELFlBQVksRUFBRSwwQkFBMEI7Z0JBQ3hDLE9BQU8sRUFBRSxxQkFBcUI7YUFDL0I7U0FDRjtLQUNGO0NBQ0YsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBjb25zdCBmclRyYW5zbGF0aW9ucyA9IHtcbiAgJ0BwcnknOiB7XG4gICAgd2lkZ2V0OiB7XG4gICAgICBtYXA6IHtcbiAgICAgICAgYXR0cmlidXRpb246ICdDcsOpZGl0cyBkZSBjZXR0ZSBjb3VjaGUnLFxuICAgICAgICBhdHRyaWJ1dGlvbnM6ICdBZmZpY2hlciBsZXMgY3LDqWRpdHMnLFxuICAgICAgICBzdHlsZTogJ1N0eWxlIGR1IGZvbmQgZGUgY2FydGUnLFxuICAgICAgICBub1N0eWxlOiAnQXVjdW4gZm9uZCBkZSBjYXJ0ZScsXG4gICAgICAgIGZpdDogJ0FkYXB0ZXIgbGEgdGFpbGxlIGF1eCBkb25uw6llcycsXG4gICAgICAgIGFkZExheWVyOiAnQWpvdXRlciB1bmUgY291Y2hlJyxcbiAgICAgICAgbGF5ZXI6ICdDb3VjaGUgbsKwe3tpbmRleH19JyxcbiAgICAgICAgbGF5ZXJPcHRpb25zOiAnT3B0aW9ucyBkZSBsYSBjb3VjaGUnLFxuICAgICAgICBsYXllclRpdGxlOiAnTGliZWxsw6kgZGUgbGEgY291Y2hlJyxcbiAgICAgICAgbGF5ZXJUeXBlOiB7XG4gICAgICAgICAgdGl0bGU6ICdUeXBlJyxcbiAgICAgICAgICBoZWF0bWFwOiAnQ2hhbGV1cicsXG4gICAgICAgICAgcmVsYXRpb246ICdSZWxhdGlvbnMnLFxuICAgICAgICAgIGJ1YmJsZTogJ0J1bGxlcycsXG4gICAgICAgICAgbWFya2VyOiAnTWFycXVldXJzJyxcbiAgICAgICAgICBwb2x5Z29uOiAnRm9ybWVzJyxcbiAgICAgICAgICB3bXM6ICdTZXJ2aWNlIFdNUycsXG4gICAgICAgICAgd210czogJ1NlcnZpY2UgV01UUycsXG4gICAgICAgICAgZmVhdHVyZWxheWVyOiAnRmVhdHVyZSBsYXllcicsXG4gICAgICAgICAgdmVjdG9ydGlsZTogJ1ZlY3RvciB0aWxlJyxcbiAgICAgICAgICByYXN0ZXJ0aWxlOiAnUmFzdGVyIHRpbGUnLFxuICAgICAgICAgIHBvaW50OiAnUG9pbnRzJyxcbiAgICAgICAgICBsaW5lOiAnTGlnbmVzJyxcbiAgICAgICAgICBnZW9zZXJ2ZXI6ICdHZW9zZXJ2ZXIgKHt7a2V5fX0pJyxcbiAgICAgICAgICAnbXVsdGktbGluZSc6ICdNdWx0aS1saWduZXMnLFxuICAgICAgICAgICdtdWx0aS1wb2x5Z29uJzogJ011bHRpLXBvbHlnb25lJ1xuICAgICAgICB9LFxuICAgICAgICB0b29sdGlwOiB7XG4gICAgICAgICAgaG92ZXI6ICdTdXJ2b2wnLFxuICAgICAgICAgIGNsaWNrOiAnQ2xpYycsXG4gICAgICAgICAgdGl0bGU6ICdPdXZlcnR1cmUgZGVzIHRvb2x0aXBzJ1xuICAgICAgICB9LFxuICAgICAgICB0aWxlOiAnT3B0aW9uIGRlIGNvdWNoZSB0dWlsZScsXG4gICAgICAgIGxvY2F0aW9uQXR0cjogJ09wdGlvbnMgZGUgcG9zaXRpb25uZW1lbnQnLFxuICAgICAgICBjbHVzdGVyaW5nOiAnT3B0aW9ucyBkZSByZWdyb3VwZW1lbnQnLFxuICAgICAgICB3bXM6IHtcbiAgICAgICAgICB1cmw6ICdVcmwgZHUgc2VydmljZScsXG4gICAgICAgICAgcGFyYW1MYXllcjogJ0lkZW50aWZpYW50IGRlIGRvbm5uw6llcycsXG4gICAgICAgICAgcGFyYW1UaWxlZDogJ1NvdXMgZm9ybWUgZGUgdHVpbGVzJyxcbiAgICAgICAgICBzdHlsZTogJ1N0eWxlJyxcbiAgICAgICAgICBtYXRyaXhTZXQ6ICdtYXRyaXhTZXQnXG4gICAgICAgIH0sXG4gICAgICAgIGRlbGV0ZUxheWVyOiAnU3VwcHJpbWVyIGxhIGNvdWNoZScsXG4gICAgICAgIGxvY2F0aW9uQXJyYXk6ICdMYXRpdHVkZSBldCBMb25naXR1ZGUgc8OpcGFyw6llcycsXG4gICAgICAgIGxvY2F0aW9uQXR0cmlidXRlOiB7XG4gICAgICAgICAgYm90aDogJ1Byb3ByacOpdMOpIGRlcyBjb29yZG9ubsOpZXMnLFxuICAgICAgICAgIGxhdDogJ1Byb3ByacOpdMOpIGRlIGxhIGxhdGl0dWRlJyxcbiAgICAgICAgICBsbmc6ICdQcm9wcmnDqXTDqSBkZSBsYSBsb25naXR1ZGUnXG4gICAgICAgIH0sXG4gICAgICAgIGludGVuc2l0eUF0dHJpYnV0ZTogXCJQcm9wcmnDqXTDqSBkZSBsJ2ludGVuc2l0w6lcIixcbiAgICAgICAgY2xhc3NlczogJ0NsYXNzZXMgYWZmaWNow6llcyBkYW5zIGNldHRlIGNvdWNoZScsXG4gICAgICAgIHJlbGF0aW9uczogJ0FmZmljaGVyIGxlcyByZWxhdGlvbnMnLFxuICAgICAgICBpbXBvcnRTdGFydDogJ0ltcG9ydGF0aW9uIGR1IGZpY2hpZXIge3tmaWxlbmFtZX19Li4uJyxcbiAgICAgICAgaW1wb3J0T2s6ICdGaWNoaWVyIHt7ZmlsZW5hbWV9fSBpbXBvcnTDqS4nLFxuICAgICAgICBpbXBvcnRFcnJvcjogXCJMJ2V4dGVuc2lvbiB7e2V4dGVuc2lvbn19IG4nZXN0IHBhcyByZWNvbm51ZS4gVm91cyBwb3V2ZXogdXRpbGlzZXI6IHt7YXV0aG9yaXplZEZvcm1hdHN9fS5cIixcbiAgICAgICAgaW1wb3J0Tm90Rm91bmRJblppcDogXCJBdWN1biBmaWNoaWVyIHt7ZXh0ZW5zaW9ufX0gdHJvdXbDqSBkYW5zIGwnYXJjaGl2ZS5cIixcbiAgICAgICAgY2x1c3RlcmVkOiAnUmVncm91cGVtZW50JyxcbiAgICAgICAgY2x1c3RlckRpc3RhbmNlOiAnRGlzdGFuY2UgZGUgcmVncm91cGVtZW50JyxcbiAgICAgICAgb3BhY2l0eTogJ09wYWNpdMOpJyxcbiAgICAgICAgYWRkcmVzczogJ0FkcmVzc2UnLFxuICAgICAgICBhZGRyZXNzQ29vcmRzOiAnQ29vcmRvbm7DqWVzJyxcbiAgICAgICAgYWN0aXZlOiAnQWN0aXZlJyxcbiAgICAgICAgaW5hY3RpdmU6ICdJbmFjdGl2ZScsXG4gICAgICAgIG1vdmU6ICdNb2RlIGTDqXBsYWNlbWVudCcsXG4gICAgICAgIGxhc3NvOiAnU8OpbGVjdGlvbiBwYXIgbGFzc28nLFxuICAgICAgICByZWN0YW5nbGU6ICdTw6lsZWN0aW9uIHBhciByZWN0YW5nbGUnLFxuICAgICAgICBjbGljazogJ1PDqWxlY3Rpb25uZXIgcGFyIGNsaWMnLFxuICAgICAgICB6b29tOiAnWm9vbSBwYXIgcmVjdGFuZ2xlJyxcbiAgICAgICAgZXhwb3J0OiAnRXhwb3J0ZXIgbGEgY2FydGUnLFxuICAgICAgICBpbXBvcnQ6ICdJbXBvcnRlciB1bmUgY291Y2hlJyxcbiAgICAgICAgbGVnZW5kOiAnTMOpZ2VuZGUgZGUgbGEgY291Y2hlIHt7bGF5ZXJ9fScsXG4gICAgICAgIGxlZ2VuZE5vdFByb3ZpZGVkOiAnTMOpZ2VuZGUgbm9uIGZvdXJuaWUgcGFyIGxlIHNlcnZldXInLFxuICAgICAgICBzZWxlY3RMYXllcnM6ICdTw6lsZWN0aW9ubmVyIGxlcyBjb3VjaGVzJyxcbiAgICAgICAgbGVnZW5kczogJ0FmZmljaGVyIGxhIGzDqWdlbmRlJ1xuICAgICAgfVxuICAgIH1cbiAgfVxufTtcbiJdfQ==
@@ -3,7 +3,6 @@ import { Overlay } from 'ol';
3
3
  import LayerSwitcher from 'ol-layerswitcher';
4
4
  import { ScaleLine } from 'ol/control';
5
5
  import { toLonLat } from 'ol/proj';
6
- import { SearchBarControl } from '../search-bar/search-bar.control';
7
6
  import { SelectionInteraction } from './selection-interaction.class';
8
7
  export class InteractionManager {
9
8
  constructor() {
@@ -48,6 +47,7 @@ export class InteractionManager {
48
47
  if (wmsLayers) {
49
48
  this.component.getFeatureFromServer(wmsLayers, event.coordinate);
50
49
  }
50
+ this.tooltipEvent = event;
51
51
  }
52
52
  };
53
53
  }
@@ -56,7 +56,6 @@ export class InteractionManager {
56
56
  this.addContextMenuInteraction();
57
57
  this.addDropInteraction();
58
58
  this.addOverlayOnInteraction();
59
- this.addSearchBarControl();
60
59
  this.addLayerSwitcher();
61
60
  this.addScaleControl();
62
61
  this.addUpdateZoomAndCenter();
@@ -94,28 +93,10 @@ export class InteractionManager {
94
93
  this.component.map.addControl(this.scaleControl);
95
94
  }
96
95
  }
97
- addSearchBarControl() {
98
- this.searchBarControl = new SearchBarControl({}).withGeocodingService(this.component.geocodingService);
99
- this.component.map.addControl(this.searchBarControl);
100
- const addressOverlay = new Overlay({
101
- element: this.component.address.nativeElement,
102
- offset: [9, 9]
103
- });
104
- this.component.map.addOverlay(addressOverlay);
105
- // @ts-ignore
106
- this.component.map.on('searched-address', (evt) => {
107
- this.component.address.nativeElement.innerHTML = `<div>
108
- <div>${this.component.translateService.instant('@pry.widget.map.address')}: ${evt.address}</div>
109
- <div>${this.component.translateService.instant('@pry.widget.map.addressCoords')}: ${evt.latLon}</div>
110
- </div>`;
111
- this.component.address.nativeElement.style.display = '';
112
- addressOverlay.setPosition(evt.coordinates);
113
- this.component.map.getView().setCenter(evt.coordinates);
114
- this.component.map.getView().setZoom(this.component.map.getView().getMaxZoom());
115
- });
116
- }
117
96
  addLayerSwitcher() {
118
97
  this.layerSwitchControl = new LayerSwitcher({
98
+ tipLabel: this.component.translateService.instant('@pry.widget.map.selectLayers'),
99
+ collapseTipLabel: this.component.translateService.instant('@pry.widget.map.selectLayers'),
119
100
  activationMode: 'click',
120
101
  reverse: false
121
102
  });
@@ -143,4 +124,4 @@ export class InteractionManager {
143
124
  });
144
125
  }
145
126
  }
146
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"interaction-manager.class.js","sourceRoot":"","sources":["../../../../../../../projects/provoly/dashboard/widgets/widget-map/interaction/interaction-manager.class.ts"],"names":[],"mappings":"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","sourcesContent":["import { ContextMenuActions, TooltipMode } from '@provoly/dashboard';\nimport { Feature, MapBrowserEvent, Overlay } from 'ol';\nimport LayerSwitcher from 'ol-layerswitcher';\nimport { ScaleLine } from 'ol/control';\nimport { Circle, Point } from 'ol/geom';\nimport { toLonLat } from 'ol/proj';\nimport { WidgetMapComponent } from '../component/widget-map.component';\nimport { AddressSearchedEvent, SearchBarControl } from '../search-bar/search-bar.control';\nimport { SelectionInteraction } from './selection-interaction.class';\n\nexport class InteractionManager {\n  interactionPopupOverlay?: Overlay;\n  private component!: WidgetMapComponent;\n  searchBarControl?: SearchBarControl;\n  layerSwitchControl?: LayerSwitcher;\n  scaleControl?: ScaleLine;\n  selectionInteraction = new SelectionInteraction();\n\n  init(component: WidgetMapComponent) {\n    this.component = component;\n    this.addContextMenuInteraction();\n    this.addDropInteraction();\n    this.addOverlayOnInteraction();\n    this.addSearchBarControl();\n    this.addLayerSwitcher();\n    this.addScaleControl();\n    this.addUpdateZoomAndCenter();\n    this.component.map.addInteraction(this.selectionInteraction.init(this.component.store));\n    return this;\n  }\n\n  listeners = {\n    contextMenu: (e: MouseEvent) => {\n      if (this.component.manifest.contextMenu !== false) {\n        const mapCoordinates = this.component.map.getEventPixel(e);\n        const itemId = this.component.map.forEachFeatureAtPixel(mapCoordinates, (feature: any) => feature.get('id'));\n        this.component.store.dispatch(\n          ContextMenuActions.open({\n            itemId,\n            clientX: e.clientX,\n            clientY: e.clientY,\n            resultSet: Array.isArray(this.component.manifest.datasource)\n              ? this.component.manifest.datasource[0]\n              : this.component.manifest.datasource,\n            from: 'map',\n            coordinates: toLonLat(\n              this.component.map.getCoordinateFromPixel(mapCoordinates),\n              this.component.map.getView().getProjection()\n            ).reverse()\n          })\n        );\n        e.preventDefault();\n      }\n    },\n    drop: (e: DragEvent) => {\n      this.component.import(e);\n      e.preventDefault();\n    },\n    popup: (event: MapBrowserEvent<MouseEvent>) => {\n      const values = this.component.map.getFeaturesAtPixel(event.pixel, { hitTolerance: 5 }) as (\n        | Feature<Circle>\n        | Feature<Point>\n      )[];\n      const valuesToDisplay = [\n        ...new Set(\n          values\n            .map((value) => value.get('id'))\n            .filter((id) => !!id)\n            .map((id) => values.find((value) => value.get('id') === id))\n            .map((value) => ({\n              oClass: value?.get('oClass'),\n              coordinates: event.coordinate,\n              values: value?.getKeys().reduce((p, c) => ({ ...p, [c]: value.get(c) }), {})\n            }))\n        )\n      ];\n      this.component.classicFeatures$.next(valuesToDisplay);\n      const wmsLayers = this.component.getWMSLayers();\n      if (wmsLayers) {\n        this.component.getFeatureFromServer(wmsLayers, event.coordinate);\n      }\n    }\n  };\n\n  private addContextMenuInteraction() {\n    this.component.map.getViewport().addEventListener('contextmenu', this.listeners.contextMenu);\n  }\n\n  private addDropInteraction() {\n    this.component.map.getViewport().addEventListener('drop', this.listeners.drop);\n  }\n\n  private addOverlayOnInteraction() {\n    if (!this.interactionPopupOverlay) {\n      this.interactionPopupOverlay = new Overlay({\n        element: this.component.popup.nativeElement,\n        offset: [9, 9]\n      });\n      this.component.map.addOverlay(this.interactionPopupOverlay);\n    }\n    if (this.component.optionsCopy.tooltipMode !== TooltipMode.NONE) {\n      this.component.map.un('singleclick', this.listeners.popup);\n      this.component.map.on('singleclick', this.listeners.popup);\n    }\n  }\n\n  private addScaleControl() {\n    if (!this.scaleControl) {\n      this.scaleControl = new ScaleLine({\n        units: 'metric',\n        bar: true,\n        steps: 4,\n        text: true,\n        minWidth: 140\n      });\n      this.component.map.addControl(this.scaleControl);\n    }\n  }\n\n  private addSearchBarControl() {\n    this.searchBarControl = new SearchBarControl({}).withGeocodingService(this.component.geocodingService);\n    this.component.map.addControl(this.searchBarControl);\n\n    const addressOverlay = new Overlay({\n      element: this.component.address.nativeElement,\n      offset: [9, 9]\n    });\n    this.component.map.addOverlay(addressOverlay);\n\n    // @ts-ignore\n    this.component.map.on('searched-address', (evt: AddressSearchedEvent) => {\n      this.component.address.nativeElement.innerHTML = `<div>\n        <div>${this.component.translateService.instant('@pry.widget.map.address')}: ${evt.address}</div>\n        <div>${this.component.translateService.instant('@pry.widget.map.addressCoords')}: ${evt.latLon}</div>\n        </div>`;\n      this.component.address.nativeElement.style.display = '';\n      addressOverlay.setPosition(evt.coordinates);\n      this.component.map.getView().setCenter(evt.coordinates);\n      this.component.map.getView().setZoom(this.component.map.getView().getMaxZoom());\n    });\n  }\n\n  private addLayerSwitcher() {\n    this.layerSwitchControl = new LayerSwitcher({\n      activationMode: 'click',\n      reverse: false\n    });\n    this.component.map.addControl(this.layerSwitchControl);\n\n    // @ts-ignore\n    this.layerSwitchControl.on('show', () => {\n      this.component.legendTabOpen = false;\n    });\n  }\n\n  private addUpdateZoomAndCenter() {\n    this.component.map.on('moveend', () => {\n      this.component.optionsCopy.zoom = {\n        start:\n          this.component.map.getView().getZoom() ??\n          this.component.optionsCopy.zoom?.start ??\n          this.component.map.getView().getMinZoom(),\n        min: this.component.map.getView().getMinZoom(),\n        max: this.component.map.getView().getMaxZoom()\n      };\n      this.component.optionsCopy.center =\n        toLonLat(this.component.map.getView().getCenter() ?? [0, 0]) ?? this.component.optionsCopy.center;\n      this.component.zoomAndCenter$.next({\n        zoom: this.component.optionsCopy.zoom,\n        center: this.component.optionsCopy.center\n      });\n    });\n  }\n}\n"]}
127
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"interaction-manager.class.js","sourceRoot":"","sources":["../../../../../../../projects/provoly/dashboard/widgets/widget-map/interaction/interaction-manager.class.ts"],"names":[],"mappings":"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","sourcesContent":["import { ContextMenuActions, TooltipMode } from '@provoly/dashboard';\nimport { Feature, MapBrowserEvent, Overlay } from 'ol';\nimport LayerSwitcher from 'ol-layerswitcher';\nimport { ScaleLine } from 'ol/control';\nimport { Circle, Point } from 'ol/geom';\nimport { toLonLat } from 'ol/proj';\n// This is not a circular dependency\nimport type { WidgetMapComponent } from '../component/widget-map.component';\nimport { SelectionInteraction } from './selection-interaction.class';\n\nexport class InteractionManager {\n  interactionPopupOverlay?: Overlay;\n  layerSwitchControl?: LayerSwitcher;\n  scaleControl?: ScaleLine;\n  selectionInteraction = new SelectionInteraction();\n  public tooltipEvent?: MapBrowserEvent<MouseEvent>;\n  private component!: WidgetMapComponent;\n\n  init(component: WidgetMapComponent) {\n    this.component = component;\n    this.addContextMenuInteraction();\n    this.addDropInteraction();\n    this.addOverlayOnInteraction();\n    this.addLayerSwitcher();\n    this.addScaleControl();\n    this.addUpdateZoomAndCenter();\n    this.component.map.addInteraction(this.selectionInteraction.init(this.component.store));\n    return this;\n  }\n\n  listeners = {\n    contextMenu: (e: MouseEvent) => {\n      if (this.component.manifest.contextMenu !== false) {\n        const mapCoordinates = this.component.map.getEventPixel(e);\n        const itemId = this.component.map.forEachFeatureAtPixel(mapCoordinates, (feature: any) => feature.get('id'));\n        this.component.store.dispatch(\n          ContextMenuActions.open({\n            itemId,\n            clientX: e.clientX,\n            clientY: e.clientY,\n            resultSet: Array.isArray(this.component.manifest.datasource)\n              ? this.component.manifest.datasource[0]\n              : this.component.manifest.datasource,\n            from: 'map',\n            coordinates: toLonLat(\n              this.component.map.getCoordinateFromPixel(mapCoordinates),\n              this.component.map.getView().getProjection()\n            ).reverse()\n          })\n        );\n        e.preventDefault();\n      }\n    },\n    drop: (e: DragEvent) => {\n      this.component.import(e);\n      e.preventDefault();\n    },\n    popup: (event: MapBrowserEvent<MouseEvent>) => {\n      const values = this.component.map.getFeaturesAtPixel(event.pixel, { hitTolerance: 5 }) as (\n        | Feature<Circle>\n        | Feature<Point>\n      )[];\n      const valuesToDisplay = [\n        ...new Set(\n          values\n            .map((value) => value.get('id'))\n            .filter((id) => !!id)\n            .map((id) => values.find((value) => value.get('id') === id))\n            .map((value) => ({\n              oClass: value?.get('oClass'),\n              coordinates: event.coordinate,\n              values: value?.getKeys().reduce((p, c) => ({ ...p, [c]: value.get(c) }), {})\n            }))\n        )\n      ];\n      this.component.classicFeatures$.next(valuesToDisplay);\n      const wmsLayers = this.component.getWMSLayers();\n      if (wmsLayers) {\n        this.component.getFeatureFromServer(wmsLayers, event.coordinate);\n      }\n      this.tooltipEvent = event;\n    }\n  };\n\n  private addContextMenuInteraction() {\n    this.component.map.getViewport().addEventListener('contextmenu', this.listeners.contextMenu);\n  }\n\n  private addDropInteraction() {\n    this.component.map.getViewport().addEventListener('drop', this.listeners.drop);\n  }\n\n  private addOverlayOnInteraction() {\n    if (!this.interactionPopupOverlay) {\n      this.interactionPopupOverlay = new Overlay({\n        element: this.component.popup.nativeElement,\n        offset: [9, 9]\n      });\n      this.component.map.addOverlay(this.interactionPopupOverlay);\n    }\n    if (this.component.optionsCopy.tooltipMode !== TooltipMode.NONE) {\n      this.component.map.un('singleclick', this.listeners.popup);\n      this.component.map.on('singleclick', this.listeners.popup);\n    }\n  }\n\n  private addScaleControl() {\n    if (!this.scaleControl) {\n      this.scaleControl = new ScaleLine({\n        units: 'metric',\n        bar: true,\n        steps: 4,\n        text: true,\n        minWidth: 140\n      });\n      this.component.map.addControl(this.scaleControl);\n    }\n  }\n\n  private addLayerSwitcher() {\n    this.layerSwitchControl = new LayerSwitcher({\n      tipLabel: this.component.translateService.instant('@pry.widget.map.selectLayers'),\n      collapseTipLabel: this.component.translateService.instant('@pry.widget.map.selectLayers'),\n      activationMode: 'click',\n      reverse: false\n    });\n    this.component.map.addControl(this.layerSwitchControl);\n\n    // @ts-ignore\n    this.layerSwitchControl.on('show', () => {\n      this.component.legendTabOpen = false;\n    });\n  }\n\n  private addUpdateZoomAndCenter() {\n    this.component.map.on('moveend', () => {\n      this.component.optionsCopy.zoom = {\n        start:\n          this.component.map.getView().getZoom() ??\n          this.component.optionsCopy.zoom?.start ??\n          this.component.map.getView().getMinZoom(),\n        min: this.component.map.getView().getMinZoom(),\n        max: this.component.map.getView().getMaxZoom()\n      };\n      this.component.optionsCopy.center =\n        toLonLat(this.component.map.getView().getCenter() ?? [0, 0]) ?? this.component.optionsCopy.center;\n      this.component.zoomAndCenter$.next({\n        zoom: this.component.optionsCopy.zoom,\n        center: this.component.optionsCopy.center\n      });\n    });\n  }\n}\n"]}
@@ -105,10 +105,10 @@ export class WidgetTileComponent extends DataWidgetComponent {
105
105
  return Object.keys(value?.metadata ?? {}).length > 0;
106
106
  }
107
107
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.6", ngImport: i0, type: WidgetTileComponent, deps: [{ token: i1.Store }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component }); }
108
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.6", type: WidgetTileComponent, selector: "pry-widget-tile", usesInheritance: true, ngImport: i0, template: "<pry-widget-tile-css></pry-widget-tile-css>\n<div class=\"o-widget o-widget--tile\">\n <pry-widget-header\n [datasourceIds]=\"(datasourceIds$ | async) ?? []\"\n *ngIf=\"displayHeader$ | async\"\n [widgetIndex]=\"widgetIndex\"\n [manifest]=\"manifest\"\n (manifestModified)=\"manifestModified.emit($event)\"\n [headerOptions]=\"(displayHeader$ | async) ?? {}\"\n #header\n >\n <pry-settings\n (saveTriggered)=\"emitManifest()\"\n (changeTitle)=\"changeWidgetTitle($event)\"\n [headerPresent]=\"displayHeader$ | async\"\n [widgetIndex]=\"widgetIndex\"\n [header]=\"header\"\n [open$]=\"open$\"\n class=\"o-settings\"\n >\n <div class=\"m-form-label-field\">\n <label class=\"a-label\" for=\"tile_classes\">{{ '@pry.widget.tile.classes' | i18n }}</label>\n <pry-select\n (ngModelChange)=\"changeClasses($event)\"\n [itemsAsOption]=\"true\"\n [items]=\"classes$ | async\"\n [multiple]=\"true\"\n [ngModel]=\"optionsCopy.classes\"\n bindLabel=\"name\"\n bindValue=\"id\"\n class=\"a-pry-select\"\n id=\"tile_classes\"\n ></pry-select>\n </div>\n </pry-settings>\n </pry-widget-header>\n <div class=\"o-widget--tile-wrapper\" [style.top]=\"(displayHeader$ | async) ? WIDGET_HEADER_HEIGHT + 'px' : 0\">\n <div class=\"no-result\" *ngIf=\"(items$ | async)?.length === 0\">\n <img\n class=\"no-result__search\"\n src=\"../../../assets/svgs/pry_recherche_pas_de_resultat.svg\"\n alt=\"{{ '@pry.widget.tile.empty' | i18n }}\"\n aria-hidden=\"true\"\n />\n <span class=\"no-result__text\">{{ '@pry.widget.tile.empty' | i18n }}</span>\n </div>\n <ul class=\"o-widget--tile__list\">\n <li\n class=\"o-widget--tile__list__item\"\n *ngFor=\"let item of items$ | async; let index = index\"\n (contextmenu)=\"contextMenu($event, item)\"\n >\n <div class=\"o-widget--tile__list__item__header\">\n <img\n [height]=\"25\"\n [width]=\"25\"\n [src]=\"item | translateItemToSymbol | async\"\n [alt]=\"item.oClass | translateId : { type: 'class', output: 'name' } | async\"\n />\n <h3 class=\"o-widget--tile__list__item__header__title\">\n {{\n item.oClass\n | translateId\n : {\n type: 'class',\n output: 'name'\n }\n | async\n }}\n </h3>\n <pry-checkbox\n [ngModel]=\"(selectedIds$ | async).includes(item.id)\"\n (click)=\"select($event, item)\"\n ></pry-checkbox>\n </div>\n <div class=\"o-properties\">\n <ul class=\"o-properties__list\">\n <ng-container *ngFor=\"let property of (propertiesToDisplay$ | async)![item.oClass]\">\n <li\n *ngFor=\"let value of getValue(item, property); let i = index; let c = count\"\n class=\"o-properties__list__item\"\n >\n <p class=\"o-properties__list__item__label\" *ngIf=\"i === 0\">{{ property }}:</p>\n <p class=\"o-properties__list__item__value\" *ngIf=\"!isRaw(property, item.oClass)\">{{ value?.value }}</p>\n <p class=\"o-properties__list__item__raw\" *ngIf=\"isRaw(property, item.oClass)\">\n <pry-vizualize-raw [item]=\"item\" [propertyName]=\"property\"></pry-vizualize-raw>\n </p>\n <ng-container *ngIf=\"hasMetadata(value)\">\n <pry-metadata [item]=\"value\"></pry-metadata>\n </ng-container>\n </li>\n </ng-container>\n </ul>\n </div>\n <div (click)=\"toggleMap(index)\" class=\"o-widget--tile__list__item__footer\">\n <button\n type=\"button\"\n class=\"a-btn a-btn--icon-text -link-like\"\n aria-controls=\"tile-map-xxx\"\n aria-expanded=\"false\"\n >\n {{ '@pry.widget.tile.map' | i18n }}\n </button>\n </div>\n <div class=\"o-widget--tile__list__item__map\" *ngIf=\"maps[index]\" id=\"tile-map-xxx\">\n <pry-widget-map [staticManifest]=\"mapManifest\" [staticResultSet]=\"resultSetWithItem(item)\"></pry-widget-map>\n </div>\n </li>\n </ul>\n </div>\n</div>\n", dependencies: [{ kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i4.SettingsComponent, selector: "pry-settings", inputs: ["widgetIndex", "isDisable", "headerPresent", "open$", "header"], outputs: ["saveTriggered", "changeTitle"] }, { kind: "component", type: i4.MetadataComponent, selector: "pry-metadata", inputs: ["item"] }, { kind: "component", type: i4.PryWidgetHeaderComponent, selector: "pry-widget-header", inputs: ["manifest", "additionalOptions", "headerOptions", "displayCount", "datasourceIds", "widgetIndex"], outputs: ["manifestModified"] }, { kind: "component", type: i4.VizualizeRawComponent, selector: "pry-vizualize-raw", inputs: ["item", "propertyName", "alt"] }, { kind: "component", type: i4.PrySelectComponent, selector: "pry-select", inputs: ["labelTranslate", "baseTranslate", "translationFn", "translationFnArgs", "clearable", "multiple", "multipleClearRight", "closeOnSelect", "placeholder", "isForm", "required", "name", "readonly", "items", "itemsAsOption", "bindData", "bindValue", "bindLabel", "bindIcon", "iconSize", "templateLabel", "templateOption", "autocomplete"] }, { kind: "component", type: i5.PryCheckboxComponent, selector: "pry-checkbox", inputs: ["circle"] }, { kind: "component", type: i6.WidgetMapComponent, selector: "pry-widget-map" }, { kind: "component", type: i7.PryWidgetTileCssComponent, selector: "pry-widget-tile-css" }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }, { kind: "pipe", type: i4.TranslateIdPipe, name: "translateId" }, { kind: "pipe", type: i4.TranslateItemToSymbolPipe, name: "translateItemToSymbol" }, { kind: "pipe", type: i4.I18nPipe, name: "i18n" }] }); }
108
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.6", type: WidgetTileComponent, selector: "pry-widget-tile", usesInheritance: true, ngImport: i0, template: "<pry-widget-tile-css></pry-widget-tile-css>\n<div class=\"o-widget o-widget--tile\">\n <pry-widget-header\n [datasourceIds]=\"(datasourceIds$ | async) ?? []\"\n *ngIf=\"displayHeader$ | async\"\n [widgetIndex]=\"widgetIndex\"\n [manifest]=\"manifest\"\n (manifestModified)=\"manifestModified.emit($event)\"\n [headerOptions]=\"(displayHeader$ | async) ?? {}\"\n #header\n >\n <pry-settings\n (saveTriggered)=\"emitManifest()\"\n (changeTitle)=\"changeWidgetTitle($event)\"\n [headerPresent]=\"displayHeader$ | async\"\n [widgetIndex]=\"widgetIndex\"\n [header]=\"header\"\n [open$]=\"open$\"\n class=\"o-settings\"\n >\n <div class=\"m-form-label-field\">\n <label class=\"a-label\" for=\"tile_classes\">{{ '@pry.widget.tile.classes' | i18n }}</label>\n <pry-select\n (ngModelChange)=\"changeClasses($event)\"\n [itemsAsOption]=\"true\"\n [items]=\"classes$ | async\"\n [multiple]=\"true\"\n [closeOnSelect]=\"false\"\n [ngModel]=\"optionsCopy.classes\"\n bindLabel=\"name\"\n bindValue=\"id\"\n class=\"a-pry-select\"\n id=\"tile_classes\"\n ></pry-select>\n </div>\n </pry-settings>\n </pry-widget-header>\n <div class=\"o-widget--tile-wrapper\" [style.top]=\"(displayHeader$ | async) ? WIDGET_HEADER_HEIGHT + 'px' : 0\">\n <div class=\"no-result\" *ngIf=\"(items$ | async)?.length === 0\">\n <img\n class=\"no-result__search\"\n src=\"../../../assets/svgs/pry_recherche_pas_de_resultat.svg\"\n alt=\"{{ '@pry.widget.tile.empty' | i18n }}\"\n aria-hidden=\"true\"\n />\n <span class=\"no-result__text\">{{ '@pry.widget.tile.empty' | i18n }}</span>\n </div>\n <ul class=\"o-widget--tile__list\">\n <li\n class=\"o-widget--tile__list__item\"\n *ngFor=\"let item of items$ | async; let index = index\"\n (contextmenu)=\"contextMenu($event, item)\"\n >\n <div class=\"o-widget--tile__list__item__header\">\n <img\n [height]=\"25\"\n [width]=\"25\"\n [src]=\"item | translateItemToSymbol | async\"\n [alt]=\"item.oClass | translateId : { type: 'class', output: 'name' } | async\"\n />\n <h3 class=\"o-widget--tile__list__item__header__title\">\n {{\n item.oClass\n | translateId\n : {\n type: 'class',\n output: 'name'\n }\n | async\n }}\n </h3>\n <pry-checkbox\n [ngModel]=\"(selectedIds$ | async).includes(item.id)\"\n (click)=\"select($event, item)\"\n ></pry-checkbox>\n </div>\n <div class=\"o-properties\">\n <ul class=\"o-properties__list\">\n <ng-container *ngFor=\"let property of (propertiesToDisplay$ | async)![item.oClass]\">\n <li\n *ngFor=\"let value of getValue(item, property); let i = index; let c = count\"\n class=\"o-properties__list__item\"\n >\n <p class=\"o-properties__list__item__label\" *ngIf=\"i === 0\">{{ property }}:</p>\n <p class=\"o-properties__list__item__value\" *ngIf=\"!isRaw(property, item.oClass)\">{{ value?.value }}</p>\n <p class=\"o-properties__list__item__raw\" *ngIf=\"isRaw(property, item.oClass)\">\n <pry-vizualize-raw [item]=\"item\" [propertyName]=\"property\"></pry-vizualize-raw>\n </p>\n <ng-container *ngIf=\"hasMetadata(value)\">\n <pry-metadata [item]=\"value\"></pry-metadata>\n </ng-container>\n </li>\n </ng-container>\n </ul>\n </div>\n <div (click)=\"toggleMap(index)\" class=\"o-widget--tile__list__item__footer\">\n <button\n type=\"button\"\n class=\"a-btn a-btn--icon-text -link-like\"\n aria-controls=\"tile-map-xxx\"\n aria-expanded=\"false\"\n >\n {{ '@pry.widget.tile.map' | i18n }}\n </button>\n </div>\n <div class=\"o-widget--tile__list__item__map\" *ngIf=\"maps[index]\" id=\"tile-map-xxx\">\n <pry-widget-map [staticManifest]=\"mapManifest\" [staticResultSet]=\"resultSetWithItem(item)\"></pry-widget-map>\n </div>\n </li>\n </ul>\n </div>\n</div>\n", dependencies: [{ kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i4.SettingsComponent, selector: "pry-settings", inputs: ["widgetIndex", "isDisable", "headerPresent", "open$", "header"], outputs: ["saveTriggered", "changeTitle"] }, { kind: "component", type: i4.MetadataComponent, selector: "pry-metadata", inputs: ["item"] }, { kind: "component", type: i4.PryWidgetHeaderComponent, selector: "pry-widget-header", inputs: ["manifest", "additionalOptions", "headerOptions", "displayCount", "datasourceIds", "widgetIndex"], outputs: ["manifestModified"] }, { kind: "component", type: i4.VizualizeRawComponent, selector: "pry-vizualize-raw", inputs: ["item", "propertyName", "alt"] }, { kind: "component", type: i4.PrySelectComponent, selector: "pry-select", inputs: ["labelTranslate", "baseTranslate", "translationFn", "translationFnArgs", "clearable", "multiple", "multipleClearRight", "closeOnSelect", "placeholder", "isForm", "required", "name", "readonly", "items", "itemsAsOption", "bindData", "bindValue", "bindLabel", "bindIcon", "iconSize", "templateLabel", "templateOption", "autocomplete"] }, { kind: "component", type: i5.PryCheckboxComponent, selector: "pry-checkbox", inputs: ["circle"] }, { kind: "component", type: i6.WidgetMapComponent, selector: "pry-widget-map" }, { kind: "component", type: i7.PryWidgetTileCssComponent, selector: "pry-widget-tile-css" }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }, { kind: "pipe", type: i4.TranslateIdPipe, name: "translateId" }, { kind: "pipe", type: i4.TranslateItemToSymbolPipe, name: "translateItemToSymbol" }, { kind: "pipe", type: i4.I18nPipe, name: "i18n" }] }); }
109
109
  }
110
110
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.6", ngImport: i0, type: WidgetTileComponent, decorators: [{
111
111
  type: Component,
112
- args: [{ selector: 'pry-widget-tile', template: "<pry-widget-tile-css></pry-widget-tile-css>\n<div class=\"o-widget o-widget--tile\">\n <pry-widget-header\n [datasourceIds]=\"(datasourceIds$ | async) ?? []\"\n *ngIf=\"displayHeader$ | async\"\n [widgetIndex]=\"widgetIndex\"\n [manifest]=\"manifest\"\n (manifestModified)=\"manifestModified.emit($event)\"\n [headerOptions]=\"(displayHeader$ | async) ?? {}\"\n #header\n >\n <pry-settings\n (saveTriggered)=\"emitManifest()\"\n (changeTitle)=\"changeWidgetTitle($event)\"\n [headerPresent]=\"displayHeader$ | async\"\n [widgetIndex]=\"widgetIndex\"\n [header]=\"header\"\n [open$]=\"open$\"\n class=\"o-settings\"\n >\n <div class=\"m-form-label-field\">\n <label class=\"a-label\" for=\"tile_classes\">{{ '@pry.widget.tile.classes' | i18n }}</label>\n <pry-select\n (ngModelChange)=\"changeClasses($event)\"\n [itemsAsOption]=\"true\"\n [items]=\"classes$ | async\"\n [multiple]=\"true\"\n [ngModel]=\"optionsCopy.classes\"\n bindLabel=\"name\"\n bindValue=\"id\"\n class=\"a-pry-select\"\n id=\"tile_classes\"\n ></pry-select>\n </div>\n </pry-settings>\n </pry-widget-header>\n <div class=\"o-widget--tile-wrapper\" [style.top]=\"(displayHeader$ | async) ? WIDGET_HEADER_HEIGHT + 'px' : 0\">\n <div class=\"no-result\" *ngIf=\"(items$ | async)?.length === 0\">\n <img\n class=\"no-result__search\"\n src=\"../../../assets/svgs/pry_recherche_pas_de_resultat.svg\"\n alt=\"{{ '@pry.widget.tile.empty' | i18n }}\"\n aria-hidden=\"true\"\n />\n <span class=\"no-result__text\">{{ '@pry.widget.tile.empty' | i18n }}</span>\n </div>\n <ul class=\"o-widget--tile__list\">\n <li\n class=\"o-widget--tile__list__item\"\n *ngFor=\"let item of items$ | async; let index = index\"\n (contextmenu)=\"contextMenu($event, item)\"\n >\n <div class=\"o-widget--tile__list__item__header\">\n <img\n [height]=\"25\"\n [width]=\"25\"\n [src]=\"item | translateItemToSymbol | async\"\n [alt]=\"item.oClass | translateId : { type: 'class', output: 'name' } | async\"\n />\n <h3 class=\"o-widget--tile__list__item__header__title\">\n {{\n item.oClass\n | translateId\n : {\n type: 'class',\n output: 'name'\n }\n | async\n }}\n </h3>\n <pry-checkbox\n [ngModel]=\"(selectedIds$ | async).includes(item.id)\"\n (click)=\"select($event, item)\"\n ></pry-checkbox>\n </div>\n <div class=\"o-properties\">\n <ul class=\"o-properties__list\">\n <ng-container *ngFor=\"let property of (propertiesToDisplay$ | async)![item.oClass]\">\n <li\n *ngFor=\"let value of getValue(item, property); let i = index; let c = count\"\n class=\"o-properties__list__item\"\n >\n <p class=\"o-properties__list__item__label\" *ngIf=\"i === 0\">{{ property }}:</p>\n <p class=\"o-properties__list__item__value\" *ngIf=\"!isRaw(property, item.oClass)\">{{ value?.value }}</p>\n <p class=\"o-properties__list__item__raw\" *ngIf=\"isRaw(property, item.oClass)\">\n <pry-vizualize-raw [item]=\"item\" [propertyName]=\"property\"></pry-vizualize-raw>\n </p>\n <ng-container *ngIf=\"hasMetadata(value)\">\n <pry-metadata [item]=\"value\"></pry-metadata>\n </ng-container>\n </li>\n </ng-container>\n </ul>\n </div>\n <div (click)=\"toggleMap(index)\" class=\"o-widget--tile__list__item__footer\">\n <button\n type=\"button\"\n class=\"a-btn a-btn--icon-text -link-like\"\n aria-controls=\"tile-map-xxx\"\n aria-expanded=\"false\"\n >\n {{ '@pry.widget.tile.map' | i18n }}\n </button>\n </div>\n <div class=\"o-widget--tile__list__item__map\" *ngIf=\"maps[index]\" id=\"tile-map-xxx\">\n <pry-widget-map [staticManifest]=\"mapManifest\" [staticResultSet]=\"resultSetWithItem(item)\"></pry-widget-map>\n </div>\n </li>\n </ul>\n </div>\n</div>\n" }]
112
+ args: [{ selector: 'pry-widget-tile', template: "<pry-widget-tile-css></pry-widget-tile-css>\n<div class=\"o-widget o-widget--tile\">\n <pry-widget-header\n [datasourceIds]=\"(datasourceIds$ | async) ?? []\"\n *ngIf=\"displayHeader$ | async\"\n [widgetIndex]=\"widgetIndex\"\n [manifest]=\"manifest\"\n (manifestModified)=\"manifestModified.emit($event)\"\n [headerOptions]=\"(displayHeader$ | async) ?? {}\"\n #header\n >\n <pry-settings\n (saveTriggered)=\"emitManifest()\"\n (changeTitle)=\"changeWidgetTitle($event)\"\n [headerPresent]=\"displayHeader$ | async\"\n [widgetIndex]=\"widgetIndex\"\n [header]=\"header\"\n [open$]=\"open$\"\n class=\"o-settings\"\n >\n <div class=\"m-form-label-field\">\n <label class=\"a-label\" for=\"tile_classes\">{{ '@pry.widget.tile.classes' | i18n }}</label>\n <pry-select\n (ngModelChange)=\"changeClasses($event)\"\n [itemsAsOption]=\"true\"\n [items]=\"classes$ | async\"\n [multiple]=\"true\"\n [closeOnSelect]=\"false\"\n [ngModel]=\"optionsCopy.classes\"\n bindLabel=\"name\"\n bindValue=\"id\"\n class=\"a-pry-select\"\n id=\"tile_classes\"\n ></pry-select>\n </div>\n </pry-settings>\n </pry-widget-header>\n <div class=\"o-widget--tile-wrapper\" [style.top]=\"(displayHeader$ | async) ? WIDGET_HEADER_HEIGHT + 'px' : 0\">\n <div class=\"no-result\" *ngIf=\"(items$ | async)?.length === 0\">\n <img\n class=\"no-result__search\"\n src=\"../../../assets/svgs/pry_recherche_pas_de_resultat.svg\"\n alt=\"{{ '@pry.widget.tile.empty' | i18n }}\"\n aria-hidden=\"true\"\n />\n <span class=\"no-result__text\">{{ '@pry.widget.tile.empty' | i18n }}</span>\n </div>\n <ul class=\"o-widget--tile__list\">\n <li\n class=\"o-widget--tile__list__item\"\n *ngFor=\"let item of items$ | async; let index = index\"\n (contextmenu)=\"contextMenu($event, item)\"\n >\n <div class=\"o-widget--tile__list__item__header\">\n <img\n [height]=\"25\"\n [width]=\"25\"\n [src]=\"item | translateItemToSymbol | async\"\n [alt]=\"item.oClass | translateId : { type: 'class', output: 'name' } | async\"\n />\n <h3 class=\"o-widget--tile__list__item__header__title\">\n {{\n item.oClass\n | translateId\n : {\n type: 'class',\n output: 'name'\n }\n | async\n }}\n </h3>\n <pry-checkbox\n [ngModel]=\"(selectedIds$ | async).includes(item.id)\"\n (click)=\"select($event, item)\"\n ></pry-checkbox>\n </div>\n <div class=\"o-properties\">\n <ul class=\"o-properties__list\">\n <ng-container *ngFor=\"let property of (propertiesToDisplay$ | async)![item.oClass]\">\n <li\n *ngFor=\"let value of getValue(item, property); let i = index; let c = count\"\n class=\"o-properties__list__item\"\n >\n <p class=\"o-properties__list__item__label\" *ngIf=\"i === 0\">{{ property }}:</p>\n <p class=\"o-properties__list__item__value\" *ngIf=\"!isRaw(property, item.oClass)\">{{ value?.value }}</p>\n <p class=\"o-properties__list__item__raw\" *ngIf=\"isRaw(property, item.oClass)\">\n <pry-vizualize-raw [item]=\"item\" [propertyName]=\"property\"></pry-vizualize-raw>\n </p>\n <ng-container *ngIf=\"hasMetadata(value)\">\n <pry-metadata [item]=\"value\"></pry-metadata>\n </ng-container>\n </li>\n </ng-container>\n </ul>\n </div>\n <div (click)=\"toggleMap(index)\" class=\"o-widget--tile__list__item__footer\">\n <button\n type=\"button\"\n class=\"a-btn a-btn--icon-text -link-like\"\n aria-controls=\"tile-map-xxx\"\n aria-expanded=\"false\"\n >\n {{ '@pry.widget.tile.map' | i18n }}\n </button>\n </div>\n <div class=\"o-widget--tile__list__item__map\" *ngIf=\"maps[index]\" id=\"tile-map-xxx\">\n <pry-widget-map [staticManifest]=\"mapManifest\" [staticResultSet]=\"resultSetWithItem(item)\"></pry-widget-map>\n </div>\n </li>\n </ul>\n </div>\n</div>\n" }]
113
113
  }], ctorParameters: function () { return [{ type: i1.Store }, { type: i0.ElementRef }]; } });
114
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"widget-tile.component.js","sourceRoot":"","sources":["../../../../../../../projects/provoly/dashboard/widgets/widget-tile/component/widget-tile.component.ts","../../../../../../../projects/provoly/dashboard/widgets/widget-tile/component/widget-tile.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef } from '@angular/core';\nimport { Store } from '@ngrx/store';\nimport {\n  AttributeSimpleValue,\n  Class,\n  ClassSelectors,\n  ConfigSelectors,\n  ContextMenuActions,\n  DashboardActions,\n  DashboardSelectors,\n  DataWidgetComponent,\n  Field,\n  FieldSelectors,\n  FieldType,\n  Item,\n  ItemUtils,\n  ResultSet,\n  TileWidgetOptions,\n  WIDGET_HEADER_HEIGHT\n} from '@provoly/dashboard';\nimport { combineLatest, Observable } from 'rxjs';\nimport { filter, map } from 'rxjs/operators';\n\n@Component({\n  selector: 'pry-widget-tile',\n  templateUrl: './widget-tile.component.html'\n})\nexport class WidgetTileComponent extends DataWidgetComponent {\n  options$: Observable<TileWidgetOptions>;\n  items$: Observable<Item[]>;\n  selectedIds$: Observable<any>;\n  maps: boolean[] = [];\n  mapManifest = {\n    type: 'map',\n    header: false,\n    layout: { x: 1, y: 1, width: 1, height: 1 },\n    options: { layers: [{ type: 'marker' }], fit: true }\n  };\n  classes$: Observable<Class[]>;\n  optionsCopy: TileWidgetOptions = {};\n  WIDGET_HEADER_HEIGHT = WIDGET_HEADER_HEIGHT;\n  propertiesToDisplay$: Observable<{ [p: string]: string[] } | undefined>;\n  fields: Field[] = [];\n  classes: Class[] = [];\n\n  constructor(store: Store<any>, el: ElementRef) {\n    super(store, el);\n    this.options$ = this.manifest$.pipe(map((manifest) => manifest.options as TileWidgetOptions));\n    this.subscriptions.add(\n      this.options$.pipe(filter((opt) => !!opt)).subscribe((options) => {\n        this.optionsCopy = { ...(JSON.parse(JSON.stringify(options)) as TileWidgetOptions) };\n      })\n    );\n    this.items$ = combineLatest([\n      this.resultSet$.pipe(map((rs) => Object.values(rs.items).reduce((p, c) => [...p, ...c], []))),\n      this.options$\n    ]).pipe(\n      map(([items, options]) =>\n        items.filter(\n          (item) => !options.classes || options.classes.length === 0 || options.classes.includes(item.oClass)\n        )\n      )\n    );\n    this.selectedIds$ = this.store.select(DashboardSelectors.selectedItemIds);\n    this.classes$ = this.store.select(ClassSelectors.classes);\n    this.propertiesToDisplay$ = combineLatest([\n      this.classes$,\n      this.store.select(ConfigSelectors.tileAttributesDefinitions),\n      this.store.select(ConfigSelectors.maxAttributesInTiles)\n    ]).pipe(\n      map(([classes, tileDefs, maxTilesAttributes]) => ({\n        ...classes\n          .map((clazz) => ({\n            [clazz.id]: [...clazz.attributes.map((attr) => attr.name).filter((_, i) => i < maxTilesAttributes)]\n          }))\n          .reduce((p, c) => ({ ...p, ...c }), {}),\n        ...tileDefs\n      }))\n    );\n    this.subscriptions.add(this.store.select(FieldSelectors.fields).subscribe((fields) => (this.fields = fields)));\n    this.subscriptions.add(this.classes$.subscribe((classes) => (this.classes = classes)));\n  }\n\n  contextMenu($event: MouseEvent, item: Item) {\n    if (this.manifest.contextMenu !== false) {\n      $event.stopPropagation();\n      $event.preventDefault();\n      this.store.dispatch(\n        ContextMenuActions.open({\n          itemId: item.id,\n          clientX: $event.clientX,\n          clientY: $event.clientY,\n          from: 'tile'\n        })\n      );\n    }\n  }\n\n  select($event: MouseEvent, item: Item) {\n    $event.stopPropagation();\n    $event.preventDefault();\n    this.store.dispatch(DashboardActions.select({ id: item.id, cumulative: !$event.shiftKey }));\n  }\n\n  toggleMap(index: number) {\n    this.maps[index] = !this.maps[index];\n  }\n\n  resultSetWithItem(item: Item): ResultSet {\n    return { items: { [item.oClass]: [item] }, relations: [] };\n  }\n\n  emitManifest() {\n    this.manifestModified.emit({\n      widgetIndex: this.widgetIndex,\n      manifest: {\n        ...this.manifest,\n        options: this.optionsCopy\n      }\n    });\n  }\n\n  changeClasses($event: any) {\n    this.optionsCopy.classes = $event;\n  }\n\n  getValue(item: Item, property: string): AttributeSimpleValue[] {\n    const value = ItemUtils.getAttributeValue(item, property);\n    return Array.isArray(value) ? value : [value];\n  }\n\n  isRaw(property: string, classId: string): boolean {\n    const clazz = this.classes.find((clazz) => clazz.id === classId);\n    if (!!clazz) {\n      const prop = clazz.attributes.find((attr) => attr.name === property);\n      if (!!prop) {\n        const field = this.fields.find((field) => field.id === prop.field);\n        if (!!field) {\n          return field.type === FieldType.RAW;\n        }\n      }\n    }\n    return false;\n  }\n\n  hasMetadata(value: AttributeSimpleValue | Item) {\n    return Object.keys(value?.metadata ?? {}).length > 0;\n  }\n}\n","<pry-widget-tile-css></pry-widget-tile-css>\n<div class=\"o-widget o-widget--tile\">\n  <pry-widget-header\n    [datasourceIds]=\"(datasourceIds$ | async) ?? []\"\n    *ngIf=\"displayHeader$ | async\"\n    [widgetIndex]=\"widgetIndex\"\n    [manifest]=\"manifest\"\n    (manifestModified)=\"manifestModified.emit($event)\"\n    [headerOptions]=\"(displayHeader$ | async) ?? {}\"\n    #header\n  >\n    <pry-settings\n      (saveTriggered)=\"emitManifest()\"\n      (changeTitle)=\"changeWidgetTitle($event)\"\n      [headerPresent]=\"displayHeader$ | async\"\n      [widgetIndex]=\"widgetIndex\"\n      [header]=\"header\"\n      [open$]=\"open$\"\n      class=\"o-settings\"\n    >\n      <div class=\"m-form-label-field\">\n        <label class=\"a-label\" for=\"tile_classes\">{{ '@pry.widget.tile.classes' | i18n }}</label>\n        <pry-select\n          (ngModelChange)=\"changeClasses($event)\"\n          [itemsAsOption]=\"true\"\n          [items]=\"classes$ | async\"\n          [multiple]=\"true\"\n          [ngModel]=\"optionsCopy.classes\"\n          bindLabel=\"name\"\n          bindValue=\"id\"\n          class=\"a-pry-select\"\n          id=\"tile_classes\"\n        ></pry-select>\n      </div>\n    </pry-settings>\n  </pry-widget-header>\n  <div class=\"o-widget--tile-wrapper\" [style.top]=\"(displayHeader$ | async) ? WIDGET_HEADER_HEIGHT + 'px' : 0\">\n    <div class=\"no-result\" *ngIf=\"(items$ | async)?.length === 0\">\n      <img\n        class=\"no-result__search\"\n        src=\"../../../assets/svgs/pry_recherche_pas_de_resultat.svg\"\n        alt=\"{{ '@pry.widget.tile.empty' | i18n }}\"\n        aria-hidden=\"true\"\n      />\n      <span class=\"no-result__text\">{{ '@pry.widget.tile.empty' | i18n }}</span>\n    </div>\n    <ul class=\"o-widget--tile__list\">\n      <li\n        class=\"o-widget--tile__list__item\"\n        *ngFor=\"let item of items$ | async; let index = index\"\n        (contextmenu)=\"contextMenu($event, item)\"\n      >\n        <div class=\"o-widget--tile__list__item__header\">\n          <img\n            [height]=\"25\"\n            [width]=\"25\"\n            [src]=\"item | translateItemToSymbol | async\"\n            [alt]=\"item.oClass | translateId : { type: 'class', output: 'name' } | async\"\n          />\n          <h3 class=\"o-widget--tile__list__item__header__title\">\n            {{\n              item.oClass\n                | translateId\n                  : {\n                      type: 'class',\n                      output: 'name'\n                    }\n                | async\n            }}\n          </h3>\n          <pry-checkbox\n            [ngModel]=\"(selectedIds$ | async).includes(item.id)\"\n            (click)=\"select($event, item)\"\n          ></pry-checkbox>\n        </div>\n        <div class=\"o-properties\">\n          <ul class=\"o-properties__list\">\n            <ng-container *ngFor=\"let property of (propertiesToDisplay$ | async)![item.oClass]\">\n              <li\n                *ngFor=\"let value of getValue(item, property); let i = index; let c = count\"\n                class=\"o-properties__list__item\"\n              >\n                <p class=\"o-properties__list__item__label\" *ngIf=\"i === 0\">{{ property }}:</p>\n                <p class=\"o-properties__list__item__value\" *ngIf=\"!isRaw(property, item.oClass)\">{{ value?.value }}</p>\n                <p class=\"o-properties__list__item__raw\" *ngIf=\"isRaw(property, item.oClass)\">\n                  <pry-vizualize-raw [item]=\"item\" [propertyName]=\"property\"></pry-vizualize-raw>\n                </p>\n                <ng-container *ngIf=\"hasMetadata(value)\">\n                  <pry-metadata [item]=\"value\"></pry-metadata>\n                </ng-container>\n              </li>\n            </ng-container>\n          </ul>\n        </div>\n        <div (click)=\"toggleMap(index)\" class=\"o-widget--tile__list__item__footer\">\n          <button\n            type=\"button\"\n            class=\"a-btn a-btn--icon-text -link-like\"\n            aria-controls=\"tile-map-xxx\"\n            aria-expanded=\"false\"\n          >\n            {{ '@pry.widget.tile.map' | i18n }}\n          </button>\n        </div>\n        <div class=\"o-widget--tile__list__item__map\" *ngIf=\"maps[index]\" id=\"tile-map-xxx\">\n          <pry-widget-map [staticManifest]=\"mapManifest\" [staticResultSet]=\"resultSetWithItem(item)\"></pry-widget-map>\n        </div>\n      </li>\n    </ul>\n  </div>\n</div>\n"]}
114
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"widget-tile.component.js","sourceRoot":"","sources":["../../../../../../../projects/provoly/dashboard/widgets/widget-tile/component/widget-tile.component.ts","../../../../../../../projects/provoly/dashboard/widgets/widget-tile/component/widget-tile.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef } from '@angular/core';\nimport { Store } from '@ngrx/store';\nimport {\n  AttributeSimpleValue,\n  Class,\n  ClassSelectors,\n  ConfigSelectors,\n  ContextMenuActions,\n  DashboardActions,\n  DashboardSelectors,\n  DataWidgetComponent,\n  Field,\n  FieldSelectors,\n  FieldType,\n  Item,\n  ItemUtils,\n  ResultSet,\n  TileWidgetOptions,\n  WIDGET_HEADER_HEIGHT\n} from '@provoly/dashboard';\nimport { combineLatest, Observable } from 'rxjs';\nimport { filter, map } from 'rxjs/operators';\n\n@Component({\n  selector: 'pry-widget-tile',\n  templateUrl: './widget-tile.component.html'\n})\nexport class WidgetTileComponent extends DataWidgetComponent {\n  options$: Observable<TileWidgetOptions>;\n  items$: Observable<Item[]>;\n  selectedIds$: Observable<any>;\n  maps: boolean[] = [];\n  mapManifest = {\n    type: 'map',\n    header: false,\n    layout: { x: 1, y: 1, width: 1, height: 1 },\n    options: { layers: [{ type: 'marker' }], fit: true }\n  };\n  classes$: Observable<Class[]>;\n  optionsCopy: TileWidgetOptions = {};\n  WIDGET_HEADER_HEIGHT = WIDGET_HEADER_HEIGHT;\n  propertiesToDisplay$: Observable<{ [p: string]: string[] } | undefined>;\n  fields: Field[] = [];\n  classes: Class[] = [];\n\n  constructor(store: Store<any>, el: ElementRef) {\n    super(store, el);\n    this.options$ = this.manifest$.pipe(map((manifest) => manifest.options as TileWidgetOptions));\n    this.subscriptions.add(\n      this.options$.pipe(filter((opt) => !!opt)).subscribe((options) => {\n        this.optionsCopy = { ...(JSON.parse(JSON.stringify(options)) as TileWidgetOptions) };\n      })\n    );\n    this.items$ = combineLatest([\n      this.resultSet$.pipe(map((rs) => Object.values(rs.items).reduce((p, c) => [...p, ...c], []))),\n      this.options$\n    ]).pipe(\n      map(([items, options]) =>\n        items.filter(\n          (item) => !options.classes || options.classes.length === 0 || options.classes.includes(item.oClass)\n        )\n      )\n    );\n    this.selectedIds$ = this.store.select(DashboardSelectors.selectedItemIds);\n    this.classes$ = this.store.select(ClassSelectors.classes);\n    this.propertiesToDisplay$ = combineLatest([\n      this.classes$,\n      this.store.select(ConfigSelectors.tileAttributesDefinitions),\n      this.store.select(ConfigSelectors.maxAttributesInTiles)\n    ]).pipe(\n      map(([classes, tileDefs, maxTilesAttributes]) => ({\n        ...classes\n          .map((clazz) => ({\n            [clazz.id]: [...clazz.attributes.map((attr) => attr.name).filter((_, i) => i < maxTilesAttributes)]\n          }))\n          .reduce((p, c) => ({ ...p, ...c }), {}),\n        ...tileDefs\n      }))\n    );\n    this.subscriptions.add(this.store.select(FieldSelectors.fields).subscribe((fields) => (this.fields = fields)));\n    this.subscriptions.add(this.classes$.subscribe((classes) => (this.classes = classes)));\n  }\n\n  contextMenu($event: MouseEvent, item: Item) {\n    if (this.manifest.contextMenu !== false) {\n      $event.stopPropagation();\n      $event.preventDefault();\n      this.store.dispatch(\n        ContextMenuActions.open({\n          itemId: item.id,\n          clientX: $event.clientX,\n          clientY: $event.clientY,\n          from: 'tile'\n        })\n      );\n    }\n  }\n\n  select($event: MouseEvent, item: Item) {\n    $event.stopPropagation();\n    $event.preventDefault();\n    this.store.dispatch(DashboardActions.select({ id: item.id, cumulative: !$event.shiftKey }));\n  }\n\n  toggleMap(index: number) {\n    this.maps[index] = !this.maps[index];\n  }\n\n  resultSetWithItem(item: Item): ResultSet {\n    return { items: { [item.oClass]: [item] }, relations: [] };\n  }\n\n  emitManifest() {\n    this.manifestModified.emit({\n      widgetIndex: this.widgetIndex,\n      manifest: {\n        ...this.manifest,\n        options: this.optionsCopy\n      }\n    });\n  }\n\n  changeClasses($event: any) {\n    this.optionsCopy.classes = $event;\n  }\n\n  getValue(item: Item, property: string): AttributeSimpleValue[] {\n    const value = ItemUtils.getAttributeValue(item, property);\n    return Array.isArray(value) ? value : [value];\n  }\n\n  isRaw(property: string, classId: string): boolean {\n    const clazz = this.classes.find((clazz) => clazz.id === classId);\n    if (!!clazz) {\n      const prop = clazz.attributes.find((attr) => attr.name === property);\n      if (!!prop) {\n        const field = this.fields.find((field) => field.id === prop.field);\n        if (!!field) {\n          return field.type === FieldType.RAW;\n        }\n      }\n    }\n    return false;\n  }\n\n  hasMetadata(value: AttributeSimpleValue | Item) {\n    return Object.keys(value?.metadata ?? {}).length > 0;\n  }\n}\n","<pry-widget-tile-css></pry-widget-tile-css>\n<div class=\"o-widget o-widget--tile\">\n  <pry-widget-header\n    [datasourceIds]=\"(datasourceIds$ | async) ?? []\"\n    *ngIf=\"displayHeader$ | async\"\n    [widgetIndex]=\"widgetIndex\"\n    [manifest]=\"manifest\"\n    (manifestModified)=\"manifestModified.emit($event)\"\n    [headerOptions]=\"(displayHeader$ | async) ?? {}\"\n    #header\n  >\n    <pry-settings\n      (saveTriggered)=\"emitManifest()\"\n      (changeTitle)=\"changeWidgetTitle($event)\"\n      [headerPresent]=\"displayHeader$ | async\"\n      [widgetIndex]=\"widgetIndex\"\n      [header]=\"header\"\n      [open$]=\"open$\"\n      class=\"o-settings\"\n    >\n      <div class=\"m-form-label-field\">\n        <label class=\"a-label\" for=\"tile_classes\">{{ '@pry.widget.tile.classes' | i18n }}</label>\n        <pry-select\n          (ngModelChange)=\"changeClasses($event)\"\n          [itemsAsOption]=\"true\"\n          [items]=\"classes$ | async\"\n          [multiple]=\"true\"\n          [closeOnSelect]=\"false\"\n          [ngModel]=\"optionsCopy.classes\"\n          bindLabel=\"name\"\n          bindValue=\"id\"\n          class=\"a-pry-select\"\n          id=\"tile_classes\"\n        ></pry-select>\n      </div>\n    </pry-settings>\n  </pry-widget-header>\n  <div class=\"o-widget--tile-wrapper\" [style.top]=\"(displayHeader$ | async) ? WIDGET_HEADER_HEIGHT + 'px' : 0\">\n    <div class=\"no-result\" *ngIf=\"(items$ | async)?.length === 0\">\n      <img\n        class=\"no-result__search\"\n        src=\"../../../assets/svgs/pry_recherche_pas_de_resultat.svg\"\n        alt=\"{{ '@pry.widget.tile.empty' | i18n }}\"\n        aria-hidden=\"true\"\n      />\n      <span class=\"no-result__text\">{{ '@pry.widget.tile.empty' | i18n }}</span>\n    </div>\n    <ul class=\"o-widget--tile__list\">\n      <li\n        class=\"o-widget--tile__list__item\"\n        *ngFor=\"let item of items$ | async; let index = index\"\n        (contextmenu)=\"contextMenu($event, item)\"\n      >\n        <div class=\"o-widget--tile__list__item__header\">\n          <img\n            [height]=\"25\"\n            [width]=\"25\"\n            [src]=\"item | translateItemToSymbol | async\"\n            [alt]=\"item.oClass | translateId : { type: 'class', output: 'name' } | async\"\n          />\n          <h3 class=\"o-widget--tile__list__item__header__title\">\n            {{\n              item.oClass\n                | translateId\n                  : {\n                      type: 'class',\n                      output: 'name'\n                    }\n                | async\n            }}\n          </h3>\n          <pry-checkbox\n            [ngModel]=\"(selectedIds$ | async).includes(item.id)\"\n            (click)=\"select($event, item)\"\n          ></pry-checkbox>\n        </div>\n        <div class=\"o-properties\">\n          <ul class=\"o-properties__list\">\n            <ng-container *ngFor=\"let property of (propertiesToDisplay$ | async)![item.oClass]\">\n              <li\n                *ngFor=\"let value of getValue(item, property); let i = index; let c = count\"\n                class=\"o-properties__list__item\"\n              >\n                <p class=\"o-properties__list__item__label\" *ngIf=\"i === 0\">{{ property }}:</p>\n                <p class=\"o-properties__list__item__value\" *ngIf=\"!isRaw(property, item.oClass)\">{{ value?.value }}</p>\n                <p class=\"o-properties__list__item__raw\" *ngIf=\"isRaw(property, item.oClass)\">\n                  <pry-vizualize-raw [item]=\"item\" [propertyName]=\"property\"></pry-vizualize-raw>\n                </p>\n                <ng-container *ngIf=\"hasMetadata(value)\">\n                  <pry-metadata [item]=\"value\"></pry-metadata>\n                </ng-container>\n              </li>\n            </ng-container>\n          </ul>\n        </div>\n        <div (click)=\"toggleMap(index)\" class=\"o-widget--tile__list__item__footer\">\n          <button\n            type=\"button\"\n            class=\"a-btn a-btn--icon-text -link-like\"\n            aria-controls=\"tile-map-xxx\"\n            aria-expanded=\"false\"\n          >\n            {{ '@pry.widget.tile.map' | i18n }}\n          </button>\n        </div>\n        <div class=\"o-widget--tile__list__item__map\" *ngIf=\"maps[index]\" id=\"tile-map-xxx\">\n          <pry-widget-map [staticManifest]=\"mapManifest\" [staticResultSet]=\"resultSetWithItem(item)\"></pry-widget-map>\n        </div>\n      </li>\n    </ul>\n  </div>\n</div>\n"]}
@@ -1195,11 +1195,11 @@ class AdminClassesCustomizeTooltipComponent extends SubscriptionnerDirective {
1195
1195
  this.currentClassConfig.options.attributes = $event;
1196
1196
  }
1197
1197
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.6", ngImport: i0, type: AdminClassesCustomizeTooltipComponent, deps: [{ token: i4.TooltipFactoryService }, { token: i0.Injector }, { token: i4.PryI18nService }, { token: i1.Store }], target: i0.ɵɵFactoryTarget.Component }); }
1198
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.6", type: AdminClassesCustomizeTooltipComponent, selector: "pry-admin-classes-customize-tooltip", inputs: { currentClass: "currentClass" }, outputs: { backPressed: "backPressed" }, viewQueries: [{ propertyName: "example", first: true, predicate: ["example"], descendants: true, read: ViewContainerRef }], usesInheritance: true, ngImport: i0, template: "<div>\n <div class=\"m-form-label-field -width-xl\">\n <label class=\"a-label\" for=\"tooltip_type\">{{ '@pry.admin.customize.type' | i18n }}</label>\n <pry-select\n id=\"tooltip_type\"\n class=\"a-pry-select\"\n (ngModelChange)=\"tooltipTypeChanged($event)\"\n [ngModel]=\"currentClassConfig.type\"\n [items]=\"possibleTooltipTypes$ | async\"\n [itemsAsOption]=\"true\"\n bindValue=\"value\"\n bindLabel=\"label\"\n [labelTranslate]=\"true\"\n ></pry-select>\n </div>\n\n <div>\n <pry-checkbox [(ngModel)]=\"advancedTooltip\">{{ '@pry.admin.customize.advanced' | i18n }}</pry-checkbox>\n </div>\n\n <ng-container *ngIf=\"!advancedTooltip && currentClassConfig.type === 'attribute'\">\n <label class=\"a-label\" for=\"customize_simplified\">{{ '@pry.admin.customize.simplified' | i18n }}</label>\n <pry-select\n id=\"customize_simplified\"\n class=\"a-pry-select\"\n (ngModelChange)=\"changeAttributes($event)\"\n [ngModel]=\"currentClassConfig.options.attributes\"\n [itemsAsOption]=\"true\"\n [items]=\"possibleAttributes\"\n [multiple]=\"true\"\n bindLabel=\"name\"\n bindValue=\"name\"\n ></pry-select>\n </ng-container>\n\n <ng-container *ngIf=\"advancedTooltip\">\n <textarea\n cols=\"100\"\n rows=\"15\"\n class=\"a-form-field\"\n [(ngModel)]=\"strOptions\"\n (focusout)=\"optionsChanged()\"\n ></textarea>\n </ng-container>\n</div>\n\n<div class=\"m-tooltip m-tooltip--example\" [class.-hidden]=\"noTooltip\">\n <div #example></div>\n</div>\n\n<div class=\"m-btn-group -width-md\">\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 class=\"a-btn a-btn--primary\" type=\"submit\" (click)=\"updateTemplate()\">\n {{ '@pry.admin.customize.update' | i18n }}\n </button>\n</div>\n", dependencies: [{ kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3$1.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$1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3$1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i5$1.PryCheckboxComponent, selector: "pry-checkbox", inputs: ["circle"] }, { kind: "component", type: i4.PrySelectComponent, selector: "pry-select", inputs: ["labelTranslate", "baseTranslate", "translationFn", "translationFnArgs", "clearable", "multiple", "multipleClearRight", "closeOnSelect", "placeholder", "isForm", "required", "name", "readonly", "items", "itemsAsOption", "bindData", "bindValue", "bindLabel", "bindIcon", "iconSize", "templateLabel", "templateOption", "autocomplete"] }, { kind: "pipe", type: i3.AsyncPipe, name: "async" }, { kind: "pipe", type: i4.I18nPipe, name: "i18n" }] }); }
1198
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.6", type: AdminClassesCustomizeTooltipComponent, selector: "pry-admin-classes-customize-tooltip", inputs: { currentClass: "currentClass" }, outputs: { backPressed: "backPressed" }, viewQueries: [{ propertyName: "example", first: true, predicate: ["example"], descendants: true, read: ViewContainerRef }], usesInheritance: true, ngImport: i0, template: "<div>\n <div class=\"m-form-label-field -width-xl\">\n <label class=\"a-label\" for=\"tooltip_type\">{{ '@pry.admin.customize.type' | i18n }}</label>\n <pry-select\n id=\"tooltip_type\"\n class=\"a-pry-select\"\n (ngModelChange)=\"tooltipTypeChanged($event)\"\n [ngModel]=\"currentClassConfig.type\"\n [items]=\"possibleTooltipTypes$ | async\"\n [itemsAsOption]=\"true\"\n bindValue=\"value\"\n bindLabel=\"label\"\n [labelTranslate]=\"true\"\n ></pry-select>\n </div>\n\n <div>\n <pry-checkbox [(ngModel)]=\"advancedTooltip\">{{ '@pry.admin.customize.advanced' | i18n }}</pry-checkbox>\n </div>\n\n <ng-container *ngIf=\"!advancedTooltip && currentClassConfig.type === 'attribute'\">\n <label class=\"a-label\" for=\"customize_simplified\">{{ '@pry.admin.customize.simplified' | i18n }}</label>\n <pry-select\n id=\"customize_simplified\"\n class=\"a-pry-select\"\n (ngModelChange)=\"changeAttributes($event)\"\n [ngModel]=\"currentClassConfig.options.attributes\"\n [itemsAsOption]=\"true\"\n [items]=\"possibleAttributes\"\n [multiple]=\"true\"\n [closeOnSelect]=\"false\"\n bindLabel=\"name\"\n bindValue=\"name\"\n ></pry-select>\n </ng-container>\n\n <ng-container *ngIf=\"advancedTooltip\">\n <textarea\n cols=\"100\"\n rows=\"15\"\n class=\"a-form-field\"\n [(ngModel)]=\"strOptions\"\n (focusout)=\"optionsChanged()\"\n ></textarea>\n </ng-container>\n</div>\n\n<div class=\"m-tooltip m-tooltip--example\" [class.-hidden]=\"noTooltip\">\n <div #example></div>\n</div>\n\n<div class=\"m-btn-group -width-md\">\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 class=\"a-btn a-btn--primary\" type=\"submit\" (click)=\"updateTemplate()\">\n {{ '@pry.admin.customize.update' | i18n }}\n </button>\n</div>\n", dependencies: [{ kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3$1.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$1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3$1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i5$1.PryCheckboxComponent, selector: "pry-checkbox", inputs: ["circle"] }, { kind: "component", type: i4.PrySelectComponent, selector: "pry-select", inputs: ["labelTranslate", "baseTranslate", "translationFn", "translationFnArgs", "clearable", "multiple", "multipleClearRight", "closeOnSelect", "placeholder", "isForm", "required", "name", "readonly", "items", "itemsAsOption", "bindData", "bindValue", "bindLabel", "bindIcon", "iconSize", "templateLabel", "templateOption", "autocomplete"] }, { kind: "pipe", type: i3.AsyncPipe, name: "async" }, { kind: "pipe", type: i4.I18nPipe, name: "i18n" }] }); }
1199
1199
  }
1200
1200
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.6", ngImport: i0, type: AdminClassesCustomizeTooltipComponent, decorators: [{
1201
1201
  type: Component,
1202
- args: [{ selector: 'pry-admin-classes-customize-tooltip', template: "<div>\n <div class=\"m-form-label-field -width-xl\">\n <label class=\"a-label\" for=\"tooltip_type\">{{ '@pry.admin.customize.type' | i18n }}</label>\n <pry-select\n id=\"tooltip_type\"\n class=\"a-pry-select\"\n (ngModelChange)=\"tooltipTypeChanged($event)\"\n [ngModel]=\"currentClassConfig.type\"\n [items]=\"possibleTooltipTypes$ | async\"\n [itemsAsOption]=\"true\"\n bindValue=\"value\"\n bindLabel=\"label\"\n [labelTranslate]=\"true\"\n ></pry-select>\n </div>\n\n <div>\n <pry-checkbox [(ngModel)]=\"advancedTooltip\">{{ '@pry.admin.customize.advanced' | i18n }}</pry-checkbox>\n </div>\n\n <ng-container *ngIf=\"!advancedTooltip && currentClassConfig.type === 'attribute'\">\n <label class=\"a-label\" for=\"customize_simplified\">{{ '@pry.admin.customize.simplified' | i18n }}</label>\n <pry-select\n id=\"customize_simplified\"\n class=\"a-pry-select\"\n (ngModelChange)=\"changeAttributes($event)\"\n [ngModel]=\"currentClassConfig.options.attributes\"\n [itemsAsOption]=\"true\"\n [items]=\"possibleAttributes\"\n [multiple]=\"true\"\n bindLabel=\"name\"\n bindValue=\"name\"\n ></pry-select>\n </ng-container>\n\n <ng-container *ngIf=\"advancedTooltip\">\n <textarea\n cols=\"100\"\n rows=\"15\"\n class=\"a-form-field\"\n [(ngModel)]=\"strOptions\"\n (focusout)=\"optionsChanged()\"\n ></textarea>\n </ng-container>\n</div>\n\n<div class=\"m-tooltip m-tooltip--example\" [class.-hidden]=\"noTooltip\">\n <div #example></div>\n</div>\n\n<div class=\"m-btn-group -width-md\">\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 class=\"a-btn a-btn--primary\" type=\"submit\" (click)=\"updateTemplate()\">\n {{ '@pry.admin.customize.update' | i18n }}\n </button>\n</div>\n" }]
1202
+ args: [{ selector: 'pry-admin-classes-customize-tooltip', template: "<div>\n <div class=\"m-form-label-field -width-xl\">\n <label class=\"a-label\" for=\"tooltip_type\">{{ '@pry.admin.customize.type' | i18n }}</label>\n <pry-select\n id=\"tooltip_type\"\n class=\"a-pry-select\"\n (ngModelChange)=\"tooltipTypeChanged($event)\"\n [ngModel]=\"currentClassConfig.type\"\n [items]=\"possibleTooltipTypes$ | async\"\n [itemsAsOption]=\"true\"\n bindValue=\"value\"\n bindLabel=\"label\"\n [labelTranslate]=\"true\"\n ></pry-select>\n </div>\n\n <div>\n <pry-checkbox [(ngModel)]=\"advancedTooltip\">{{ '@pry.admin.customize.advanced' | i18n }}</pry-checkbox>\n </div>\n\n <ng-container *ngIf=\"!advancedTooltip && currentClassConfig.type === 'attribute'\">\n <label class=\"a-label\" for=\"customize_simplified\">{{ '@pry.admin.customize.simplified' | i18n }}</label>\n <pry-select\n id=\"customize_simplified\"\n class=\"a-pry-select\"\n (ngModelChange)=\"changeAttributes($event)\"\n [ngModel]=\"currentClassConfig.options.attributes\"\n [itemsAsOption]=\"true\"\n [items]=\"possibleAttributes\"\n [multiple]=\"true\"\n [closeOnSelect]=\"false\"\n bindLabel=\"name\"\n bindValue=\"name\"\n ></pry-select>\n </ng-container>\n\n <ng-container *ngIf=\"advancedTooltip\">\n <textarea\n cols=\"100\"\n rows=\"15\"\n class=\"a-form-field\"\n [(ngModel)]=\"strOptions\"\n (focusout)=\"optionsChanged()\"\n ></textarea>\n </ng-container>\n</div>\n\n<div class=\"m-tooltip m-tooltip--example\" [class.-hidden]=\"noTooltip\">\n <div #example></div>\n</div>\n\n<div class=\"m-btn-group -width-md\">\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 class=\"a-btn a-btn--primary\" type=\"submit\" (click)=\"updateTemplate()\">\n {{ '@pry.admin.customize.update' | i18n }}\n </button>\n</div>\n" }]
1203
1203
  }], ctorParameters: function () { return [{ type: i4.TooltipFactoryService }, { type: i0.Injector }, { type: i4.PryI18nService }, { type: i1.Store }]; }, propDecorators: { example: [{
1204
1204
  type: ViewChild,
1205
1205
  args: ['example', { read: ViewContainerRef }]