geonetwork-ui 2.6.0-dev.582b4530a → 2.6.0-dev.9df114cd4

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 (43) hide show
  1. package/esm2022/libs/feature/search/src/lib/favorites/favorite-star/favorite-star.component.mjs +7 -6
  2. package/esm2022/libs/feature/search/src/lib/results-list/results-list.container.component.mjs +2 -2
  3. package/esm2022/libs/ui/inputs/src/index.mjs +1 -2
  4. package/esm2022/libs/ui/inputs/src/lib/star-toggle/star-toggle.component.mjs +4 -3
  5. package/esm2022/libs/ui/layout/src/lib/anchor-link/anchor-link.directive.mjs +43 -3
  6. package/esm2022/translations/de.json +2 -1
  7. package/esm2022/translations/en.json +2 -1
  8. package/esm2022/translations/es.json +2 -1
  9. package/esm2022/translations/fr.json +4 -3
  10. package/esm2022/translations/it.json +2 -1
  11. package/esm2022/translations/nl.json +2 -1
  12. package/esm2022/translations/pt.json +2 -1
  13. package/fesm2022/geonetwork-ui.mjs +68 -33
  14. package/fesm2022/geonetwork-ui.mjs.map +1 -1
  15. package/libs/feature/search/src/lib/favorites/favorite-star/favorite-star.component.d.ts.map +1 -1
  16. package/libs/ui/inputs/src/index.d.ts +0 -1
  17. package/libs/ui/inputs/src/index.d.ts.map +1 -1
  18. package/libs/ui/inputs/src/lib/star-toggle/star-toggle.component.d.ts.map +1 -1
  19. package/libs/ui/layout/src/lib/anchor-link/anchor-link.directive.d.ts +10 -3
  20. package/libs/ui/layout/src/lib/anchor-link/anchor-link.directive.d.ts.map +1 -1
  21. package/package.json +1 -1
  22. package/src/libs/feature/search/src/lib/favorites/favorite-star/favorite-star.component.html +0 -6
  23. package/src/libs/feature/search/src/lib/favorites/favorite-star/favorite-star.component.ts +14 -6
  24. package/src/libs/feature/search/src/lib/results-list/results-list.container.component.css +6 -0
  25. package/src/libs/ui/inputs/src/index.ts +0 -1
  26. package/src/libs/ui/inputs/src/lib/star-toggle/star-toggle.component.html +5 -5
  27. package/src/libs/ui/inputs/src/lib/star-toggle/star-toggle.component.ts +2 -1
  28. package/src/libs/ui/layout/src/lib/anchor-link/anchor-link.directive.ts +46 -2
  29. package/tailwind.base.css +16 -11
  30. package/translations/de.json +2 -1
  31. package/translations/en.json +2 -1
  32. package/translations/es.json +2 -1
  33. package/translations/fr.json +4 -3
  34. package/translations/it.json +2 -1
  35. package/translations/nl.json +2 -1
  36. package/translations/pt.json +2 -1
  37. package/translations/sk.json +2 -1
  38. package/esm2022/libs/ui/inputs/src/lib/navigation-button/navigation-button.component.mjs +0 -16
  39. package/libs/ui/inputs/src/lib/navigation-button/navigation-button.component.d.ts +0 -8
  40. package/libs/ui/inputs/src/lib/navigation-button/navigation-button.component.d.ts.map +0 -1
  41. package/src/libs/ui/inputs/src/lib/navigation-button/navigation-button.component.css +0 -3
  42. package/src/libs/ui/inputs/src/lib/navigation-button/navigation-button.component.html +0 -9
  43. package/src/libs/ui/inputs/src/lib/navigation-button/navigation-button.component.ts +0 -15
@@ -1,5 +1,5 @@
1
1
  import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ElementRef, Input, ViewChild, } from '@angular/core';
2
- import { map, pairwise, withLatestFrom } from 'rxjs/operators';
2
+ import { map, pairwise, startWith, switchMap, withLatestFrom, } from 'rxjs/operators';
3
3
  import tippy from 'tippy.js';
4
4
  import { TranslateService } from '@ngx-translate/core';
5
5
  import { StarToggleComponent } from '../../../../../../../libs/ui/inputs/src';
@@ -36,9 +36,10 @@ export class FavoriteStarComponent {
36
36
  this.isAnonymous$ = this.platformService.isAnonymous();
37
37
  this.loading = false;
38
38
  this.loginUrl = this.authService.loginUrl;
39
- this.loginMessage$ = this.translateService.get('favorite.not.authenticated.tooltip', {
39
+ this.loginMessage$ = this.translateService.onLangChange.pipe(startWith(null), // make sure to wait for translations to be loaded with and without language change
40
+ switchMap(() => this.translateService.get('favorite.not.authenticated.tooltip', {
40
41
  link: this.loginUrl,
41
- });
42
+ })));
42
43
  }
43
44
  ngAfterViewInit() {
44
45
  this.subscription = this.isAnonymous$
@@ -94,11 +95,11 @@ export class FavoriteStarComponent {
94
95
  });
95
96
  }
96
97
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FavoriteStarComponent, deps: [{ token: i1.FavoritesService }, { token: i2.PlatformServiceInterface }, { token: i0.ChangeDetectorRef }, { token: i1.AuthService }, { token: i3.TranslateService }], target: i0.ɵɵFactoryTarget.Component }); }
97
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: FavoriteStarComponent, isStandalone: true, selector: "gn-ui-favorite-star", inputs: { displayCount: "displayCount", record: "record" }, viewQueries: [{ propertyName: "starToggleRef", first: true, predicate: StarToggleComponent, descendants: true, read: ElementRef }], ngImport: i0, template: "<div class=\"flex flex-row items-center\">\n <span\n class=\"align-text-top mr-1.5 mt-0.5\"\n data-test=\"favorite-count\"\n *ngIf=\"hasFavoriteCount && displayCount\"\n >{{ favoriteCount }}</span\n >\n <gn-ui-star-toggle\n [toggled]=\"isFavorite$ | async\"\n (newValue)=\"toggleFavorite($event)\"\n [disabled]=\"loading || (isAnonymous$ | async)\"\n ></gn-ui-star-toggle>\n <span\n class=\"align-text-top ml-1.5\"\n data-test=\"favorite-count\"\n *ngIf=\"!displayCount\"\n translate=\"datahub.record.addToFavorites\"\n ></span>\n</div>\n", styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i4.AsyncPipe, name: "async" }, { kind: "component", type: StarToggleComponent, selector: "gn-ui-star-toggle", inputs: ["toggled", "disabled"], outputs: ["newValue"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
98
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: FavoriteStarComponent, isStandalone: true, selector: "gn-ui-favorite-star", inputs: { displayCount: "displayCount", record: "record" }, viewQueries: [{ propertyName: "starToggleRef", first: true, predicate: StarToggleComponent, descendants: true, read: ElementRef }], ngImport: i0, template: "<div class=\"flex flex-row items-center\">\n <span\n class=\"align-text-top mr-1.5 mt-0.5\"\n data-test=\"favorite-count\"\n *ngIf=\"hasFavoriteCount && displayCount\"\n >{{ favoriteCount }}</span\n >\n <gn-ui-star-toggle\n [toggled]=\"isFavorite$ | async\"\n (newValue)=\"toggleFavorite($event)\"\n [disabled]=\"loading || (isAnonymous$ | async)\"\n ></gn-ui-star-toggle>\n</div>\n", styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i4.AsyncPipe, name: "async" }, { kind: "component", type: StarToggleComponent, selector: "gn-ui-star-toggle", inputs: ["toggled", "disabled"], outputs: ["newValue"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
98
99
  }
99
100
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FavoriteStarComponent, decorators: [{
100
101
  type: Component,
101
- args: [{ selector: 'gn-ui-favorite-star', changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, imports: [CommonModule, StarToggleComponent], template: "<div class=\"flex flex-row items-center\">\n <span\n class=\"align-text-top mr-1.5 mt-0.5\"\n data-test=\"favorite-count\"\n *ngIf=\"hasFavoriteCount && displayCount\"\n >{{ favoriteCount }}</span\n >\n <gn-ui-star-toggle\n [toggled]=\"isFavorite$ | async\"\n (newValue)=\"toggleFavorite($event)\"\n [disabled]=\"loading || (isAnonymous$ | async)\"\n ></gn-ui-star-toggle>\n <span\n class=\"align-text-top ml-1.5\"\n data-test=\"favorite-count\"\n *ngIf=\"!displayCount\"\n translate=\"datahub.record.addToFavorites\"\n ></span>\n</div>\n" }]
102
+ args: [{ selector: 'gn-ui-favorite-star', changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, imports: [CommonModule, StarToggleComponent], template: "<div class=\"flex flex-row items-center\">\n <span\n class=\"align-text-top mr-1.5 mt-0.5\"\n data-test=\"favorite-count\"\n *ngIf=\"hasFavoriteCount && displayCount\"\n >{{ favoriteCount }}</span\n >\n <gn-ui-star-toggle\n [toggled]=\"isFavorite$ | async\"\n (newValue)=\"toggleFavorite($event)\"\n [disabled]=\"loading || (isAnonymous$ | async)\"\n ></gn-ui-star-toggle>\n</div>\n" }]
102
103
  }], ctorParameters: () => [{ type: i1.FavoritesService }, { type: i2.PlatformServiceInterface }, { type: i0.ChangeDetectorRef }, { type: i1.AuthService }, { type: i3.TranslateService }], propDecorators: { displayCount: [{
103
104
  type: Input
104
105
  }], record: [{
@@ -107,4 +108,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
107
108
  type: ViewChild,
108
109
  args: [StarToggleComponent, { read: ElementRef }]
109
110
  }] } });
110
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"favorite-star.component.js","sourceRoot":"","sources":["../../../../../../../../../libs/feature/search/src/lib/favorites/favorite-star/favorite-star.component.ts","../../../../../../../../../libs/feature/search/src/lib/favorites/favorite-star/favorite-star.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  Input,\n  OnDestroy,\n  ViewChild,\n} from '@angular/core'\nimport { map, pairwise, withLatestFrom } from 'rxjs/operators'\nimport tippy from 'tippy.js'\nimport { TranslateService } from '@ngx-translate/core'\nimport { StarToggleComponent } from '../../../../../../../libs/ui/inputs/src'\nimport { Observable, Subscription } from 'rxjs'\nimport { CatalogRecord } from '../../../../../../../libs/common/domain/src/lib/model/record'\nimport { AuthService, FavoritesService } from '../../../../../../../libs/api/repository/src'\nimport { PlatformServiceInterface } from '../../../../../../../libs/common/domain/src/lib/platform.service.interface'\nimport { CommonModule } from '@angular/common'\n\n@Component({\n  selector: 'gn-ui-favorite-star',\n  templateUrl: './favorite-star.component.html',\n  styleUrls: ['./favorite-star.component.css'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true,\n  imports: [CommonModule, StarToggleComponent],\n})\nexport class FavoriteStarComponent implements AfterViewInit, OnDestroy {\n  @Input() displayCount? = true\n  @Input() set record(value) {\n    this.record_ = value\n    this.favoriteCount =\n      'extras' in this.record_ && 'favoriteCount' in this.record_.extras\n        ? (this.record_.extras.favoriteCount as number)\n        : null\n  }\n  get record() {\n    return this.record_\n  }\n  isFavorite$ = this.favoritesService.myFavoritesUuid$.pipe(\n    map((favorites) => favorites.indexOf(this.record.uniqueIdentifier) > -1)\n  )\n  isAnonymous$ = this.platformService.isAnonymous()\n  record_: Partial<CatalogRecord>\n  favoriteCount: number | null\n  loading = false\n  loginUrl = this.authService.loginUrl\n  loginMessage$: Observable<string> = this.translateService.get(\n    'favorite.not.authenticated.tooltip',\n    {\n      link: this.loginUrl,\n    }\n  )\n  @ViewChild(StarToggleComponent, { read: ElementRef })\n  starToggleRef: ElementRef\n  subscription: Subscription\n  countSubscription: Subscription\n\n  get hasFavoriteCount() {\n    return this.favoriteCount !== null\n  }\n\n  constructor(\n    private favoritesService: FavoritesService,\n    private platformService: PlatformServiceInterface,\n    private changeDetector: ChangeDetectorRef,\n    private authService: AuthService,\n    private translateService: TranslateService\n  ) {}\n\n  ngAfterViewInit(): void {\n    this.subscription = this.isAnonymous$\n      .pipe(withLatestFrom(this.loginMessage$))\n      .subscribe(([anonymous, loginMessage]) => {\n        if (anonymous) {\n          tippy(this.starToggleRef.nativeElement, {\n            appendTo: () => document.body,\n            content: loginMessage,\n            allowHTML: true,\n            interactive: true,\n            zIndex: 40,\n            maxWidth: 250,\n          })\n        }\n      })\n    this.countSubscription = this.favoritesService.myFavoritesUuid$\n      .pipe(pairwise())\n      .subscribe(([oldFavs, newFavs]) => {\n        const editedFavs = (\n          oldFavs.length < newFavs.length\n            ? newFavs.slice(-1)\n            : oldFavs.filter((fav) => !newFavs.includes(fav))\n        )[0]\n        if (\n          this.hasFavoriteCount &&\n          editedFavs === this.record.uniqueIdentifier\n        ) {\n          if (newFavs.includes(editedFavs)) {\n            this.favoriteCount += 1\n          } else {\n            this.favoriteCount += -1\n          }\n        }\n      })\n  }\n\n  ngOnDestroy(): void {\n    this.subscription.unsubscribe()\n    this.countSubscription.unsubscribe()\n  }\n\n  toggleFavorite(isFavorite) {\n    this.loading = true\n    ;(isFavorite\n      ? this.favoritesService.addToFavorites([this.record.uniqueIdentifier])\n      : this.favoritesService.removeFromFavorites([\n          this.record.uniqueIdentifier,\n        ])\n    ).subscribe({\n      complete: () => {\n        this.loading = false\n        this.changeDetector.detectChanges()\n      },\n      error: () => {\n        this.loading = false\n        this.changeDetector.detectChanges()\n      },\n    })\n  }\n}\n","<div class=\"flex flex-row items-center\">\n  <span\n    class=\"align-text-top mr-1.5 mt-0.5\"\n    data-test=\"favorite-count\"\n    *ngIf=\"hasFavoriteCount && displayCount\"\n    >{{ favoriteCount }}</span\n  >\n  <gn-ui-star-toggle\n    [toggled]=\"isFavorite$ | async\"\n    (newValue)=\"toggleFavorite($event)\"\n    [disabled]=\"loading || (isAnonymous$ | async)\"\n  ></gn-ui-star-toggle>\n  <span\n    class=\"align-text-top ml-1.5\"\n    data-test=\"favorite-count\"\n    *ngIf=\"!displayCount\"\n    translate=\"datahub.record.addToFavorites\"\n  ></span>\n</div>\n"]}
111
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"favorite-star.component.js","sourceRoot":"","sources":["../../../../../../../../../libs/feature/search/src/lib/favorites/favorite-star/favorite-star.component.ts","../../../../../../../../../libs/feature/search/src/lib/favorites/favorite-star/favorite-star.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  Input,\n  OnDestroy,\n  ViewChild,\n} from '@angular/core'\nimport {\n  map,\n  pairwise,\n  startWith,\n  switchMap,\n  withLatestFrom,\n} from 'rxjs/operators'\nimport tippy from 'tippy.js'\nimport { TranslateService } from '@ngx-translate/core'\nimport { StarToggleComponent } from '../../../../../../../libs/ui/inputs/src'\nimport { Observable, Subscription } from 'rxjs'\nimport { CatalogRecord } from '../../../../../../../libs/common/domain/src/lib/model/record'\nimport { AuthService, FavoritesService } from '../../../../../../../libs/api/repository/src'\nimport { PlatformServiceInterface } from '../../../../../../../libs/common/domain/src/lib/platform.service.interface'\nimport { CommonModule } from '@angular/common'\n\n@Component({\n  selector: 'gn-ui-favorite-star',\n  templateUrl: './favorite-star.component.html',\n  styleUrls: ['./favorite-star.component.css'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true,\n  imports: [CommonModule, StarToggleComponent],\n})\nexport class FavoriteStarComponent implements AfterViewInit, OnDestroy {\n  @Input() displayCount? = true\n  @Input() set record(value) {\n    this.record_ = value\n    this.favoriteCount =\n      'extras' in this.record_ && 'favoriteCount' in this.record_.extras\n        ? (this.record_.extras.favoriteCount as number)\n        : null\n  }\n  get record() {\n    return this.record_\n  }\n  isFavorite$ = this.favoritesService.myFavoritesUuid$.pipe(\n    map((favorites) => favorites.indexOf(this.record.uniqueIdentifier) > -1)\n  )\n  isAnonymous$ = this.platformService.isAnonymous()\n  record_: Partial<CatalogRecord>\n  favoriteCount: number | null\n  loading = false\n  loginUrl = this.authService.loginUrl\n  loginMessage$: Observable<string> = this.translateService.onLangChange.pipe(\n    startWith(null), // make sure to wait for translations to be loaded with and without language change\n    switchMap(() =>\n      this.translateService.get('favorite.not.authenticated.tooltip', {\n        link: this.loginUrl,\n      })\n    )\n  )\n  @ViewChild(StarToggleComponent, { read: ElementRef })\n  starToggleRef: ElementRef\n  subscription: Subscription\n  countSubscription: Subscription\n\n  get hasFavoriteCount() {\n    return this.favoriteCount !== null\n  }\n\n  constructor(\n    private favoritesService: FavoritesService,\n    private platformService: PlatformServiceInterface,\n    private changeDetector: ChangeDetectorRef,\n    private authService: AuthService,\n    private translateService: TranslateService\n  ) {}\n\n  ngAfterViewInit(): void {\n    this.subscription = this.isAnonymous$\n      .pipe(withLatestFrom(this.loginMessage$))\n      .subscribe(([anonymous, loginMessage]) => {\n        if (anonymous) {\n          tippy(this.starToggleRef.nativeElement, {\n            appendTo: () => document.body,\n            content: loginMessage,\n            allowHTML: true,\n            interactive: true,\n            zIndex: 40,\n            maxWidth: 250,\n          })\n        }\n      })\n    this.countSubscription = this.favoritesService.myFavoritesUuid$\n      .pipe(pairwise())\n      .subscribe(([oldFavs, newFavs]) => {\n        const editedFavs = (\n          oldFavs.length < newFavs.length\n            ? newFavs.slice(-1)\n            : oldFavs.filter((fav) => !newFavs.includes(fav))\n        )[0]\n        if (\n          this.hasFavoriteCount &&\n          editedFavs === this.record.uniqueIdentifier\n        ) {\n          if (newFavs.includes(editedFavs)) {\n            this.favoriteCount += 1\n          } else {\n            this.favoriteCount += -1\n          }\n        }\n      })\n  }\n\n  ngOnDestroy(): void {\n    this.subscription.unsubscribe()\n    this.countSubscription.unsubscribe()\n  }\n\n  toggleFavorite(isFavorite) {\n    this.loading = true\n    ;(isFavorite\n      ? this.favoritesService.addToFavorites([this.record.uniqueIdentifier])\n      : this.favoritesService.removeFromFavorites([\n          this.record.uniqueIdentifier,\n        ])\n    ).subscribe({\n      complete: () => {\n        this.loading = false\n        this.changeDetector.detectChanges()\n      },\n      error: () => {\n        this.loading = false\n        this.changeDetector.detectChanges()\n      },\n    })\n  }\n}\n","<div class=\"flex flex-row items-center\">\n  <span\n    class=\"align-text-top mr-1.5 mt-0.5\"\n    data-test=\"favorite-count\"\n    *ngIf=\"hasFavoriteCount && displayCount\"\n    >{{ favoriteCount }}</span\n  >\n  <gn-ui-star-toggle\n    [toggled]=\"isFavorite$ | async\"\n    (newValue)=\"toggleFavorite($event)\"\n    [disabled]=\"loading || (isAnonymous$ | async)\"\n  ></gn-ui-star-toggle>\n</div>\n"]}
@@ -56,11 +56,11 @@ export class ResultsListContainerComponent {
56
56
  return this.recordUrlTemplate.replace('${uuid}', metadata.uniqueIdentifier);
57
57
  }
58
58
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ResultsListContainerComponent, deps: [{ token: i1.SearchFacade }, { token: RESULTS_LAYOUT_CONFIG }, { token: RECORD_URL_TOKEN, optional: true }], target: i0.ɵɵFactoryTarget.Component }); }
59
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: ResultsListContainerComponent, selector: "gn-ui-results-list-container", inputs: { metadataQualityDisplay: "metadataQualityDisplay", layout: "layout", showMore: "showMore" }, outputs: { mdSelect: "mdSelect" }, ngImport: i0, template: "<div *ngIf=\"(error$ | async) === null\" class=\"search-results relative\">\n <gn-ui-results-list\n [records]=\"facade.results$ | async\"\n [layoutConfig]=\"layoutConfig$ | async\"\n [metadataQualityDisplay]=\"\n metadataQualityDisplay && (pipelineForQualityScoreActivated | async)\n \"\n [favoriteTemplate]=\"favoriteToggle\"\n [recordUrlGetter]=\"recordUrlGetter\"\n (mdSelect)=\"onMetadataSelection($event)\"\n ></gn-ui-results-list>\n <ng-container *ngIf=\"allowShowMore$ | async\">\n <div class=\"show-more h-[100px] pt-[30px]\" *ngIf=\"showMore === 'button'\">\n <gn-ui-button\n data-cy=\"addMoreBtn\"\n type=\"secondary\"\n (buttonClick)=\"onShowMore()\"\n extraClass=\"m-auto !p-[22px]\"\n >\n <span class=\"uppercase font-medium tracking-widest\" translate\n >results.showMore</span\n >\n </gn-ui-button>\n </div>\n <div class=\"show-more h-[100px]\" *ngIf=\"showMore === 'auto'\">\n <gn-ui-viewport-intersector\n (entersViewport)=\"onShowMore()\"\n ></gn-ui-viewport-intersector>\n </div>\n </ng-container>\n\n <ng-container *ngIf=\"(facade.isLoading$ | async) === true\">\n <div class=\"loading flex justify-center h-[100px] pt-[45px]\">\n <gn-ui-spinning-loader></gn-ui-spinning-loader>\n </div>\n </ng-container>\n</div>\n\n<div class=\"p-4 max-w-[600px] m-auto text-[13px]\">\n <gn-ui-error\n *ngIf=\"(errorCode$ | async) === 0\"\n [type]=\"errorTypes.COULD_NOT_REACH_API\"\n >\n </gn-ui-error>\n <gn-ui-error\n *ngIf=\"(error$ | async) !== null && (errorCode$ | async) !== 0\"\n [type]=\"errorTypes.RECEIVED_ERROR\"\n [error]=\"errorMessage$ | async\"\n ></gn-ui-error>\n</div>\n\n<ng-template #favoriteToggle let-record>\n <gn-ui-favorite-star [record]=\"record\"></gn-ui-favorite-star>\n</ng-template>\n", styles: [""], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.TranslateDirective, selector: "[translate],[ngx-translate]", inputs: ["translate", "translateParams"] }, { kind: "component", type: i4.ResultsListComponent, selector: "gn-ui-results-list", inputs: ["records", "layoutConfig", "favoriteTemplate", "recordUrlGetter", "metadataQualityDisplay"], outputs: ["mdSelect"] }, { kind: "component", type: i5.ButtonComponent, selector: "gn-ui-button", inputs: ["type", "disabled", "extraClass"], outputs: ["buttonClick"] }, { kind: "component", type: i6.ViewportIntersectorComponent, selector: "gn-ui-viewport-intersector", outputs: ["isInViewport", "entersViewport", "exitsViewport"] }, { kind: "component", type: i7.SpinningLoaderComponent, selector: "gn-ui-spinning-loader" }, { kind: "component", type: i8.ErrorComponent, selector: "gn-ui-error", inputs: ["type", "error", "recordId"] }, { kind: "component", type: i9.FavoriteStarComponent, selector: "gn-ui-favorite-star", inputs: ["displayCount", "record"] }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }] }); }
59
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: ResultsListContainerComponent, selector: "gn-ui-results-list-container", inputs: { metadataQualityDisplay: "metadataQualityDisplay", layout: "layout", showMore: "showMore" }, outputs: { mdSelect: "mdSelect" }, ngImport: i0, template: "<div *ngIf=\"(error$ | async) === null\" class=\"search-results relative\">\n <gn-ui-results-list\n [records]=\"facade.results$ | async\"\n [layoutConfig]=\"layoutConfig$ | async\"\n [metadataQualityDisplay]=\"\n metadataQualityDisplay && (pipelineForQualityScoreActivated | async)\n \"\n [favoriteTemplate]=\"favoriteToggle\"\n [recordUrlGetter]=\"recordUrlGetter\"\n (mdSelect)=\"onMetadataSelection($event)\"\n ></gn-ui-results-list>\n <ng-container *ngIf=\"allowShowMore$ | async\">\n <div class=\"show-more h-[100px] pt-[30px]\" *ngIf=\"showMore === 'button'\">\n <gn-ui-button\n data-cy=\"addMoreBtn\"\n type=\"secondary\"\n (buttonClick)=\"onShowMore()\"\n extraClass=\"m-auto !p-[22px]\"\n >\n <span class=\"uppercase font-medium tracking-widest\" translate\n >results.showMore</span\n >\n </gn-ui-button>\n </div>\n <div class=\"show-more h-[100px]\" *ngIf=\"showMore === 'auto'\">\n <gn-ui-viewport-intersector\n (entersViewport)=\"onShowMore()\"\n ></gn-ui-viewport-intersector>\n </div>\n </ng-container>\n\n <ng-container *ngIf=\"(facade.isLoading$ | async) === true\">\n <div class=\"loading flex justify-center h-[100px] pt-[45px]\">\n <gn-ui-spinning-loader></gn-ui-spinning-loader>\n </div>\n </ng-container>\n</div>\n\n<div class=\"p-4 max-w-[600px] m-auto text-[13px]\">\n <gn-ui-error\n *ngIf=\"(errorCode$ | async) === 0\"\n [type]=\"errorTypes.COULD_NOT_REACH_API\"\n >\n </gn-ui-error>\n <gn-ui-error\n *ngIf=\"(error$ | async) !== null && (errorCode$ | async) !== 0\"\n [type]=\"errorTypes.RECEIVED_ERROR\"\n [error]=\"errorMessage$ | async\"\n ></gn-ui-error>\n</div>\n\n<ng-template #favoriteToggle let-record>\n <gn-ui-favorite-star [record]=\"record\"></gn-ui-favorite-star>\n</ng-template>\n", styles: [":host{--gn-ui-button-height: 24px;--gn-ui-button-width: 24px;--gn-ui-button-color: var(--color-secondary);--gn-ui-button-border-width: 0px}\n"], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.TranslateDirective, selector: "[translate],[ngx-translate]", inputs: ["translate", "translateParams"] }, { kind: "component", type: i4.ResultsListComponent, selector: "gn-ui-results-list", inputs: ["records", "layoutConfig", "favoriteTemplate", "recordUrlGetter", "metadataQualityDisplay"], outputs: ["mdSelect"] }, { kind: "component", type: i5.ButtonComponent, selector: "gn-ui-button", inputs: ["type", "disabled", "extraClass"], outputs: ["buttonClick"] }, { kind: "component", type: i6.ViewportIntersectorComponent, selector: "gn-ui-viewport-intersector", outputs: ["isInViewport", "entersViewport", "exitsViewport"] }, { kind: "component", type: i7.SpinningLoaderComponent, selector: "gn-ui-spinning-loader" }, { kind: "component", type: i8.ErrorComponent, selector: "gn-ui-error", inputs: ["type", "error", "recordId"] }, { kind: "component", type: i9.FavoriteStarComponent, selector: "gn-ui-favorite-star", inputs: ["displayCount", "record"] }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }] }); }
60
60
  }
61
61
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ResultsListContainerComponent, decorators: [{
62
62
  type: Component,
63
- args: [{ selector: 'gn-ui-results-list-container', template: "<div *ngIf=\"(error$ | async) === null\" class=\"search-results relative\">\n <gn-ui-results-list\n [records]=\"facade.results$ | async\"\n [layoutConfig]=\"layoutConfig$ | async\"\n [metadataQualityDisplay]=\"\n metadataQualityDisplay && (pipelineForQualityScoreActivated | async)\n \"\n [favoriteTemplate]=\"favoriteToggle\"\n [recordUrlGetter]=\"recordUrlGetter\"\n (mdSelect)=\"onMetadataSelection($event)\"\n ></gn-ui-results-list>\n <ng-container *ngIf=\"allowShowMore$ | async\">\n <div class=\"show-more h-[100px] pt-[30px]\" *ngIf=\"showMore === 'button'\">\n <gn-ui-button\n data-cy=\"addMoreBtn\"\n type=\"secondary\"\n (buttonClick)=\"onShowMore()\"\n extraClass=\"m-auto !p-[22px]\"\n >\n <span class=\"uppercase font-medium tracking-widest\" translate\n >results.showMore</span\n >\n </gn-ui-button>\n </div>\n <div class=\"show-more h-[100px]\" *ngIf=\"showMore === 'auto'\">\n <gn-ui-viewport-intersector\n (entersViewport)=\"onShowMore()\"\n ></gn-ui-viewport-intersector>\n </div>\n </ng-container>\n\n <ng-container *ngIf=\"(facade.isLoading$ | async) === true\">\n <div class=\"loading flex justify-center h-[100px] pt-[45px]\">\n <gn-ui-spinning-loader></gn-ui-spinning-loader>\n </div>\n </ng-container>\n</div>\n\n<div class=\"p-4 max-w-[600px] m-auto text-[13px]\">\n <gn-ui-error\n *ngIf=\"(errorCode$ | async) === 0\"\n [type]=\"errorTypes.COULD_NOT_REACH_API\"\n >\n </gn-ui-error>\n <gn-ui-error\n *ngIf=\"(error$ | async) !== null && (errorCode$ | async) !== 0\"\n [type]=\"errorTypes.RECEIVED_ERROR\"\n [error]=\"errorMessage$ | async\"\n ></gn-ui-error>\n</div>\n\n<ng-template #favoriteToggle let-record>\n <gn-ui-favorite-star [record]=\"record\"></gn-ui-favorite-star>\n</ng-template>\n" }]
63
+ args: [{ selector: 'gn-ui-results-list-container', template: "<div *ngIf=\"(error$ | async) === null\" class=\"search-results relative\">\n <gn-ui-results-list\n [records]=\"facade.results$ | async\"\n [layoutConfig]=\"layoutConfig$ | async\"\n [metadataQualityDisplay]=\"\n metadataQualityDisplay && (pipelineForQualityScoreActivated | async)\n \"\n [favoriteTemplate]=\"favoriteToggle\"\n [recordUrlGetter]=\"recordUrlGetter\"\n (mdSelect)=\"onMetadataSelection($event)\"\n ></gn-ui-results-list>\n <ng-container *ngIf=\"allowShowMore$ | async\">\n <div class=\"show-more h-[100px] pt-[30px]\" *ngIf=\"showMore === 'button'\">\n <gn-ui-button\n data-cy=\"addMoreBtn\"\n type=\"secondary\"\n (buttonClick)=\"onShowMore()\"\n extraClass=\"m-auto !p-[22px]\"\n >\n <span class=\"uppercase font-medium tracking-widest\" translate\n >results.showMore</span\n >\n </gn-ui-button>\n </div>\n <div class=\"show-more h-[100px]\" *ngIf=\"showMore === 'auto'\">\n <gn-ui-viewport-intersector\n (entersViewport)=\"onShowMore()\"\n ></gn-ui-viewport-intersector>\n </div>\n </ng-container>\n\n <ng-container *ngIf=\"(facade.isLoading$ | async) === true\">\n <div class=\"loading flex justify-center h-[100px] pt-[45px]\">\n <gn-ui-spinning-loader></gn-ui-spinning-loader>\n </div>\n </ng-container>\n</div>\n\n<div class=\"p-4 max-w-[600px] m-auto text-[13px]\">\n <gn-ui-error\n *ngIf=\"(errorCode$ | async) === 0\"\n [type]=\"errorTypes.COULD_NOT_REACH_API\"\n >\n </gn-ui-error>\n <gn-ui-error\n *ngIf=\"(error$ | async) !== null && (errorCode$ | async) !== 0\"\n [type]=\"errorTypes.RECEIVED_ERROR\"\n [error]=\"errorMessage$ | async\"\n ></gn-ui-error>\n</div>\n\n<ng-template #favoriteToggle let-record>\n <gn-ui-favorite-star [record]=\"record\"></gn-ui-favorite-star>\n</ng-template>\n", styles: [":host{--gn-ui-button-height: 24px;--gn-ui-button-width: 24px;--gn-ui-button-color: var(--color-secondary);--gn-ui-button-border-width: 0px}\n"] }]
64
64
  }], ctorParameters: () => [{ type: i1.SearchFacade }, { type: undefined, decorators: [{
65
65
  type: Inject,
66
66
  args: [RESULTS_LAYOUT_CONFIG]
@@ -15,7 +15,6 @@ export * from './lib/dropdown-selector/dropdown-selector.model';
15
15
  export * from './lib/editable-label/editable-label.directive';
16
16
  export * from './lib/file-input/file-input.component';
17
17
  export * from './lib/files-drop/files-drop.directive';
18
- export * from './lib/navigation-button/navigation-button.component';
19
18
  export * from './lib/search-input/search-input.component';
20
19
  export * from './lib/star-toggle/star-toggle.component';
21
20
  export * from './lib/switch-toggle/switch-toggle.component';
@@ -24,4 +23,4 @@ export * from './lib/text-input/text-input.component';
24
23
  export * from './lib/ui-inputs.module';
25
24
  export * from './lib/url-input/url-input.component';
26
25
  export * from './lib/viewport-intersector/viewport-intersector.component';
27
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzL3VpL2lucHV0cy9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYywyQ0FBMkMsQ0FBQTtBQUN6RCxjQUFjLDZCQUE2QixDQUFBO0FBQzNDLGNBQWMsK0JBQStCLENBQUE7QUFDN0MsY0FBYywyQ0FBMkMsQ0FBQTtBQUN6RCxjQUFjLG1DQUFtQyxDQUFBO0FBQ2pELGNBQWMsbURBQW1ELENBQUE7QUFDakUsY0FBYyx5Q0FBeUMsQ0FBQTtBQUN2RCxjQUFjLHlEQUF5RCxDQUFBO0FBQ3ZFLGNBQWMscURBQXFELENBQUE7QUFDbkUsY0FBYyxtRUFBbUUsQ0FBQTtBQUNqRixjQUFjLDJEQUEyRCxDQUFBO0FBQ3pFLGNBQWMsdURBQXVELENBQUE7QUFDckUsY0FBYyxxREFBcUQsQ0FBQTtBQUNuRSxjQUFjLGlEQUFpRCxDQUFBO0FBQy9ELGNBQWMsK0NBQStDLENBQUE7QUFDN0QsY0FBYyx1Q0FBdUMsQ0FBQTtBQUNyRCxjQUFjLHVDQUF1QyxDQUFBO0FBQ3JELGNBQWMscURBQXFELENBQUE7QUFDbkUsY0FBYywyQ0FBMkMsQ0FBQTtBQUN6RCxjQUFjLHlDQUF5QyxDQUFBO0FBQ3ZELGNBQWMsNkNBQTZDLENBQUE7QUFDM0QsY0FBYyxxQ0FBcUMsQ0FBQTtBQUNuRCxjQUFjLHVDQUF1QyxDQUFBO0FBQ3JELGNBQWMsd0JBQXdCLENBQUE7QUFDdEMsY0FBYyxxQ0FBcUMsQ0FBQTtBQUNuRCxjQUFjLDJEQUEyRCxDQUFBIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9saWIvYXV0b2NvbXBsZXRlL2F1dG9jb21wbGV0ZS5jb21wb25lbnQnXG5leHBvcnQgKiBmcm9tICcuL2xpYi9iYWRnZS9iYWRnZS5jb21wb25lbnQnXG5leHBvcnQgKiBmcm9tICcuL2xpYi9idXR0b24vYnV0dG9uLmNvbXBvbmVudCdcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NoZWNrLXRvZ2dsZS9jaGVjay10b2dnbGUuY29tcG9uZW50J1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY2hlY2tib3gvY2hlY2tib3guY29tcG9uZW50J1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29weS10ZXh0LWJ1dHRvbi9jb3B5LXRleHQtYnV0dG9uLmNvbXBvbmVudCdcbmV4cG9ydCAqIGZyb20gJy4vbGliL2RhdGUtcGlja2VyL2RhdGUtcGlja2VyLmNvbXBvbmVudCdcbmV4cG9ydCAqIGZyb20gJy4vbGliL2RhdGUtcmFuZ2UtZHJvcGRvd24vZGF0ZS1yYW5nZS1kcm9wZG93bi5jb21wb25lbnQnXG5leHBvcnQgKiBmcm9tICcuL2xpYi9kYXRlLXJhbmdlLXBpY2tlci9kYXRlLXJhbmdlLXBpY2tlci5jb21wb25lbnQnXG5leHBvcnQgKiBmcm9tICcuL2xpYi9kcmFnLWFuZC1kcm9wLWZpbGUtaW5wdXQvZHJhZy1hbmQtZHJvcC1maWxlLWlucHV0LmNvbXBvbmVudCdcbmV4cG9ydCAqIGZyb20gJy4vbGliL2Ryb3Bkb3duLW11bHRpc2VsZWN0L2Ryb3Bkb3duLW11bHRpc2VsZWN0LmNvbXBvbmVudCdcbmV4cG9ydCAqIGZyb20gJy4vbGliL2Ryb3Bkb3duLW11bHRpc2VsZWN0L2Ryb3Bkb3duLW11bHRpc2VsZWN0Lm1vZGVsJ1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZHJvcGRvd24tc2VsZWN0b3IvZHJvcGRvd24tc2VsZWN0b3IuY29tcG9uZW50J1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZHJvcGRvd24tc2VsZWN0b3IvZHJvcGRvd24tc2VsZWN0b3IubW9kZWwnXG5leHBvcnQgKiBmcm9tICcuL2xpYi9lZGl0YWJsZS1sYWJlbC9lZGl0YWJsZS1sYWJlbC5kaXJlY3RpdmUnXG5leHBvcnQgKiBmcm9tICcuL2xpYi9maWxlLWlucHV0L2ZpbGUtaW5wdXQuY29tcG9uZW50J1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZmlsZXMtZHJvcC9maWxlcy1kcm9wLmRpcmVjdGl2ZSdcbmV4cG9ydCAqIGZyb20gJy4vbGliL25hdmlnYXRpb24tYnV0dG9uL25hdmlnYXRpb24tYnV0dG9uLmNvbXBvbmVudCdcbmV4cG9ydCAqIGZyb20gJy4vbGliL3NlYXJjaC1pbnB1dC9zZWFyY2gtaW5wdXQuY29tcG9uZW50J1xuZXhwb3J0ICogZnJvbSAnLi9saWIvc3Rhci10b2dnbGUvc3Rhci10b2dnbGUuY29tcG9uZW50J1xuZXhwb3J0ICogZnJvbSAnLi9saWIvc3dpdGNoLXRvZ2dsZS9zd2l0Y2gtdG9nZ2xlLmNvbXBvbmVudCdcbmV4cG9ydCAqIGZyb20gJy4vbGliL3RleHQtYXJlYS90ZXh0LWFyZWEuY29tcG9uZW50J1xuZXhwb3J0ICogZnJvbSAnLi9saWIvdGV4dC1pbnB1dC90ZXh0LWlucHV0LmNvbXBvbmVudCdcbmV4cG9ydCAqIGZyb20gJy4vbGliL3VpLWlucHV0cy5tb2R1bGUnXG5leHBvcnQgKiBmcm9tICcuL2xpYi91cmwtaW5wdXQvdXJsLWlucHV0LmNvbXBvbmVudCdcbmV4cG9ydCAqIGZyb20gJy4vbGliL3ZpZXdwb3J0LWludGVyc2VjdG9yL3ZpZXdwb3J0LWludGVyc2VjdG9yLmNvbXBvbmVudCdcbiJdfQ==
26
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzL3VpL2lucHV0cy9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYywyQ0FBMkMsQ0FBQTtBQUN6RCxjQUFjLDZCQUE2QixDQUFBO0FBQzNDLGNBQWMsK0JBQStCLENBQUE7QUFDN0MsY0FBYywyQ0FBMkMsQ0FBQTtBQUN6RCxjQUFjLG1DQUFtQyxDQUFBO0FBQ2pELGNBQWMsbURBQW1ELENBQUE7QUFDakUsY0FBYyx5Q0FBeUMsQ0FBQTtBQUN2RCxjQUFjLHlEQUF5RCxDQUFBO0FBQ3ZFLGNBQWMscURBQXFELENBQUE7QUFDbkUsY0FBYyxtRUFBbUUsQ0FBQTtBQUNqRixjQUFjLDJEQUEyRCxDQUFBO0FBQ3pFLGNBQWMsdURBQXVELENBQUE7QUFDckUsY0FBYyxxREFBcUQsQ0FBQTtBQUNuRSxjQUFjLGlEQUFpRCxDQUFBO0FBQy9ELGNBQWMsK0NBQStDLENBQUE7QUFDN0QsY0FBYyx1Q0FBdUMsQ0FBQTtBQUNyRCxjQUFjLHVDQUF1QyxDQUFBO0FBQ3JELGNBQWMsMkNBQTJDLENBQUE7QUFDekQsY0FBYyx5Q0FBeUMsQ0FBQTtBQUN2RCxjQUFjLDZDQUE2QyxDQUFBO0FBQzNELGNBQWMscUNBQXFDLENBQUE7QUFDbkQsY0FBYyx1Q0FBdUMsQ0FBQTtBQUNyRCxjQUFjLHdCQUF3QixDQUFBO0FBQ3RDLGNBQWMscUNBQXFDLENBQUE7QUFDbkQsY0FBYywyREFBMkQsQ0FBQSIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vbGliL2F1dG9jb21wbGV0ZS9hdXRvY29tcGxldGUuY29tcG9uZW50J1xuZXhwb3J0ICogZnJvbSAnLi9saWIvYmFkZ2UvYmFkZ2UuY29tcG9uZW50J1xuZXhwb3J0ICogZnJvbSAnLi9saWIvYnV0dG9uL2J1dHRvbi5jb21wb25lbnQnXG5leHBvcnQgKiBmcm9tICcuL2xpYi9jaGVjay10b2dnbGUvY2hlY2stdG9nZ2xlLmNvbXBvbmVudCdcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NoZWNrYm94L2NoZWNrYm94LmNvbXBvbmVudCdcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvcHktdGV4dC1idXR0b24vY29weS10ZXh0LWJ1dHRvbi5jb21wb25lbnQnXG5leHBvcnQgKiBmcm9tICcuL2xpYi9kYXRlLXBpY2tlci9kYXRlLXBpY2tlci5jb21wb25lbnQnXG5leHBvcnQgKiBmcm9tICcuL2xpYi9kYXRlLXJhbmdlLWRyb3Bkb3duL2RhdGUtcmFuZ2UtZHJvcGRvd24uY29tcG9uZW50J1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZGF0ZS1yYW5nZS1waWNrZXIvZGF0ZS1yYW5nZS1waWNrZXIuY29tcG9uZW50J1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZHJhZy1hbmQtZHJvcC1maWxlLWlucHV0L2RyYWctYW5kLWRyb3AtZmlsZS1pbnB1dC5jb21wb25lbnQnXG5leHBvcnQgKiBmcm9tICcuL2xpYi9kcm9wZG93bi1tdWx0aXNlbGVjdC9kcm9wZG93bi1tdWx0aXNlbGVjdC5jb21wb25lbnQnXG5leHBvcnQgKiBmcm9tICcuL2xpYi9kcm9wZG93bi1tdWx0aXNlbGVjdC9kcm9wZG93bi1tdWx0aXNlbGVjdC5tb2RlbCdcbmV4cG9ydCAqIGZyb20gJy4vbGliL2Ryb3Bkb3duLXNlbGVjdG9yL2Ryb3Bkb3duLXNlbGVjdG9yLmNvbXBvbmVudCdcbmV4cG9ydCAqIGZyb20gJy4vbGliL2Ryb3Bkb3duLXNlbGVjdG9yL2Ryb3Bkb3duLXNlbGVjdG9yLm1vZGVsJ1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZWRpdGFibGUtbGFiZWwvZWRpdGFibGUtbGFiZWwuZGlyZWN0aXZlJ1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZmlsZS1pbnB1dC9maWxlLWlucHV0LmNvbXBvbmVudCdcbmV4cG9ydCAqIGZyb20gJy4vbGliL2ZpbGVzLWRyb3AvZmlsZXMtZHJvcC5kaXJlY3RpdmUnXG5leHBvcnQgKiBmcm9tICcuL2xpYi9zZWFyY2gtaW5wdXQvc2VhcmNoLWlucHV0LmNvbXBvbmVudCdcbmV4cG9ydCAqIGZyb20gJy4vbGliL3N0YXItdG9nZ2xlL3N0YXItdG9nZ2xlLmNvbXBvbmVudCdcbmV4cG9ydCAqIGZyb20gJy4vbGliL3N3aXRjaC10b2dnbGUvc3dpdGNoLXRvZ2dsZS5jb21wb25lbnQnXG5leHBvcnQgKiBmcm9tICcuL2xpYi90ZXh0LWFyZWEvdGV4dC1hcmVhLmNvbXBvbmVudCdcbmV4cG9ydCAqIGZyb20gJy4vbGliL3RleHQtaW5wdXQvdGV4dC1pbnB1dC5jb21wb25lbnQnXG5leHBvcnQgKiBmcm9tICcuL2xpYi91aS1pbnB1dHMubW9kdWxlJ1xuZXhwb3J0ICogZnJvbSAnLi9saWIvdXJsLWlucHV0L3VybC1pbnB1dC5jb21wb25lbnQnXG5leHBvcnQgKiBmcm9tICcuL2xpYi92aWV3cG9ydC1pbnRlcnNlY3Rvci92aWV3cG9ydC1pbnRlcnNlY3Rvci5jb21wb25lbnQnXG4iXX0=
@@ -3,6 +3,7 @@ import { propagateToDocumentOnly } from '../../../../../../libs/util/shared/src'
3
3
  import { NgIcon, provideIcons } from '@ng-icons/core';
4
4
  import { CommonModule } from '@angular/common';
5
5
  import { matStar, matStarBorder } from '@ng-icons/material-icons/baseline';
6
+ import { ButtonComponent } from '../button/button.component';
6
7
  import * as i0 from "@angular/core";
7
8
  import * as i1 from "@angular/common";
8
9
  export class StarToggleComponent {
@@ -24,11 +25,11 @@ export class StarToggleComponent {
24
25
  event.preventDefault();
25
26
  }
26
27
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: StarToggleComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
27
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: StarToggleComponent, isStandalone: true, selector: "gn-ui-star-toggle", inputs: { toggled: "toggled", disabled: "disabled" }, outputs: { newValue: "newValue" }, viewQueries: [{ propertyName: "overlay", first: true, predicate: ["starOverlay"], descendants: true }], ngImport: i0, template: "<div class=\"inline-block relative align-middle\" style=\"line-height: 0.7em\">\n <button\n type=\"button\"\n class=\"-m-[8px] p-[8px]\"\n (click)=\"toggle($event)\"\n [ngClass]=\"{\n enabled: toggled,\n 'disabled opacity-45': !toggled,\n 'transition hover:scale-125 will-change-transform': !disabled,\n 'cursor-default': disabled,\n }\"\n >\n <ng-icon [name]=\"toggled ? 'matStar' : 'matStarBorder'\"></ng-icon>\n </button>\n <svg\n #starOverlay\n class=\"star-toggle-overlay\"\n width=\"40px\"\n height=\"40px\"\n viewBox=\"-15 -15 30 30\"\n >\n <g>\n <path d=\"M 0,13.229167 V 0\" />\n <path d=\"M -12.484186,4.0880377 0,0\" />\n <path d=\"M -7.6784102,-10.70262 0,0\" />\n <path d=\"M 7.8734079,-10.70262 0,0\" />\n <path d=\"M 12.679184,4.0880376 0,0\" />\n </g>\n </svg>\n</div>\n", styles: ["button.enabled{color:var(--star-toggle-enabled-color, var(--color-secondary))}button.disabled{color:var(--star-toggle-disabled-color, var(--color-primary))}.star-filled{font-variation-settings:\"FILL\" 1}.star-toggle-overlay{stroke:var(--color-secondary);stroke-width:3.5px;stroke-linecap:round;position:absolute;top:50%;left:50%;width:2.5em;height:2.5em;transform:translate(-50%,-50%);pointer-events:none;stroke-dasharray:5 20;stroke-dashoffset:-15;animation:overlay-dash .8s cubic-bezier(.16,.66,.44,.96) forwards;animation-play-state:paused}@keyframes overlay-dash{to{stroke-dashoffset:7}}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "component", type: NgIcon, selector: "ng-icon", inputs: ["name", "svg", "size", "strokeWidth", "color"] }], viewProviders: [provideIcons({ matStar, matStarBorder })], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
28
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: StarToggleComponent, isStandalone: true, selector: "gn-ui-star-toggle", inputs: { toggled: "toggled", disabled: "disabled" }, outputs: { newValue: "newValue" }, viewQueries: [{ propertyName: "overlay", first: true, predicate: ["starOverlay"], descendants: true }], ngImport: i0, template: "<div class=\"inline-block relative align-middle\" style=\"line-height: 0.7em\">\n <gn-ui-button\n [type]=\"'outline'\"\n class=\"-m-[8px] p-[8px]\"\n (buttonClick)=\"toggle($event)\"\n [ngClass]=\"{\n enabled: toggled,\n disabled: !toggled,\n 'transition hover:scale-125 will-change-transform': !disabled,\n 'cursor-default': disabled,\n }\"\n >\n <ng-icon [name]=\"toggled ? 'matStar' : 'matStarBorder'\"></ng-icon>\n </gn-ui-button>\n <svg\n #starOverlay\n class=\"star-toggle-overlay\"\n width=\"40px\"\n height=\"40px\"\n viewBox=\"-15 -15 30 30\"\n >\n <g>\n <path d=\"M 0,13.229167 V 0\" />\n <path d=\"M -12.484186,4.0880377 0,0\" />\n <path d=\"M -7.6784102,-10.70262 0,0\" />\n <path d=\"M 7.8734079,-10.70262 0,0\" />\n <path d=\"M 12.679184,4.0880376 0,0\" />\n </g>\n </svg>\n</div>\n", styles: ["button.enabled{color:var(--star-toggle-enabled-color, var(--color-secondary))}button.disabled{color:var(--star-toggle-disabled-color, var(--color-primary))}.star-filled{font-variation-settings:\"FILL\" 1}.star-toggle-overlay{stroke:var(--color-secondary);stroke-width:3.5px;stroke-linecap:round;position:absolute;top:50%;left:50%;width:2.5em;height:2.5em;transform:translate(-50%,-50%);pointer-events:none;stroke-dasharray:5 20;stroke-dashoffset:-15;animation:overlay-dash .8s cubic-bezier(.16,.66,.44,.96) forwards;animation-play-state:paused}@keyframes overlay-dash{to{stroke-dashoffset:7}}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "component", type: NgIcon, selector: "ng-icon", inputs: ["name", "svg", "size", "strokeWidth", "color"] }, { kind: "component", type: ButtonComponent, selector: "gn-ui-button", inputs: ["type", "disabled", "extraClass"], outputs: ["buttonClick"] }], viewProviders: [provideIcons({ matStar, matStarBorder })], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
28
29
  }
29
30
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: StarToggleComponent, decorators: [{
30
31
  type: Component,
31
- args: [{ selector: 'gn-ui-star-toggle', changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, imports: [CommonModule, NgIcon], viewProviders: [provideIcons({ matStar, matStarBorder })], template: "<div class=\"inline-block relative align-middle\" style=\"line-height: 0.7em\">\n <button\n type=\"button\"\n class=\"-m-[8px] p-[8px]\"\n (click)=\"toggle($event)\"\n [ngClass]=\"{\n enabled: toggled,\n 'disabled opacity-45': !toggled,\n 'transition hover:scale-125 will-change-transform': !disabled,\n 'cursor-default': disabled,\n }\"\n >\n <ng-icon [name]=\"toggled ? 'matStar' : 'matStarBorder'\"></ng-icon>\n </button>\n <svg\n #starOverlay\n class=\"star-toggle-overlay\"\n width=\"40px\"\n height=\"40px\"\n viewBox=\"-15 -15 30 30\"\n >\n <g>\n <path d=\"M 0,13.229167 V 0\" />\n <path d=\"M -12.484186,4.0880377 0,0\" />\n <path d=\"M -7.6784102,-10.70262 0,0\" />\n <path d=\"M 7.8734079,-10.70262 0,0\" />\n <path d=\"M 12.679184,4.0880376 0,0\" />\n </g>\n </svg>\n</div>\n", styles: ["button.enabled{color:var(--star-toggle-enabled-color, var(--color-secondary))}button.disabled{color:var(--star-toggle-disabled-color, var(--color-primary))}.star-filled{font-variation-settings:\"FILL\" 1}.star-toggle-overlay{stroke:var(--color-secondary);stroke-width:3.5px;stroke-linecap:round;position:absolute;top:50%;left:50%;width:2.5em;height:2.5em;transform:translate(-50%,-50%);pointer-events:none;stroke-dasharray:5 20;stroke-dashoffset:-15;animation:overlay-dash .8s cubic-bezier(.16,.66,.44,.96) forwards;animation-play-state:paused}@keyframes overlay-dash{to{stroke-dashoffset:7}}\n"] }]
32
+ args: [{ selector: 'gn-ui-star-toggle', changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, imports: [CommonModule, NgIcon, ButtonComponent], viewProviders: [provideIcons({ matStar, matStarBorder })], template: "<div class=\"inline-block relative align-middle\" style=\"line-height: 0.7em\">\n <gn-ui-button\n [type]=\"'outline'\"\n class=\"-m-[8px] p-[8px]\"\n (buttonClick)=\"toggle($event)\"\n [ngClass]=\"{\n enabled: toggled,\n disabled: !toggled,\n 'transition hover:scale-125 will-change-transform': !disabled,\n 'cursor-default': disabled,\n }\"\n >\n <ng-icon [name]=\"toggled ? 'matStar' : 'matStarBorder'\"></ng-icon>\n </gn-ui-button>\n <svg\n #starOverlay\n class=\"star-toggle-overlay\"\n width=\"40px\"\n height=\"40px\"\n viewBox=\"-15 -15 30 30\"\n >\n <g>\n <path d=\"M 0,13.229167 V 0\" />\n <path d=\"M -12.484186,4.0880377 0,0\" />\n <path d=\"M -7.6784102,-10.70262 0,0\" />\n <path d=\"M 7.8734079,-10.70262 0,0\" />\n <path d=\"M 12.679184,4.0880376 0,0\" />\n </g>\n </svg>\n</div>\n", styles: ["button.enabled{color:var(--star-toggle-enabled-color, var(--color-secondary))}button.disabled{color:var(--star-toggle-disabled-color, var(--color-primary))}.star-filled{font-variation-settings:\"FILL\" 1}.star-toggle-overlay{stroke:var(--color-secondary);stroke-width:3.5px;stroke-linecap:round;position:absolute;top:50%;left:50%;width:2.5em;height:2.5em;transform:translate(-50%,-50%);pointer-events:none;stroke-dasharray:5 20;stroke-dashoffset:-15;animation:overlay-dash .8s cubic-bezier(.16,.66,.44,.96) forwards;animation-play-state:paused}@keyframes overlay-dash{to{stroke-dashoffset:7}}\n"] }]
32
33
  }], propDecorators: { toggled: [{
33
34
  type: Input
34
35
  }], disabled: [{
@@ -39,4 +40,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
39
40
  type: ViewChild,
40
41
  args: ['starOverlay']
41
42
  }] } });
42
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3Rhci10b2dnbGUuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy91aS9pbnB1dHMvc3JjL2xpYi9zdGFyLXRvZ2dsZS9zdGFyLXRvZ2dsZS5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL3VpL2lucHV0cy9zcmMvbGliL3N0YXItdG9nZ2xlL3N0YXItdG9nZ2xlLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFDTCx1QkFBdUIsRUFDdkIsU0FBUyxFQUNULFVBQVUsRUFDVixZQUFZLEVBQ1osS0FBSyxFQUNMLE1BQU0sRUFDTixTQUFTLEdBQ1YsTUFBTSxlQUFlLENBQUE7QUFDdEIsT0FBTyxFQUFFLHVCQUF1QixFQUFFLE1BQU0sd0NBQXdDLENBQUE7QUFDaEYsT0FBTyxFQUFFLE1BQU0sRUFBRSxZQUFZLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQTtBQUNyRCxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUE7QUFDOUMsT0FBTyxFQUFFLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxtQ0FBbUMsQ0FBQTs7O0FBVzFFLE1BQU0sT0FBTyxtQkFBbUI7SUFUaEM7UUFXVyxhQUFRLEdBQUcsS0FBSyxDQUFBO1FBQ2YsYUFBUSxHQUFHLElBQUksWUFBWSxFQUFXLENBQUE7S0FnQmpEO0lBYkMsTUFBTSxDQUFDLEtBQVk7UUFDakIsSUFBSSxDQUFDLElBQUksQ0FBQyxRQUFRLEVBQUUsQ0FBQztZQUNuQixJQUFJLENBQUMsT0FBTyxHQUFHLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQTtZQUM1QixJQUFJLElBQUksQ0FBQyxPQUFPLEVBQUUsQ0FBQztnQkFDakIsTUFBTSxJQUFJLEdBQUcsSUFBSSxDQUFDLE9BQU8sQ0FBQyxhQUFhLENBQUMsYUFBYSxFQUFFLENBQUMsQ0FBQyxDQUFDLENBQUE7Z0JBQzFELElBQUksQ0FBQyxNQUFNLEVBQUUsQ0FBQTtnQkFDYixJQUFJLENBQUMsSUFBSSxFQUFFLENBQUE7WUFDYixDQUFDO1lBQ0QsSUFBSSxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxDQUFBO1FBQ2xDLENBQUM7UUFDRCx1QkFBdUIsQ0FBQyxLQUFLLENBQUMsQ0FBQTtRQUM5QixLQUFLLENBQUMsY0FBYyxFQUFFLENBQUE7SUFDeEIsQ0FBQzsrR0FsQlUsbUJBQW1CO21HQUFuQixtQkFBbUIsOFFDdkJoQyw4MkJBOEJBLDJvQkRWWSxZQUFZLDZIQUFFLE1BQU0sa0dBQ2YsQ0FBQyxZQUFZLENBQUMsRUFBRSxPQUFPLEVBQUUsYUFBYSxFQUFFLENBQUMsQ0FBQzs7NEZBRTlDLG1CQUFtQjtrQkFUL0IsU0FBUzsrQkFDRSxtQkFBbUIsbUJBR1osdUJBQXVCLENBQUMsTUFBTSxjQUNuQyxJQUFJLFdBQ1AsQ0FBQyxZQUFZLEVBQUUsTUFBTSxDQUFDLGlCQUNoQixDQUFDLFlBQVksQ0FBQyxFQUFFLE9BQU8sRUFBRSxhQUFhLEVBQUUsQ0FBQyxDQUFDOzhCQUdoRCxPQUFPO3NCQUFmLEtBQUs7Z0JBQ0csUUFBUTtzQkFBaEIsS0FBSztnQkFDSSxRQUFRO3NCQUFqQixNQUFNO2dCQUNtQixPQUFPO3NCQUFoQyxTQUFTO3VCQUFDLGFBQWEiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSxcbiAgQ29tcG9uZW50LFxuICBFbGVtZW50UmVmLFxuICBFdmVudEVtaXR0ZXIsXG4gIElucHV0LFxuICBPdXRwdXQsXG4gIFZpZXdDaGlsZCxcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSdcbmltcG9ydCB7IHByb3BhZ2F0ZVRvRG9jdW1lbnRPbmx5IH0gZnJvbSAnLi4vLi4vLi4vLi4vLi4vLi4vbGlicy91dGlsL3NoYXJlZC9zcmMnXG5pbXBvcnQgeyBOZ0ljb24sIHByb3ZpZGVJY29ucyB9IGZyb20gJ0BuZy1pY29ucy9jb3JlJ1xuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJ1xuaW1wb3J0IHsgbWF0U3RhciwgbWF0U3RhckJvcmRlciB9IGZyb20gJ0BuZy1pY29ucy9tYXRlcmlhbC1pY29ucy9iYXNlbGluZSdcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnZ24tdWktc3Rhci10b2dnbGUnLFxuICB0ZW1wbGF0ZVVybDogJy4vc3Rhci10b2dnbGUuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi9zdGFyLXRvZ2dsZS5jb21wb25lbnQuY3NzJ10sXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxuICBzdGFuZGFsb25lOiB0cnVlLFxuICBpbXBvcnRzOiBbQ29tbW9uTW9kdWxlLCBOZ0ljb25dLFxuICB2aWV3UHJvdmlkZXJzOiBbcHJvdmlkZUljb25zKHsgbWF0U3RhciwgbWF0U3RhckJvcmRlciB9KV0sXG59KVxuZXhwb3J0IGNsYXNzIFN0YXJUb2dnbGVDb21wb25lbnQge1xuICBASW5wdXQoKSB0b2dnbGVkITogYm9vbGVhblxuICBASW5wdXQoKSBkaXNhYmxlZCA9IGZhbHNlXG4gIEBPdXRwdXQoKSBuZXdWYWx1ZSA9IG5ldyBFdmVudEVtaXR0ZXI8Ym9vbGVhbj4oKVxuICBAVmlld0NoaWxkKCdzdGFyT3ZlcmxheScpIG92ZXJsYXk6IEVsZW1lbnRSZWZcblxuICB0b2dnbGUoZXZlbnQ6IEV2ZW50KSB7XG4gICAgaWYgKCF0aGlzLmRpc2FibGVkKSB7XG4gICAgICB0aGlzLnRvZ2dsZWQgPSAhdGhpcy50b2dnbGVkXG4gICAgICBpZiAodGhpcy50b2dnbGVkKSB7XG4gICAgICAgIGNvbnN0IGFuaW0gPSB0aGlzLm92ZXJsYXkubmF0aXZlRWxlbWVudC5nZXRBbmltYXRpb25zKClbMF1cbiAgICAgICAgYW5pbS5jYW5jZWwoKVxuICAgICAgICBhbmltLnBsYXkoKVxuICAgICAgfVxuICAgICAgdGhpcy5uZXdWYWx1ZS5lbWl0KHRoaXMudG9nZ2xlZClcbiAgICB9XG4gICAgcHJvcGFnYXRlVG9Eb2N1bWVudE9ubHkoZXZlbnQpXG4gICAgZXZlbnQucHJldmVudERlZmF1bHQoKVxuICB9XG59XG4iLCI8ZGl2IGNsYXNzPVwiaW5saW5lLWJsb2NrIHJlbGF0aXZlIGFsaWduLW1pZGRsZVwiIHN0eWxlPVwibGluZS1oZWlnaHQ6IDAuN2VtXCI+XG4gIDxidXR0b25cbiAgICB0eXBlPVwiYnV0dG9uXCJcbiAgICBjbGFzcz1cIi1tLVs4cHhdIHAtWzhweF1cIlxuICAgIChjbGljayk9XCJ0b2dnbGUoJGV2ZW50KVwiXG4gICAgW25nQ2xhc3NdPVwie1xuICAgICAgZW5hYmxlZDogdG9nZ2xlZCxcbiAgICAgICdkaXNhYmxlZCBvcGFjaXR5LTQ1JzogIXRvZ2dsZWQsXG4gICAgICAndHJhbnNpdGlvbiBob3ZlcjpzY2FsZS0xMjUgd2lsbC1jaGFuZ2UtdHJhbnNmb3JtJzogIWRpc2FibGVkLFxuICAgICAgJ2N1cnNvci1kZWZhdWx0JzogZGlzYWJsZWQsXG4gICAgfVwiXG4gID5cbiAgICA8bmctaWNvbiBbbmFtZV09XCJ0b2dnbGVkID8gJ21hdFN0YXInIDogJ21hdFN0YXJCb3JkZXInXCI+PC9uZy1pY29uPlxuICA8L2J1dHRvbj5cbiAgPHN2Z1xuICAgICNzdGFyT3ZlcmxheVxuICAgIGNsYXNzPVwic3Rhci10b2dnbGUtb3ZlcmxheVwiXG4gICAgd2lkdGg9XCI0MHB4XCJcbiAgICBoZWlnaHQ9XCI0MHB4XCJcbiAgICB2aWV3Qm94PVwiLTE1IC0xNSAzMCAzMFwiXG4gID5cbiAgICA8Zz5cbiAgICAgIDxwYXRoIGQ9XCJNIDAsMTMuMjI5MTY3IFYgMFwiIC8+XG4gICAgICA8cGF0aCBkPVwiTSAtMTIuNDg0MTg2LDQuMDg4MDM3NyAwLDBcIiAvPlxuICAgICAgPHBhdGggZD1cIk0gLTcuNjc4NDEwMiwtMTAuNzAyNjIgMCwwXCIgLz5cbiAgICAgIDxwYXRoIGQ9XCJNIDcuODczNDA3OSwtMTAuNzAyNjIgMCwwXCIgLz5cbiAgICAgIDxwYXRoIGQ9XCJNIDEyLjY3OTE4NCw0LjA4ODAzNzYgMCwwXCIgLz5cbiAgICA8L2c+XG4gIDwvc3ZnPlxuPC9kaXY+XG4iXX0=
43
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3Rhci10b2dnbGUuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy91aS9pbnB1dHMvc3JjL2xpYi9zdGFyLXRvZ2dsZS9zdGFyLXRvZ2dsZS5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL3VpL2lucHV0cy9zcmMvbGliL3N0YXItdG9nZ2xlL3N0YXItdG9nZ2xlLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFDTCx1QkFBdUIsRUFDdkIsU0FBUyxFQUNULFVBQVUsRUFDVixZQUFZLEVBQ1osS0FBSyxFQUNMLE1BQU0sRUFDTixTQUFTLEdBQ1YsTUFBTSxlQUFlLENBQUE7QUFDdEIsT0FBTyxFQUFFLHVCQUF1QixFQUFFLE1BQU0sd0NBQXdDLENBQUE7QUFDaEYsT0FBTyxFQUFFLE1BQU0sRUFBRSxZQUFZLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQTtBQUNyRCxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUE7QUFDOUMsT0FBTyxFQUFFLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxtQ0FBbUMsQ0FBQTtBQUMxRSxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sNEJBQTRCLENBQUE7OztBQVc1RCxNQUFNLE9BQU8sbUJBQW1CO0lBVGhDO1FBV1csYUFBUSxHQUFHLEtBQUssQ0FBQTtRQUNmLGFBQVEsR0FBRyxJQUFJLFlBQVksRUFBVyxDQUFBO0tBZ0JqRDtJQWJDLE1BQU0sQ0FBQyxLQUFZO1FBQ2pCLElBQUksQ0FBQyxJQUFJLENBQUMsUUFBUSxFQUFFLENBQUM7WUFDbkIsSUFBSSxDQUFDLE9BQU8sR0FBRyxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUE7WUFDNUIsSUFBSSxJQUFJLENBQUMsT0FBTyxFQUFFLENBQUM7Z0JBQ2pCLE1BQU0sSUFBSSxHQUFHLElBQUksQ0FBQyxPQUFPLENBQUMsYUFBYSxDQUFDLGFBQWEsRUFBRSxDQUFDLENBQUMsQ0FBQyxDQUFBO2dCQUMxRCxJQUFJLENBQUMsTUFBTSxFQUFFLENBQUE7Z0JBQ2IsSUFBSSxDQUFDLElBQUksRUFBRSxDQUFBO1lBQ2IsQ0FBQztZQUNELElBQUksQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsQ0FBQTtRQUNsQyxDQUFDO1FBQ0QsdUJBQXVCLENBQUMsS0FBSyxDQUFDLENBQUE7UUFDOUIsS0FBSyxDQUFDLGNBQWMsRUFBRSxDQUFBO0lBQ3hCLENBQUM7K0dBbEJVLG1CQUFtQjttR0FBbkIsbUJBQW1CLDhRQ3hCaEMsdzNCQThCQSwyb0JEVFksWUFBWSw2SEFBRSxNQUFNLDZHQUFFLGVBQWUsb0hBQ2hDLENBQUMsWUFBWSxDQUFDLEVBQUUsT0FBTyxFQUFFLGFBQWEsRUFBRSxDQUFDLENBQUM7OzRGQUU5QyxtQkFBbUI7a0JBVC9CLFNBQVM7K0JBQ0UsbUJBQW1CLG1CQUdaLHVCQUF1QixDQUFDLE1BQU0sY0FDbkMsSUFBSSxXQUNQLENBQUMsWUFBWSxFQUFFLE1BQU0sRUFBRSxlQUFlLENBQUMsaUJBQ2pDLENBQUMsWUFBWSxDQUFDLEVBQUUsT0FBTyxFQUFFLGFBQWEsRUFBRSxDQUFDLENBQUM7OEJBR2hELE9BQU87c0JBQWYsS0FBSztnQkFDRyxRQUFRO3NCQUFoQixLQUFLO2dCQUNJLFFBQVE7c0JBQWpCLE1BQU07Z0JBQ21CLE9BQU87c0JBQWhDLFNBQVM7dUJBQUMsYUFBYSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIENoYW5nZURldGVjdGlvblN0cmF0ZWd5LFxuICBDb21wb25lbnQsXG4gIEVsZW1lbnRSZWYsXG4gIEV2ZW50RW1pdHRlcixcbiAgSW5wdXQsXG4gIE91dHB1dCxcbiAgVmlld0NoaWxkLFxufSBmcm9tICdAYW5ndWxhci9jb3JlJ1xuaW1wb3J0IHsgcHJvcGFnYXRlVG9Eb2N1bWVudE9ubHkgfSBmcm9tICcuLi8uLi8uLi8uLi8uLi8uLi9saWJzL3V0aWwvc2hhcmVkL3NyYydcbmltcG9ydCB7IE5nSWNvbiwgcHJvdmlkZUljb25zIH0gZnJvbSAnQG5nLWljb25zL2NvcmUnXG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nXG5pbXBvcnQgeyBtYXRTdGFyLCBtYXRTdGFyQm9yZGVyIH0gZnJvbSAnQG5nLWljb25zL21hdGVyaWFsLWljb25zL2Jhc2VsaW5lJ1xuaW1wb3J0IHsgQnV0dG9uQ29tcG9uZW50IH0gZnJvbSAnLi4vYnV0dG9uL2J1dHRvbi5jb21wb25lbnQnXG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2duLXVpLXN0YXItdG9nZ2xlJyxcbiAgdGVtcGxhdGVVcmw6ICcuL3N0YXItdG9nZ2xlLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vc3Rhci10b2dnbGUuY29tcG9uZW50LmNzcyddLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgaW1wb3J0czogW0NvbW1vbk1vZHVsZSwgTmdJY29uLCBCdXR0b25Db21wb25lbnRdLFxuICB2aWV3UHJvdmlkZXJzOiBbcHJvdmlkZUljb25zKHsgbWF0U3RhciwgbWF0U3RhckJvcmRlciB9KV0sXG59KVxuZXhwb3J0IGNsYXNzIFN0YXJUb2dnbGVDb21wb25lbnQge1xuICBASW5wdXQoKSB0b2dnbGVkITogYm9vbGVhblxuICBASW5wdXQoKSBkaXNhYmxlZCA9IGZhbHNlXG4gIEBPdXRwdXQoKSBuZXdWYWx1ZSA9IG5ldyBFdmVudEVtaXR0ZXI8Ym9vbGVhbj4oKVxuICBAVmlld0NoaWxkKCdzdGFyT3ZlcmxheScpIG92ZXJsYXk6IEVsZW1lbnRSZWZcblxuICB0b2dnbGUoZXZlbnQ6IEV2ZW50KSB7XG4gICAgaWYgKCF0aGlzLmRpc2FibGVkKSB7XG4gICAgICB0aGlzLnRvZ2dsZWQgPSAhdGhpcy50b2dnbGVkXG4gICAgICBpZiAodGhpcy50b2dnbGVkKSB7XG4gICAgICAgIGNvbnN0IGFuaW0gPSB0aGlzLm92ZXJsYXkubmF0aXZlRWxlbWVudC5nZXRBbmltYXRpb25zKClbMF1cbiAgICAgICAgYW5pbS5jYW5jZWwoKVxuICAgICAgICBhbmltLnBsYXkoKVxuICAgICAgfVxuICAgICAgdGhpcy5uZXdWYWx1ZS5lbWl0KHRoaXMudG9nZ2xlZClcbiAgICB9XG4gICAgcHJvcGFnYXRlVG9Eb2N1bWVudE9ubHkoZXZlbnQpXG4gICAgZXZlbnQucHJldmVudERlZmF1bHQoKVxuICB9XG59XG4iLCI8ZGl2IGNsYXNzPVwiaW5saW5lLWJsb2NrIHJlbGF0aXZlIGFsaWduLW1pZGRsZVwiIHN0eWxlPVwibGluZS1oZWlnaHQ6IDAuN2VtXCI+XG4gIDxnbi11aS1idXR0b25cbiAgICBbdHlwZV09XCInb3V0bGluZSdcIlxuICAgIGNsYXNzPVwiLW0tWzhweF0gcC1bOHB4XVwiXG4gICAgKGJ1dHRvbkNsaWNrKT1cInRvZ2dsZSgkZXZlbnQpXCJcbiAgICBbbmdDbGFzc109XCJ7XG4gICAgICBlbmFibGVkOiB0b2dnbGVkLFxuICAgICAgZGlzYWJsZWQ6ICF0b2dnbGVkLFxuICAgICAgJ3RyYW5zaXRpb24gaG92ZXI6c2NhbGUtMTI1IHdpbGwtY2hhbmdlLXRyYW5zZm9ybSc6ICFkaXNhYmxlZCxcbiAgICAgICdjdXJzb3ItZGVmYXVsdCc6IGRpc2FibGVkLFxuICAgIH1cIlxuICA+XG4gICAgPG5nLWljb24gW25hbWVdPVwidG9nZ2xlZCA/ICdtYXRTdGFyJyA6ICdtYXRTdGFyQm9yZGVyJ1wiPjwvbmctaWNvbj5cbiAgPC9nbi11aS1idXR0b24+XG4gIDxzdmdcbiAgICAjc3Rhck92ZXJsYXlcbiAgICBjbGFzcz1cInN0YXItdG9nZ2xlLW92ZXJsYXlcIlxuICAgIHdpZHRoPVwiNDBweFwiXG4gICAgaGVpZ2h0PVwiNDBweFwiXG4gICAgdmlld0JveD1cIi0xNSAtMTUgMzAgMzBcIlxuICA+XG4gICAgPGc+XG4gICAgICA8cGF0aCBkPVwiTSAwLDEzLjIyOTE2NyBWIDBcIiAvPlxuICAgICAgPHBhdGggZD1cIk0gLTEyLjQ4NDE4Niw0LjA4ODAzNzcgMCwwXCIgLz5cbiAgICAgIDxwYXRoIGQ9XCJNIC03LjY3ODQxMDIsLTEwLjcwMjYyIDAsMFwiIC8+XG4gICAgICA8cGF0aCBkPVwiTSA3Ljg3MzQwNzksLTEwLjcwMjYyIDAsMFwiIC8+XG4gICAgICA8cGF0aCBkPVwiTSAxMi42NzkxODQsNC4wODgwMzc2IDAsMFwiIC8+XG4gICAgPC9nPlxuICA8L3N2Zz5cbjwvZGl2PlxuIl19
@@ -2,7 +2,15 @@ import { ChangeDetectorRef, Directive, HostBinding, HostListener, Input, } from
2
2
  import * as i0 from "@angular/core";
3
3
  export class AnchorLinkDirective {
4
4
  get elementClass() {
5
- return this.disabled ? this.disabledClass : this.enabledClass;
5
+ if (this.disabled) {
6
+ return this.disabledClass;
7
+ }
8
+ if (this.inView) {
9
+ return `${this.inViewClass} ${this.enabledClass}`;
10
+ }
11
+ else {
12
+ return `${this.outOfViewClass} ${this.enabledClass}`;
13
+ }
6
14
  }
7
15
  constructor(changeDetector) {
8
16
  this.changeDetector = changeDetector;
@@ -10,6 +18,8 @@ export class AnchorLinkDirective {
10
18
  this.observer = new MutationObserver(() => {
11
19
  this.refreshDisabledState();
12
20
  });
21
+ this.inView = false;
22
+ this.initialized = false;
13
23
  }
14
24
  ngOnInit() {
15
25
  this.observer.observe(document.body, {
@@ -18,8 +28,32 @@ export class AnchorLinkDirective {
18
28
  });
19
29
  this.refreshDisabledState();
20
30
  }
31
+ ngAfterViewChecked() {
32
+ if (!this.initialized && !this.disabled) {
33
+ const target = document.getElementById(this.targetId);
34
+ if (target) {
35
+ this.initializeIntersectionObserver(target);
36
+ this.initialized = true;
37
+ }
38
+ }
39
+ }
40
+ initializeIntersectionObserver(target) {
41
+ this.intersectionObserver = new IntersectionObserver((entries) => {
42
+ entries.forEach((entry) => {
43
+ this.inView = entry.isIntersecting;
44
+ this.changeDetector.detectChanges();
45
+ });
46
+ }, {
47
+ root: null,
48
+ rootMargin: '-30% 0% -60% 0%',
49
+ });
50
+ this.intersectionObserver.observe(target);
51
+ }
21
52
  ngOnDestroy() {
22
53
  this.observer.disconnect();
54
+ if (this.intersectionObserver) {
55
+ this.intersectionObserver.disconnect();
56
+ }
23
57
  }
24
58
  refreshDisabledState() {
25
59
  const targetNotPresent = !document.getElementById(this.targetId);
@@ -38,7 +72,7 @@ export class AnchorLinkDirective {
38
72
  });
39
73
  }
40
74
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: AnchorLinkDirective, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Directive }); }
41
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.13", type: AnchorLinkDirective, selector: "[gnUiAnchorLink]", inputs: { targetId: ["gnUiAnchorLink", "targetId"], disabledClass: ["gnUiAnchorLinkDisabledClass", "disabledClass"], enabledClass: ["gnUiAnchorLinkEnabledClass", "enabledClass"] }, host: { listeners: { "click": "scrollToTarget()" }, properties: { "class": "this.elementClass" } }, ngImport: i0 }); }
75
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.13", type: AnchorLinkDirective, selector: "[gnUiAnchorLink]", inputs: { targetId: ["gnUiAnchorLink", "targetId"], disabledClass: ["gnUiAnchorLinkDisabledClass", "disabledClass"], enabledClass: ["gnUiAnchorLinkEnabledClass", "enabledClass"], inViewClass: ["gnUiAnchorLinkInViewClass", "inViewClass"], outOfViewClass: ["gnUiAnchorLinkOutOfViewClass", "outOfViewClass"] }, host: { listeners: { "click": "scrollToTarget()" }, properties: { "class": "this.elementClass" } }, ngImport: i0 }); }
42
76
  }
43
77
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: AnchorLinkDirective, decorators: [{
44
78
  type: Directive,
@@ -54,6 +88,12 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
54
88
  }], enabledClass: [{
55
89
  type: Input,
56
90
  args: ['gnUiAnchorLinkEnabledClass']
91
+ }], inViewClass: [{
92
+ type: Input,
93
+ args: ['gnUiAnchorLinkInViewClass']
94
+ }], outOfViewClass: [{
95
+ type: Input,
96
+ args: ['gnUiAnchorLinkOutOfViewClass']
57
97
  }], elementClass: [{
58
98
  type: HostBinding,
59
99
  args: ['class']
@@ -61,4 +101,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
61
101
  type: HostListener,
62
102
  args: ['click']
63
103
  }] } });
64
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYW5jaG9yLWxpbmsuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy91aS9sYXlvdXQvc3JjL2xpYi9hbmNob3ItbGluay9hbmNob3ItbGluay5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUNMLGlCQUFpQixFQUNqQixTQUFTLEVBQ1QsV0FBVyxFQUNYLFlBQVksRUFDWixLQUFLLEdBR04sTUFBTSxlQUFlLENBQUE7O0FBS3RCLE1BQU0sT0FBTyxtQkFBbUI7SUFLOUIsSUFDSSxZQUFZO1FBQ2QsT0FBTyxJQUFJLENBQUMsUUFBUSxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsYUFBYSxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsWUFBWSxDQUFBO0lBQy9ELENBQUM7SUFPRCxZQUFvQixjQUFpQztRQUFqQyxtQkFBYyxHQUFkLGNBQWMsQ0FBbUI7UUFMckQsYUFBUSxHQUFHLEtBQUssQ0FBQTtRQUNoQixhQUFRLEdBQUcsSUFBSSxnQkFBZ0IsQ0FBQyxHQUFHLEVBQUU7WUFDbkMsSUFBSSxDQUFDLG9CQUFvQixFQUFFLENBQUE7UUFDN0IsQ0FBQyxDQUFDLENBQUE7SUFFc0QsQ0FBQztJQUV6RCxRQUFRO1FBQ04sSUFBSSxDQUFDLFFBQVEsQ0FBQyxPQUFPLENBQUMsUUFBUSxDQUFDLElBQUksRUFBRTtZQUNuQyxTQUFTLEVBQUUsSUFBSTtZQUNmLE9BQU8sRUFBRSxJQUFJO1NBQ2QsQ0FBQyxDQUFBO1FBQ0YsSUFBSSxDQUFDLG9CQUFvQixFQUFFLENBQUE7SUFDN0IsQ0FBQztJQUVELFdBQVc7UUFDVCxJQUFJLENBQUMsUUFBUSxDQUFDLFVBQVUsRUFBRSxDQUFBO0lBQzVCLENBQUM7SUFFRCxvQkFBb0I7UUFDbEIsTUFBTSxnQkFBZ0IsR0FBRyxDQUFDLFFBQVEsQ0FBQyxjQUFjLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxDQUFBO1FBQ2hFLElBQUksZ0JBQWdCLEtBQUssSUFBSSxDQUFDLFFBQVEsRUFBRSxDQUFDO1lBQ3ZDLElBQUksQ0FBQyxRQUFRLEdBQUcsZ0JBQWdCLENBQUE7WUFDaEMsSUFBSSxDQUFDLGNBQWMsQ0FBQyxhQUFhLEVBQUUsQ0FBQTtRQUNyQyxDQUFDO0lBQ0gsQ0FBQztJQUVzQixjQUFjO1FBQ25DLE1BQU0sTUFBTSxHQUFHLFFBQVEsQ0FBQyxjQUFjLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxDQUFBO1FBQ3JELElBQUksQ0FBQyxNQUFNO1lBQUUsT0FBTTtRQUNuQixNQUFNLENBQUMsY0FBYyxDQUFDO1lBQ3BCLFFBQVEsRUFBRSxRQUFRO1lBQ2xCLEtBQUssRUFBRSxPQUFPO1NBQ2YsQ0FBQyxDQUFBO0lBQ0osQ0FBQzsrR0E1Q1UsbUJBQW1CO21HQUFuQixtQkFBbUI7OzRGQUFuQixtQkFBbUI7a0JBSC9CLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLGtCQUFrQjtpQkFDN0I7c0ZBRTBCLFFBQVE7c0JBQWhDLEtBQUs7dUJBQUMsZ0JBQWdCO2dCQUNlLGFBQWE7c0JBQWxELEtBQUs7dUJBQUMsNkJBQTZCO2dCQUNDLFlBQVk7c0JBQWhELEtBQUs7dUJBQUMsNEJBQTRCO2dCQUcvQixZQUFZO3NCQURmLFdBQVc7dUJBQUMsT0FBTztnQkFnQ0csY0FBYztzQkFBcEMsWUFBWTt1QkFBQyxPQUFPIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgQ2hhbmdlRGV0ZWN0b3JSZWYsXG4gIERpcmVjdGl2ZSxcbiAgSG9zdEJpbmRpbmcsXG4gIEhvc3RMaXN0ZW5lcixcbiAgSW5wdXQsXG4gIE9uRGVzdHJveSxcbiAgT25Jbml0LFxufSBmcm9tICdAYW5ndWxhci9jb3JlJ1xuXG5ARGlyZWN0aXZlKHtcbiAgc2VsZWN0b3I6ICdbZ25VaUFuY2hvckxpbmtdJyxcbn0pXG5leHBvcnQgY2xhc3MgQW5jaG9yTGlua0RpcmVjdGl2ZSBpbXBsZW1lbnRzIE9uSW5pdCwgT25EZXN0cm95IHtcbiAgQElucHV0KCdnblVpQW5jaG9yTGluaycpIHRhcmdldElkOiBzdHJpbmdcbiAgQElucHV0KCdnblVpQW5jaG9yTGlua0Rpc2FibGVkQ2xhc3MnKSBkaXNhYmxlZENsYXNzOiBzdHJpbmdcbiAgQElucHV0KCdnblVpQW5jaG9yTGlua0VuYWJsZWRDbGFzcycpIGVuYWJsZWRDbGFzczogc3RyaW5nXG5cbiAgQEhvc3RCaW5kaW5nKCdjbGFzcycpXG4gIGdldCBlbGVtZW50Q2xhc3MoKTogc3RyaW5nIHtcbiAgICByZXR1cm4gdGhpcy5kaXNhYmxlZCA/IHRoaXMuZGlzYWJsZWRDbGFzcyA6IHRoaXMuZW5hYmxlZENsYXNzXG4gIH1cblxuICBkaXNhYmxlZCA9IGZhbHNlXG4gIG9ic2VydmVyID0gbmV3IE11dGF0aW9uT2JzZXJ2ZXIoKCkgPT4ge1xuICAgIHRoaXMucmVmcmVzaERpc2FibGVkU3RhdGUoKVxuICB9KVxuXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgY2hhbmdlRGV0ZWN0b3I6IENoYW5nZURldGVjdG9yUmVmKSB7fVxuXG4gIG5nT25Jbml0KCkge1xuICAgIHRoaXMub2JzZXJ2ZXIub2JzZXJ2ZShkb2N1bWVudC5ib2R5LCB7XG4gICAgICBjaGlsZExpc3Q6IHRydWUsXG4gICAgICBzdWJ0cmVlOiB0cnVlLFxuICAgIH0pXG4gICAgdGhpcy5yZWZyZXNoRGlzYWJsZWRTdGF0ZSgpXG4gIH1cblxuICBuZ09uRGVzdHJveSgpIHtcbiAgICB0aGlzLm9ic2VydmVyLmRpc2Nvbm5lY3QoKVxuICB9XG5cbiAgcmVmcmVzaERpc2FibGVkU3RhdGUoKSB7XG4gICAgY29uc3QgdGFyZ2V0Tm90UHJlc2VudCA9ICFkb2N1bWVudC5nZXRFbGVtZW50QnlJZCh0aGlzLnRhcmdldElkKVxuICAgIGlmICh0YXJnZXROb3RQcmVzZW50ICE9PSB0aGlzLmRpc2FibGVkKSB7XG4gICAgICB0aGlzLmRpc2FibGVkID0gdGFyZ2V0Tm90UHJlc2VudFxuICAgICAgdGhpcy5jaGFuZ2VEZXRlY3Rvci5kZXRlY3RDaGFuZ2VzKClcbiAgICB9XG4gIH1cblxuICBASG9zdExpc3RlbmVyKCdjbGljaycpIHNjcm9sbFRvVGFyZ2V0KCkge1xuICAgIGNvbnN0IHRhcmdldCA9IGRvY3VtZW50LmdldEVsZW1lbnRCeUlkKHRoaXMudGFyZ2V0SWQpXG4gICAgaWYgKCF0YXJnZXQpIHJldHVyblxuICAgIHRhcmdldC5zY3JvbGxJbnRvVmlldyh7XG4gICAgICBiZWhhdmlvcjogJ3Ntb290aCcsXG4gICAgICBibG9jazogJ3N0YXJ0JyxcbiAgICB9KVxuICB9XG59XG4iXX0=
104
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYW5jaG9yLWxpbmsuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy91aS9sYXlvdXQvc3JjL2xpYi9hbmNob3ItbGluay9hbmNob3ItbGluay5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUVMLGlCQUFpQixFQUNqQixTQUFTLEVBQ1QsV0FBVyxFQUNYLFlBQVksRUFDWixLQUFLLEdBR04sTUFBTSxlQUFlLENBQUE7O0FBS3RCLE1BQU0sT0FBTyxtQkFBbUI7SUFTOUIsSUFDSSxZQUFZO1FBQ2QsSUFBSSxJQUFJLENBQUMsUUFBUSxFQUFFLENBQUM7WUFDbEIsT0FBTyxJQUFJLENBQUMsYUFBYSxDQUFBO1FBQzNCLENBQUM7UUFDRCxJQUFJLElBQUksQ0FBQyxNQUFNLEVBQUUsQ0FBQztZQUNoQixPQUFPLEdBQUcsSUFBSSxDQUFDLFdBQVcsSUFBSSxJQUFJLENBQUMsWUFBWSxFQUFFLENBQUE7UUFDbkQsQ0FBQzthQUFNLENBQUM7WUFDTixPQUFPLEdBQUcsSUFBSSxDQUFDLGNBQWMsSUFBSSxJQUFJLENBQUMsWUFBWSxFQUFFLENBQUE7UUFDdEQsQ0FBQztJQUNILENBQUM7SUFVRCxZQUFvQixjQUFpQztRQUFqQyxtQkFBYyxHQUFkLGNBQWMsQ0FBbUI7UUFSckQsYUFBUSxHQUFHLEtBQUssQ0FBQTtRQUNoQixhQUFRLEdBQUcsSUFBSSxnQkFBZ0IsQ0FBQyxHQUFHLEVBQUU7WUFDbkMsSUFBSSxDQUFDLG9CQUFvQixFQUFFLENBQUE7UUFDN0IsQ0FBQyxDQUFDLENBQUE7UUFDRixXQUFNLEdBQUcsS0FBSyxDQUFBO1FBRWQsZ0JBQVcsR0FBRyxLQUFLLENBQUE7SUFFcUMsQ0FBQztJQUV6RCxRQUFRO1FBQ04sSUFBSSxDQUFDLFFBQVEsQ0FBQyxPQUFPLENBQUMsUUFBUSxDQUFDLElBQUksRUFBRTtZQUNuQyxTQUFTLEVBQUUsSUFBSTtZQUNmLE9BQU8sRUFBRSxJQUFJO1NBQ2QsQ0FBQyxDQUFBO1FBQ0YsSUFBSSxDQUFDLG9CQUFvQixFQUFFLENBQUE7SUFDN0IsQ0FBQztJQUVELGtCQUFrQjtRQUNoQixJQUFJLENBQUMsSUFBSSxDQUFDLFdBQVcsSUFBSSxDQUFDLElBQUksQ0FBQyxRQUFRLEVBQUUsQ0FBQztZQUN4QyxNQUFNLE1BQU0sR0FBRyxRQUFRLENBQUMsY0FBYyxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsQ0FBQTtZQUNyRCxJQUFJLE1BQU0sRUFBRSxDQUFDO2dCQUNYLElBQUksQ0FBQyw4QkFBOEIsQ0FBQyxNQUFNLENBQUMsQ0FBQTtnQkFDM0MsSUFBSSxDQUFDLFdBQVcsR0FBRyxJQUFJLENBQUE7WUFDekIsQ0FBQztRQUNILENBQUM7SUFDSCxDQUFDO0lBRUQsOEJBQThCLENBQUMsTUFBbUI7UUFDaEQsSUFBSSxDQUFDLG9CQUFvQixHQUFHLElBQUksb0JBQW9CLENBQ2xELENBQUMsT0FBTyxFQUFFLEVBQUU7WUFDVixPQUFPLENBQUMsT0FBTyxDQUFDLENBQUMsS0FBSyxFQUFFLEVBQUU7Z0JBQ3hCLElBQUksQ0FBQyxNQUFNLEdBQUcsS0FBSyxDQUFDLGNBQWMsQ0FBQTtnQkFDbEMsSUFBSSxDQUFDLGNBQWMsQ0FBQyxhQUFhLEVBQUUsQ0FBQTtZQUNyQyxDQUFDLENBQUMsQ0FBQTtRQUNKLENBQUMsRUFDRDtZQUNFLElBQUksRUFBRSxJQUFJO1lBQ1YsVUFBVSxFQUFFLGlCQUFpQjtTQUM5QixDQUNGLENBQUE7UUFDRCxJQUFJLENBQUMsb0JBQW9CLENBQUMsT0FBTyxDQUFDLE1BQU0sQ0FBQyxDQUFBO0lBQzNDLENBQUM7SUFFRCxXQUFXO1FBQ1QsSUFBSSxDQUFDLFFBQVEsQ0FBQyxVQUFVLEVBQUUsQ0FBQTtRQUMxQixJQUFJLElBQUksQ0FBQyxvQkFBb0IsRUFBRSxDQUFDO1lBQzlCLElBQUksQ0FBQyxvQkFBb0IsQ0FBQyxVQUFVLEVBQUUsQ0FBQTtRQUN4QyxDQUFDO0lBQ0gsQ0FBQztJQUVELG9CQUFvQjtRQUNsQixNQUFNLGdCQUFnQixHQUFHLENBQUMsUUFBUSxDQUFDLGNBQWMsQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLENBQUE7UUFDaEUsSUFBSSxnQkFBZ0IsS0FBSyxJQUFJLENBQUMsUUFBUSxFQUFFLENBQUM7WUFDdkMsSUFBSSxDQUFDLFFBQVEsR0FBRyxnQkFBZ0IsQ0FBQTtZQUNoQyxJQUFJLENBQUMsY0FBYyxDQUFDLGFBQWEsRUFBRSxDQUFBO1FBQ3JDLENBQUM7SUFDSCxDQUFDO0lBRXNCLGNBQWM7UUFDbkMsTUFBTSxNQUFNLEdBQUcsUUFBUSxDQUFDLGNBQWMsQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLENBQUE7UUFDckQsSUFBSSxDQUFDLE1BQU07WUFBRSxPQUFNO1FBQ25CLE1BQU0sQ0FBQyxjQUFjLENBQUM7WUFDcEIsUUFBUSxFQUFFLFFBQVE7WUFDbEIsS0FBSyxFQUFFLE9BQU87U0FDZixDQUFDLENBQUE7SUFDSixDQUFDOytHQXZGVSxtQkFBbUI7bUdBQW5CLG1CQUFtQjs7NEZBQW5CLG1CQUFtQjtrQkFIL0IsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUsa0JBQWtCO2lCQUM3QjtzRkFJMEIsUUFBUTtzQkFBaEMsS0FBSzt1QkFBQyxnQkFBZ0I7Z0JBQ2UsYUFBYTtzQkFBbEQsS0FBSzt1QkFBQyw2QkFBNkI7Z0JBQ0MsWUFBWTtzQkFBaEQsS0FBSzt1QkFBQyw0QkFBNEI7Z0JBQ0MsV0FBVztzQkFBOUMsS0FBSzt1QkFBQywyQkFBMkI7Z0JBQ0ssY0FBYztzQkFBcEQsS0FBSzt1QkFBQyw4QkFBOEI7Z0JBR2pDLFlBQVk7c0JBRGYsV0FBVzt1QkFBQyxPQUFPO2dCQXVFRyxjQUFjO3NCQUFwQyxZQUFZO3VCQUFDLE9BQU8iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICBBZnRlclZpZXdDaGVja2VkLFxuICBDaGFuZ2VEZXRlY3RvclJlZixcbiAgRGlyZWN0aXZlLFxuICBIb3N0QmluZGluZyxcbiAgSG9zdExpc3RlbmVyLFxuICBJbnB1dCxcbiAgT25EZXN0cm95LFxuICBPbkluaXQsXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnXG5cbkBEaXJlY3RpdmUoe1xuICBzZWxlY3RvcjogJ1tnblVpQW5jaG9yTGlua10nLFxufSlcbmV4cG9ydCBjbGFzcyBBbmNob3JMaW5rRGlyZWN0aXZlXG4gIGltcGxlbWVudHMgT25Jbml0LCBBZnRlclZpZXdDaGVja2VkLCBPbkRlc3Ryb3lcbntcbiAgQElucHV0KCdnblVpQW5jaG9yTGluaycpIHRhcmdldElkOiBzdHJpbmdcbiAgQElucHV0KCdnblVpQW5jaG9yTGlua0Rpc2FibGVkQ2xhc3MnKSBkaXNhYmxlZENsYXNzOiBzdHJpbmdcbiAgQElucHV0KCdnblVpQW5jaG9yTGlua0VuYWJsZWRDbGFzcycpIGVuYWJsZWRDbGFzczogc3RyaW5nXG4gIEBJbnB1dCgnZ25VaUFuY2hvckxpbmtJblZpZXdDbGFzcycpIGluVmlld0NsYXNzOiBzdHJpbmdcbiAgQElucHV0KCdnblVpQW5jaG9yTGlua091dE9mVmlld0NsYXNzJykgb3V0T2ZWaWV3Q2xhc3M6IHN0cmluZ1xuXG4gIEBIb3N0QmluZGluZygnY2xhc3MnKVxuICBnZXQgZWxlbWVudENsYXNzKCk6IHN0cmluZyB7XG4gICAgaWYgKHRoaXMuZGlzYWJsZWQpIHtcbiAgICAgIHJldHVybiB0aGlzLmRpc2FibGVkQ2xhc3NcbiAgICB9XG4gICAgaWYgKHRoaXMuaW5WaWV3KSB7XG4gICAgICByZXR1cm4gYCR7dGhpcy5pblZpZXdDbGFzc30gJHt0aGlzLmVuYWJsZWRDbGFzc31gXG4gICAgfSBlbHNlIHtcbiAgICAgIHJldHVybiBgJHt0aGlzLm91dE9mVmlld0NsYXNzfSAke3RoaXMuZW5hYmxlZENsYXNzfWBcbiAgICB9XG4gIH1cblxuICBkaXNhYmxlZCA9IGZhbHNlXG4gIG9ic2VydmVyID0gbmV3IE11dGF0aW9uT2JzZXJ2ZXIoKCkgPT4ge1xuICAgIHRoaXMucmVmcmVzaERpc2FibGVkU3RhdGUoKVxuICB9KVxuICBpblZpZXcgPSBmYWxzZVxuICBpbnRlcnNlY3Rpb25PYnNlcnZlcjogSW50ZXJzZWN0aW9uT2JzZXJ2ZXJcbiAgaW5pdGlhbGl6ZWQgPSBmYWxzZVxuXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgY2hhbmdlRGV0ZWN0b3I6IENoYW5nZURldGVjdG9yUmVmKSB7fVxuXG4gIG5nT25Jbml0KCkge1xuICAgIHRoaXMub2JzZXJ2ZXIub2JzZXJ2ZShkb2N1bWVudC5ib2R5LCB7XG4gICAgICBjaGlsZExpc3Q6IHRydWUsXG4gICAgICBzdWJ0cmVlOiB0cnVlLFxuICAgIH0pXG4gICAgdGhpcy5yZWZyZXNoRGlzYWJsZWRTdGF0ZSgpXG4gIH1cblxuICBuZ0FmdGVyVmlld0NoZWNrZWQoKSB7XG4gICAgaWYgKCF0aGlzLmluaXRpYWxpemVkICYmICF0aGlzLmRpc2FibGVkKSB7XG4gICAgICBjb25zdCB0YXJnZXQgPSBkb2N1bWVudC5nZXRFbGVtZW50QnlJZCh0aGlzLnRhcmdldElkKVxuICAgICAgaWYgKHRhcmdldCkge1xuICAgICAgICB0aGlzLmluaXRpYWxpemVJbnRlcnNlY3Rpb25PYnNlcnZlcih0YXJnZXQpXG4gICAgICAgIHRoaXMuaW5pdGlhbGl6ZWQgPSB0cnVlXG4gICAgICB9XG4gICAgfVxuICB9XG5cbiAgaW5pdGlhbGl6ZUludGVyc2VjdGlvbk9ic2VydmVyKHRhcmdldDogSFRNTEVsZW1lbnQpIHtcbiAgICB0aGlzLmludGVyc2VjdGlvbk9ic2VydmVyID0gbmV3IEludGVyc2VjdGlvbk9ic2VydmVyKFxuICAgICAgKGVudHJpZXMpID0+IHtcbiAgICAgICAgZW50cmllcy5mb3JFYWNoKChlbnRyeSkgPT4ge1xuICAgICAgICAgIHRoaXMuaW5WaWV3ID0gZW50cnkuaXNJbnRlcnNlY3RpbmdcbiAgICAgICAgICB0aGlzLmNoYW5nZURldGVjdG9yLmRldGVjdENoYW5nZXMoKVxuICAgICAgICB9KVxuICAgICAgfSxcbiAgICAgIHtcbiAgICAgICAgcm9vdDogbnVsbCxcbiAgICAgICAgcm9vdE1hcmdpbjogJy0zMCUgMCUgLTYwJSAwJScsXG4gICAgICB9XG4gICAgKVxuICAgIHRoaXMuaW50ZXJzZWN0aW9uT2JzZXJ2ZXIub2JzZXJ2ZSh0YXJnZXQpXG4gIH1cblxuICBuZ09uRGVzdHJveSgpIHtcbiAgICB0aGlzLm9ic2VydmVyLmRpc2Nvbm5lY3QoKVxuICAgIGlmICh0aGlzLmludGVyc2VjdGlvbk9ic2VydmVyKSB7XG4gICAgICB0aGlzLmludGVyc2VjdGlvbk9ic2VydmVyLmRpc2Nvbm5lY3QoKVxuICAgIH1cbiAgfVxuXG4gIHJlZnJlc2hEaXNhYmxlZFN0YXRlKCkge1xuICAgIGNvbnN0IHRhcmdldE5vdFByZXNlbnQgPSAhZG9jdW1lbnQuZ2V0RWxlbWVudEJ5SWQodGhpcy50YXJnZXRJZClcbiAgICBpZiAodGFyZ2V0Tm90UHJlc2VudCAhPT0gdGhpcy5kaXNhYmxlZCkge1xuICAgICAgdGhpcy5kaXNhYmxlZCA9IHRhcmdldE5vdFByZXNlbnRcbiAgICAgIHRoaXMuY2hhbmdlRGV0ZWN0b3IuZGV0ZWN0Q2hhbmdlcygpXG4gICAgfVxuICB9XG5cbiAgQEhvc3RMaXN0ZW5lcignY2xpY2snKSBzY3JvbGxUb1RhcmdldCgpIHtcbiAgICBjb25zdCB0YXJnZXQgPSBkb2N1bWVudC5nZXRFbGVtZW50QnlJZCh0aGlzLnRhcmdldElkKVxuICAgIGlmICghdGFyZ2V0KSByZXR1cm5cbiAgICB0YXJnZXQuc2Nyb2xsSW50b1ZpZXcoe1xuICAgICAgYmVoYXZpb3I6ICdzbW9vdGgnLFxuICAgICAgYmxvY2s6ICdzdGFydCcsXG4gICAgfSlcbiAgfVxufVxuIl19
@@ -63,7 +63,6 @@
63
63
  "datahub.news.contact.title": "Ein spezielles Bedürfnis?",
64
64
  "datahub.news.feed": "Nachrichtenfeed",
65
65
  "datahub.news.figures": "Indikatoren",
66
- "datahub.record.addToFavorites": "Zu Favoriten hinzufügen",
67
66
  "datahub.search.back": "Zurück",
68
67
  "datahub.search.filter.all": "Alle",
69
68
  "datahub.search.filter.generatedByAPI": "Generiert durch eine API",
@@ -333,6 +332,7 @@
333
332
  "map.wms.urlInput.hint": "Geben Sie die WMS URL ein",
334
333
  "multiselect.filter.placeholder": "Suche",
335
334
  "nav.back": "Zurück",
335
+ "navbar.mobile.menuTitle": "Schnellzugriff",
336
336
  "next": "weiter",
337
337
  "ogc.unreachable.unknown": "Der Dienst konnte nicht erreicht werden",
338
338
  "organisation.filter.placeholder": "Ergebnisse filtern",
@@ -395,6 +395,7 @@
395
395
  "record.metadata.api.form.zoneTitle": "",
396
396
  "record.metadata.api.form.zoneTooltip": "",
397
397
  "record.metadata.api.gpfdl": "",
398
+ "record.metadata.capabilities": "",
398
399
  "record.metadata.catalog": "Katalog",
399
400
  "record.metadata.contact": "Kontakt",
400
401
  "record.metadata.creation": "Erstellungsdatum",
@@ -63,7 +63,6 @@
63
63
  "datahub.news.contact.title": "A specific need?",
64
64
  "datahub.news.feed": "News feed",
65
65
  "datahub.news.figures": "Indicators",
66
- "datahub.record.addToFavorites": "Add to favorites",
67
66
  "datahub.search.back": "Back",
68
67
  "datahub.search.filter.all": "All",
69
68
  "datahub.search.filter.generatedByAPI": "Generated by an API",
@@ -333,6 +332,7 @@
333
332
  "map.wms.urlInput.hint": "Enter WMS service URL",
334
333
  "multiselect.filter.placeholder": "Search",
335
334
  "nav.back": "Back",
335
+ "navbar.mobile.menuTitle": "Quick access",
336
336
  "next": "Next",
337
337
  "ogc.unreachable.unknown": "The service could not be reached",
338
338
  "organisation.filter.placeholder": "Filter results",
@@ -395,6 +395,7 @@
395
395
  "record.metadata.api.form.zoneTitle": "Zone",
396
396
  "record.metadata.api.form.zoneTooltip": "Dropdown for selecting a geographic zone",
397
397
  "record.metadata.api.gpfdl": "Data download",
398
+ "record.metadata.capabilities": "",
398
399
  "record.metadata.catalog": "Catalog",
399
400
  "record.metadata.contact": "Contact",
400
401
  "record.metadata.creation": "Date of creation",
@@ -63,7 +63,6 @@
63
63
  "datahub.news.contact.title": "",
64
64
  "datahub.news.feed": "",
65
65
  "datahub.news.figures": "",
66
- "datahub.record.addToFavorites": "",
67
66
  "datahub.search.back": "",
68
67
  "datahub.search.filter.all": "",
69
68
  "datahub.search.filter.generatedByAPI": "",
@@ -333,6 +332,7 @@
333
332
  "map.wms.urlInput.hint": "",
334
333
  "multiselect.filter.placeholder": "",
335
334
  "nav.back": "",
335
+ "navbar.mobile.menuTitle": "Acceso rápido",
336
336
  "next": "",
337
337
  "ogc.unreachable.unknown": "",
338
338
  "organisation.filter.placeholder": "",
@@ -395,6 +395,7 @@
395
395
  "record.metadata.api.form.zoneTitle": "",
396
396
  "record.metadata.api.form.zoneTooltip": "",
397
397
  "record.metadata.api.gpfdl": "",
398
+ "record.metadata.capabilities": "",
398
399
  "record.metadata.catalog": "",
399
400
  "record.metadata.contact": "",
400
401
  "record.metadata.creation": "",
@@ -63,7 +63,6 @@
63
63
  "datahub.news.contact.title": "Un besoin spécifique ?",
64
64
  "datahub.news.feed": "Fil d'activité",
65
65
  "datahub.news.figures": "Quelques chiffres",
66
- "datahub.record.addToFavorites": "Ajouter aux favoris",
67
66
  "datahub.search.back": "Retour",
68
67
  "datahub.search.filter.all": "Tous",
69
68
  "datahub.search.filter.generatedByAPI": "généré par une API",
@@ -333,6 +332,7 @@
333
332
  "map.wms.urlInput.hint": "Entrez l'URL du service WMS",
334
333
  "multiselect.filter.placeholder": "Rechercher",
335
334
  "nav.back": "Retour",
335
+ "navbar.mobile.menuTitle": "Navigation rapide",
336
336
  "next": "Suivant",
337
337
  "ogc.unreachable.unknown": "Le service n'est pas accessible",
338
338
  "organisation.filter.placeholder": "Filtrer les résultats",
@@ -362,7 +362,7 @@
362
362
  "record.kind.dataset": "Donnée",
363
363
  "record.kind.reuse": "Réutilisation",
364
364
  "record.kind.service": "Service",
365
- "record.metadata.about": "Description",
365
+ "record.metadata.about": "A propos",
366
366
  "record.metadata.api": "API",
367
367
  "record.metadata.api.form.closeButton": "Fermer",
368
368
  "record.metadata.api.form.closeForm": "Fermer le panneau de personnalisation",
@@ -395,6 +395,7 @@
395
395
  "record.metadata.api.form.zoneTitle": "Zone",
396
396
  "record.metadata.api.form.zoneTooltip": "Menu déroulant pour sélectionner une zone géographique",
397
397
  "record.metadata.api.gpfdl": "Téléchargement",
398
+ "record.metadata.capabilities": "Capacités du service",
398
399
  "record.metadata.catalog": "Catalogue",
399
400
  "record.metadata.contact": "Contact",
400
401
  "record.metadata.creation": "Date de création",
@@ -404,7 +405,7 @@
404
405
  "record.metadata.keywords": "Mots-clés",
405
406
  "record.metadata.languages": "Langues",
406
407
  "record.metadata.lastUpdate": "Mis à jour le {date}",
407
- "record.metadata.links": "Liens",
408
+ "record.metadata.links": "Ressources & liens",
408
409
  "record.metadata.noUsage": "Aucune condition d'utilisation spécifiée pour ces données",
409
410
  "record.metadata.otherConstraints": "Limitations d'usage",
410
411
  "record.metadata.owner": "Catalogue d'origine",
@@ -63,7 +63,6 @@
63
63
  "datahub.news.contact.title": "Ha un bisogno specifico?",
64
64
  "datahub.news.feed": "Feed di attività",
65
65
  "datahub.news.figures": "Alcune figure",
66
- "datahub.record.addToFavorites": "Aggiungere a miei preferiti",
67
66
  "datahub.search.back": "Ritorna",
68
67
  "datahub.search.filter.all": "Tutti",
69
68
  "datahub.search.filter.generatedByAPI": "generato da un'API",
@@ -333,6 +332,7 @@
333
332
  "map.wms.urlInput.hint": "Inserisci URL del servizio WMS",
334
333
  "multiselect.filter.placeholder": "Cerca",
335
334
  "nav.back": "Indietro",
335
+ "navbar.mobile.menuTitle": "",
336
336
  "next": "successivo",
337
337
  "ogc.unreachable.unknown": "Il servizio non è accessibile",
338
338
  "organisation.filter.placeholder": "Filtra i risultati",
@@ -395,6 +395,7 @@
395
395
  "record.metadata.api.form.zoneTitle": "Zona",
396
396
  "record.metadata.api.form.zoneTooltip": "Menu a discesa per selezionare una zona geografica",
397
397
  "record.metadata.api.gpfdl": "Scarica",
398
+ "record.metadata.capabilities": "",
398
399
  "record.metadata.catalog": "Catalogo",
399
400
  "record.metadata.contact": "Contatto",
400
401
  "record.metadata.creation": "Data di creazione",
@@ -63,7 +63,6 @@
63
63
  "datahub.news.contact.title": "",
64
64
  "datahub.news.feed": "",
65
65
  "datahub.news.figures": "",
66
- "datahub.record.addToFavorites": "",
67
66
  "datahub.search.back": "",
68
67
  "datahub.search.filter.all": "",
69
68
  "datahub.search.filter.generatedByAPI": "",
@@ -333,6 +332,7 @@
333
332
  "map.wms.urlInput.hint": "",
334
333
  "multiselect.filter.placeholder": "",
335
334
  "nav.back": "",
335
+ "navbar.mobile.menuTitle": "",
336
336
  "next": "",
337
337
  "ogc.unreachable.unknown": "",
338
338
  "organisation.filter.placeholder": "",
@@ -395,6 +395,7 @@
395
395
  "record.metadata.api.form.zoneTitle": "",
396
396
  "record.metadata.api.form.zoneTooltip": "",
397
397
  "record.metadata.api.gpfdl": "",
398
+ "record.metadata.capabilities": "",
398
399
  "record.metadata.catalog": "",
399
400
  "record.metadata.contact": "",
400
401
  "record.metadata.creation": "",
@@ -63,7 +63,6 @@
63
63
  "datahub.news.contact.title": "",
64
64
  "datahub.news.feed": "",
65
65
  "datahub.news.figures": "",
66
- "datahub.record.addToFavorites": "",
67
66
  "datahub.search.back": "",
68
67
  "datahub.search.filter.all": "",
69
68
  "datahub.search.filter.generatedByAPI": "",
@@ -333,6 +332,7 @@
333
332
  "map.wms.urlInput.hint": "",
334
333
  "multiselect.filter.placeholder": "",
335
334
  "nav.back": "",
335
+ "navbar.mobile.menuTitle": "",
336
336
  "next": "",
337
337
  "ogc.unreachable.unknown": "",
338
338
  "organisation.filter.placeholder": "",
@@ -395,6 +395,7 @@
395
395
  "record.metadata.api.form.zoneTitle": "",
396
396
  "record.metadata.api.form.zoneTooltip": "",
397
397
  "record.metadata.api.gpfdl": "",
398
+ "record.metadata.capabilities": "",
398
399
  "record.metadata.catalog": "",
399
400
  "record.metadata.contact": "",
400
401
  "record.metadata.creation": "",