geonetwork-ui 2.7.0-dev.8ac6cd7aa → 2.7.0-dev.b9840dab3

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 (72) hide show
  1. package/esm2022/libs/api/metadata-converter/src/lib/iso19139/utils/status.mapper.mjs +4 -1
  2. package/esm2022/libs/api/metadata-converter/src/lib/iso19139/write-parts.mjs +5 -1
  3. package/esm2022/libs/api/repository/src/lib/gn4/elasticsearch/constant.mjs +4 -6
  4. package/esm2022/libs/api/repository/src/lib/gn4/platform/gn4-platform.service.mjs +18 -4
  5. package/esm2022/libs/common/domain/src/lib/model/record/metadata.model.mjs +5 -1
  6. package/esm2022/libs/feature/dataviz/src/lib/service/data.service.mjs +2 -2
  7. package/esm2022/libs/feature/editor/src/lib/components/metadata-quality-panel/metadata-quality-panel.component.mjs +2 -2
  8. package/esm2022/libs/feature/record/src/lib/map-view/map-view.component.mjs +4 -2
  9. package/esm2022/libs/ui/elements/src/lib/downloads-list/downloads-list.component.mjs +5 -4
  10. package/esm2022/libs/ui/elements/src/lib/geo-data-badge/geo-data-badge.component.mjs +5 -4
  11. package/esm2022/libs/ui/inputs/src/lib/search-feature-catalog/search-feature-catalog.component.mjs +5 -4
  12. package/esm2022/libs/util/shared/src/lib/links/link-utils.mjs +4 -2
  13. package/esm2022/libs/util/shared/src/lib/utils/index.mjs +2 -1
  14. package/esm2022/libs/util/shared/src/lib/utils/mobile-screen.mjs +9 -0
  15. package/esm2022/translations/de.json +2 -0
  16. package/esm2022/translations/en.json +2 -0
  17. package/esm2022/translations/es.json +2 -0
  18. package/esm2022/translations/fr.json +3 -1
  19. package/esm2022/translations/it.json +2 -0
  20. package/esm2022/translations/nl.json +2 -0
  21. package/esm2022/translations/pt.json +2 -0
  22. package/esm2022/translations/sk.json +2 -0
  23. package/fesm2022/geonetwork-ui.mjs +76 -22
  24. package/fesm2022/geonetwork-ui.mjs.map +1 -1
  25. package/libs/api/metadata-converter/src/lib/iso19139/utils/status.mapper.d.ts.map +1 -1
  26. package/libs/api/metadata-converter/src/lib/iso19139/write-parts.d.ts.map +1 -1
  27. package/libs/api/repository/src/lib/gn4/elasticsearch/constant.d.ts.map +1 -1
  28. package/libs/api/repository/src/lib/gn4/platform/gn4-platform.service.d.ts +2 -0
  29. package/libs/api/repository/src/lib/gn4/platform/gn4-platform.service.d.ts.map +1 -1
  30. package/libs/common/domain/src/lib/model/record/metadata.model.d.ts.map +1 -1
  31. package/libs/feature/dataviz/src/lib/service/data.service.d.ts.map +1 -1
  32. package/libs/feature/editor/src/lib/components/metadata-quality-panel/metadata-quality-panel.component.d.ts.map +1 -1
  33. package/libs/feature/record/src/lib/map-view/map-view.component.d.ts.map +1 -1
  34. package/libs/ui/elements/src/lib/downloads-list/downloads-list.component.d.ts +1 -0
  35. package/libs/ui/elements/src/lib/downloads-list/downloads-list.component.d.ts.map +1 -1
  36. package/libs/ui/elements/src/lib/geo-data-badge/geo-data-badge.component.d.ts +1 -0
  37. package/libs/ui/elements/src/lib/geo-data-badge/geo-data-badge.component.d.ts.map +1 -1
  38. package/libs/ui/inputs/src/lib/search-feature-catalog/search-feature-catalog.component.d.ts +1 -0
  39. package/libs/ui/inputs/src/lib/search-feature-catalog/search-feature-catalog.component.d.ts.map +1 -1
  40. package/libs/util/shared/src/lib/links/link-utils.d.ts +1 -1
  41. package/libs/util/shared/src/lib/links/link-utils.d.ts.map +1 -1
  42. package/libs/util/shared/src/lib/utils/index.d.ts +1 -0
  43. package/libs/util/shared/src/lib/utils/index.d.ts.map +1 -1
  44. package/libs/util/shared/src/lib/utils/mobile-screen.d.ts +2 -0
  45. package/libs/util/shared/src/lib/utils/mobile-screen.d.ts.map +1 -0
  46. package/package.json +1 -1
  47. package/src/libs/api/metadata-converter/src/lib/dcat-ap/utils/status.mapper.ts +3 -0
  48. package/src/libs/api/metadata-converter/src/lib/iso19139/utils/status.mapper.ts +3 -0
  49. package/src/libs/api/metadata-converter/src/lib/iso19139/write-parts.ts +4 -0
  50. package/src/libs/api/repository/src/lib/gn4/elasticsearch/constant.ts +3 -5
  51. package/src/libs/api/repository/src/lib/gn4/platform/gn4-platform.service.ts +19 -6
  52. package/src/libs/common/domain/src/lib/model/record/metadata.model.ts +4 -0
  53. package/src/libs/feature/dataviz/src/lib/service/data.service.ts +3 -1
  54. package/src/libs/feature/editor/src/lib/components/metadata-quality-panel/metadata-quality-panel.component.ts +1 -4
  55. package/src/libs/feature/record/src/lib/map-view/map-view.component.ts +3 -1
  56. package/src/libs/ui/elements/src/lib/downloads-list/downloads-list.component.html +12 -11
  57. package/src/libs/ui/elements/src/lib/downloads-list/downloads-list.component.ts +7 -1
  58. package/src/libs/ui/elements/src/lib/geo-data-badge/geo-data-badge.component.html +4 -1
  59. package/src/libs/ui/elements/src/lib/geo-data-badge/geo-data-badge.component.ts +7 -1
  60. package/src/libs/ui/inputs/src/lib/search-feature-catalog/search-feature-catalog.component.html +7 -1
  61. package/src/libs/ui/inputs/src/lib/search-feature-catalog/search-feature-catalog.component.ts +3 -1
  62. package/src/libs/util/shared/src/lib/links/link-utils.ts +2 -1
  63. package/src/libs/util/shared/src/lib/utils/index.ts +1 -0
  64. package/src/libs/util/shared/src/lib/utils/mobile-screen.ts +14 -0
  65. package/translations/de.json +2 -0
  66. package/translations/en.json +2 -0
  67. package/translations/es.json +2 -0
  68. package/translations/fr.json +3 -1
  69. package/translations/it.json +2 -0
  70. package/translations/nl.json +2 -0
  71. package/translations/pt.json +2 -0
  72. package/translations/sk.json +2 -0
@@ -245,7 +245,9 @@ export class MapViewComponent {
245
245
  link.accessServiceProtocol === 'tms') {
246
246
  // FIXME: here we're assuming that the TMS serves vector tiles only; should be checked with ogc-client first
247
247
  return of({
248
- url: link.url.toString().replace(/\/?$/, '/{z}/{x}/{y}.pbf'),
248
+ url: link.url
249
+ .toString()
250
+ .replace(/\/?$/, `/${link.name}/{z}/{x}/{y}.pbf`),
249
251
  type: 'xyz',
250
252
  tileFormat: 'application/vnd.mapbox-vector-tile',
251
253
  name: link.name,
@@ -333,4 +335,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
333
335
  type: ViewChild,
334
336
  args: ['mapContainer']
335
337
  }] } });
336
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"map-view.component.js","sourceRoot":"","sources":["../../../../../../../../libs/feature/record/src/lib/map-view/map-view.component.ts","../../../../../../../../libs/feature/record/src/lib/map-view/map-view.component.html"],"names":[],"mappings":"AAAA,OAAO,EAEL,uBAAuB,EACvB,iBAAiB,EACjB,SAAS,EACT,YAAY,EACZ,KAAK,EACL,MAAM,EACN,SAAS,GACV,MAAM,eAAe,CAAA;AACtB,OAAO,EAAE,eAAe,EAAE,MAAM,wCAAwC,CAAA;AACxE,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,MAAM,wCAAwC,CAAA;AAChF,OAAO,EACL,eAAe,EACf,aAAa,EACb,IAAI,EAEJ,EAAE,EACF,SAAS,EACT,UAAU,EACV,cAAc,GACf,MAAM,MAAM,CAAA;AACb,OAAO,EACL,UAAU,EACV,oBAAoB,EACpB,QAAQ,EACR,GAAG,EACH,WAAW,EACX,SAAS,EAET,GAAG,GACJ,MAAM,gBAAgB,CAAA;AACvB,OAAO,EAAE,YAAY,EAAE,MAAM,wBAAwB,CAAA;AACrD,OAAO,EAAE,WAAW,EAAE,MAAM,4CAA4C,CAAA;AAKxE,OAAO,EACL,mBAAmB,GAIpB,MAAM,sBAAsB,CAAA;AAC7B,OAAO,EACL,sBAAsB,EACtB,qBAAqB,EACrB,kBAAkB,EAClB,oBAAoB,GACrB,MAAM,mCAAmC,CAAA;AAE1C,OAAO,EAAE,eAAe,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAA;AAC9D,OAAO,EAAE,QAAQ,EAAE,MAAM,mCAAmC,CAAA;AAC5D,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAA;AAC9C,OAAO,EACL,eAAe,EACf,yBAAyB,GAC1B,MAAM,sCAAsC,CAAA;AAC7C,OAAO,EACL,kBAAkB,EAClB,aAAa,EACb,gBAAgB,GACjB,MAAM,qBAAqB,CAAA;AAC5B,OAAO,EAAE,6BAA6B,EAAE,MAAM,4DAA4D,CAAA;AAC1G,OAAO,EACL,oBAAoB,EACpB,mBAAmB,GACpB,MAAM,uCAAuC,CAAA;AAC9C,OAAO,EAAE,MAAM,EAAE,MAAM,yCAAyC,CAAA;AAChE,OAAO,EAAE,UAAU,EAAE,MAAM,8CAA8C,CAAA;;;;;;;AAEzE,MAAM,CAAC,0BAA0B,CAAC,CAAA;AAClC,MAAM,CAAC,mBAAmB,CAAC,CAAA;AAC3B,MAAM,CAAC,gCAAgC,CAAC,CAAA;AACxC,MAAM,CAAC,kBAAkB,CAAC,CAAA;AAwB1B,MAAM,OAAO,gBAAgB;IAC3B,IAAa,YAAY,CAAC,KAAc;QACtC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,KAAK,CAAC,CAAA;IAC9B,CAAC;IAMD,IAAa,YAAY,CAAC,KAAa;QACrC,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,KAAK,CAAC,CAAA;IAChC,CAAC;IACD,IAAa,aAAa,CAAC,KAAU;QACnC,IAAI,KAAK,CAAC,IAAI,KAAK,KAAK,EAAE,CAAC;YACzB,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAA;YACnC,IAAI,KAAK,CAAC,aAAa,EAAE,CAAC;gBACxB,IAAI,CAAC,gBAAgB,GAAG,KAAK,CAAC,aAAa,CAAA;YAC7C,CAAC;YACD,IAAI,KAAK,CAAC,MAAM,EAAE,CAAC;gBACjB,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,CAAA;YACzC,CAAC;QACH,CAAC;IACH,CAAC;IAcD,mBAAmB,CAAC,EAAU;QAC5B,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,EAAE,CAAC,CAAA;IAC/B,CAAC;IAED,oBAAoB,CAAC,CAAS;QAC5B,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,CAAC,CAAC,CAAA;QAC7B,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC,CAAC,CAAA;IAC5B,CAAC;IAED,YAAY;QACV,IAAI,CAAC,UAAU,GAAG,CAAC,IAAI,CAAC,UAAU,CAAA;IACpC,CAAC;IACD,oBAAoB,CAAC,CAAU;QAC7B,IAAI,CAAC,YAAY,GAAG,CAAC,CAAA;IACvB,CAAC;IA6LD,YACU,YAA0B,EAC1B,QAAyB,EACzB,WAAwB,EACxB,SAA4B,EAC5B,gBAAkC;QAJlC,iBAAY,GAAZ,YAAY,CAAc;QAC1B,aAAQ,GAAR,QAAQ,CAAiB;QACzB,gBAAW,GAAX,WAAW,CAAa;QACxB,cAAS,GAAT,SAAS,CAAmB;QAC5B,qBAAgB,GAAhB,gBAAgB,CAAkB;QAhP5C,oBAAe,GAAG,IAAI,eAAe,CAAC,IAAI,CAAC,CAAA;QAC3C,oBAAe,GAAG,IAAI,CAAA;QACtB,qBAAgB,GAAG,IAAI,CAAA;QAEvB,YAAO,GAAuC,IAAI,GAAG,EAAE,CAAA;QAe9C,kBAAa,GAAG,IAAI,CAAA;QACnB,iBAAY,GAAG,IAAI,YAAY,EAAyB,CAAA;QACxD,kBAAa,GAAG,IAAI,YAAY,EAAU,CAAA;QAGpD,gBAAW,GAAG,IAAI,eAAe,CAAC,KAAK,CAAC,CAAA;QACxC,gBAAW,GAAG,KAAK,CAAA;QAEnB,eAAU,GAAG,IAAI,CAAA;QACjB,iBAAY,GAAG,KAAK,CAAA;QACpB,YAAO,GAAG,KAAK,CAAA;QACf,UAAK,GAAG,IAAI,CAAA;QAkBZ,wBAAmB,GAAG,aAAa,CAAC;YAClC,IAAI,CAAC,YAAY,CAAC,YAAY;YAC9B,IAAI,CAAC,YAAY,CAAC,yBAAyB;SAC5C,CAAC,CAAC,IAAI,CACL,GAAG,CAAC,CAAC,CAAC,WAAW,EAAE,wBAAwB,CAAC,EAAE,EAAE,CAAC;YAC/C,GAAG,WAAW;YACd,GAAG,wBAAwB;SAC5B,CAAC,EACF,WAAW,CAAC,CAAC,CAAC,CACf,CAAA;QAED,qBAAgB,GAAG,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAC9C,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE;YACZ,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,CAAA;YACpB,KAAK,CAAC,OAAO,CAAC,CAAC,IAA2B,EAAE,EAAE,CAC5C,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,SAAS,CAAC,IAAI,CAAC,EAAE,IAAI,CAAC,CACxC,CAAA;YACD,OAAO,KAAK,CAAC,MAAM;gBACjB,CAAC,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC;oBACnB,KAAK,EAAE,YAAY,CAAC,IAAI,CAAC;oBACzB,KAAK,EAAE,SAAS,CAAC,IAAI,CAAC;iBACvB,CAAC,CAAC;gBACL,CAAC,CAAC,CAAC,EAAE,KAAK,EAAE,0BAA0B,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC,CAAA;QACxD,CAAC,CAAC,CACH,CAAA;QAED,kBAAa,GAAG,IAAI,eAAe,CAAC,IAAI,CAAC,CAAA;QACzC,oBAAe,GAAG,IAAI,eAAe,CAAC,IAAI,CAAC,CAAA;QAC3C,qBAAgB,GAAG,IAAI,eAAe,CAAC,IAAI,CAAC,CAAA;QAE5C,wBAAmB,GAAG,aAAa,CAAC;YAClC,IAAI,CAAC,mBAAmB;YACxB,IAAI,CAAC,eAAe;YACpB,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,oBAAoB,EAAE,CAAC;YACjD,IAAI,CAAC,aAAa;SACnB,CAAC,CAAC,IAAI,CACL,GAAG,CAAC,GAAG,EAAE;YACP,IAAI,CAAC,KAAK,GAAG,IAAI,CAAA;QACnB,CAAC,CAAC,EACF,GAAG,CAAC,CAAC,CAAC,eAAe,EAAE,UAAU,EAAE,EAAE,EAAE,IAAI,CAAC,EAAE,EAAE;YAC9C,IAAI,IAAI,KAAK,KAAK,EAAE,CAAC;gBACnB,IACE,UAAU;oBACV,CAAC,EAAE;oBACH,eAAe,CAAC,IAAI,CAClB,CAAC,IAAI,EAAE,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,KAAK,SAAS,CAAC,UAAU,CAAC,CACpD,EACD,CAAC;oBACD,IAAI,CAAC,eAAe,GAAG,SAAS,CAAC,UAAU,CAAC,CAAA;oBAC5C,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,UAAU,CAAC,CAAA;oBAClC,OAAO,UAAU,CAAA;gBACnB,CAAC;qBAAM,IAAI,EAAE,EAAE,CAAC;oBACd,IAAI,CAAC,eAAe,GAAG,EAAE,CAAA;oBACzB,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,CAAA;oBAC5C,OAAO,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC,CAAA;gBAC7B,CAAC;qBAAM,CAAC;oBACN,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC,CAAC,CAAC,CAAA;oBAC1C,OAAO,eAAe,CAAC,CAAC,CAAC,CAAA;gBAC3B,CAAC;YACH,CAAC;QACH,CAAC,CAAC,CACH,CAAA;QAED,gBAAW,GAAG,IAAI,CAAC,mBAAmB,CAAC,IAAI,CACzC,SAAS,CAAC,CAAC,GAAG,EAAE,EAAE;YAChB,IACE,GAAG;gBACH,GAAG,CAAC,IAAI,KAAK,SAAS;gBACtB,GAAG,CAAC,qBAAqB,KAAK,KAAK,EACnC,CAAC;gBACD,OAAO,IAAI;gBACT,8HAA8H;gBAC9H,gDAAgD;gBAChD,IAAI,CAAC,WAAW,CAAC,sBAAsB,CACrC,GAAiC,EACjC,KAAK,CACN,CACF,CAAC,IAAI;gBACJ,sFAAsF;gBACtF,0FAA0F;gBAC1F,GAAG,CACD,CAAC,KAAK,EAAE,EAAE,CACR,KAAK,EAAE,MAAM,CACX,CAAC,IAAI,EAAE,EAAE,CACP,IAAI,CAAC,IAAI,KAAK,SAAS;oBACvB,IAAI,CAAC,qBAAqB,KAAK,gBAAgB,CAClD,IAAI,EAAE,CACV,EACD,UAAU,CAAC,CAAC,KAAK,EAAE,EAAE;oBACnB,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,CAAA;oBACvB,OAAO,EAAE,CAAC,GAAG,CAAC,CAAA;gBAChB,CAAC,CAAC,CACH,CAAA;YACH,CAAC;YACD,OAAO,EAAE,CAAC,EAAE,CAAC,CAAA;QACf,CAAC,CAAC,EACF,GAAG,CAAC,CAAC,MAAM,EAAE,EAAE;YACb,IAAI,IAAI,CAAC,gBAAgB,IAAI,IAAI,CAAC,gBAAgB,IAAI,MAAM,CAAC,MAAM,EAAE,CAAC;gBACpE,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAA;YACnD,CAAC;iBAAM,CAAC;gBACN,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,CAAC,CAAC,CAAA;YAC/B,CAAC;QACH,CAAC,CAAC,EACF,WAAW,CAAC,CAAC,CAAC,CACf,CAAA;QAED,0BAAqB,GAAG,IAAI,CAAC,WAAW,CAAC,IAAI,CAC3C,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CACZ,KAAK,CAAC,MAAM;YACV,CAAC,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,KAAK,EAAE,EAAE,CAAC,CAAC;gBAC1B,KAAK,EAAE,YAAY,CAAC,IAAI,CAAC;gBACzB,KAAK,EAAE,KAAK;aACb,CAAC,CAAC;YACL,CAAC,CAAC;gBACE;oBACE,KAAK,EAAE,0BAA0B;oBACjC,KAAK,EAAE,CAAC;iBACT;aACF,CACN,CACF,CAAA;QAED,kBAAa,GAAG,aAAa,CAAC;YAC5B,IAAI,CAAC,mBAAmB;YACxB,IAAI,CAAC,WAAW;YAChB,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,oBAAoB,EAAE,CAAC;SACnD,CAAC,CAAC,IAAI,CACL,GAAG,CAAC,CAAC,CAAC,GAAG,EAAE,MAAM,EAAE,QAAQ,CAAC,EAAE,EAAE,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,EAC1E,WAAW,CAAC,CAAC,CAAC,CACf,CAAA;QAED,mBAAc,GAAG,aAAa,CAAC,CAAC,IAAI,CAAC,aAAa,EAAE,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,IAAI,CACzE,SAAS,CAAC,CAAC,CAAC,IAAI,EAAE,UAAU,CAAC,EAAE,EAAE;YAC/B,IAAI,CAAC,IAAI,EAAE,CAAC;gBACV,OAAO,EAAE,CAAC,EAAE,CAAC,CAAA;YACf,CAAC;YACD,IAAI,UAAU,IAAI,IAAI,CAAC,qBAAqB,KAAK,KAAK,EAAE,CAAC;gBACvD,IAAI,CAAC,WAAW,GAAG,IAAI,CAAA;gBACvB,OAAO,EAAE,CAAC,EAAE,CAAC,CAAA;YACf,CAAC;YACD,IAAI,CAAC,WAAW,GAAG,KAAK,CAAA;YACxB,IAAI,CAAC,OAAO,GAAG,IAAI,CAAA;YACnB,IAAI,IAAI,CAAC,gBAAgB,EAAE,CAAC;gBAC1B,IAAI,CAAC,WAAW,CAAC,gCAAgC,CAAC,CAAA;gBAClD,OAAO,EAAE,CAAC,EAAE,CAAC,CAAA;YACf,CAAC;YACD,OAAO,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,CAAC,IAAI,CACrC,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,EACvB,UAAU,CAAC,CAAC,CAAC,EAAE,EAAE;gBACf,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,CAAA;gBACnB,OAAO,EAAE,CAAC,EAAE,CAAC,CAAA;YACf,CAAC,CAAC,EACF,QAAQ,CAAC,GAAG,EAAE,CAAC,CAAC,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC,CAAC,CACvC,CAAA;QACH,CAAC,CAAC,CACH,CAAA;QAED,gBAAW,GAA2B,IAAI,CAAC,cAAc,CAAC,IAAI,CAC5D,SAAS,CAAC,CAAC,MAAM,EAAE,EAAE,CACnB,IAAI,CAAC,mBAAmB,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CACvC,UAAU,CAAC,GAAG,EAAE,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,EAAE,qDAAqD;QACjF,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC;YACb,MAAM;YACN,IAAI;SACL,CAAC,CAAC,EACH,GAAG,CAAC,GAAG,EAAE;YACP,IAAI,CAAC,cAAc,EAAE,CAAA;QACvB,CAAC,CAAC,CACH,CACF,EACD,SAAS,CAAC;YACR,MAAM,EAAE,EAAE;YACV,IAAI,EAAE,IAAI;SACX,CAAC,EACF,cAAc,CAAC,IAAI,CAAC,YAAY,CAAC,SAAS,CAAC,EAC3C,GAAG,CAAC,CAAC,CAAC,OAAO,EAAE,QAAQ,CAAC,EAAE,EAAE;YAC1B,IAAI,OAAO,CAAC,IAAI;gBAAE,OAAO,OAAO,CAAA;YAChC,MAAM,MAAM,GAAG,IAAI,CAAC,QAAQ,CAAC,eAAe,CAAC,QAAQ,CAAC,CAAA;YACtD,MAAM,IAAI,GAAG,MAAM,CAAC,CAAC,CAAC,EAAE,MAAM,EAAE,CAAC,CAAC,CAAC,IAAI,CAAA;YACvC,OAAO;gBACL,GAAG,OAAO;gBACV,IAAI;aACL,CAAA;QACH,CAAC,CAAC,EACF,WAAW,CAAC,CAAC,CAAC,CACf,CAAA;IAQE,CAAC;IAEJ,KAAK,CAAC,eAAe;QACnB,MAAM,GAAG,GAAG,MAAM,IAAI,CAAC,YAAY,CAAC,aAAa,CAAA;QACjD,oBAAoB,CAAC,GAAG,CAAC,eAAe,EAAE,CAAC,CAAA;IAC7C,CAAC;IAED,kBAAkB,CAAC,QAAmB;QACpC,IAAI,CAAC,cAAc,EAAE,CAAA;QACrB,IAAI,CAAC,SAAS,GAAG,QAAQ,EAAE,MAAM,GAAG,CAAC,IAAI,QAAQ,CAAC,CAAC,CAAC,CAAA;QACpD,IAAI,IAAI,CAAC,SAAS,EAAE,CAAC;YACnB,6CAA6C;YAC7C,+CAA+C;QACjD,CAAC;QACD,IAAI,CAAC,SAAS,CAAC,aAAa,EAAE,CAAA;IAChC,CAAC;IAED,iBAAiB,CAAC,KAA2B;QAC3C,IAAI,KAAK,CAAC,UAAU,KAAK,GAAG,IAAI,KAAK,CAAC,UAAU,KAAK,GAAG,EAAE,CAAC;YACzD,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,gBAAgB,CAAC,OAAO,CAAC,yBAAyB,CAAC,CAAA;QACvE,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,gBAAgB,CAAC,OAAO,CAAC,oBAAoB,EAAE;gBAC/D,IAAI,EAAE,KAAK,CAAC,UAAU;aACvB,CAAC,CAAA;QACJ,CAAC;IACH,CAAC;IAED,cAAc;QACZ,IAAI,IAAI,CAAC,SAAS,EAAE,CAAC;YACnB,6CAA6C;YAC7C,gCAAgC;QAClC,CAAC;QACD,IAAI,CAAC,SAAS,GAAG,IAAI,CAAA;IACvB,CAAC;IAED,gBAAgB,CAAC,IAA2B;QAC1C,IAAI,IAAI,CAAC,IAAI,KAAK,SAAS,IAAI,IAAI,CAAC,qBAAqB,KAAK,KAAK,EAAE,CAAC;YACpE,OAAO,EAAE,CAAC;gBACR,GAAG,EAAE,IAAI,CAAC,GAAG,CAAC,QAAQ,EAAE;gBACxB,IAAI,EAAE,KAAK;gBACX,IAAI,EAAE,IAAI,CAAC,IAAI;aAChB,CAAC,CAAA;QACJ,CAAC;aAAM,IACL,IAAI,CAAC,IAAI,KAAK,SAAS;YACvB,IAAI,CAAC,qBAAqB,KAAK,KAAK,EACpC,CAAC;YACD,4GAA4G;YAC5G,OAAO,EAAE,CAAC;gBACR,GAAG,EAAE,IAAI,CAAC,GAAG,CAAC,QAAQ,EAAE,CAAC,OAAO,CAAC,MAAM,EAAE,kBAAkB,CAAC;gBAC5D,IAAI,EAAE,KAAK;gBACX,UAAU,EAAE,oCAAoC;gBAChD,IAAI,EAAE,IAAI,CAAC,IAAI;aAChB,CAAC,CAAA;QACJ,CAAC;aAAM,IACL,IAAI,CAAC,IAAI,KAAK,SAAS;YACvB,IAAI,CAAC,qBAAqB,KAAK,gBAAgB,EAC/C,CAAC;YACD,OAAO,EAAE,CAAC;gBACR,IAAI,EAAE,gBAAgB;gBACtB,IAAI,EAAE,IAAI,CAAC,IAAI;gBACf,QAAQ,EAAE,IAAI,CAAC,GAAG,CAAC,QAAQ,EAAE;aAC9B,CAAC,CAAA;QACJ,CAAC;aAAM,IACL,IAAI,CAAC,IAAI,KAAK,SAAS;YACvB,IAAI,CAAC,qBAAqB,KAAK,MAAM,EACrC,CAAC;YACD,OAAO,EAAE,CAAC;gBACR,GAAG,EAAE,IAAI,CAAC,GAAG,CAAC,QAAQ,EAAE;gBACxB,IAAI,EAAE,MAAM;gBACZ,IAAI,EAAE,IAAI,CAAC,IAAI;aAChB,CAAC,CAAA;QACJ,CAAC;aAAM,IACL,CAAC,IAAI,CAAC,IAAI,KAAK,SAAS;YACtB,CAAC,IAAI,CAAC,qBAAqB,KAAK,KAAK;gBACnC,IAAI,CAAC,qBAAqB,KAAK,UAAU;gBACzC,IAAI,CAAC,qBAAqB,KAAK,aAAa,CAAC,CAAC;YAClD,IAAI,CAAC,IAAI,KAAK,UAAU,EACxB,CAAC;YACD,MAAM,WAAW,GAAG,IAAI,CAAA,CAAC,iDAAiD;YAC1E,OAAO,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,IAAI,EAAE,WAAW,CAAC,CAAC,IAAI,CAC3D,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC;gBACb,IAAI,EAAE,SAAS;gBACf,IAAI;aACL,CAAC,CAAC,CACJ,CAAA;QACH,CAAC;QACD,OAAO,UAAU,CAAC,GAAG,EAAE,CAAC,wBAAwB,CAAC,CAAA;IACnD,CAAC;IACD,WAAW,CAAC,KAAkC;QAC5C,IAAI,KAAK,YAAY,UAAU,EAAE,CAAC;YAChC,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,gBAAgB,CAAC,OAAO,CACxC,iBAAiB,KAAK,CAAC,IAAI,EAAE,EAC7B;gBACE,IAAI,EAAE,KAAK,CAAC,IAAI;aACjB,CACF,CAAA;YACD,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAA;QAC7B,CAAC;aAAM,IAAI,KAAK,YAAY,KAAK,EAAE,CAAC;YAClC,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,gBAAgB,CAAC,OAAO,CAAC,KAAK,CAAC,OAAO,CAAC,CAAA;YACzD,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,IAAI,KAAK,CAAC,CAAA;QACpC,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,gBAAgB,CAAC,OAAO,CAAC,KAAK,CAAC,CAAA;YACjD,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,CAAA;QACrB,CAAC;QACD,IAAI,CAAC,OAAO,GAAG,KAAK,CAAA;QACpB,IAAI,CAAC,SAAS,CAAC,aAAa,EAAE,CAAA;IAChC,CAAC;+GA/VU,gBAAgB;mGAAhB,gBAAgB,2YClG7B,4wJAuIA,yDDpDI,YAAY,sRACZ,yBAAyB,qNACzB,qBAAqB,iKACrB,sBAAsB,wGACtB,mBAAmB,oGACnB,kBAAkB,6GAClB,aAAa,kDACb,oBAAoB,oFACpB,eAAe,6GACf,6BAA6B,yGAC7B,eAAe,+HACf,kBAAkB,wGAEL,CAAC,YAAY,CAAC,EAAE,QAAQ,EAAE,CAAC,CAAC;;4FAEhC,gBAAgB;kBAtB5B,SAAS;+BACE,gBAAgB,mBAGT,uBAAuB,CAAC,MAAM,cACnC,IAAI,WACP;wBACP,YAAY;wBACZ,yBAAyB;wBACzB,qBAAqB;wBACrB,sBAAsB;wBACtB,mBAAmB;wBACnB,kBAAkB;wBAClB,aAAa;wBACb,oBAAoB;wBACpB,eAAe;wBACf,6BAA6B;wBAC7B,eAAe;wBACf,kBAAkB;qBACnB,iBACc,CAAC,YAAY,CAAC,EAAE,QAAQ,EAAE,CAAC,CAAC;wMAG9B,YAAY;sBAAxB,KAAK;gBAQO,YAAY;sBAAxB,KAAK;gBAGO,aAAa;sBAAzB,KAAK;gBAWG,aAAa;sBAArB,KAAK;gBACI,YAAY;sBAArB,MAAM;gBACG,aAAa;sBAAtB,MAAM;gBACoB,YAAY;sBAAtC,SAAS;uBAAC,cAAc","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  Input,\n  Output,\n  ViewChild,\n} from '@angular/core'\nimport { MapUtilsService } from '../../../../../../libs/feature/map/src'\nimport { getLinkId, getLinkLabel } from '../../../../../../libs/util/shared/src'\nimport {\n  BehaviorSubject,\n  combineLatest,\n  from,\n  Observable,\n  of,\n  startWith,\n  throwError,\n  withLatestFrom,\n} from 'rxjs'\nimport {\n  catchError,\n  distinctUntilChanged,\n  finalize,\n  map,\n  shareReplay,\n  switchMap,\n  take,\n  tap,\n} from 'rxjs/operators'\nimport { MdViewFacade } from '../state/mdview.facade'\nimport { DataService } from '../../../../../../libs/feature/dataviz/src'\nimport {\n  DatasetOnlineResource,\n  DatasetServiceDistribution,\n} from '../../../../../../libs/common/domain/src/lib/model/record'\nimport {\n  createViewFromLayer,\n  MapContext,\n  MapContextLayer,\n  SourceLoadErrorEvent,\n} from '@geospatial-sdk/core'\nimport {\n  FeatureDetailComponent,\n  MapContainerComponent,\n  MapLegendComponent,\n  prioritizePageScroll,\n} from '../../../../../../libs/ui/map/src'\nimport { Feature } from 'geojson'\nimport { NgIconComponent, provideIcons } from '@ng-icons/core'\nimport { matClose } from '@ng-icons/material-icons/baseline'\nimport { CommonModule } from '@angular/common'\nimport {\n  ButtonComponent,\n  DropdownSelectorComponent,\n} from '../../../../../../libs/ui/inputs/src'\nimport {\n  TranslateDirective,\n  TranslatePipe,\n  TranslateService,\n} from '@ngx-translate/core'\nimport { ExternalViewerButtonComponent } from '../external-viewer-button/external-viewer-button.component'\nimport {\n  LoadingMaskComponent,\n  PopupAlertComponent,\n} from '../../../../../../libs/ui/widgets/src'\nimport { marker } from '@biesbjerg/ngx-translate-extract-marker'\nimport { FetchError } from '../../../../../../libs/util/data-fetcher/src'\n\nmarker('map.dropdown.placeholder')\nmarker('wfs.feature.limit')\nmarker('dataset.error.restrictedAccess')\nmarker('map.select.style')\n\n@Component({\n  selector: 'gn-ui-map-view',\n  templateUrl: './map-view.component.html',\n  styleUrls: ['./map-view.component.css'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true,\n  imports: [\n    CommonModule,\n    DropdownSelectorComponent,\n    MapContainerComponent,\n    FeatureDetailComponent,\n    PopupAlertComponent,\n    TranslateDirective,\n    TranslatePipe,\n    LoadingMaskComponent,\n    NgIconComponent,\n    ExternalViewerButtonComponent,\n    ButtonComponent,\n    MapLegendComponent,\n  ],\n  viewProviders: [provideIcons({ matClose })],\n})\nexport class MapViewComponent implements AfterViewInit {\n  @Input() set exceedsLimit(value: boolean) {\n    this.excludeWfs$.next(value)\n  }\n  linkFromConfig$ = new BehaviorSubject(null)\n  _selectedChoice = null\n  _styleFromConfig = null\n\n  linkMap: Map<string, DatasetOnlineResource> = new Map()\n  @Input() set selectedView(value: string) {\n    this.selectedView$.next(value)\n  }\n  @Input() set datavizConfig(value: any) {\n    if (value.view === 'map') {\n      this.selectedView$.next(value.view)\n      if (value.styleTMSIndex) {\n        this._styleFromConfig = value.styleTMSIndex\n      }\n      if (value.source) {\n        this.linkFromConfig$.next(value.source)\n      }\n    }\n  }\n  @Input() displaySource = true\n  @Output() linkSelected = new EventEmitter<DatasetOnlineResource>()\n  @Output() styleSelected = new EventEmitter<number>()\n  @ViewChild('mapContainer') mapContainer: MapContainerComponent\n\n  excludeWfs$ = new BehaviorSubject(false)\n  hidePreview = false\n  selection: Feature\n  showLegend = true\n  legendExists = false\n  loading = false\n  error = null\n\n  selectLinkToDisplay(id: string) {\n    this.selectedLinkId$.next(id)\n  }\n\n  selectStyleToDisplay(i: number) {\n    this.selectedStyleId$.next(i)\n    this.styleSelected.emit(i)\n  }\n\n  toggleLegend() {\n    this.showLegend = !this.showLegend\n  }\n  onLegendStatusChange(v: boolean) {\n    this.legendExists = v\n  }\n\n  compatibleMapLinks$ = combineLatest([\n    this.mdViewFacade.mapApiLinks$,\n    this.mdViewFacade.geoDataLinksWithGeometry$,\n  ]).pipe(\n    map(([mapApiLinks, geoDataLinksWithGeometry]) => [\n      ...mapApiLinks,\n      ...geoDataLinksWithGeometry,\n    ]),\n    shareReplay(1)\n  )\n\n  dropdownChoices$ = this.compatibleMapLinks$.pipe(\n    map((links) => {\n      this.linkMap.clear()\n      links.forEach((link: DatasetOnlineResource) =>\n        this.linkMap.set(getLinkId(link), link)\n      )\n      return links.length\n        ? links.map((link) => ({\n            label: getLinkLabel(link),\n            value: getLinkId(link),\n          }))\n        : [{ label: 'map.dropdown.placeholder', value: '' }]\n    })\n  )\n\n  selectedView$ = new BehaviorSubject(null)\n  selectedLinkId$ = new BehaviorSubject(null)\n  selectedStyleId$ = new BehaviorSubject(null)\n\n  selectedSourceLink$ = combineLatest([\n    this.compatibleMapLinks$,\n    this.linkFromConfig$,\n    this.selectedLinkId$.pipe(distinctUntilChanged()),\n    this.selectedView$,\n  ]).pipe(\n    tap(() => {\n      this.error = null\n    }),\n    map(([compatibleLinks, configLink, id, view]) => {\n      if (view === 'map') {\n        if (\n          configLink &&\n          !id &&\n          compatibleLinks.some(\n            (link) => getLinkId(link) === getLinkId(configLink)\n          )\n        ) {\n          this._selectedChoice = getLinkId(configLink)\n          this.linkSelected.emit(configLink)\n          return configLink\n        } else if (id) {\n          this._selectedChoice = id\n          this.linkSelected.emit(this.linkMap.get(id))\n          return this.linkMap.get(id)\n        } else {\n          this.linkSelected.emit(compatibleLinks[0])\n          return compatibleLinks[0]\n        }\n      }\n    })\n  )\n\n  styleLinks$ = this.selectedSourceLink$.pipe(\n    switchMap((src) => {\n      if (\n        src &&\n        src.type === 'service' &&\n        src.accessServiceProtocol === 'tms'\n      ) {\n        return from(\n          // WARNING: when using \"getGeodataLinksFromTms\", make sure to add error handling to prevent the rest of the logic from failing\n          // this may happen when TMS endpoint is in error\n          this.dataService.getGeodataLinksFromTms(\n            src as DatasetServiceDistribution,\n            false\n          )\n        ).pipe(\n          // We need to check for maplibre-style links because when a TMS service has no styles,\n          // getGeodataLinksFromTms returns the original TMS link, which isn't a maplibre-style link\n          map(\n            (links) =>\n              links?.filter(\n                (link) =>\n                  link.type === 'service' &&\n                  link.accessServiceProtocol === 'maplibre-style'\n              ) || []\n          ),\n          catchError((error) => {\n            this.handleError(error)\n            return of(src)\n          })\n        )\n      }\n      return of([])\n    }),\n    tap((styles) => {\n      if (this._styleFromConfig && this._styleFromConfig <= styles.length) {\n        this.selectedStyleId$.next(this._styleFromConfig)\n      } else {\n        this.selectedStyleId$.next(0)\n      }\n    }),\n    shareReplay(1)\n  )\n\n  styleDropdownChoices$ = this.styleLinks$.pipe(\n    map((links) =>\n      links.length\n        ? links.map((link, index) => ({\n            label: getLinkLabel(link),\n            value: index,\n          }))\n        : [\n            {\n              label: '\\u00A0\\u00A0\\u00A0\\u00A0',\n              value: 0,\n            },\n          ]\n    )\n  )\n\n  selectedLink$ = combineLatest([\n    this.selectedSourceLink$,\n    this.styleLinks$,\n    this.selectedStyleId$.pipe(distinctUntilChanged()),\n  ]).pipe(\n    map(([src, styles, styleIdx]) => (styles.length ? styles[styleIdx] : src)),\n    shareReplay(1)\n  )\n\n  currentLayers$ = combineLatest([this.selectedLink$, this.excludeWfs$]).pipe(\n    switchMap(([link, excludeWfs]) => {\n      if (!link) {\n        return of([])\n      }\n      if (excludeWfs && link.accessServiceProtocol === 'wfs') {\n        this.hidePreview = true\n        return of([])\n      }\n      this.hidePreview = false\n      this.loading = true\n      if (link.accessRestricted) {\n        this.handleError('dataset.error.restrictedAccess')\n        return of([])\n      }\n      return this.getLayerFromLink(link).pipe(\n        map((layer) => [layer]),\n        catchError((e) => {\n          this.handleError(e)\n          return of([])\n        }),\n        finalize(() => (this.loading = false))\n      )\n    })\n  )\n\n  mapContext$: Observable<MapContext> = this.currentLayers$.pipe(\n    switchMap((layers) =>\n      from(createViewFromLayer(layers[0])).pipe(\n        catchError(() => of(null)), // could not zoom on the layer: use the record extent\n        map((view) => ({\n          layers,\n          view,\n        })),\n        tap(() => {\n          this.resetSelection()\n        })\n      )\n    ),\n    startWith({\n      layers: [],\n      view: null,\n    }),\n    withLatestFrom(this.mdViewFacade.metadata$),\n    map(([context, metadata]) => {\n      if (context.view) return context\n      const extent = this.mapUtils.getRecordExtent(metadata)\n      const view = extent ? { extent } : null\n      return {\n        ...context,\n        view,\n      }\n    }),\n    shareReplay(1)\n  )\n\n  constructor(\n    private mdViewFacade: MdViewFacade,\n    private mapUtils: MapUtilsService,\n    private dataService: DataService,\n    private changeRef: ChangeDetectorRef,\n    private translateService: TranslateService\n  ) {}\n\n  async ngAfterViewInit() {\n    const map = await this.mapContainer.openlayersMap\n    prioritizePageScroll(map.getInteractions())\n  }\n\n  onMapFeatureSelect(features: Feature[]): void {\n    this.resetSelection()\n    this.selection = features?.length > 0 && features[0]\n    if (this.selection) {\n      // FIXME: restore styling of selected feature\n      // this.selection.setStyle(this.selectionStyle)\n    }\n    this.changeRef.detectChanges()\n  }\n\n  onSourceLoadError(error: SourceLoadErrorEvent) {\n    if (error.httpStatus === 403 || error.httpStatus === 401) {\n      this.error = this.translateService.instant(`dataset.error.forbidden`)\n    } else {\n      this.error = this.translateService.instant(`dataset.error.http`, {\n        info: error.httpStatus,\n      })\n    }\n  }\n\n  resetSelection(): void {\n    if (this.selection) {\n      // FIXME: restore styling of selected feature\n      // this.selection.setStyle(null)\n    }\n    this.selection = null\n  }\n\n  getLayerFromLink(link: DatasetOnlineResource): Observable<MapContextLayer> {\n    if (link.type === 'service' && link.accessServiceProtocol === 'wms') {\n      return of({\n        url: link.url.toString(),\n        type: 'wms',\n        name: link.name,\n      })\n    } else if (\n      link.type === 'service' &&\n      link.accessServiceProtocol === 'tms'\n    ) {\n      // FIXME: here we're assuming that the TMS serves vector tiles only; should be checked with ogc-client first\n      return of({\n        url: link.url.toString().replace(/\\/?$/, '/{z}/{x}/{y}.pbf'),\n        type: 'xyz',\n        tileFormat: 'application/vnd.mapbox-vector-tile',\n        name: link.name,\n      })\n    } else if (\n      link.type === 'service' &&\n      link.accessServiceProtocol === 'maplibre-style'\n    ) {\n      return of({\n        type: 'maplibre-style',\n        name: link.name,\n        styleUrl: link.url.toString(),\n      })\n    } else if (\n      link.type === 'service' &&\n      link.accessServiceProtocol === 'wmts'\n    ) {\n      return of({\n        url: link.url.toString(),\n        type: 'wmts',\n        name: link.name,\n      })\n    } else if (\n      (link.type === 'service' &&\n        (link.accessServiceProtocol === 'wfs' ||\n          link.accessServiceProtocol === 'esriRest' ||\n          link.accessServiceProtocol === 'ogcFeatures')) ||\n      link.type === 'download'\n    ) {\n      const cacheActive = true // TODO implement whether should be true or false\n      return this.dataService.readAsGeoJson(link, cacheActive).pipe(\n        map((data) => ({\n          type: 'geojson',\n          data,\n        }))\n      )\n    }\n    return throwError(() => 'protocol not supported')\n  }\n  handleError(error: FetchError | Error | string) {\n    if (error instanceof FetchError) {\n      this.error = this.translateService.instant(\n        `dataset.error.${error.type}`,\n        {\n          info: error.info,\n        }\n      )\n      console.warn(error.message)\n    } else if (error instanceof Error) {\n      this.error = this.translateService.instant(error.message)\n      console.warn(error.stack || error)\n    } else {\n      this.error = this.translateService.instant(error)\n      console.warn(error)\n    }\n    this.loading = false\n    this.changeRef.detectChanges()\n  }\n}\n","<div class=\"w-full h-full flex flex-col gap-[13px]\">\n  <div\n    class=\"flex flex-col md:flex-row gap-4 py-4 px-5 bg-white border border-color-border rounded-lg mt-6\"\n  >\n    <gn-ui-dropdown-selector\n      *ngIf=\"displaySource\"\n      class=\"w-full md:flex-1 md:min-w-0\"\n      extraBtnClass=\"font-sans font-bold\"\n      [title]=\"'map.select.layer' | translate\"\n      [choices]=\"dropdownChoices$ | async\"\n      [selected]=\"_selectedChoice\"\n      (selectValue)=\"selectLinkToDisplay($event)\"\n    ></gn-ui-dropdown-selector>\n\n    <ng-container *ngIf=\"(styleLinks$ | async)?.length > 0; else styleDisabled\">\n      <gn-ui-dropdown-selector\n        class=\"w-full md:flex-1 md:min-w-0\"\n        extraBtnClass=\"font-sans font-bold\"\n        [title]=\"'map.select.style' | translate\"\n        [choices]=\"styleDropdownChoices$ | async\"\n        [selected]=\"_styleFromConfig\"\n        (selectValue)=\"selectStyleToDisplay($event)\"\n      ></gn-ui-dropdown-selector>\n    </ng-container>\n    <ng-template #styleDisabled>\n      <gn-ui-dropdown-selector\n        class=\"w-full md:flex-1 md:min-w-0 text-gray-400\"\n        extraBtnClass=\"font-sans font-bold text-gray-400\"\n        [title]=\"'map.select.style' | translate\"\n        [choices]=\"styleDropdownChoices$ | async\"\n        [disabled]=\"true\"\n      ></gn-ui-dropdown-selector>\n    </ng-template>\n\n    <div class=\"self-end md:ml-2\">\n      <gn-ui-external-viewer-button\n        extraClass=\"w-[44px] h-[44px]\"\n        [link]=\"selectedLink$ | async\"\n      >\n      </gn-ui-external-viewer-button>\n    </div>\n  </div>\n  <ng-container *ngIf=\"hidePreview; else mapView\">\n    <gn-ui-popup-alert\n      type=\"warning\"\n      icon=\"matErrorOutlineOutline\"\n      class=\"block h-12 p-1\"\n    >\n      <span translate>record.feature.limit</span>\n    </gn-ui-popup-alert>\n  </ng-container>\n  <ng-template #mapView>\n    <div\n      class=\"relative w-full h-full bg-white border border-gray-300 rounded-lg overflow-hidden\"\n    >\n      <gn-ui-map-container\n        #mapContainer\n        [context]=\"mapContext$ | async\"\n        (featuresClick)=\"onMapFeatureSelect($event)\"\n        (sourceLoadError)=\"onSourceLoadError($event)\"\n      ></gn-ui-map-container>\n      <div\n        class=\"top-[1em] right-[1em] p-3 bg-white absolute overflow-y-auto overflow-x-hidden max-h-72 w-56\"\n        [class.hidden]=\"!selection\"\n      >\n        <gn-ui-button\n          type=\"light\"\n          (buttonClick)=\"resetSelection()\"\n          style=\"\n            --gn-ui-button-padding: 0px;\n            --gn-ui-button-width: 24px;\n            --gn-ui-button-height: 24px;\n          \"\n          extraClass=\"absolute right-[0.5em] ml-[8px] mr-[10px]\"\n        >\n          <ng-icon name=\"matClose\" class=\"align-middle text-sm\"></ng-icon>\n        </gn-ui-button>\n        <gn-ui-feature-detail\n          [featureCatalog]=\"mdViewFacade.featureCatalog$ | async\"\n          [feature]=\"selection\"\n        ></gn-ui-feature-detail>\n      </div>\n\n      <div\n        class=\"top-[1em] p-3 bg-white absolute overflow-y-auto overflow-x-hidden max-h-72 w-56\"\n        [ngClass]=\"{ 'right-[1em]': !selection, 'right-[16em]': selection }\"\n        [hidden]=\"!showLegend || !legendExists\"\n      >\n        <div class=\"flex justify-between items-center mb-2\">\n          <div class=\"text-primary font-bold\" translate>map.legend.title</div>\n          <gn-ui-button\n            type=\"light\"\n            (buttonClick)=\"toggleLegend()\"\n            style=\"\n              --gn-ui-button-padding: 0px;\n              --gn-ui-button-width: 24px;\n              --gn-ui-button-height: 24px;\n            \"\n            extraClass=\"ml-[8px] mr-[10px]\"\n          >\n            <ng-icon name=\"matClose\" class=\"align-middle text-sm\"></ng-icon>\n          </gn-ui-button>\n        </div>\n        <gn-ui-map-legend\n          [context]=\"mapContext$ | async\"\n          (legendStatusChange)=\"onLegendStatusChange($event)\"\n        ></gn-ui-map-legend>\n      </div>\n\n      <gn-ui-button\n        *ngIf=\"!showLegend && legendExists && !selection\"\n        type=\"outline\"\n        (buttonClick)=\"toggleLegend()\"\n        extraClass=\"absolute top-[1em] right-[1em] rounded p-1 text-xs bg-white\"\n        translate\n      >\n        map.legend.title\n      </gn-ui-button>\n\n      <gn-ui-loading-mask\n        *ngIf=\"loading\"\n        class=\"absolute inset-0\"\n        [message]=\"'map.loading.data' | translate\"\n      ></gn-ui-loading-mask>\n      <gn-ui-popup-alert\n        *ngIf=\"error\"\n        type=\"warning\"\n        icon=\"matErrorOutlineOutline\"\n        class=\"absolute m-2 inset-0\"\n      >\n        <span translate>{{ error }}</span>\n      </gn-ui-popup-alert>\n    </div>\n  </ng-template>\n</div>\n"]}
338
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"map-view.component.js","sourceRoot":"","sources":["../../../../../../../../libs/feature/record/src/lib/map-view/map-view.component.ts","../../../../../../../../libs/feature/record/src/lib/map-view/map-view.component.html"],"names":[],"mappings":"AAAA,OAAO,EAEL,uBAAuB,EACvB,iBAAiB,EACjB,SAAS,EACT,YAAY,EACZ,KAAK,EACL,MAAM,EACN,SAAS,GACV,MAAM,eAAe,CAAA;AACtB,OAAO,EAAE,eAAe,EAAE,MAAM,wCAAwC,CAAA;AACxE,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,MAAM,wCAAwC,CAAA;AAChF,OAAO,EACL,eAAe,EACf,aAAa,EACb,IAAI,EAEJ,EAAE,EACF,SAAS,EACT,UAAU,EACV,cAAc,GACf,MAAM,MAAM,CAAA;AACb,OAAO,EACL,UAAU,EACV,oBAAoB,EACpB,QAAQ,EACR,GAAG,EACH,WAAW,EACX,SAAS,EAET,GAAG,GACJ,MAAM,gBAAgB,CAAA;AACvB,OAAO,EAAE,YAAY,EAAE,MAAM,wBAAwB,CAAA;AACrD,OAAO,EAAE,WAAW,EAAE,MAAM,4CAA4C,CAAA;AAKxE,OAAO,EACL,mBAAmB,GAIpB,MAAM,sBAAsB,CAAA;AAC7B,OAAO,EACL,sBAAsB,EACtB,qBAAqB,EACrB,kBAAkB,EAClB,oBAAoB,GACrB,MAAM,mCAAmC,CAAA;AAE1C,OAAO,EAAE,eAAe,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAA;AAC9D,OAAO,EAAE,QAAQ,EAAE,MAAM,mCAAmC,CAAA;AAC5D,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAA;AAC9C,OAAO,EACL,eAAe,EACf,yBAAyB,GAC1B,MAAM,sCAAsC,CAAA;AAC7C,OAAO,EACL,kBAAkB,EAClB,aAAa,EACb,gBAAgB,GACjB,MAAM,qBAAqB,CAAA;AAC5B,OAAO,EAAE,6BAA6B,EAAE,MAAM,4DAA4D,CAAA;AAC1G,OAAO,EACL,oBAAoB,EACpB,mBAAmB,GACpB,MAAM,uCAAuC,CAAA;AAC9C,OAAO,EAAE,MAAM,EAAE,MAAM,yCAAyC,CAAA;AAChE,OAAO,EAAE,UAAU,EAAE,MAAM,8CAA8C,CAAA;;;;;;;AAEzE,MAAM,CAAC,0BAA0B,CAAC,CAAA;AAClC,MAAM,CAAC,mBAAmB,CAAC,CAAA;AAC3B,MAAM,CAAC,gCAAgC,CAAC,CAAA;AACxC,MAAM,CAAC,kBAAkB,CAAC,CAAA;AAwB1B,MAAM,OAAO,gBAAgB;IAC3B,IAAa,YAAY,CAAC,KAAc;QACtC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,KAAK,CAAC,CAAA;IAC9B,CAAC;IAMD,IAAa,YAAY,CAAC,KAAa;QACrC,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,KAAK,CAAC,CAAA;IAChC,CAAC;IACD,IAAa,aAAa,CAAC,KAAU;QACnC,IAAI,KAAK,CAAC,IAAI,KAAK,KAAK,EAAE,CAAC;YACzB,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAA;YACnC,IAAI,KAAK,CAAC,aAAa,EAAE,CAAC;gBACxB,IAAI,CAAC,gBAAgB,GAAG,KAAK,CAAC,aAAa,CAAA;YAC7C,CAAC;YACD,IAAI,KAAK,CAAC,MAAM,EAAE,CAAC;gBACjB,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,CAAA;YACzC,CAAC;QACH,CAAC;IACH,CAAC;IAcD,mBAAmB,CAAC,EAAU;QAC5B,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,EAAE,CAAC,CAAA;IAC/B,CAAC;IAED,oBAAoB,CAAC,CAAS;QAC5B,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,CAAC,CAAC,CAAA;QAC7B,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC,CAAC,CAAA;IAC5B,CAAC;IAED,YAAY;QACV,IAAI,CAAC,UAAU,GAAG,CAAC,IAAI,CAAC,UAAU,CAAA;IACpC,CAAC;IACD,oBAAoB,CAAC,CAAU;QAC7B,IAAI,CAAC,YAAY,GAAG,CAAC,CAAA;IACvB,CAAC;IA6LD,YACU,YAA0B,EAC1B,QAAyB,EACzB,WAAwB,EACxB,SAA4B,EAC5B,gBAAkC;QAJlC,iBAAY,GAAZ,YAAY,CAAc;QAC1B,aAAQ,GAAR,QAAQ,CAAiB;QACzB,gBAAW,GAAX,WAAW,CAAa;QACxB,cAAS,GAAT,SAAS,CAAmB;QAC5B,qBAAgB,GAAhB,gBAAgB,CAAkB;QAhP5C,oBAAe,GAAG,IAAI,eAAe,CAAC,IAAI,CAAC,CAAA;QAC3C,oBAAe,GAAG,IAAI,CAAA;QACtB,qBAAgB,GAAG,IAAI,CAAA;QAEvB,YAAO,GAAuC,IAAI,GAAG,EAAE,CAAA;QAe9C,kBAAa,GAAG,IAAI,CAAA;QACnB,iBAAY,GAAG,IAAI,YAAY,EAAyB,CAAA;QACxD,kBAAa,GAAG,IAAI,YAAY,EAAU,CAAA;QAGpD,gBAAW,GAAG,IAAI,eAAe,CAAC,KAAK,CAAC,CAAA;QACxC,gBAAW,GAAG,KAAK,CAAA;QAEnB,eAAU,GAAG,IAAI,CAAA;QACjB,iBAAY,GAAG,KAAK,CAAA;QACpB,YAAO,GAAG,KAAK,CAAA;QACf,UAAK,GAAG,IAAI,CAAA;QAkBZ,wBAAmB,GAAG,aAAa,CAAC;YAClC,IAAI,CAAC,YAAY,CAAC,YAAY;YAC9B,IAAI,CAAC,YAAY,CAAC,yBAAyB;SAC5C,CAAC,CAAC,IAAI,CACL,GAAG,CAAC,CAAC,CAAC,WAAW,EAAE,wBAAwB,CAAC,EAAE,EAAE,CAAC;YAC/C,GAAG,WAAW;YACd,GAAG,wBAAwB;SAC5B,CAAC,EACF,WAAW,CAAC,CAAC,CAAC,CACf,CAAA;QAED,qBAAgB,GAAG,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAC9C,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE;YACZ,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,CAAA;YACpB,KAAK,CAAC,OAAO,CAAC,CAAC,IAA2B,EAAE,EAAE,CAC5C,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,SAAS,CAAC,IAAI,CAAC,EAAE,IAAI,CAAC,CACxC,CAAA;YACD,OAAO,KAAK,CAAC,MAAM;gBACjB,CAAC,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC;oBACnB,KAAK,EAAE,YAAY,CAAC,IAAI,CAAC;oBACzB,KAAK,EAAE,SAAS,CAAC,IAAI,CAAC;iBACvB,CAAC,CAAC;gBACL,CAAC,CAAC,CAAC,EAAE,KAAK,EAAE,0BAA0B,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC,CAAA;QACxD,CAAC,CAAC,CACH,CAAA;QAED,kBAAa,GAAG,IAAI,eAAe,CAAC,IAAI,CAAC,CAAA;QACzC,oBAAe,GAAG,IAAI,eAAe,CAAC,IAAI,CAAC,CAAA;QAC3C,qBAAgB,GAAG,IAAI,eAAe,CAAC,IAAI,CAAC,CAAA;QAE5C,wBAAmB,GAAG,aAAa,CAAC;YAClC,IAAI,CAAC,mBAAmB;YACxB,IAAI,CAAC,eAAe;YACpB,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,oBAAoB,EAAE,CAAC;YACjD,IAAI,CAAC,aAAa;SACnB,CAAC,CAAC,IAAI,CACL,GAAG,CAAC,GAAG,EAAE;YACP,IAAI,CAAC,KAAK,GAAG,IAAI,CAAA;QACnB,CAAC,CAAC,EACF,GAAG,CAAC,CAAC,CAAC,eAAe,EAAE,UAAU,EAAE,EAAE,EAAE,IAAI,CAAC,EAAE,EAAE;YAC9C,IAAI,IAAI,KAAK,KAAK,EAAE,CAAC;gBACnB,IACE,UAAU;oBACV,CAAC,EAAE;oBACH,eAAe,CAAC,IAAI,CAClB,CAAC,IAAI,EAAE,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,KAAK,SAAS,CAAC,UAAU,CAAC,CACpD,EACD,CAAC;oBACD,IAAI,CAAC,eAAe,GAAG,SAAS,CAAC,UAAU,CAAC,CAAA;oBAC5C,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,UAAU,CAAC,CAAA;oBAClC,OAAO,UAAU,CAAA;gBACnB,CAAC;qBAAM,IAAI,EAAE,EAAE,CAAC;oBACd,IAAI,CAAC,eAAe,GAAG,EAAE,CAAA;oBACzB,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,CAAA;oBAC5C,OAAO,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC,CAAA;gBAC7B,CAAC;qBAAM,CAAC;oBACN,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC,CAAC,CAAC,CAAA;oBAC1C,OAAO,eAAe,CAAC,CAAC,CAAC,CAAA;gBAC3B,CAAC;YACH,CAAC;QACH,CAAC,CAAC,CACH,CAAA;QAED,gBAAW,GAAG,IAAI,CAAC,mBAAmB,CAAC,IAAI,CACzC,SAAS,CAAC,CAAC,GAAG,EAAE,EAAE;YAChB,IACE,GAAG;gBACH,GAAG,CAAC,IAAI,KAAK,SAAS;gBACtB,GAAG,CAAC,qBAAqB,KAAK,KAAK,EACnC,CAAC;gBACD,OAAO,IAAI;gBACT,8HAA8H;gBAC9H,gDAAgD;gBAChD,IAAI,CAAC,WAAW,CAAC,sBAAsB,CACrC,GAAiC,EACjC,KAAK,CACN,CACF,CAAC,IAAI;gBACJ,sFAAsF;gBACtF,0FAA0F;gBAC1F,GAAG,CACD,CAAC,KAAK,EAAE,EAAE,CACR,KAAK,EAAE,MAAM,CACX,CAAC,IAAI,EAAE,EAAE,CACP,IAAI,CAAC,IAAI,KAAK,SAAS;oBACvB,IAAI,CAAC,qBAAqB,KAAK,gBAAgB,CAClD,IAAI,EAAE,CACV,EACD,UAAU,CAAC,CAAC,KAAK,EAAE,EAAE;oBACnB,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,CAAA;oBACvB,OAAO,EAAE,CAAC,GAAG,CAAC,CAAA;gBAChB,CAAC,CAAC,CACH,CAAA;YACH,CAAC;YACD,OAAO,EAAE,CAAC,EAAE,CAAC,CAAA;QACf,CAAC,CAAC,EACF,GAAG,CAAC,CAAC,MAAM,EAAE,EAAE;YACb,IAAI,IAAI,CAAC,gBAAgB,IAAI,IAAI,CAAC,gBAAgB,IAAI,MAAM,CAAC,MAAM,EAAE,CAAC;gBACpE,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAA;YACnD,CAAC;iBAAM,CAAC;gBACN,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,CAAC,CAAC,CAAA;YAC/B,CAAC;QACH,CAAC,CAAC,EACF,WAAW,CAAC,CAAC,CAAC,CACf,CAAA;QAED,0BAAqB,GAAG,IAAI,CAAC,WAAW,CAAC,IAAI,CAC3C,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CACZ,KAAK,CAAC,MAAM;YACV,CAAC,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,KAAK,EAAE,EAAE,CAAC,CAAC;gBAC1B,KAAK,EAAE,YAAY,CAAC,IAAI,CAAC;gBACzB,KAAK,EAAE,KAAK;aACb,CAAC,CAAC;YACL,CAAC,CAAC;gBACE;oBACE,KAAK,EAAE,0BAA0B;oBACjC,KAAK,EAAE,CAAC;iBACT;aACF,CACN,CACF,CAAA;QAED,kBAAa,GAAG,aAAa,CAAC;YAC5B,IAAI,CAAC,mBAAmB;YACxB,IAAI,CAAC,WAAW;YAChB,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,oBAAoB,EAAE,CAAC;SACnD,CAAC,CAAC,IAAI,CACL,GAAG,CAAC,CAAC,CAAC,GAAG,EAAE,MAAM,EAAE,QAAQ,CAAC,EAAE,EAAE,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,EAC1E,WAAW,CAAC,CAAC,CAAC,CACf,CAAA;QAED,mBAAc,GAAG,aAAa,CAAC,CAAC,IAAI,CAAC,aAAa,EAAE,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,IAAI,CACzE,SAAS,CAAC,CAAC,CAAC,IAAI,EAAE,UAAU,CAAC,EAAE,EAAE;YAC/B,IAAI,CAAC,IAAI,EAAE,CAAC;gBACV,OAAO,EAAE,CAAC,EAAE,CAAC,CAAA;YACf,CAAC;YACD,IAAI,UAAU,IAAI,IAAI,CAAC,qBAAqB,KAAK,KAAK,EAAE,CAAC;gBACvD,IAAI,CAAC,WAAW,GAAG,IAAI,CAAA;gBACvB,OAAO,EAAE,CAAC,EAAE,CAAC,CAAA;YACf,CAAC;YACD,IAAI,CAAC,WAAW,GAAG,KAAK,CAAA;YACxB,IAAI,CAAC,OAAO,GAAG,IAAI,CAAA;YACnB,IAAI,IAAI,CAAC,gBAAgB,EAAE,CAAC;gBAC1B,IAAI,CAAC,WAAW,CAAC,gCAAgC,CAAC,CAAA;gBAClD,OAAO,EAAE,CAAC,EAAE,CAAC,CAAA;YACf,CAAC;YACD,OAAO,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,CAAC,IAAI,CACrC,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,EACvB,UAAU,CAAC,CAAC,CAAC,EAAE,EAAE;gBACf,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,CAAA;gBACnB,OAAO,EAAE,CAAC,EAAE,CAAC,CAAA;YACf,CAAC,CAAC,EACF,QAAQ,CAAC,GAAG,EAAE,CAAC,CAAC,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC,CAAC,CACvC,CAAA;QACH,CAAC,CAAC,CACH,CAAA;QAED,gBAAW,GAA2B,IAAI,CAAC,cAAc,CAAC,IAAI,CAC5D,SAAS,CAAC,CAAC,MAAM,EAAE,EAAE,CACnB,IAAI,CAAC,mBAAmB,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CACvC,UAAU,CAAC,GAAG,EAAE,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,EAAE,qDAAqD;QACjF,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC;YACb,MAAM;YACN,IAAI;SACL,CAAC,CAAC,EACH,GAAG,CAAC,GAAG,EAAE;YACP,IAAI,CAAC,cAAc,EAAE,CAAA;QACvB,CAAC,CAAC,CACH,CACF,EACD,SAAS,CAAC;YACR,MAAM,EAAE,EAAE;YACV,IAAI,EAAE,IAAI;SACX,CAAC,EACF,cAAc,CAAC,IAAI,CAAC,YAAY,CAAC,SAAS,CAAC,EAC3C,GAAG,CAAC,CAAC,CAAC,OAAO,EAAE,QAAQ,CAAC,EAAE,EAAE;YAC1B,IAAI,OAAO,CAAC,IAAI;gBAAE,OAAO,OAAO,CAAA;YAChC,MAAM,MAAM,GAAG,IAAI,CAAC,QAAQ,CAAC,eAAe,CAAC,QAAQ,CAAC,CAAA;YACtD,MAAM,IAAI,GAAG,MAAM,CAAC,CAAC,CAAC,EAAE,MAAM,EAAE,CAAC,CAAC,CAAC,IAAI,CAAA;YACvC,OAAO;gBACL,GAAG,OAAO;gBACV,IAAI;aACL,CAAA;QACH,CAAC,CAAC,EACF,WAAW,CAAC,CAAC,CAAC,CACf,CAAA;IAQE,CAAC;IAEJ,KAAK,CAAC,eAAe;QACnB,MAAM,GAAG,GAAG,MAAM,IAAI,CAAC,YAAY,CAAC,aAAa,CAAA;QACjD,oBAAoB,CAAC,GAAG,CAAC,eAAe,EAAE,CAAC,CAAA;IAC7C,CAAC;IAED,kBAAkB,CAAC,QAAmB;QACpC,IAAI,CAAC,cAAc,EAAE,CAAA;QACrB,IAAI,CAAC,SAAS,GAAG,QAAQ,EAAE,MAAM,GAAG,CAAC,IAAI,QAAQ,CAAC,CAAC,CAAC,CAAA;QACpD,IAAI,IAAI,CAAC,SAAS,EAAE,CAAC;YACnB,6CAA6C;YAC7C,+CAA+C;QACjD,CAAC;QACD,IAAI,CAAC,SAAS,CAAC,aAAa,EAAE,CAAA;IAChC,CAAC;IAED,iBAAiB,CAAC,KAA2B;QAC3C,IAAI,KAAK,CAAC,UAAU,KAAK,GAAG,IAAI,KAAK,CAAC,UAAU,KAAK,GAAG,EAAE,CAAC;YACzD,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,gBAAgB,CAAC,OAAO,CAAC,yBAAyB,CAAC,CAAA;QACvE,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,gBAAgB,CAAC,OAAO,CAAC,oBAAoB,EAAE;gBAC/D,IAAI,EAAE,KAAK,CAAC,UAAU;aACvB,CAAC,CAAA;QACJ,CAAC;IACH,CAAC;IAED,cAAc;QACZ,IAAI,IAAI,CAAC,SAAS,EAAE,CAAC;YACnB,6CAA6C;YAC7C,gCAAgC;QAClC,CAAC;QACD,IAAI,CAAC,SAAS,GAAG,IAAI,CAAA;IACvB,CAAC;IAED,gBAAgB,CAAC,IAA2B;QAC1C,IAAI,IAAI,CAAC,IAAI,KAAK,SAAS,IAAI,IAAI,CAAC,qBAAqB,KAAK,KAAK,EAAE,CAAC;YACpE,OAAO,EAAE,CAAC;gBACR,GAAG,EAAE,IAAI,CAAC,GAAG,CAAC,QAAQ,EAAE;gBACxB,IAAI,EAAE,KAAK;gBACX,IAAI,EAAE,IAAI,CAAC,IAAI;aAChB,CAAC,CAAA;QACJ,CAAC;aAAM,IACL,IAAI,CAAC,IAAI,KAAK,SAAS;YACvB,IAAI,CAAC,qBAAqB,KAAK,KAAK,EACpC,CAAC;YACD,4GAA4G;YAC5G,OAAO,EAAE,CAAC;gBACR,GAAG,EAAE,IAAI,CAAC,GAAG;qBACV,QAAQ,EAAE;qBACV,OAAO,CAAC,MAAM,EAAE,IAAI,IAAI,CAAC,IAAI,kBAAkB,CAAC;gBACnD,IAAI,EAAE,KAAK;gBACX,UAAU,EAAE,oCAAoC;gBAChD,IAAI,EAAE,IAAI,CAAC,IAAI;aAChB,CAAC,CAAA;QACJ,CAAC;aAAM,IACL,IAAI,CAAC,IAAI,KAAK,SAAS;YACvB,IAAI,CAAC,qBAAqB,KAAK,gBAAgB,EAC/C,CAAC;YACD,OAAO,EAAE,CAAC;gBACR,IAAI,EAAE,gBAAgB;gBACtB,IAAI,EAAE,IAAI,CAAC,IAAI;gBACf,QAAQ,EAAE,IAAI,CAAC,GAAG,CAAC,QAAQ,EAAE;aAC9B,CAAC,CAAA;QACJ,CAAC;aAAM,IACL,IAAI,CAAC,IAAI,KAAK,SAAS;YACvB,IAAI,CAAC,qBAAqB,KAAK,MAAM,EACrC,CAAC;YACD,OAAO,EAAE,CAAC;gBACR,GAAG,EAAE,IAAI,CAAC,GAAG,CAAC,QAAQ,EAAE;gBACxB,IAAI,EAAE,MAAM;gBACZ,IAAI,EAAE,IAAI,CAAC,IAAI;aAChB,CAAC,CAAA;QACJ,CAAC;aAAM,IACL,CAAC,IAAI,CAAC,IAAI,KAAK,SAAS;YACtB,CAAC,IAAI,CAAC,qBAAqB,KAAK,KAAK;gBACnC,IAAI,CAAC,qBAAqB,KAAK,UAAU;gBACzC,IAAI,CAAC,qBAAqB,KAAK,aAAa,CAAC,CAAC;YAClD,IAAI,CAAC,IAAI,KAAK,UAAU,EACxB,CAAC;YACD,MAAM,WAAW,GAAG,IAAI,CAAA,CAAC,iDAAiD;YAC1E,OAAO,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,IAAI,EAAE,WAAW,CAAC,CAAC,IAAI,CAC3D,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC;gBACb,IAAI,EAAE,SAAS;gBACf,IAAI;aACL,CAAC,CAAC,CACJ,CAAA;QACH,CAAC;QACD,OAAO,UAAU,CAAC,GAAG,EAAE,CAAC,wBAAwB,CAAC,CAAA;IACnD,CAAC;IACD,WAAW,CAAC,KAAkC;QAC5C,IAAI,KAAK,YAAY,UAAU,EAAE,CAAC;YAChC,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,gBAAgB,CAAC,OAAO,CACxC,iBAAiB,KAAK,CAAC,IAAI,EAAE,EAC7B;gBACE,IAAI,EAAE,KAAK,CAAC,IAAI;aACjB,CACF,CAAA;YACD,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAA;QAC7B,CAAC;aAAM,IAAI,KAAK,YAAY,KAAK,EAAE,CAAC;YAClC,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,gBAAgB,CAAC,OAAO,CAAC,KAAK,CAAC,OAAO,CAAC,CAAA;YACzD,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,IAAI,KAAK,CAAC,CAAA;QACpC,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,gBAAgB,CAAC,OAAO,CAAC,KAAK,CAAC,CAAA;YACjD,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,CAAA;QACrB,CAAC;QACD,IAAI,CAAC,OAAO,GAAG,KAAK,CAAA;QACpB,IAAI,CAAC,SAAS,CAAC,aAAa,EAAE,CAAA;IAChC,CAAC;+GAjWU,gBAAgB;mGAAhB,gBAAgB,2YClG7B,4wJAuIA,yDDpDI,YAAY,sRACZ,yBAAyB,qNACzB,qBAAqB,iKACrB,sBAAsB,wGACtB,mBAAmB,oGACnB,kBAAkB,6GAClB,aAAa,kDACb,oBAAoB,oFACpB,eAAe,6GACf,6BAA6B,yGAC7B,eAAe,+HACf,kBAAkB,wGAEL,CAAC,YAAY,CAAC,EAAE,QAAQ,EAAE,CAAC,CAAC;;4FAEhC,gBAAgB;kBAtB5B,SAAS;+BACE,gBAAgB,mBAGT,uBAAuB,CAAC,MAAM,cACnC,IAAI,WACP;wBACP,YAAY;wBACZ,yBAAyB;wBACzB,qBAAqB;wBACrB,sBAAsB;wBACtB,mBAAmB;wBACnB,kBAAkB;wBAClB,aAAa;wBACb,oBAAoB;wBACpB,eAAe;wBACf,6BAA6B;wBAC7B,eAAe;wBACf,kBAAkB;qBACnB,iBACc,CAAC,YAAY,CAAC,EAAE,QAAQ,EAAE,CAAC,CAAC;wMAG9B,YAAY;sBAAxB,KAAK;gBAQO,YAAY;sBAAxB,KAAK;gBAGO,aAAa;sBAAzB,KAAK;gBAWG,aAAa;sBAArB,KAAK;gBACI,YAAY;sBAArB,MAAM;gBACG,aAAa;sBAAtB,MAAM;gBACoB,YAAY;sBAAtC,SAAS;uBAAC,cAAc","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  Input,\n  Output,\n  ViewChild,\n} from '@angular/core'\nimport { MapUtilsService } from '../../../../../../libs/feature/map/src'\nimport { getLinkId, getLinkLabel } from '../../../../../../libs/util/shared/src'\nimport {\n  BehaviorSubject,\n  combineLatest,\n  from,\n  Observable,\n  of,\n  startWith,\n  throwError,\n  withLatestFrom,\n} from 'rxjs'\nimport {\n  catchError,\n  distinctUntilChanged,\n  finalize,\n  map,\n  shareReplay,\n  switchMap,\n  take,\n  tap,\n} from 'rxjs/operators'\nimport { MdViewFacade } from '../state/mdview.facade'\nimport { DataService } from '../../../../../../libs/feature/dataviz/src'\nimport {\n  DatasetOnlineResource,\n  DatasetServiceDistribution,\n} from '../../../../../../libs/common/domain/src/lib/model/record'\nimport {\n  createViewFromLayer,\n  MapContext,\n  MapContextLayer,\n  SourceLoadErrorEvent,\n} from '@geospatial-sdk/core'\nimport {\n  FeatureDetailComponent,\n  MapContainerComponent,\n  MapLegendComponent,\n  prioritizePageScroll,\n} from '../../../../../../libs/ui/map/src'\nimport { Feature } from 'geojson'\nimport { NgIconComponent, provideIcons } from '@ng-icons/core'\nimport { matClose } from '@ng-icons/material-icons/baseline'\nimport { CommonModule } from '@angular/common'\nimport {\n  ButtonComponent,\n  DropdownSelectorComponent,\n} from '../../../../../../libs/ui/inputs/src'\nimport {\n  TranslateDirective,\n  TranslatePipe,\n  TranslateService,\n} from '@ngx-translate/core'\nimport { ExternalViewerButtonComponent } from '../external-viewer-button/external-viewer-button.component'\nimport {\n  LoadingMaskComponent,\n  PopupAlertComponent,\n} from '../../../../../../libs/ui/widgets/src'\nimport { marker } from '@biesbjerg/ngx-translate-extract-marker'\nimport { FetchError } from '../../../../../../libs/util/data-fetcher/src'\n\nmarker('map.dropdown.placeholder')\nmarker('wfs.feature.limit')\nmarker('dataset.error.restrictedAccess')\nmarker('map.select.style')\n\n@Component({\n  selector: 'gn-ui-map-view',\n  templateUrl: './map-view.component.html',\n  styleUrls: ['./map-view.component.css'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true,\n  imports: [\n    CommonModule,\n    DropdownSelectorComponent,\n    MapContainerComponent,\n    FeatureDetailComponent,\n    PopupAlertComponent,\n    TranslateDirective,\n    TranslatePipe,\n    LoadingMaskComponent,\n    NgIconComponent,\n    ExternalViewerButtonComponent,\n    ButtonComponent,\n    MapLegendComponent,\n  ],\n  viewProviders: [provideIcons({ matClose })],\n})\nexport class MapViewComponent implements AfterViewInit {\n  @Input() set exceedsLimit(value: boolean) {\n    this.excludeWfs$.next(value)\n  }\n  linkFromConfig$ = new BehaviorSubject(null)\n  _selectedChoice = null\n  _styleFromConfig = null\n\n  linkMap: Map<string, DatasetOnlineResource> = new Map()\n  @Input() set selectedView(value: string) {\n    this.selectedView$.next(value)\n  }\n  @Input() set datavizConfig(value: any) {\n    if (value.view === 'map') {\n      this.selectedView$.next(value.view)\n      if (value.styleTMSIndex) {\n        this._styleFromConfig = value.styleTMSIndex\n      }\n      if (value.source) {\n        this.linkFromConfig$.next(value.source)\n      }\n    }\n  }\n  @Input() displaySource = true\n  @Output() linkSelected = new EventEmitter<DatasetOnlineResource>()\n  @Output() styleSelected = new EventEmitter<number>()\n  @ViewChild('mapContainer') mapContainer: MapContainerComponent\n\n  excludeWfs$ = new BehaviorSubject(false)\n  hidePreview = false\n  selection: Feature\n  showLegend = true\n  legendExists = false\n  loading = false\n  error = null\n\n  selectLinkToDisplay(id: string) {\n    this.selectedLinkId$.next(id)\n  }\n\n  selectStyleToDisplay(i: number) {\n    this.selectedStyleId$.next(i)\n    this.styleSelected.emit(i)\n  }\n\n  toggleLegend() {\n    this.showLegend = !this.showLegend\n  }\n  onLegendStatusChange(v: boolean) {\n    this.legendExists = v\n  }\n\n  compatibleMapLinks$ = combineLatest([\n    this.mdViewFacade.mapApiLinks$,\n    this.mdViewFacade.geoDataLinksWithGeometry$,\n  ]).pipe(\n    map(([mapApiLinks, geoDataLinksWithGeometry]) => [\n      ...mapApiLinks,\n      ...geoDataLinksWithGeometry,\n    ]),\n    shareReplay(1)\n  )\n\n  dropdownChoices$ = this.compatibleMapLinks$.pipe(\n    map((links) => {\n      this.linkMap.clear()\n      links.forEach((link: DatasetOnlineResource) =>\n        this.linkMap.set(getLinkId(link), link)\n      )\n      return links.length\n        ? links.map((link) => ({\n            label: getLinkLabel(link),\n            value: getLinkId(link),\n          }))\n        : [{ label: 'map.dropdown.placeholder', value: '' }]\n    })\n  )\n\n  selectedView$ = new BehaviorSubject(null)\n  selectedLinkId$ = new BehaviorSubject(null)\n  selectedStyleId$ = new BehaviorSubject(null)\n\n  selectedSourceLink$ = combineLatest([\n    this.compatibleMapLinks$,\n    this.linkFromConfig$,\n    this.selectedLinkId$.pipe(distinctUntilChanged()),\n    this.selectedView$,\n  ]).pipe(\n    tap(() => {\n      this.error = null\n    }),\n    map(([compatibleLinks, configLink, id, view]) => {\n      if (view === 'map') {\n        if (\n          configLink &&\n          !id &&\n          compatibleLinks.some(\n            (link) => getLinkId(link) === getLinkId(configLink)\n          )\n        ) {\n          this._selectedChoice = getLinkId(configLink)\n          this.linkSelected.emit(configLink)\n          return configLink\n        } else if (id) {\n          this._selectedChoice = id\n          this.linkSelected.emit(this.linkMap.get(id))\n          return this.linkMap.get(id)\n        } else {\n          this.linkSelected.emit(compatibleLinks[0])\n          return compatibleLinks[0]\n        }\n      }\n    })\n  )\n\n  styleLinks$ = this.selectedSourceLink$.pipe(\n    switchMap((src) => {\n      if (\n        src &&\n        src.type === 'service' &&\n        src.accessServiceProtocol === 'tms'\n      ) {\n        return from(\n          // WARNING: when using \"getGeodataLinksFromTms\", make sure to add error handling to prevent the rest of the logic from failing\n          // this may happen when TMS endpoint is in error\n          this.dataService.getGeodataLinksFromTms(\n            src as DatasetServiceDistribution,\n            false\n          )\n        ).pipe(\n          // We need to check for maplibre-style links because when a TMS service has no styles,\n          // getGeodataLinksFromTms returns the original TMS link, which isn't a maplibre-style link\n          map(\n            (links) =>\n              links?.filter(\n                (link) =>\n                  link.type === 'service' &&\n                  link.accessServiceProtocol === 'maplibre-style'\n              ) || []\n          ),\n          catchError((error) => {\n            this.handleError(error)\n            return of(src)\n          })\n        )\n      }\n      return of([])\n    }),\n    tap((styles) => {\n      if (this._styleFromConfig && this._styleFromConfig <= styles.length) {\n        this.selectedStyleId$.next(this._styleFromConfig)\n      } else {\n        this.selectedStyleId$.next(0)\n      }\n    }),\n    shareReplay(1)\n  )\n\n  styleDropdownChoices$ = this.styleLinks$.pipe(\n    map((links) =>\n      links.length\n        ? links.map((link, index) => ({\n            label: getLinkLabel(link),\n            value: index,\n          }))\n        : [\n            {\n              label: '\\u00A0\\u00A0\\u00A0\\u00A0',\n              value: 0,\n            },\n          ]\n    )\n  )\n\n  selectedLink$ = combineLatest([\n    this.selectedSourceLink$,\n    this.styleLinks$,\n    this.selectedStyleId$.pipe(distinctUntilChanged()),\n  ]).pipe(\n    map(([src, styles, styleIdx]) => (styles.length ? styles[styleIdx] : src)),\n    shareReplay(1)\n  )\n\n  currentLayers$ = combineLatest([this.selectedLink$, this.excludeWfs$]).pipe(\n    switchMap(([link, excludeWfs]) => {\n      if (!link) {\n        return of([])\n      }\n      if (excludeWfs && link.accessServiceProtocol === 'wfs') {\n        this.hidePreview = true\n        return of([])\n      }\n      this.hidePreview = false\n      this.loading = true\n      if (link.accessRestricted) {\n        this.handleError('dataset.error.restrictedAccess')\n        return of([])\n      }\n      return this.getLayerFromLink(link).pipe(\n        map((layer) => [layer]),\n        catchError((e) => {\n          this.handleError(e)\n          return of([])\n        }),\n        finalize(() => (this.loading = false))\n      )\n    })\n  )\n\n  mapContext$: Observable<MapContext> = this.currentLayers$.pipe(\n    switchMap((layers) =>\n      from(createViewFromLayer(layers[0])).pipe(\n        catchError(() => of(null)), // could not zoom on the layer: use the record extent\n        map((view) => ({\n          layers,\n          view,\n        })),\n        tap(() => {\n          this.resetSelection()\n        })\n      )\n    ),\n    startWith({\n      layers: [],\n      view: null,\n    }),\n    withLatestFrom(this.mdViewFacade.metadata$),\n    map(([context, metadata]) => {\n      if (context.view) return context\n      const extent = this.mapUtils.getRecordExtent(metadata)\n      const view = extent ? { extent } : null\n      return {\n        ...context,\n        view,\n      }\n    }),\n    shareReplay(1)\n  )\n\n  constructor(\n    private mdViewFacade: MdViewFacade,\n    private mapUtils: MapUtilsService,\n    private dataService: DataService,\n    private changeRef: ChangeDetectorRef,\n    private translateService: TranslateService\n  ) {}\n\n  async ngAfterViewInit() {\n    const map = await this.mapContainer.openlayersMap\n    prioritizePageScroll(map.getInteractions())\n  }\n\n  onMapFeatureSelect(features: Feature[]): void {\n    this.resetSelection()\n    this.selection = features?.length > 0 && features[0]\n    if (this.selection) {\n      // FIXME: restore styling of selected feature\n      // this.selection.setStyle(this.selectionStyle)\n    }\n    this.changeRef.detectChanges()\n  }\n\n  onSourceLoadError(error: SourceLoadErrorEvent) {\n    if (error.httpStatus === 403 || error.httpStatus === 401) {\n      this.error = this.translateService.instant(`dataset.error.forbidden`)\n    } else {\n      this.error = this.translateService.instant(`dataset.error.http`, {\n        info: error.httpStatus,\n      })\n    }\n  }\n\n  resetSelection(): void {\n    if (this.selection) {\n      // FIXME: restore styling of selected feature\n      // this.selection.setStyle(null)\n    }\n    this.selection = null\n  }\n\n  getLayerFromLink(link: DatasetOnlineResource): Observable<MapContextLayer> {\n    if (link.type === 'service' && link.accessServiceProtocol === 'wms') {\n      return of({\n        url: link.url.toString(),\n        type: 'wms',\n        name: link.name,\n      })\n    } else if (\n      link.type === 'service' &&\n      link.accessServiceProtocol === 'tms'\n    ) {\n      // FIXME: here we're assuming that the TMS serves vector tiles only; should be checked with ogc-client first\n      return of({\n        url: link.url\n          .toString()\n          .replace(/\\/?$/, `/${link.name}/{z}/{x}/{y}.pbf`),\n        type: 'xyz',\n        tileFormat: 'application/vnd.mapbox-vector-tile',\n        name: link.name,\n      })\n    } else if (\n      link.type === 'service' &&\n      link.accessServiceProtocol === 'maplibre-style'\n    ) {\n      return of({\n        type: 'maplibre-style',\n        name: link.name,\n        styleUrl: link.url.toString(),\n      })\n    } else if (\n      link.type === 'service' &&\n      link.accessServiceProtocol === 'wmts'\n    ) {\n      return of({\n        url: link.url.toString(),\n        type: 'wmts',\n        name: link.name,\n      })\n    } else if (\n      (link.type === 'service' &&\n        (link.accessServiceProtocol === 'wfs' ||\n          link.accessServiceProtocol === 'esriRest' ||\n          link.accessServiceProtocol === 'ogcFeatures')) ||\n      link.type === 'download'\n    ) {\n      const cacheActive = true // TODO implement whether should be true or false\n      return this.dataService.readAsGeoJson(link, cacheActive).pipe(\n        map((data) => ({\n          type: 'geojson',\n          data,\n        }))\n      )\n    }\n    return throwError(() => 'protocol not supported')\n  }\n  handleError(error: FetchError | Error | string) {\n    if (error instanceof FetchError) {\n      this.error = this.translateService.instant(\n        `dataset.error.${error.type}`,\n        {\n          info: error.info,\n        }\n      )\n      console.warn(error.message)\n    } else if (error instanceof Error) {\n      this.error = this.translateService.instant(error.message)\n      console.warn(error.stack || error)\n    } else {\n      this.error = this.translateService.instant(error)\n      console.warn(error)\n    }\n    this.loading = false\n    this.changeRef.detectChanges()\n  }\n}\n","<div class=\"w-full h-full flex flex-col gap-[13px]\">\n  <div\n    class=\"flex flex-col md:flex-row gap-4 py-4 px-5 bg-white border border-color-border rounded-lg mt-6\"\n  >\n    <gn-ui-dropdown-selector\n      *ngIf=\"displaySource\"\n      class=\"w-full md:flex-1 md:min-w-0\"\n      extraBtnClass=\"font-sans font-bold\"\n      [title]=\"'map.select.layer' | translate\"\n      [choices]=\"dropdownChoices$ | async\"\n      [selected]=\"_selectedChoice\"\n      (selectValue)=\"selectLinkToDisplay($event)\"\n    ></gn-ui-dropdown-selector>\n\n    <ng-container *ngIf=\"(styleLinks$ | async)?.length > 0; else styleDisabled\">\n      <gn-ui-dropdown-selector\n        class=\"w-full md:flex-1 md:min-w-0\"\n        extraBtnClass=\"font-sans font-bold\"\n        [title]=\"'map.select.style' | translate\"\n        [choices]=\"styleDropdownChoices$ | async\"\n        [selected]=\"_styleFromConfig\"\n        (selectValue)=\"selectStyleToDisplay($event)\"\n      ></gn-ui-dropdown-selector>\n    </ng-container>\n    <ng-template #styleDisabled>\n      <gn-ui-dropdown-selector\n        class=\"w-full md:flex-1 md:min-w-0 text-gray-400\"\n        extraBtnClass=\"font-sans font-bold text-gray-400\"\n        [title]=\"'map.select.style' | translate\"\n        [choices]=\"styleDropdownChoices$ | async\"\n        [disabled]=\"true\"\n      ></gn-ui-dropdown-selector>\n    </ng-template>\n\n    <div class=\"self-end md:ml-2\">\n      <gn-ui-external-viewer-button\n        extraClass=\"w-[44px] h-[44px]\"\n        [link]=\"selectedLink$ | async\"\n      >\n      </gn-ui-external-viewer-button>\n    </div>\n  </div>\n  <ng-container *ngIf=\"hidePreview; else mapView\">\n    <gn-ui-popup-alert\n      type=\"warning\"\n      icon=\"matErrorOutlineOutline\"\n      class=\"block h-12 p-1\"\n    >\n      <span translate>record.feature.limit</span>\n    </gn-ui-popup-alert>\n  </ng-container>\n  <ng-template #mapView>\n    <div\n      class=\"relative w-full h-full bg-white border border-gray-300 rounded-lg overflow-hidden\"\n    >\n      <gn-ui-map-container\n        #mapContainer\n        [context]=\"mapContext$ | async\"\n        (featuresClick)=\"onMapFeatureSelect($event)\"\n        (sourceLoadError)=\"onSourceLoadError($event)\"\n      ></gn-ui-map-container>\n      <div\n        class=\"top-[1em] right-[1em] p-3 bg-white absolute overflow-y-auto overflow-x-hidden max-h-72 w-56\"\n        [class.hidden]=\"!selection\"\n      >\n        <gn-ui-button\n          type=\"light\"\n          (buttonClick)=\"resetSelection()\"\n          style=\"\n            --gn-ui-button-padding: 0px;\n            --gn-ui-button-width: 24px;\n            --gn-ui-button-height: 24px;\n          \"\n          extraClass=\"absolute right-[0.5em] ml-[8px] mr-[10px]\"\n        >\n          <ng-icon name=\"matClose\" class=\"align-middle text-sm\"></ng-icon>\n        </gn-ui-button>\n        <gn-ui-feature-detail\n          [featureCatalog]=\"mdViewFacade.featureCatalog$ | async\"\n          [feature]=\"selection\"\n        ></gn-ui-feature-detail>\n      </div>\n\n      <div\n        class=\"top-[1em] p-3 bg-white absolute overflow-y-auto overflow-x-hidden max-h-72 w-56\"\n        [ngClass]=\"{ 'right-[1em]': !selection, 'right-[16em]': selection }\"\n        [hidden]=\"!showLegend || !legendExists\"\n      >\n        <div class=\"flex justify-between items-center mb-2\">\n          <div class=\"text-primary font-bold\" translate>map.legend.title</div>\n          <gn-ui-button\n            type=\"light\"\n            (buttonClick)=\"toggleLegend()\"\n            style=\"\n              --gn-ui-button-padding: 0px;\n              --gn-ui-button-width: 24px;\n              --gn-ui-button-height: 24px;\n            \"\n            extraClass=\"ml-[8px] mr-[10px]\"\n          >\n            <ng-icon name=\"matClose\" class=\"align-middle text-sm\"></ng-icon>\n          </gn-ui-button>\n        </div>\n        <gn-ui-map-legend\n          [context]=\"mapContext$ | async\"\n          (legendStatusChange)=\"onLegendStatusChange($event)\"\n        ></gn-ui-map-legend>\n      </div>\n\n      <gn-ui-button\n        *ngIf=\"!showLegend && legendExists && !selection\"\n        type=\"outline\"\n        (buttonClick)=\"toggleLegend()\"\n        extraClass=\"absolute top-[1em] right-[1em] rounded p-1 text-xs bg-white\"\n        translate\n      >\n        map.legend.title\n      </gn-ui-button>\n\n      <gn-ui-loading-mask\n        *ngIf=\"loading\"\n        class=\"absolute inset-0\"\n        [message]=\"'map.loading.data' | translate\"\n      ></gn-ui-loading-mask>\n      <gn-ui-popup-alert\n        *ngIf=\"error\"\n        type=\"warning\"\n        icon=\"matErrorOutlineOutline\"\n        class=\"absolute m-2 inset-0\"\n      >\n        <span translate>{{ error }}</span>\n      </gn-ui-popup-alert>\n    </div>\n  </ng-template>\n</div>\n"]}
@@ -1,7 +1,7 @@
1
1
  import { ChangeDetectionStrategy, ChangeDetectorRef, Component, Input, } from '@angular/core';
2
2
  import { TranslateDirective, TranslateService } from '@ngx-translate/core';
3
3
  import { marker } from '@biesbjerg/ngx-translate-extract-marker';
4
- import { getBadgeColor, getFileFormat } from '../../../../../../libs/util/shared/src';
4
+ import { getBadgeColor, getFileFormat, getIsMobile, } from '../../../../../../libs/util/shared/src';
5
5
  import { CommonModule } from '@angular/common';
6
6
  import { ButtonComponent } from '../../../../../../libs/ui/inputs/src';
7
7
  import { DownloadItemComponent } from '../download-item/download-item.component';
@@ -16,6 +16,7 @@ export class DownloadsListComponent {
16
16
  constructor(translateService, changeDetector) {
17
17
  this.translateService = translateService;
18
18
  this.changeDetector = changeDetector;
19
+ this.isMobile$ = getIsMobile();
19
20
  this.activeFilterFormats = ['all'];
20
21
  }
21
22
  get linksCount() {
@@ -103,7 +104,7 @@ export class DownloadsListComponent {
103
104
  link.accessServiceProtocol === 'ogcFeatures'));
104
105
  }
105
106
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DownloadsListComponent, deps: [{ token: i1.TranslateService }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
106
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: DownloadsListComponent, isStandalone: true, selector: "gn-ui-downloads-list", inputs: { links: "links" }, ngImport: i0, template: "<div\n class=\"flex flex-wrap justify-between items-center pb-4\"\n *ngIf=\"links && links.length > 0\"\n>\n <div class=\"flex flex-row items-center gap-x-4\">\n <div>\n <h3\n class=\"inline-block font-title text-xl text-title font-medium mr-4\"\n translate\n >\n record.metadata.download\n </h3>\n <span class=\"px-3\">({{ linksCount }})</span>\n </div>\n <gn-ui-previous-next-buttons\n class=\"md:block hidden\"\n *ngIf=\"_list?.pagesCount > 1\"\n [listComponent]=\"_list\"\n ></gn-ui-previous-next-buttons>\n </div>\n\n <div\n class=\"flex flex-wrap justify-start sm:justify-end\"\n data-cy=\"download-format-filters\"\n >\n <gn-ui-button\n class=\"m-1 format-filter\"\n [extraClass]=\"\n '!px-[12px] !py-[8px] !text-[15px]' +\n (isFilterActive(format) ? ' opacity-100' : ' opacity-60')\n \"\n (buttonClick)=\"toggleFilterFormat(format)\"\n [attr.data-format]=\"format\"\n *ngFor=\"let format of visibleFormats\"\n >\n {{ getFilterFormatTitle(format) }}\n </gn-ui-button>\n </div>\n</div>\n\n<ng-container>\n <gn-ui-block-list\n class=\"md:block hidden\"\n #blockList\n (listChanges)=\"updateList($event)\"\n containerClass=\"gap-4 pt-5 pb-7\"\n >\n <gn-ui-download-item\n #block\n *ngFor=\"let link of filteredLinks\"\n [link]=\"link\"\n [color]=\"getLinkColor(link)\"\n [format]=\"getLinkFormat(link)\"\n [isFromApi]=\"isFromApi(link)\"\n [size]=\"blockList.subComponentSize\"\n ></gn-ui-download-item>\n </gn-ui-block-list>\n</ng-container>\n\n<div class=\"mb-5 md:hidden block\" *ngFor=\"let link of filteredLinks\">\n <gn-ui-download-item\n size=\"M\"\n [link]=\"link\"\n [color]=\"getLinkColor(link)\"\n [format]=\"getLinkFormat(link)\"\n [isFromApi]=\"isFromApi(link)\"\n ></gn-ui-download-item>\n</div>\n", styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: ButtonComponent, selector: "gn-ui-button", inputs: ["type", "disabled", "extraClass"], outputs: ["buttonClick"] }, { kind: "component", type: BlockListComponent, selector: "gn-ui-block-list", inputs: ["containerClass", "paginationContainerClass"], outputs: ["listChanges"] }, { kind: "component", type: DownloadItemComponent, selector: "gn-ui-download-item", inputs: ["link", "color", "format", "isFromApi", "size"], outputs: ["exportUrl"] }, { kind: "directive", type: TranslateDirective, selector: "[translate],[ngx-translate]", inputs: ["translate", "translateParams"] }, { kind: "component", type: PreviousNextButtonsComponent, selector: "gn-ui-previous-next-buttons", inputs: ["listComponent"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
107
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: DownloadsListComponent, isStandalone: true, selector: "gn-ui-downloads-list", inputs: { links: "links" }, ngImport: i0, template: "<div\n class=\"flex flex-wrap justify-between items-center pb-4\"\n *ngIf=\"links && links.length > 0\"\n>\n <div class=\"flex flex-row items-center gap-x-4\">\n <div>\n <h3\n class=\"inline-block font-title text-xl text-title font-medium mr-4\"\n translate\n >\n record.metadata.download\n </h3>\n <span class=\"px-3\">({{ linksCount }})</span>\n </div>\n <gn-ui-previous-next-buttons\n *ngIf=\"(isMobile$ | async) === false && _list?.pagesCount > 1\"\n [listComponent]=\"_list\"\n ></gn-ui-previous-next-buttons>\n </div>\n\n <div\n class=\"flex flex-wrap justify-start sm:justify-end\"\n data-cy=\"download-format-filters\"\n >\n <gn-ui-button\n class=\"m-1 format-filter\"\n [extraClass]=\"\n '!px-[12px] !py-[8px] !text-[15px]' +\n (isFilterActive(format) ? ' opacity-100' : ' opacity-60')\n \"\n (buttonClick)=\"toggleFilterFormat(format)\"\n [attr.data-format]=\"format\"\n *ngFor=\"let format of visibleFormats\"\n >\n {{ getFilterFormatTitle(format) }}\n </gn-ui-button>\n </div>\n</div>\n\n<ng-container>\n <gn-ui-block-list\n *ngIf=\"(isMobile$ | async) === false\"\n #blockList\n (listChanges)=\"updateList($event)\"\n containerClass=\"gap-4 pt-5 pb-7\"\n >\n <gn-ui-download-item\n #block\n *ngFor=\"let link of filteredLinks\"\n [link]=\"link\"\n [color]=\"getLinkColor(link)\"\n [format]=\"getLinkFormat(link)\"\n [isFromApi]=\"isFromApi(link)\"\n [size]=\"blockList.subComponentSize\"\n ></gn-ui-download-item>\n </gn-ui-block-list>\n</ng-container>\n\n<div class=\"mb-5\" *ngFor=\"let link of filteredLinks\">\n <ng-container *ngIf=\"(isMobile$ | async) === true\">\n <gn-ui-download-item\n size=\"M\"\n [link]=\"link\"\n [color]=\"getLinkColor(link)\"\n [format]=\"getLinkFormat(link)\"\n [isFromApi]=\"isFromApi(link)\"\n ></gn-ui-download-item>\n </ng-container>\n</div>\n", styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }, { kind: "component", type: ButtonComponent, selector: "gn-ui-button", inputs: ["type", "disabled", "extraClass"], outputs: ["buttonClick"] }, { kind: "component", type: BlockListComponent, selector: "gn-ui-block-list", inputs: ["containerClass", "paginationContainerClass"], outputs: ["listChanges"] }, { kind: "component", type: DownloadItemComponent, selector: "gn-ui-download-item", inputs: ["link", "color", "format", "isFromApi", "size"], outputs: ["exportUrl"] }, { kind: "directive", type: TranslateDirective, selector: "[translate],[ngx-translate]", inputs: ["translate", "translateParams"] }, { kind: "component", type: PreviousNextButtonsComponent, selector: "gn-ui-previous-next-buttons", inputs: ["listComponent"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
107
108
  }
108
109
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DownloadsListComponent, decorators: [{
109
110
  type: Component,
@@ -114,8 +115,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
114
115
  DownloadItemComponent,
115
116
  TranslateDirective,
116
117
  PreviousNextButtonsComponent,
117
- ], template: "<div\n class=\"flex flex-wrap justify-between items-center pb-4\"\n *ngIf=\"links && links.length > 0\"\n>\n <div class=\"flex flex-row items-center gap-x-4\">\n <div>\n <h3\n class=\"inline-block font-title text-xl text-title font-medium mr-4\"\n translate\n >\n record.metadata.download\n </h3>\n <span class=\"px-3\">({{ linksCount }})</span>\n </div>\n <gn-ui-previous-next-buttons\n class=\"md:block hidden\"\n *ngIf=\"_list?.pagesCount > 1\"\n [listComponent]=\"_list\"\n ></gn-ui-previous-next-buttons>\n </div>\n\n <div\n class=\"flex flex-wrap justify-start sm:justify-end\"\n data-cy=\"download-format-filters\"\n >\n <gn-ui-button\n class=\"m-1 format-filter\"\n [extraClass]=\"\n '!px-[12px] !py-[8px] !text-[15px]' +\n (isFilterActive(format) ? ' opacity-100' : ' opacity-60')\n \"\n (buttonClick)=\"toggleFilterFormat(format)\"\n [attr.data-format]=\"format\"\n *ngFor=\"let format of visibleFormats\"\n >\n {{ getFilterFormatTitle(format) }}\n </gn-ui-button>\n </div>\n</div>\n\n<ng-container>\n <gn-ui-block-list\n class=\"md:block hidden\"\n #blockList\n (listChanges)=\"updateList($event)\"\n containerClass=\"gap-4 pt-5 pb-7\"\n >\n <gn-ui-download-item\n #block\n *ngFor=\"let link of filteredLinks\"\n [link]=\"link\"\n [color]=\"getLinkColor(link)\"\n [format]=\"getLinkFormat(link)\"\n [isFromApi]=\"isFromApi(link)\"\n [size]=\"blockList.subComponentSize\"\n ></gn-ui-download-item>\n </gn-ui-block-list>\n</ng-container>\n\n<div class=\"mb-5 md:hidden block\" *ngFor=\"let link of filteredLinks\">\n <gn-ui-download-item\n size=\"M\"\n [link]=\"link\"\n [color]=\"getLinkColor(link)\"\n [format]=\"getLinkFormat(link)\"\n [isFromApi]=\"isFromApi(link)\"\n ></gn-ui-download-item>\n</div>\n" }]
118
+ ], template: "<div\n class=\"flex flex-wrap justify-between items-center pb-4\"\n *ngIf=\"links && links.length > 0\"\n>\n <div class=\"flex flex-row items-center gap-x-4\">\n <div>\n <h3\n class=\"inline-block font-title text-xl text-title font-medium mr-4\"\n translate\n >\n record.metadata.download\n </h3>\n <span class=\"px-3\">({{ linksCount }})</span>\n </div>\n <gn-ui-previous-next-buttons\n *ngIf=\"(isMobile$ | async) === false && _list?.pagesCount > 1\"\n [listComponent]=\"_list\"\n ></gn-ui-previous-next-buttons>\n </div>\n\n <div\n class=\"flex flex-wrap justify-start sm:justify-end\"\n data-cy=\"download-format-filters\"\n >\n <gn-ui-button\n class=\"m-1 format-filter\"\n [extraClass]=\"\n '!px-[12px] !py-[8px] !text-[15px]' +\n (isFilterActive(format) ? ' opacity-100' : ' opacity-60')\n \"\n (buttonClick)=\"toggleFilterFormat(format)\"\n [attr.data-format]=\"format\"\n *ngFor=\"let format of visibleFormats\"\n >\n {{ getFilterFormatTitle(format) }}\n </gn-ui-button>\n </div>\n</div>\n\n<ng-container>\n <gn-ui-block-list\n *ngIf=\"(isMobile$ | async) === false\"\n #blockList\n (listChanges)=\"updateList($event)\"\n containerClass=\"gap-4 pt-5 pb-7\"\n >\n <gn-ui-download-item\n #block\n *ngFor=\"let link of filteredLinks\"\n [link]=\"link\"\n [color]=\"getLinkColor(link)\"\n [format]=\"getLinkFormat(link)\"\n [isFromApi]=\"isFromApi(link)\"\n [size]=\"blockList.subComponentSize\"\n ></gn-ui-download-item>\n </gn-ui-block-list>\n</ng-container>\n\n<div class=\"mb-5\" *ngFor=\"let link of filteredLinks\">\n <ng-container *ngIf=\"(isMobile$ | async) === true\">\n <gn-ui-download-item\n size=\"M\"\n [link]=\"link\"\n [color]=\"getLinkColor(link)\"\n [format]=\"getLinkFormat(link)\"\n [isFromApi]=\"isFromApi(link)\"\n ></gn-ui-download-item>\n </ng-container>\n</div>\n" }]
118
119
  }], ctorParameters: () => [{ type: i1.TranslateService }, { type: i0.ChangeDetectorRef }], propDecorators: { links: [{
119
120
  type: Input
120
121
  }] } });
121
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"downloads-list.component.js","sourceRoot":"","sources":["../../../../../../../../libs/ui/elements/src/lib/downloads-list/downloads-list.component.ts","../../../../../../../../libs/ui/elements/src/lib/downloads-list/downloads-list.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  Input,\n} from '@angular/core'\nimport { TranslateDirective, TranslateService } from '@ngx-translate/core'\nimport { marker } from '@biesbjerg/ngx-translate-extract-marker'\nimport { getBadgeColor, getFileFormat } from '../../../../../../libs/util/shared/src'\nimport { DatasetDownloadDistribution } from '../../../../../../libs/common/domain/src/lib/model/record'\nimport { CommonModule } from '@angular/common'\nimport { ButtonComponent } from '../../../../../../libs/ui/inputs/src'\nimport { DownloadItemComponent } from '../download-item/download-item.component'\nimport {\n  BlockListComponent,\n  PreviousNextButtonsComponent,\n} from '../../../../../../libs/ui/layout/src'\n\nmarker('datahub.search.filter.all')\nmarker('datahub.search.filter.others')\n\nconst FILTER_FORMATS = ['all', 'csv', 'excel', 'json', 'shp', 'others'] as const\ntype FilterFormat = (typeof FILTER_FORMATS)[number]\n\n@Component({\n  selector: 'gn-ui-downloads-list',\n  templateUrl: './downloads-list.component.html',\n  styleUrls: ['./downloads-list.component.css'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true,\n  imports: [\n    CommonModule,\n    ButtonComponent,\n    BlockListComponent,\n    DownloadItemComponent,\n    TranslateDirective,\n    PreviousNextButtonsComponent,\n  ],\n})\nexport class DownloadsListComponent {\n  constructor(\n    private translateService: TranslateService,\n    private changeDetector: ChangeDetectorRef\n  ) {}\n\n  _list: BlockListComponent\n  @Input() links: DatasetDownloadDistribution[]\n\n  get linksCount(): number {\n    return this.filteredLinks?.length || 0\n  }\n\n  activeFilterFormats: FilterFormat[] = ['all']\n\n  updateList($event: BlockListComponent) {\n    this._list = $event\n    this.changeDetector.detectChanges()\n  }\n\n  private removeDuplicateFormats(\n    links: DatasetDownloadDistribution[]\n  ): DatasetDownloadDistribution[] {\n    const preferredLinks = new Map<string, DatasetDownloadDistribution>()\n\n    links.forEach((link) => {\n      const format = getFileFormat(link)\n      const withoutNameSpace = (link.name || link.description || '').replace(\n        /^.*?:/,\n        ''\n      )\n      const uniqueKey = `${format}-${withoutNameSpace}`\n      if (!preferredLinks.has(uniqueKey)) {\n        preferredLinks.set(uniqueKey, link)\n      } else {\n        const existingLink = preferredLinks.get(uniqueKey)\n        if (\n          link.accessServiceProtocol === 'ogcFeatures' &&\n          existingLink?.accessServiceProtocol !== 'ogcFeatures'\n        ) {\n          preferredLinks.set(uniqueKey, link)\n        }\n      }\n    })\n\n    return Array.from(preferredLinks.values())\n  }\n\n  get filteredLinks(): DatasetDownloadDistribution[] {\n    const filteredByFormat = this.links.filter((link) =>\n      this.activeFilterFormats.some((format) =>\n        this.isLinkOfFormat(link, format)\n      )\n    )\n    return this.removeDuplicateFormats(filteredByFormat)\n  }\n\n  get visibleFormats(): FilterFormat[] {\n    return FILTER_FORMATS.filter((format) =>\n      this.links.some((link) => this.isLinkOfFormat(link, format))\n    )\n  }\n\n  toggleFilterFormat(format: FilterFormat): void {\n    if (format === 'all') {\n      this.activeFilterFormats = ['all']\n      return\n    }\n    if (this.isFilterActive(format)) {\n      this.activeFilterFormats = this.activeFilterFormats.filter(\n        (f: string) => format !== f\n      )\n    } else {\n      this.activeFilterFormats = [\n        ...this.activeFilterFormats.filter((f) => f !== 'all'),\n        format,\n      ]\n    }\n    if (this.activeFilterFormats.length === 0) {\n      this.activeFilterFormats = ['all']\n    }\n  }\n\n  isFilterActive(filter: FilterFormat): boolean {\n    return this.activeFilterFormats.includes(filter)\n  }\n\n  getFilterFormatTitle(format: FilterFormat) {\n    if (format === 'all' || format === 'others') {\n      return this.translateService.instant(`datahub.search.filter.${format}`)\n    }\n    return format\n  }\n\n  isLinkOfFormat(\n    link: DatasetDownloadDistribution,\n    format: FilterFormat\n  ): boolean {\n    if (format === 'all') {\n      return true\n    }\n    if (getFileFormat(link) === null) {\n      return format === 'others'\n    }\n    if (format === 'others') {\n      const knownFormats = FILTER_FORMATS.filter(\n        (format) => format !== 'all' && format !== 'others'\n      )\n      return knownFormats.every(\n        (knownFormat) => !getFileFormat(link).includes(knownFormat)\n      )\n    }\n    return getFileFormat(link).includes(format)\n  }\n\n  getLinkFormat(link: DatasetDownloadDistribution) {\n    return getFileFormat(link)\n  }\n\n  getLinkColor(link: DatasetDownloadDistribution) {\n    return getBadgeColor(getFileFormat(link))\n  }\n\n  isFromApi(link: DatasetDownloadDistribution) {\n    return (\n      link.type === 'download' &&\n      (link.accessServiceProtocol === 'wfs' ||\n        link.accessServiceProtocol === 'ogcFeatures')\n    )\n  }\n}\n","<div\n  class=\"flex flex-wrap justify-between items-center pb-4\"\n  *ngIf=\"links && links.length > 0\"\n>\n  <div class=\"flex flex-row items-center gap-x-4\">\n    <div>\n      <h3\n        class=\"inline-block font-title text-xl text-title font-medium mr-4\"\n        translate\n      >\n        record.metadata.download\n      </h3>\n      <span class=\"px-3\">({{ linksCount }})</span>\n    </div>\n    <gn-ui-previous-next-buttons\n      class=\"md:block hidden\"\n      *ngIf=\"_list?.pagesCount > 1\"\n      [listComponent]=\"_list\"\n    ></gn-ui-previous-next-buttons>\n  </div>\n\n  <div\n    class=\"flex flex-wrap justify-start sm:justify-end\"\n    data-cy=\"download-format-filters\"\n  >\n    <gn-ui-button\n      class=\"m-1 format-filter\"\n      [extraClass]=\"\n        '!px-[12px] !py-[8px] !text-[15px]' +\n        (isFilterActive(format) ? ' opacity-100' : ' opacity-60')\n      \"\n      (buttonClick)=\"toggleFilterFormat(format)\"\n      [attr.data-format]=\"format\"\n      *ngFor=\"let format of visibleFormats\"\n    >\n      {{ getFilterFormatTitle(format) }}\n    </gn-ui-button>\n  </div>\n</div>\n\n<ng-container>\n  <gn-ui-block-list\n    class=\"md:block hidden\"\n    #blockList\n    (listChanges)=\"updateList($event)\"\n    containerClass=\"gap-4 pt-5 pb-7\"\n  >\n    <gn-ui-download-item\n      #block\n      *ngFor=\"let link of filteredLinks\"\n      [link]=\"link\"\n      [color]=\"getLinkColor(link)\"\n      [format]=\"getLinkFormat(link)\"\n      [isFromApi]=\"isFromApi(link)\"\n      [size]=\"blockList.subComponentSize\"\n    ></gn-ui-download-item>\n  </gn-ui-block-list>\n</ng-container>\n\n<div class=\"mb-5 md:hidden block\" *ngFor=\"let link of filteredLinks\">\n  <gn-ui-download-item\n    size=\"M\"\n    [link]=\"link\"\n    [color]=\"getLinkColor(link)\"\n    [format]=\"getLinkFormat(link)\"\n    [isFromApi]=\"isFromApi(link)\"\n  ></gn-ui-download-item>\n</div>\n"]}
122
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"downloads-list.component.js","sourceRoot":"","sources":["../../../../../../../../libs/ui/elements/src/lib/downloads-list/downloads-list.component.ts","../../../../../../../../libs/ui/elements/src/lib/downloads-list/downloads-list.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  Input,\n} from '@angular/core'\nimport { TranslateDirective, TranslateService } from '@ngx-translate/core'\nimport { marker } from '@biesbjerg/ngx-translate-extract-marker'\nimport {\n  getBadgeColor,\n  getFileFormat,\n  getIsMobile,\n} from '../../../../../../libs/util/shared/src'\nimport { DatasetDownloadDistribution } from '../../../../../../libs/common/domain/src/lib/model/record'\nimport { CommonModule } from '@angular/common'\nimport { ButtonComponent } from '../../../../../../libs/ui/inputs/src'\nimport { DownloadItemComponent } from '../download-item/download-item.component'\nimport {\n  BlockListComponent,\n  PreviousNextButtonsComponent,\n} from '../../../../../../libs/ui/layout/src'\n\nmarker('datahub.search.filter.all')\nmarker('datahub.search.filter.others')\n\nconst FILTER_FORMATS = ['all', 'csv', 'excel', 'json', 'shp', 'others'] as const\ntype FilterFormat = (typeof FILTER_FORMATS)[number]\n\n@Component({\n  selector: 'gn-ui-downloads-list',\n  templateUrl: './downloads-list.component.html',\n  styleUrls: ['./downloads-list.component.css'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true,\n  imports: [\n    CommonModule,\n    ButtonComponent,\n    BlockListComponent,\n    DownloadItemComponent,\n    TranslateDirective,\n    PreviousNextButtonsComponent,\n  ],\n})\nexport class DownloadsListComponent {\n  constructor(\n    private translateService: TranslateService,\n    private changeDetector: ChangeDetectorRef\n  ) {}\n\n  _list: BlockListComponent\n  @Input() links: DatasetDownloadDistribution[]\n\n  get linksCount(): number {\n    return this.filteredLinks?.length || 0\n  }\n\n  isMobile$ = getIsMobile()\n\n  activeFilterFormats: FilterFormat[] = ['all']\n\n  updateList($event: BlockListComponent) {\n    this._list = $event\n    this.changeDetector.detectChanges()\n  }\n\n  private removeDuplicateFormats(\n    links: DatasetDownloadDistribution[]\n  ): DatasetDownloadDistribution[] {\n    const preferredLinks = new Map<string, DatasetDownloadDistribution>()\n\n    links.forEach((link) => {\n      const format = getFileFormat(link)\n      const withoutNameSpace = (link.name || link.description || '').replace(\n        /^.*?:/,\n        ''\n      )\n      const uniqueKey = `${format}-${withoutNameSpace}`\n      if (!preferredLinks.has(uniqueKey)) {\n        preferredLinks.set(uniqueKey, link)\n      } else {\n        const existingLink = preferredLinks.get(uniqueKey)\n        if (\n          link.accessServiceProtocol === 'ogcFeatures' &&\n          existingLink?.accessServiceProtocol !== 'ogcFeatures'\n        ) {\n          preferredLinks.set(uniqueKey, link)\n        }\n      }\n    })\n\n    return Array.from(preferredLinks.values())\n  }\n\n  get filteredLinks(): DatasetDownloadDistribution[] {\n    const filteredByFormat = this.links.filter((link) =>\n      this.activeFilterFormats.some((format) =>\n        this.isLinkOfFormat(link, format)\n      )\n    )\n    return this.removeDuplicateFormats(filteredByFormat)\n  }\n\n  get visibleFormats(): FilterFormat[] {\n    return FILTER_FORMATS.filter((format) =>\n      this.links.some((link) => this.isLinkOfFormat(link, format))\n    )\n  }\n\n  toggleFilterFormat(format: FilterFormat): void {\n    if (format === 'all') {\n      this.activeFilterFormats = ['all']\n      return\n    }\n    if (this.isFilterActive(format)) {\n      this.activeFilterFormats = this.activeFilterFormats.filter(\n        (f: string) => format !== f\n      )\n    } else {\n      this.activeFilterFormats = [\n        ...this.activeFilterFormats.filter((f) => f !== 'all'),\n        format,\n      ]\n    }\n    if (this.activeFilterFormats.length === 0) {\n      this.activeFilterFormats = ['all']\n    }\n  }\n\n  isFilterActive(filter: FilterFormat): boolean {\n    return this.activeFilterFormats.includes(filter)\n  }\n\n  getFilterFormatTitle(format: FilterFormat) {\n    if (format === 'all' || format === 'others') {\n      return this.translateService.instant(`datahub.search.filter.${format}`)\n    }\n    return format\n  }\n\n  isLinkOfFormat(\n    link: DatasetDownloadDistribution,\n    format: FilterFormat\n  ): boolean {\n    if (format === 'all') {\n      return true\n    }\n    if (getFileFormat(link) === null) {\n      return format === 'others'\n    }\n    if (format === 'others') {\n      const knownFormats = FILTER_FORMATS.filter(\n        (format) => format !== 'all' && format !== 'others'\n      )\n      return knownFormats.every(\n        (knownFormat) => !getFileFormat(link).includes(knownFormat)\n      )\n    }\n    return getFileFormat(link).includes(format)\n  }\n\n  getLinkFormat(link: DatasetDownloadDistribution) {\n    return getFileFormat(link)\n  }\n\n  getLinkColor(link: DatasetDownloadDistribution) {\n    return getBadgeColor(getFileFormat(link))\n  }\n\n  isFromApi(link: DatasetDownloadDistribution) {\n    return (\n      link.type === 'download' &&\n      (link.accessServiceProtocol === 'wfs' ||\n        link.accessServiceProtocol === 'ogcFeatures')\n    )\n  }\n}\n","<div\n  class=\"flex flex-wrap justify-between items-center pb-4\"\n  *ngIf=\"links && links.length > 0\"\n>\n  <div class=\"flex flex-row items-center gap-x-4\">\n    <div>\n      <h3\n        class=\"inline-block font-title text-xl text-title font-medium mr-4\"\n        translate\n      >\n        record.metadata.download\n      </h3>\n      <span class=\"px-3\">({{ linksCount }})</span>\n    </div>\n    <gn-ui-previous-next-buttons\n      *ngIf=\"(isMobile$ | async) === false && _list?.pagesCount > 1\"\n      [listComponent]=\"_list\"\n    ></gn-ui-previous-next-buttons>\n  </div>\n\n  <div\n    class=\"flex flex-wrap justify-start sm:justify-end\"\n    data-cy=\"download-format-filters\"\n  >\n    <gn-ui-button\n      class=\"m-1 format-filter\"\n      [extraClass]=\"\n        '!px-[12px] !py-[8px] !text-[15px]' +\n        (isFilterActive(format) ? ' opacity-100' : ' opacity-60')\n      \"\n      (buttonClick)=\"toggleFilterFormat(format)\"\n      [attr.data-format]=\"format\"\n      *ngFor=\"let format of visibleFormats\"\n    >\n      {{ getFilterFormatTitle(format) }}\n    </gn-ui-button>\n  </div>\n</div>\n\n<ng-container>\n  <gn-ui-block-list\n    *ngIf=\"(isMobile$ | async) === false\"\n    #blockList\n    (listChanges)=\"updateList($event)\"\n    containerClass=\"gap-4 pt-5 pb-7\"\n  >\n    <gn-ui-download-item\n      #block\n      *ngFor=\"let link of filteredLinks\"\n      [link]=\"link\"\n      [color]=\"getLinkColor(link)\"\n      [format]=\"getLinkFormat(link)\"\n      [isFromApi]=\"isFromApi(link)\"\n      [size]=\"blockList.subComponentSize\"\n    ></gn-ui-download-item>\n  </gn-ui-block-list>\n</ng-container>\n\n<div class=\"mb-5\" *ngFor=\"let link of filteredLinks\">\n  <ng-container *ngIf=\"(isMobile$ | async) === true\">\n    <gn-ui-download-item\n      size=\"M\"\n      [link]=\"link\"\n      [color]=\"getLinkColor(link)\"\n      [format]=\"getLinkFormat(link)\"\n      [isFromApi]=\"isFromApi(link)\"\n    ></gn-ui-download-item>\n  </ng-container>\n</div>\n"]}
@@ -3,7 +3,7 @@ import { matLocationSearchingOutline } from '@ng-icons/material-icons/outline';
3
3
  import { CommonModule } from '@angular/common';
4
4
  import { TranslateDirective, TranslatePipe } from '@ngx-translate/core';
5
5
  import { NgIcon, provideIcons } from '@ng-icons/core';
6
- import { LinkClassifierService, LinkUsage } from '../../../../../../libs/util/shared/src';
6
+ import { getIsMobile, LinkClassifierService, LinkUsage, } from '../../../../../../libs/util/shared/src';
7
7
  import * as i0 from "@angular/core";
8
8
  import * as i1 from "../../../../../../libs/util/shared/src";
9
9
  import * as i2 from "@angular/common";
@@ -29,9 +29,10 @@ export class GeoDataBadgeComponent {
29
29
  this.linkClassifier = linkClassifier;
30
30
  this.showLabel = true;
31
31
  this.styling = 'default';
32
+ this.isMobile$ = getIsMobile();
32
33
  }
33
34
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: GeoDataBadgeComponent, deps: [{ token: i1.LinkClassifierService }], target: i0.ɵɵFactoryTarget.Component }); }
34
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: GeoDataBadgeComponent, isStandalone: true, selector: "gn-ui-geo-data-badge", inputs: { showLabel: "showLabel", styling: "styling", record: "record" }, ngImport: i0, template: "<div\n [class]=\"badgeClasses\"\n [title]=\"'record.metadata.isGeographical' | translate\"\n *ngIf=\"isGeodata()\"\n>\n <ng-icon\n class=\"shrink-0 text-[0.75em]\"\n name=\"matLocationSearchingOutline\"\n ></ng-icon>\n <span class=\"ml-1 hidden sm:inline-block shrink-0\" *ngIf=\"showLabel\" translate\n >record.metadata.isGeographical</span\n >\n</div>\n", styles: [":host{--gn-ui-geo-data-badge-background-color: var(--color-primary-white);--gn-ui-geo-data-badge-text-color: var(--color-primary-darkest)}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: NgIcon, selector: "ng-icon", inputs: ["name", "svg", "size", "strokeWidth", "color"] }, { kind: "directive", type: TranslateDirective, selector: "[translate],[ngx-translate]", inputs: ["translate", "translateParams"] }, { kind: "pipe", type: TranslatePipe, name: "translate" }], viewProviders: [
35
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: GeoDataBadgeComponent, isStandalone: true, selector: "gn-ui-geo-data-badge", inputs: { showLabel: "showLabel", styling: "styling", record: "record" }, ngImport: i0, template: "<div\n [class]=\"badgeClasses\"\n [title]=\"'record.metadata.isGeographical' | translate\"\n *ngIf=\"isGeodata()\"\n>\n <ng-icon\n class=\"shrink-0 text-[0.75em]\"\n name=\"matLocationSearchingOutline\"\n ></ng-icon>\n <span\n class=\"ml-1 inline-block shrink-0\"\n *ngIf=\"(isMobile$ | async) === false && showLabel\"\n translate\n >record.metadata.isGeographical</span\n >\n</div>\n", styles: [":host{--gn-ui-geo-data-badge-background-color: var(--color-primary-white);--gn-ui-geo-data-badge-text-color: var(--color-primary-darkest)}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }, { kind: "component", type: NgIcon, selector: "ng-icon", inputs: ["name", "svg", "size", "strokeWidth", "color"] }, { kind: "directive", type: TranslateDirective, selector: "[translate],[ngx-translate]", inputs: ["translate", "translateParams"] }, { kind: "pipe", type: TranslatePipe, name: "translate" }], viewProviders: [
35
36
  provideIcons({
36
37
  matLocationSearchingOutline,
37
38
  }),
@@ -43,7 +44,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
43
44
  provideIcons({
44
45
  matLocationSearchingOutline,
45
46
  }),
46
- ], template: "<div\n [class]=\"badgeClasses\"\n [title]=\"'record.metadata.isGeographical' | translate\"\n *ngIf=\"isGeodata()\"\n>\n <ng-icon\n class=\"shrink-0 text-[0.75em]\"\n name=\"matLocationSearchingOutline\"\n ></ng-icon>\n <span class=\"ml-1 hidden sm:inline-block shrink-0\" *ngIf=\"showLabel\" translate\n >record.metadata.isGeographical</span\n >\n</div>\n", styles: [":host{--gn-ui-geo-data-badge-background-color: var(--color-primary-white);--gn-ui-geo-data-badge-text-color: var(--color-primary-darkest)}\n"] }]
47
+ ], template: "<div\n [class]=\"badgeClasses\"\n [title]=\"'record.metadata.isGeographical' | translate\"\n *ngIf=\"isGeodata()\"\n>\n <ng-icon\n class=\"shrink-0 text-[0.75em]\"\n name=\"matLocationSearchingOutline\"\n ></ng-icon>\n <span\n class=\"ml-1 inline-block shrink-0\"\n *ngIf=\"(isMobile$ | async) === false && showLabel\"\n translate\n >record.metadata.isGeographical</span\n >\n</div>\n", styles: [":host{--gn-ui-geo-data-badge-background-color: var(--color-primary-white);--gn-ui-geo-data-badge-text-color: var(--color-primary-darkest)}\n"] }]
47
48
  }], ctorParameters: () => [{ type: i1.LinkClassifierService }], propDecorators: { showLabel: [{
48
49
  type: Input
49
50
  }], styling: [{
@@ -51,4 +52,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
51
52
  }], record: [{
52
53
  type: Input
53
54
  }] } });
54
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ2VvLWRhdGEtYmFkZ2UuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy91aS9lbGVtZW50cy9zcmMvbGliL2dlby1kYXRhLWJhZGdlL2dlby1kYXRhLWJhZGdlLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvdWkvZWxlbWVudHMvc3JjL2xpYi9nZW8tZGF0YS1iYWRnZS9nZW8tZGF0YS1iYWRnZS5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQTtBQUN6RSxPQUFPLEVBQUUsMkJBQTJCLEVBQUUsTUFBTSxrQ0FBa0MsQ0FBQTtBQUU5RSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUE7QUFDOUMsT0FBTyxFQUFFLGtCQUFrQixFQUFFLGFBQWEsRUFBRSxNQUFNLHFCQUFxQixDQUFBO0FBQ3ZFLE9BQU8sRUFBRSxNQUFNLEVBQUUsWUFBWSxFQUFFLE1BQU0sZ0JBQWdCLENBQUE7QUFDckQsT0FBTyxFQUFFLHFCQUFxQixFQUFFLFNBQVMsRUFBRSxNQUFNLHdDQUF3QyxDQUFBOzs7O0FBZXpGLE1BQU0sT0FBTyxxQkFBcUI7SUFLaEMsU0FBUztRQUNQLE1BQU0sS0FBSyxHQUNULGlCQUFpQixJQUFJLElBQUksQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsZUFBZSxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUE7UUFDckUsTUFBTSxTQUFTLEdBQUcsS0FBSyxDQUFDLElBQUksQ0FBQyxDQUFDLElBQUksRUFBRSxFQUFFLENBQ3BDLElBQUksQ0FBQyxjQUFjLENBQUMsUUFBUSxDQUFDLElBQUksRUFBRSxTQUFTLENBQUMsT0FBTyxDQUFDLENBQ3RELENBQUE7UUFDRCxNQUFNLFVBQVUsR0FBRyxLQUFLLENBQUMsSUFBSSxDQUFDLENBQUMsSUFBSSxFQUFFLEVBQUUsQ0FDckMsSUFBSSxDQUFDLGNBQWMsQ0FBQyxRQUFRLENBQUMsSUFBSSxFQUFFLFNBQVMsQ0FBQyxPQUFPLENBQUMsQ0FDdEQsQ0FBQTtRQUNELE9BQU8sU0FBUyxJQUFJLFVBQVUsQ0FBQTtJQUNoQyxDQUFDO0lBRUQsSUFBSSxZQUFZO1FBQ2QsTUFBTSxXQUFXLEdBQ2YseUVBQXlFLENBQUE7UUFFM0UsUUFBUSxJQUFJLENBQUMsT0FBTyxFQUFFLENBQUM7WUFDckIsS0FBSyxPQUFPO2dCQUNWLE9BQU8sR0FBRyxXQUFXLHdDQUF3QyxDQUFBO1lBQy9ELEtBQUssU0FBUztnQkFDWixPQUFPLEdBQUcsV0FBVywrQkFBK0IsQ0FBQTtZQUN0RDtnQkFDRSxPQUFPLDRCQUE0QixDQUFBO1FBQ3ZDLENBQUM7SUFDSCxDQUFDO0lBRUQsWUFBbUIsY0FBcUM7UUFBckMsbUJBQWMsR0FBZCxjQUFjLENBQXVCO1FBOUIvQyxjQUFTLEdBQUcsSUFBSSxDQUFBO1FBQ2hCLFlBQU8sR0FBRyxTQUFTLENBQUE7SUE2QitCLENBQUM7K0dBL0JqRCxxQkFBcUI7bUdBQXJCLHFCQUFxQiwwSkNyQmxDLHFYQWFBLHFNRENZLFlBQVksbUlBQUUsTUFBTSw2R0FBRSxrQkFBa0IsNkdBQUUsYUFBYSx1Q0FDbEQ7WUFDYixZQUFZLENBQUM7Z0JBQ1gsMkJBQTJCO2FBQzVCLENBQUM7U0FDSDs7NEZBRVUscUJBQXFCO2tCQWJqQyxTQUFTOytCQUNFLHNCQUFzQixtQkFHZix1QkFBdUIsQ0FBQyxNQUFNLGNBQ25DLElBQUksV0FDUCxDQUFDLFlBQVksRUFBRSxNQUFNLEVBQUUsa0JBQWtCLEVBQUUsYUFBYSxDQUFDLGlCQUNuRDt3QkFDYixZQUFZLENBQUM7NEJBQ1gsMkJBQTJCO3lCQUM1QixDQUFDO3FCQUNIOzBGQUdRLFNBQVM7c0JBQWpCLEtBQUs7Z0JBQ0csT0FBTztzQkFBZixLQUFLO2dCQUNHLE1BQU07c0JBQWQsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQsIElucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSdcbmltcG9ydCB7IG1hdExvY2F0aW9uU2VhcmNoaW5nT3V0bGluZSB9IGZyb20gJ0BuZy1pY29ucy9tYXRlcmlhbC1pY29ucy9vdXRsaW5lJ1xuaW1wb3J0IHsgQ2F0YWxvZ1JlY29yZCB9IGZyb20gJy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29tbW9uL2RvbWFpbi9zcmMvbGliL21vZGVsL3JlY29yZCdcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbidcbmltcG9ydCB7IFRyYW5zbGF0ZURpcmVjdGl2ZSwgVHJhbnNsYXRlUGlwZSB9IGZyb20gJ0BuZ3gtdHJhbnNsYXRlL2NvcmUnXG5pbXBvcnQgeyBOZ0ljb24sIHByb3ZpZGVJY29ucyB9IGZyb20gJ0BuZy1pY29ucy9jb3JlJ1xuaW1wb3J0IHsgTGlua0NsYXNzaWZpZXJTZXJ2aWNlLCBMaW5rVXNhZ2UgfSBmcm9tICcuLi8uLi8uLi8uLi8uLi8uLi9saWJzL3V0aWwvc2hhcmVkL3NyYydcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnZ24tdWktZ2VvLWRhdGEtYmFkZ2UnLFxuICB0ZW1wbGF0ZVVybDogJy4vZ2VvLWRhdGEtYmFkZ2UuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi9nZW8tZGF0YS1iYWRnZS5jb21wb25lbnQuY3NzJ10sXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxuICBzdGFuZGFsb25lOiB0cnVlLFxuICBpbXBvcnRzOiBbQ29tbW9uTW9kdWxlLCBOZ0ljb24sIFRyYW5zbGF0ZURpcmVjdGl2ZSwgVHJhbnNsYXRlUGlwZV0sXG4gIHZpZXdQcm92aWRlcnM6IFtcbiAgICBwcm92aWRlSWNvbnMoe1xuICAgICAgbWF0TG9jYXRpb25TZWFyY2hpbmdPdXRsaW5lLFxuICAgIH0pLFxuICBdLFxufSlcbmV4cG9ydCBjbGFzcyBHZW9EYXRhQmFkZ2VDb21wb25lbnQge1xuICBASW5wdXQoKSBzaG93TGFiZWwgPSB0cnVlXG4gIEBJbnB1dCgpIHN0eWxpbmcgPSAnZGVmYXVsdCdcbiAgQElucHV0KCkgcmVjb3JkOiBDYXRhbG9nUmVjb3JkXG5cbiAgaXNHZW9kYXRhKCkge1xuICAgIGNvbnN0IGxpbmtzID1cbiAgICAgICdvbmxpbmVSZXNvdXJjZXMnIGluIHRoaXMucmVjb3JkID8gdGhpcy5yZWNvcmQub25saW5lUmVzb3VyY2VzIDogW11cbiAgICBjb25zdCBoYXNNYXBBcGkgPSBsaW5rcy5zb21lKChsaW5rKSA9PlxuICAgICAgdGhpcy5saW5rQ2xhc3NpZmllci5oYXNVc2FnZShsaW5rLCBMaW5rVXNhZ2UuTUFQX0FQSSlcbiAgICApXG4gICAgY29uc3QgaGFzR2VvRGF0YSA9IGxpbmtzLnNvbWUoKGxpbmspID0+XG4gICAgICB0aGlzLmxpbmtDbGFzc2lmaWVyLmhhc1VzYWdlKGxpbmssIExpbmtVc2FnZS5HRU9EQVRBKVxuICAgIClcbiAgICByZXR1cm4gaGFzTWFwQXBpIHx8IGhhc0dlb0RhdGFcbiAgfVxuXG4gIGdldCBiYWRnZUNsYXNzZXMoKTogc3RyaW5nIHtcbiAgICBjb25zdCBiYXNlQ2xhc3NlcyA9XG4gICAgICAnZmxleCBzaHJpbmstMCBpdGVtcy1jZW50ZXIgYmFkZ2UtYnRuIGJhZGdlLWJ0biB0ZXh0LXhzIHB4LTIgaC02IG1pbi1oLTYnXG5cbiAgICBzd2l0Y2ggKHRoaXMuc3R5bGluZykge1xuICAgICAgY2FzZSAnbGlnaHQnOlxuICAgICAgICByZXR1cm4gYCR7YmFzZUNsYXNzZXN9IGJnLXByaW1hcnktd2hpdGUgdGV4dC1wcmltYXJ5LWRhcmtlc3RgXG4gICAgICBjYXNlICdkZWZhdWx0JzpcbiAgICAgICAgcmV0dXJuIGAke2Jhc2VDbGFzc2VzfSBiZy1wcmltYXJ5LWRhcmtlciB0ZXh0LXdoaXRlYFxuICAgICAgZGVmYXVsdDpcbiAgICAgICAgcmV0dXJuICdmbGV4IHNocmluay0wIGl0ZW1zLWNlbnRlcidcbiAgICB9XG4gIH1cblxuICBjb25zdHJ1Y3RvcihwdWJsaWMgbGlua0NsYXNzaWZpZXI6IExpbmtDbGFzc2lmaWVyU2VydmljZSkge31cbn1cbiIsIjxkaXZcbiAgW2NsYXNzXT1cImJhZGdlQ2xhc3Nlc1wiXG4gIFt0aXRsZV09XCIncmVjb3JkLm1ldGFkYXRhLmlzR2VvZ3JhcGhpY2FsJyB8IHRyYW5zbGF0ZVwiXG4gICpuZ0lmPVwiaXNHZW9kYXRhKClcIlxuPlxuICA8bmctaWNvblxuICAgIGNsYXNzPVwic2hyaW5rLTAgdGV4dC1bMC43NWVtXVwiXG4gICAgbmFtZT1cIm1hdExvY2F0aW9uU2VhcmNoaW5nT3V0bGluZVwiXG4gID48L25nLWljb24+XG4gIDxzcGFuIGNsYXNzPVwibWwtMSBoaWRkZW4gc206aW5saW5lLWJsb2NrIHNocmluay0wXCIgKm5nSWY9XCJzaG93TGFiZWxcIiB0cmFuc2xhdGVcbiAgICA+cmVjb3JkLm1ldGFkYXRhLmlzR2VvZ3JhcGhpY2FsPC9zcGFuXG4gID5cbjwvZGl2PlxuIl19
55
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ2VvLWRhdGEtYmFkZ2UuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy91aS9lbGVtZW50cy9zcmMvbGliL2dlby1kYXRhLWJhZGdlL2dlby1kYXRhLWJhZGdlLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvdWkvZWxlbWVudHMvc3JjL2xpYi9nZW8tZGF0YS1iYWRnZS9nZW8tZGF0YS1iYWRnZS5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQTtBQUN6RSxPQUFPLEVBQUUsMkJBQTJCLEVBQUUsTUFBTSxrQ0FBa0MsQ0FBQTtBQUU5RSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUE7QUFDOUMsT0FBTyxFQUFFLGtCQUFrQixFQUFFLGFBQWEsRUFBRSxNQUFNLHFCQUFxQixDQUFBO0FBQ3ZFLE9BQU8sRUFBRSxNQUFNLEVBQUUsWUFBWSxFQUFFLE1BQU0sZ0JBQWdCLENBQUE7QUFDckQsT0FBTyxFQUNMLFdBQVcsRUFDWCxxQkFBcUIsRUFDckIsU0FBUyxHQUNWLE1BQU0sd0NBQXdDLENBQUE7Ozs7QUFlL0MsTUFBTSxPQUFPLHFCQUFxQjtJQU9oQyxTQUFTO1FBQ1AsTUFBTSxLQUFLLEdBQ1QsaUJBQWlCLElBQUksSUFBSSxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxlQUFlLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQTtRQUNyRSxNQUFNLFNBQVMsR0FBRyxLQUFLLENBQUMsSUFBSSxDQUFDLENBQUMsSUFBSSxFQUFFLEVBQUUsQ0FDcEMsSUFBSSxDQUFDLGNBQWMsQ0FBQyxRQUFRLENBQUMsSUFBSSxFQUFFLFNBQVMsQ0FBQyxPQUFPLENBQUMsQ0FDdEQsQ0FBQTtRQUNELE1BQU0sVUFBVSxHQUFHLEtBQUssQ0FBQyxJQUFJLENBQUMsQ0FBQyxJQUFJLEVBQUUsRUFBRSxDQUNyQyxJQUFJLENBQUMsY0FBYyxDQUFDLFFBQVEsQ0FBQyxJQUFJLEVBQUUsU0FBUyxDQUFDLE9BQU8sQ0FBQyxDQUN0RCxDQUFBO1FBQ0QsT0FBTyxTQUFTLElBQUksVUFBVSxDQUFBO0lBQ2hDLENBQUM7SUFFRCxJQUFJLFlBQVk7UUFDZCxNQUFNLFdBQVcsR0FDZix5RUFBeUUsQ0FBQTtRQUUzRSxRQUFRLElBQUksQ0FBQyxPQUFPLEVBQUUsQ0FBQztZQUNyQixLQUFLLE9BQU87Z0JBQ1YsT0FBTyxHQUFHLFdBQVcsd0NBQXdDLENBQUE7WUFDL0QsS0FBSyxTQUFTO2dCQUNaLE9BQU8sR0FBRyxXQUFXLCtCQUErQixDQUFBO1lBQ3REO2dCQUNFLE9BQU8sNEJBQTRCLENBQUE7UUFDdkMsQ0FBQztJQUNILENBQUM7SUFFRCxZQUFtQixjQUFxQztRQUFyQyxtQkFBYyxHQUFkLGNBQWMsQ0FBdUI7UUFoQy9DLGNBQVMsR0FBRyxJQUFJLENBQUE7UUFDaEIsWUFBTyxHQUFHLFNBQVMsQ0FBQTtRQUc1QixjQUFTLEdBQUcsV0FBVyxFQUFFLENBQUE7SUE0QmtDLENBQUM7K0dBakNqRCxxQkFBcUI7bUdBQXJCLHFCQUFxQiwwSkN6QmxDLDJaQWdCQSxxTURFWSxZQUFZLHdMQUFFLE1BQU0sNkdBQUUsa0JBQWtCLDZHQUFFLGFBQWEsdUNBQ2xEO1lBQ2IsWUFBWSxDQUFDO2dCQUNYLDJCQUEyQjthQUM1QixDQUFDO1NBQ0g7OzRGQUVVLHFCQUFxQjtrQkFiakMsU0FBUzsrQkFDRSxzQkFBc0IsbUJBR2YsdUJBQXVCLENBQUMsTUFBTSxjQUNuQyxJQUFJLFdBQ1AsQ0FBQyxZQUFZLEVBQUUsTUFBTSxFQUFFLGtCQUFrQixFQUFFLGFBQWEsQ0FBQyxpQkFDbkQ7d0JBQ2IsWUFBWSxDQUFDOzRCQUNYLDJCQUEyQjt5QkFDNUIsQ0FBQztxQkFDSDswRkFHUSxTQUFTO3NCQUFqQixLQUFLO2dCQUNHLE9BQU87c0JBQWYsS0FBSztnQkFDRyxNQUFNO3NCQUFkLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50LCBJbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnXG5pbXBvcnQgeyBtYXRMb2NhdGlvblNlYXJjaGluZ091dGxpbmUgfSBmcm9tICdAbmctaWNvbnMvbWF0ZXJpYWwtaWNvbnMvb3V0bGluZSdcbmltcG9ydCB7IENhdGFsb2dSZWNvcmQgfSBmcm9tICcuLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbW1vbi9kb21haW4vc3JjL2xpYi9tb2RlbC9yZWNvcmQnXG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nXG5pbXBvcnQgeyBUcmFuc2xhdGVEaXJlY3RpdmUsIFRyYW5zbGF0ZVBpcGUgfSBmcm9tICdAbmd4LXRyYW5zbGF0ZS9jb3JlJ1xuaW1wb3J0IHsgTmdJY29uLCBwcm92aWRlSWNvbnMgfSBmcm9tICdAbmctaWNvbnMvY29yZSdcbmltcG9ydCB7XG4gIGdldElzTW9iaWxlLFxuICBMaW5rQ2xhc3NpZmllclNlcnZpY2UsXG4gIExpbmtVc2FnZSxcbn0gZnJvbSAnLi4vLi4vLi4vLi4vLi4vLi4vbGlicy91dGlsL3NoYXJlZC9zcmMnXG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2duLXVpLWdlby1kYXRhLWJhZGdlJyxcbiAgdGVtcGxhdGVVcmw6ICcuL2dlby1kYXRhLWJhZGdlLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vZ2VvLWRhdGEtYmFkZ2UuY29tcG9uZW50LmNzcyddLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgaW1wb3J0czogW0NvbW1vbk1vZHVsZSwgTmdJY29uLCBUcmFuc2xhdGVEaXJlY3RpdmUsIFRyYW5zbGF0ZVBpcGVdLFxuICB2aWV3UHJvdmlkZXJzOiBbXG4gICAgcHJvdmlkZUljb25zKHtcbiAgICAgIG1hdExvY2F0aW9uU2VhcmNoaW5nT3V0bGluZSxcbiAgICB9KSxcbiAgXSxcbn0pXG5leHBvcnQgY2xhc3MgR2VvRGF0YUJhZGdlQ29tcG9uZW50IHtcbiAgQElucHV0KCkgc2hvd0xhYmVsID0gdHJ1ZVxuICBASW5wdXQoKSBzdHlsaW5nID0gJ2RlZmF1bHQnXG4gIEBJbnB1dCgpIHJlY29yZDogQ2F0YWxvZ1JlY29yZFxuXG4gIGlzTW9iaWxlJCA9IGdldElzTW9iaWxlKClcblxuICBpc0dlb2RhdGEoKSB7XG4gICAgY29uc3QgbGlua3MgPVxuICAgICAgJ29ubGluZVJlc291cmNlcycgaW4gdGhpcy5yZWNvcmQgPyB0aGlzLnJlY29yZC5vbmxpbmVSZXNvdXJjZXMgOiBbXVxuICAgIGNvbnN0IGhhc01hcEFwaSA9IGxpbmtzLnNvbWUoKGxpbmspID0+XG4gICAgICB0aGlzLmxpbmtDbGFzc2lmaWVyLmhhc1VzYWdlKGxpbmssIExpbmtVc2FnZS5NQVBfQVBJKVxuICAgIClcbiAgICBjb25zdCBoYXNHZW9EYXRhID0gbGlua3Muc29tZSgobGluaykgPT5cbiAgICAgIHRoaXMubGlua0NsYXNzaWZpZXIuaGFzVXNhZ2UobGluaywgTGlua1VzYWdlLkdFT0RBVEEpXG4gICAgKVxuICAgIHJldHVybiBoYXNNYXBBcGkgfHwgaGFzR2VvRGF0YVxuICB9XG5cbiAgZ2V0IGJhZGdlQ2xhc3NlcygpOiBzdHJpbmcge1xuICAgIGNvbnN0IGJhc2VDbGFzc2VzID1cbiAgICAgICdmbGV4IHNocmluay0wIGl0ZW1zLWNlbnRlciBiYWRnZS1idG4gYmFkZ2UtYnRuIHRleHQteHMgcHgtMiBoLTYgbWluLWgtNidcblxuICAgIHN3aXRjaCAodGhpcy5zdHlsaW5nKSB7XG4gICAgICBjYXNlICdsaWdodCc6XG4gICAgICAgIHJldHVybiBgJHtiYXNlQ2xhc3Nlc30gYmctcHJpbWFyeS13aGl0ZSB0ZXh0LXByaW1hcnktZGFya2VzdGBcbiAgICAgIGNhc2UgJ2RlZmF1bHQnOlxuICAgICAgICByZXR1cm4gYCR7YmFzZUNsYXNzZXN9IGJnLXByaW1hcnktZGFya2VyIHRleHQtd2hpdGVgXG4gICAgICBkZWZhdWx0OlxuICAgICAgICByZXR1cm4gJ2ZsZXggc2hyaW5rLTAgaXRlbXMtY2VudGVyJ1xuICAgIH1cbiAgfVxuXG4gIGNvbnN0cnVjdG9yKHB1YmxpYyBsaW5rQ2xhc3NpZmllcjogTGlua0NsYXNzaWZpZXJTZXJ2aWNlKSB7fVxufVxuIiwiPGRpdlxuICBbY2xhc3NdPVwiYmFkZ2VDbGFzc2VzXCJcbiAgW3RpdGxlXT1cIidyZWNvcmQubWV0YWRhdGEuaXNHZW9ncmFwaGljYWwnIHwgdHJhbnNsYXRlXCJcbiAgKm5nSWY9XCJpc0dlb2RhdGEoKVwiXG4+XG4gIDxuZy1pY29uXG4gICAgY2xhc3M9XCJzaHJpbmstMCB0ZXh0LVswLjc1ZW1dXCJcbiAgICBuYW1lPVwibWF0TG9jYXRpb25TZWFyY2hpbmdPdXRsaW5lXCJcbiAgPjwvbmctaWNvbj5cbiAgPHNwYW5cbiAgICBjbGFzcz1cIm1sLTEgaW5saW5lLWJsb2NrIHNocmluay0wXCJcbiAgICAqbmdJZj1cIihpc01vYmlsZSQgfCBhc3luYykgPT09IGZhbHNlICYmIHNob3dMYWJlbFwiXG4gICAgdHJhbnNsYXRlXG4gICAgPnJlY29yZC5tZXRhZGF0YS5pc0dlb2dyYXBoaWNhbDwvc3BhblxuICA+XG48L2Rpdj5cbiJdfQ==
@@ -5,13 +5,14 @@ import { NgIcon, provideIcons, provideNgIconsConfig } from '@ng-icons/core';
5
5
  import { FormsModule } from '@angular/forms';
6
6
  import { of } from 'rxjs';
7
7
  import { debounceTime, distinctUntilChanged, tap } from 'rxjs/operators';
8
- import { createFuzzyFilter } from '../../../../../../libs/util/shared/src';
8
+ import { createFuzzyFilter, getIsMobile } from '../../../../../../libs/util/shared/src';
9
9
  import { iconoirSearch } from '@ng-icons/iconoir';
10
10
  import * as i0 from "@angular/core";
11
11
  import * as i1 from "@angular/common";
12
12
  import * as i2 from "@angular/forms";
13
13
  export class SearchFeatureCatalogComponent {
14
14
  constructor() {
15
+ this.isMobile$ = getIsMobile();
15
16
  this.filteredFeatureCatalogChange = new EventEmitter();
16
17
  this.filterAction = (searchTerm) => {
17
18
  of(searchTerm)
@@ -44,7 +45,7 @@ export class SearchFeatureCatalogComponent {
44
45
  return (this.filteredFeatureCatalog?.featureTypes?.reduce((total, featureType) => total + (featureType.attributes?.length || 0), 0) || 0);
45
46
  }
46
47
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: SearchFeatureCatalogComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
47
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: SearchFeatureCatalogComponent, isStandalone: true, selector: "gn-ui-search-feature-catalog", inputs: { featureCatalog: "featureCatalog" }, outputs: { filteredFeatureCatalogChange: "filteredFeatureCatalogChange" }, ngImport: i0, template: "<div\n class=\"flex items-center justify-between p-3 mt-8 bg-white rounded-lg border-b solid border-gray-300\"\n>\n <div\n class=\"relative shrink-0\"\n *ngIf=\"featureCatalog?.featureTypes?.length > 1\"\n >\n <input\n type=\"text\"\n [placeholder]=\"'search.filter.into.feature.catalog' | translate\"\n class=\"w-[220px] h-8 pl-3 pr-10 py-2 border rounded-md\"\n [(ngModel)]=\"searchTerm\"\n (ngModelChange)=\"filterAction(searchTerm)\"\n />\n <ng-icon\n class=\"absolute right-2.5 top-1 w-6 h-6 text-black\"\n name=\"iconoirSearch\"\n ></ng-icon>\n </div>\n <div class=\"text-sm px-1 ml-auto hidden sm:inline\">\n <ng-container *ngIf=\"featureCatalog?.featureTypes?.length > 1\">\n <span\n class=\"text-sm font-medium text-gray-900\"\n data-cy=\"total-objects-label\"\n translate\n >record.feature.catalog.number.total.object</span\n ><span\n class=\"text-sm font-bold px-1 text-gray-900\"\n data-cy=\"total-objects\"\n >{{ totalObjects }}</span\n >\n <span class=\"px-1.5\">|</span>\n </ng-container>\n <span\n class=\"text-sm font-medium px-1 text-gray-900\"\n data-cy=\"total-attributes-label\"\n translate\n >record.feature.catalog.number.total.attribute</span\n ><span class=\"text-sm font-bold text-gray-900\" data-cy=\"total-attributes\">{{\n totalAttributes\n }}</span>\n </div>\n</div>\n", styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: NgIcon, selector: "ng-icon", inputs: ["name", "svg", "size", "strokeWidth", "color"] }, { kind: "directive", type: TranslateDirective, selector: "[translate],[ngx-translate]", inputs: ["translate", "translateParams"] }, { kind: "pipe", type: TranslatePipe, name: "translate" }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i2.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: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }], viewProviders: [
48
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: SearchFeatureCatalogComponent, isStandalone: true, selector: "gn-ui-search-feature-catalog", inputs: { featureCatalog: "featureCatalog" }, outputs: { filteredFeatureCatalogChange: "filteredFeatureCatalogChange" }, ngImport: i0, template: "<div\n class=\"flex items-center justify-between p-3 mt-8 bg-white rounded-lg border-b solid border-gray-300\"\n *ngIf=\"\n (isMobile$ | async) === false || featureCatalog?.featureTypes?.length > 1\n \"\n>\n <div\n class=\"relative shrink-0\"\n *ngIf=\"featureCatalog?.featureTypes?.length > 1\"\n >\n <input\n type=\"text\"\n [placeholder]=\"'search.filter.into.feature.catalog' | translate\"\n class=\"w-[220px] h-8 pl-3 pr-10 py-2 border rounded-md\"\n [(ngModel)]=\"searchTerm\"\n (ngModelChange)=\"filterAction(searchTerm)\"\n />\n <ng-icon\n class=\"absolute right-2.5 top-1 w-6 h-6 text-black\"\n name=\"iconoirSearch\"\n ></ng-icon>\n </div>\n <div\n *ngIf=\"(isMobile$ | async) === false\"\n class=\"text-sm px-1 ml-auto inline\"\n >\n <ng-container *ngIf=\"featureCatalog?.featureTypes?.length > 1\">\n <span\n class=\"text-sm font-medium text-gray-900\"\n data-cy=\"total-objects-label\"\n translate\n >record.feature.catalog.number.total.object</span\n ><span\n class=\"text-sm font-bold px-1 text-gray-900\"\n data-cy=\"total-objects\"\n >{{ totalObjects }}</span\n >\n <span class=\"px-1.5\">|</span>\n </ng-container>\n <span\n class=\"text-sm font-medium px-1 text-gray-900\"\n data-cy=\"total-attributes-label\"\n translate\n >record.feature.catalog.number.total.attribute</span\n ><span class=\"text-sm font-bold text-gray-900\" data-cy=\"total-attributes\">{{\n totalAttributes\n }}</span>\n </div>\n</div>\n", styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }, { kind: "component", type: NgIcon, selector: "ng-icon", inputs: ["name", "svg", "size", "strokeWidth", "color"] }, { kind: "directive", type: TranslateDirective, selector: "[translate],[ngx-translate]", inputs: ["translate", "translateParams"] }, { kind: "pipe", type: TranslatePipe, name: "translate" }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i2.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: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }], viewProviders: [
48
49
  provideIcons({ iconoirSearch }),
49
50
  provideNgIconsConfig({
50
51
  size: '1.5rem',
@@ -64,10 +65,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
64
65
  provideNgIconsConfig({
65
66
  size: '1.5rem',
66
67
  }),
67
- ], template: "<div\n class=\"flex items-center justify-between p-3 mt-8 bg-white rounded-lg border-b solid border-gray-300\"\n>\n <div\n class=\"relative shrink-0\"\n *ngIf=\"featureCatalog?.featureTypes?.length > 1\"\n >\n <input\n type=\"text\"\n [placeholder]=\"'search.filter.into.feature.catalog' | translate\"\n class=\"w-[220px] h-8 pl-3 pr-10 py-2 border rounded-md\"\n [(ngModel)]=\"searchTerm\"\n (ngModelChange)=\"filterAction(searchTerm)\"\n />\n <ng-icon\n class=\"absolute right-2.5 top-1 w-6 h-6 text-black\"\n name=\"iconoirSearch\"\n ></ng-icon>\n </div>\n <div class=\"text-sm px-1 ml-auto hidden sm:inline\">\n <ng-container *ngIf=\"featureCatalog?.featureTypes?.length > 1\">\n <span\n class=\"text-sm font-medium text-gray-900\"\n data-cy=\"total-objects-label\"\n translate\n >record.feature.catalog.number.total.object</span\n ><span\n class=\"text-sm font-bold px-1 text-gray-900\"\n data-cy=\"total-objects\"\n >{{ totalObjects }}</span\n >\n <span class=\"px-1.5\">|</span>\n </ng-container>\n <span\n class=\"text-sm font-medium px-1 text-gray-900\"\n data-cy=\"total-attributes-label\"\n translate\n >record.feature.catalog.number.total.attribute</span\n ><span class=\"text-sm font-bold text-gray-900\" data-cy=\"total-attributes\">{{\n totalAttributes\n }}</span>\n </div>\n</div>\n" }]
68
+ ], template: "<div\n class=\"flex items-center justify-between p-3 mt-8 bg-white rounded-lg border-b solid border-gray-300\"\n *ngIf=\"\n (isMobile$ | async) === false || featureCatalog?.featureTypes?.length > 1\n \"\n>\n <div\n class=\"relative shrink-0\"\n *ngIf=\"featureCatalog?.featureTypes?.length > 1\"\n >\n <input\n type=\"text\"\n [placeholder]=\"'search.filter.into.feature.catalog' | translate\"\n class=\"w-[220px] h-8 pl-3 pr-10 py-2 border rounded-md\"\n [(ngModel)]=\"searchTerm\"\n (ngModelChange)=\"filterAction(searchTerm)\"\n />\n <ng-icon\n class=\"absolute right-2.5 top-1 w-6 h-6 text-black\"\n name=\"iconoirSearch\"\n ></ng-icon>\n </div>\n <div\n *ngIf=\"(isMobile$ | async) === false\"\n class=\"text-sm px-1 ml-auto inline\"\n >\n <ng-container *ngIf=\"featureCatalog?.featureTypes?.length > 1\">\n <span\n class=\"text-sm font-medium text-gray-900\"\n data-cy=\"total-objects-label\"\n translate\n >record.feature.catalog.number.total.object</span\n ><span\n class=\"text-sm font-bold px-1 text-gray-900\"\n data-cy=\"total-objects\"\n >{{ totalObjects }}</span\n >\n <span class=\"px-1.5\">|</span>\n </ng-container>\n <span\n class=\"text-sm font-medium px-1 text-gray-900\"\n data-cy=\"total-attributes-label\"\n translate\n >record.feature.catalog.number.total.attribute</span\n ><span class=\"text-sm font-bold text-gray-900\" data-cy=\"total-attributes\">{{\n totalAttributes\n }}</span>\n </div>\n</div>\n" }]
68
69
  }], propDecorators: { featureCatalog: [{
69
70
  type: Input
70
71
  }], filteredFeatureCatalogChange: [{
71
72
  type: Output
72
73
  }] } });
73
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"search-feature-catalog.component.js","sourceRoot":"","sources":["../../../../../../../../libs/ui/inputs/src/lib/search-feature-catalog/search-feature-catalog.component.ts","../../../../../../../../libs/ui/inputs/src/lib/search-feature-catalog/search-feature-catalog.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, Output } from '@angular/core'\nimport { CommonModule } from '@angular/common'\nimport { TranslateDirective, TranslatePipe } from '@ngx-translate/core'\nimport { NgIcon, provideIcons, provideNgIconsConfig } from '@ng-icons/core'\nimport { DatasetFeatureCatalog } from '../../../../../../libs/common/domain/src/lib/model/record'\nimport { FormsModule } from '@angular/forms'\nimport { of } from 'rxjs'\nimport { debounceTime, distinctUntilChanged, tap } from 'rxjs/operators'\nimport { createFuzzyFilter } from '../../../../../../libs/util/shared/src'\nimport { iconoirSearch } from '@ng-icons/iconoir'\n\n@Component({\n  selector: 'gn-ui-search-feature-catalog',\n  templateUrl: './search-feature-catalog.component.html',\n  styleUrls: ['./search-feature-catalog.component.css'],\n  standalone: true,\n  imports: [\n    CommonModule,\n    NgIcon,\n    TranslateDirective,\n    TranslatePipe,\n    FormsModule,\n  ],\n  viewProviders: [\n    provideIcons({ iconoirSearch }),\n    provideNgIconsConfig({\n      size: '1.5rem',\n    }),\n  ],\n})\nexport class SearchFeatureCatalogComponent {\n  private _featureCatalog: DatasetFeatureCatalog\n  searchTerm: any\n  @Input() set featureCatalog(value: DatasetFeatureCatalog) {\n    this._featureCatalog = value\n    this.filteredFeatureCatalog = value\n  }\n  get featureCatalog(): DatasetFeatureCatalog {\n    return this._featureCatalog\n  }\n\n  @Output() filteredFeatureCatalogChange =\n    new EventEmitter<DatasetFeatureCatalog>()\n  filteredFeatureCatalog: DatasetFeatureCatalog\n\n  filterAction = (searchTerm: string): void => {\n    of(searchTerm)\n      .pipe(\n        debounceTime(300),\n        distinctUntilChanged(),\n        tap(() => {\n          const filtered = (this.featureCatalog?.featureTypes || []).filter(\n            (featureType) => {\n              const fuzzyFilter = createFuzzyFilter(searchTerm)\n              return (\n                fuzzyFilter(featureType.name) ||\n                (featureType.definition && fuzzyFilter(featureType.definition))\n              )\n            }\n          )\n          this.filteredFeatureCatalog = {\n            ...this.featureCatalog,\n            featureTypes: filtered,\n          }\n          this.filteredFeatureCatalogChange.emit(this.filteredFeatureCatalog)\n        })\n      )\n      .subscribe()\n  }\n\n  get totalObjects(): number {\n    return this.filteredFeatureCatalog?.featureTypes?.length || 0\n  }\n\n  get totalAttributes(): number {\n    return (\n      this.filteredFeatureCatalog?.featureTypes?.reduce(\n        (total, featureType) => total + (featureType.attributes?.length || 0),\n        0\n      ) || 0\n    )\n  }\n}\n","<div\n  class=\"flex items-center justify-between p-3 mt-8 bg-white rounded-lg border-b solid border-gray-300\"\n>\n  <div\n    class=\"relative shrink-0\"\n    *ngIf=\"featureCatalog?.featureTypes?.length > 1\"\n  >\n    <input\n      type=\"text\"\n      [placeholder]=\"'search.filter.into.feature.catalog' | translate\"\n      class=\"w-[220px] h-8 pl-3 pr-10 py-2 border rounded-md\"\n      [(ngModel)]=\"searchTerm\"\n      (ngModelChange)=\"filterAction(searchTerm)\"\n    />\n    <ng-icon\n      class=\"absolute right-2.5 top-1 w-6 h-6 text-black\"\n      name=\"iconoirSearch\"\n    ></ng-icon>\n  </div>\n  <div class=\"text-sm px-1 ml-auto hidden sm:inline\">\n    <ng-container *ngIf=\"featureCatalog?.featureTypes?.length > 1\">\n      <span\n        class=\"text-sm font-medium text-gray-900\"\n        data-cy=\"total-objects-label\"\n        translate\n        >record.feature.catalog.number.total.object</span\n      ><span\n        class=\"text-sm font-bold px-1 text-gray-900\"\n        data-cy=\"total-objects\"\n        >{{ totalObjects }}</span\n      >\n      <span class=\"px-1.5\">|</span>\n    </ng-container>\n    <span\n      class=\"text-sm font-medium px-1 text-gray-900\"\n      data-cy=\"total-attributes-label\"\n      translate\n      >record.feature.catalog.number.total.attribute</span\n    ><span class=\"text-sm font-bold text-gray-900\" data-cy=\"total-attributes\">{{\n      totalAttributes\n    }}</span>\n  </div>\n</div>\n"]}
74
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"search-feature-catalog.component.js","sourceRoot":"","sources":["../../../../../../../../libs/ui/inputs/src/lib/search-feature-catalog/search-feature-catalog.component.ts","../../../../../../../../libs/ui/inputs/src/lib/search-feature-catalog/search-feature-catalog.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, Output } from '@angular/core'\nimport { CommonModule } from '@angular/common'\nimport { TranslateDirective, TranslatePipe } from '@ngx-translate/core'\nimport { NgIcon, provideIcons, provideNgIconsConfig } from '@ng-icons/core'\nimport { DatasetFeatureCatalog } from '../../../../../../libs/common/domain/src/lib/model/record'\nimport { FormsModule } from '@angular/forms'\nimport { of } from 'rxjs'\nimport { debounceTime, distinctUntilChanged, tap } from 'rxjs/operators'\nimport { createFuzzyFilter, getIsMobile } from '../../../../../../libs/util/shared/src'\nimport { iconoirSearch } from '@ng-icons/iconoir'\n\n@Component({\n  selector: 'gn-ui-search-feature-catalog',\n  templateUrl: './search-feature-catalog.component.html',\n  styleUrls: ['./search-feature-catalog.component.css'],\n  standalone: true,\n  imports: [\n    CommonModule,\n    NgIcon,\n    TranslateDirective,\n    TranslatePipe,\n    FormsModule,\n  ],\n  viewProviders: [\n    provideIcons({ iconoirSearch }),\n    provideNgIconsConfig({\n      size: '1.5rem',\n    }),\n  ],\n})\nexport class SearchFeatureCatalogComponent {\n  private _featureCatalog: DatasetFeatureCatalog\n  searchTerm: any\n  @Input() set featureCatalog(value: DatasetFeatureCatalog) {\n    this._featureCatalog = value\n    this.filteredFeatureCatalog = value\n  }\n  get featureCatalog(): DatasetFeatureCatalog {\n    return this._featureCatalog\n  }\n\n  isMobile$ = getIsMobile()\n\n  @Output() filteredFeatureCatalogChange =\n    new EventEmitter<DatasetFeatureCatalog>()\n  filteredFeatureCatalog: DatasetFeatureCatalog\n\n  filterAction = (searchTerm: string): void => {\n    of(searchTerm)\n      .pipe(\n        debounceTime(300),\n        distinctUntilChanged(),\n        tap(() => {\n          const filtered = (this.featureCatalog?.featureTypes || []).filter(\n            (featureType) => {\n              const fuzzyFilter = createFuzzyFilter(searchTerm)\n              return (\n                fuzzyFilter(featureType.name) ||\n                (featureType.definition && fuzzyFilter(featureType.definition))\n              )\n            }\n          )\n          this.filteredFeatureCatalog = {\n            ...this.featureCatalog,\n            featureTypes: filtered,\n          }\n          this.filteredFeatureCatalogChange.emit(this.filteredFeatureCatalog)\n        })\n      )\n      .subscribe()\n  }\n\n  get totalObjects(): number {\n    return this.filteredFeatureCatalog?.featureTypes?.length || 0\n  }\n\n  get totalAttributes(): number {\n    return (\n      this.filteredFeatureCatalog?.featureTypes?.reduce(\n        (total, featureType) => total + (featureType.attributes?.length || 0),\n        0\n      ) || 0\n    )\n  }\n}\n","<div\n  class=\"flex items-center justify-between p-3 mt-8 bg-white rounded-lg border-b solid border-gray-300\"\n  *ngIf=\"\n    (isMobile$ | async) === false || featureCatalog?.featureTypes?.length > 1\n  \"\n>\n  <div\n    class=\"relative shrink-0\"\n    *ngIf=\"featureCatalog?.featureTypes?.length > 1\"\n  >\n    <input\n      type=\"text\"\n      [placeholder]=\"'search.filter.into.feature.catalog' | translate\"\n      class=\"w-[220px] h-8 pl-3 pr-10 py-2 border rounded-md\"\n      [(ngModel)]=\"searchTerm\"\n      (ngModelChange)=\"filterAction(searchTerm)\"\n    />\n    <ng-icon\n      class=\"absolute right-2.5 top-1 w-6 h-6 text-black\"\n      name=\"iconoirSearch\"\n    ></ng-icon>\n  </div>\n  <div\n    *ngIf=\"(isMobile$ | async) === false\"\n    class=\"text-sm px-1 ml-auto inline\"\n  >\n    <ng-container *ngIf=\"featureCatalog?.featureTypes?.length > 1\">\n      <span\n        class=\"text-sm font-medium text-gray-900\"\n        data-cy=\"total-objects-label\"\n        translate\n        >record.feature.catalog.number.total.object</span\n      ><span\n        class=\"text-sm font-bold px-1 text-gray-900\"\n        data-cy=\"total-objects\"\n        >{{ totalObjects }}</span\n      >\n      <span class=\"px-1.5\">|</span>\n    </ng-container>\n    <span\n      class=\"text-sm font-medium px-1 text-gray-900\"\n      data-cy=\"total-attributes-label\"\n      translate\n      >record.feature.catalog.number.total.attribute</span\n    ><span class=\"text-sm font-bold text-gray-900\" data-cy=\"total-attributes\">{{\n      totalAttributes\n    }}</span>\n  </div>\n</div>\n"]}