geonetwork-ui 2.6.0-dev.7be6567ef → 2.6.0-dev.b306f1194
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.
- package/esm2022/libs/feature/search/src/lib/favorites/favorite-star/favorite-star.component.mjs +3 -3
- package/esm2022/libs/ui/elements/src/index.mjs +2 -1
- package/esm2022/libs/ui/elements/src/lib/internal-link-card/internal-link-card.component.mjs +163 -0
- package/esm2022/libs/ui/elements/src/lib/metadata-quality/metadata-quality.component.mjs +3 -3
- package/esm2022/libs/ui/elements/src/lib/ui-elements.module.mjs +10 -4
- package/esm2022/libs/ui/widgets/src/lib/progress-bar/progress-bar.component.mjs +3 -3
- package/esm2022/translations/de.json +5 -0
- package/esm2022/translations/en.json +5 -0
- package/esm2022/translations/es.json +5 -0
- package/esm2022/translations/fr.json +5 -0
- package/esm2022/translations/it.json +5 -0
- package/esm2022/translations/nl.json +5 -0
- package/esm2022/translations/pt.json +5 -0
- package/fesm2022/geonetwork-ui.mjs +202 -14
- package/fesm2022/geonetwork-ui.mjs.map +1 -1
- package/libs/ui/elements/src/index.d.ts +1 -0
- package/libs/ui/elements/src/index.d.ts.map +1 -1
- package/libs/ui/elements/src/lib/internal-link-card/internal-link-card.component.d.ts +43 -0
- package/libs/ui/elements/src/lib/internal-link-card/internal-link-card.component.d.ts.map +1 -0
- package/libs/ui/elements/src/lib/ui-elements.module.d.ts +2 -1
- package/libs/ui/elements/src/lib/ui-elements.module.d.ts.map +1 -1
- package/package.json +1 -1
- package/src/libs/feature/search/src/lib/favorites/favorite-star/favorite-star.component.html +1 -1
- package/src/libs/ui/elements/src/index.ts +1 -0
- package/src/libs/ui/elements/src/lib/internal-link-card/internal-link-card.component.css +0 -0
- package/src/libs/ui/elements/src/lib/internal-link-card/internal-link-card.component.html +156 -0
- package/src/libs/ui/elements/src/lib/internal-link-card/internal-link-card.component.ts +190 -0
- package/src/libs/ui/elements/src/lib/metadata-quality/metadata-quality.component.html +4 -2
- package/src/libs/ui/elements/src/lib/ui-elements.module.ts +3 -0
- package/src/libs/ui/widgets/src/lib/progress-bar/progress-bar.component.html +2 -2
- package/translations/de.json +5 -0
- package/translations/en.json +5 -0
- package/translations/es.json +5 -0
- package/translations/fr.json +5 -0
- package/translations/it.json +5 -0
- package/translations/nl.json +5 -0
- package/translations/pt.json +5 -0
- package/translations/sk.json +5 -0
package/esm2022/libs/feature/search/src/lib/favorites/favorite-star/favorite-star.component.mjs
CHANGED
|
@@ -94,11 +94,11 @@ export class FavoriteStarComponent {
|
|
|
94
94
|
});
|
|
95
95
|
}
|
|
96
96
|
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\"\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 }); }
|
|
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
98
|
}
|
|
99
99
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FavoriteStarComponent, decorators: [{
|
|
100
100
|
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\"\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" }]
|
|
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
102
|
}], ctorParameters: () => [{ type: i1.FavoritesService }, { type: i2.PlatformServiceInterface }, { type: i0.ChangeDetectorRef }, { type: i1.AuthService }, { type: i3.TranslateService }], propDecorators: { displayCount: [{
|
|
103
103
|
type: Input
|
|
104
104
|
}], record: [{
|
|
@@ -107,4 +107,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
107
107
|
type: ViewChild,
|
|
108
108
|
args: [StarToggleComponent, { read: ElementRef }]
|
|
109
109
|
}] } });
|
|
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\"\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"]}
|
|
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"]}
|
|
@@ -23,4 +23,5 @@ export * from './lib/ui-elements.module';
|
|
|
23
23
|
export * from './lib/user-feedback-item/user-feedback-item.component';
|
|
24
24
|
export * from './lib/user-preview/user-preview.component';
|
|
25
25
|
export * from './lib/application-banner/application-banner.component';
|
|
26
|
-
|
|
26
|
+
export * from './lib/internal-link-card/internal-link-card.component';
|
|
27
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzL3VpL2VsZW1lbnRzL3NyYy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLG1DQUFtQyxDQUFBO0FBQ2pELGNBQWMsK0JBQStCLENBQUE7QUFDN0MsY0FBYyx5REFBeUQsQ0FBQTtBQUN2RSxjQUFjLDZDQUE2QyxDQUFBO0FBQzNELGNBQWMsNkNBQTZDLENBQUE7QUFDM0QsY0FBYywrQ0FBK0MsQ0FBQTtBQUM3RCxjQUFjLDZCQUE2QixDQUFBO0FBQzNDLGNBQWMseUNBQXlDLENBQUE7QUFDdkQsY0FBYyw2REFBNkQsQ0FBQTtBQUMzRSxjQUFjLHFDQUFxQyxDQUFBO0FBQ25ELGNBQWMsaURBQWlELENBQUE7QUFDL0QsY0FBYyxpREFBaUQsQ0FBQTtBQUMvRCxjQUFjLG1EQUFtRCxDQUFBO0FBQ2pFLGNBQWMsbURBQW1ELENBQUE7QUFDakUsY0FBYyw2Q0FBNkMsQ0FBQTtBQUMzRCxjQUFjLDZEQUE2RCxDQUFBO0FBQzNFLGNBQWMsbURBQW1ELENBQUE7QUFDakUsY0FBYywyQ0FBMkMsQ0FBQTtBQUN6RCxjQUFjLGlEQUFpRCxDQUFBO0FBQy9ELGNBQWMseURBQXlELENBQUE7QUFDdkUsY0FBYyxxQ0FBcUMsQ0FBQTtBQUNuRCxjQUFjLDBCQUEwQixDQUFBO0FBQ3hDLGNBQWMsdURBQXVELENBQUE7QUFDckUsY0FBYywyQ0FBMkMsQ0FBQTtBQUN6RCxjQUFjLHVEQUF1RCxDQUFBO0FBQ3JFLGNBQWMsdURBQXVELENBQUEiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2xpYi9hcGktY2FyZC9hcGktY2FyZC5jb21wb25lbnQnXG5leHBvcnQgKiBmcm9tICcuL2xpYi9hdmF0YXIvYXZhdGFyLmNvbXBvbmVudCdcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbmZpcm1hdGlvbi1kaWFsb2cvY29uZmlybWF0aW9uLWRpYWxvZy5jb21wb25lbnQnXG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb250ZW50LWdob3N0L2NvbnRlbnQtZ2hvc3QuY29tcG9uZW50J1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZG93bmxvYWQtaXRlbS9kb3dubG9hZC1pdGVtLmNvbXBvbmVudCdcbmV4cG9ydCAqIGZyb20gJy4vbGliL2Rvd25sb2Fkcy1saXN0L2Rvd25sb2Fkcy1saXN0LmNvbXBvbmVudCdcbmV4cG9ydCAqIGZyb20gJy4vbGliL2Vycm9yL2Vycm9yLmNvbXBvbmVudCdcbmV4cG9ydCAqIGZyb20gJy4vbGliL2ltYWdlLWlucHV0L2ltYWdlLWlucHV0LmNvbXBvbmVudCdcbmV4cG9ydCAqIGZyb20gJy4vbGliL2ltYWdlLW92ZXJsYXktcHJldmlldy9pbWFnZS1vdmVybGF5LXByZXZpZXcuY29tcG9uZW50J1xuZXhwb3J0ICogZnJvbSAnLi9saWIvbGluay1jYXJkL2xpbmstY2FyZC5jb21wb25lbnQnXG5leHBvcnQgKiBmcm9tICcuL2xpYi9tYXJrZG93bi1lZGl0b3IvbWFya2Rvd24tZWRpdG9yLmNvbXBvbmVudCdcbmV4cG9ydCAqIGZyb20gJy4vbGliL21hcmtkb3duLXBhcnNlci9tYXJrZG93bi1wYXJzZXIuY29tcG9uZW50J1xuZXhwb3J0ICogZnJvbSAnLi9saWIvbWV0YWRhdGEtY2F0YWxvZy9tZXRhZGF0YS1jYXRhbG9nLmNvbXBvbmVudCdcbmV4cG9ydCAqIGZyb20gJy4vbGliL21ldGFkYXRhLWNvbnRhY3QvbWV0YWRhdGEtY29udGFjdC5jb21wb25lbnQnXG5leHBvcnQgKiBmcm9tICcuL2xpYi9tZXRhZGF0YS1pbmZvL21ldGFkYXRhLWluZm8uY29tcG9uZW50J1xuZXhwb3J0ICogZnJvbSAnLi9saWIvbWV0YWRhdGEtcXVhbGl0eS1pdGVtL21ldGFkYXRhLXF1YWxpdHktaXRlbS5jb21wb25lbnQnXG5leHBvcnQgKiBmcm9tICcuL2xpYi9tZXRhZGF0YS1xdWFsaXR5L21ldGFkYXRhLXF1YWxpdHkuY29tcG9uZW50J1xuZXhwb3J0ICogZnJvbSAnLi9saWIvbm90aWZpY2F0aW9uL25vdGlmaWNhdGlvbi5jb21wb25lbnQnXG5leHBvcnQgKiBmcm9tICcuL2xpYi9yZWNvcmQtYXBpLWZvcm0vcmVjb3JkLWFwaS1mb3JtLmNvbXBvbmVudCdcbmV4cG9ydCAqIGZyb20gJy4vbGliL3JlbGF0ZWQtcmVjb3JkLWNhcmQvcmVsYXRlZC1yZWNvcmQtY2FyZC5jb21wb25lbnQnXG5leHBvcnQgKiBmcm9tICcuL2xpYi90aHVtYm5haWwvdGh1bWJuYWlsLmNvbXBvbmVudCdcbmV4cG9ydCAqIGZyb20gJy4vbGliL3VpLWVsZW1lbnRzLm1vZHVsZSdcbmV4cG9ydCAqIGZyb20gJy4vbGliL3VzZXItZmVlZGJhY2staXRlbS91c2VyLWZlZWRiYWNrLWl0ZW0uY29tcG9uZW50J1xuZXhwb3J0ICogZnJvbSAnLi9saWIvdXNlci1wcmV2aWV3L3VzZXItcHJldmlldy5jb21wb25lbnQnXG5leHBvcnQgKiBmcm9tICcuL2xpYi9hcHBsaWNhdGlvbi1iYW5uZXIvYXBwbGljYXRpb24tYmFubmVyLmNvbXBvbmVudCdcbmV4cG9ydCAqIGZyb20gJy4vbGliL2ludGVybmFsLWxpbmstY2FyZC9pbnRlcm5hbC1saW5rLWNhcmQuY29tcG9uZW50J1xuIl19
|
|
@@ -0,0 +1,163 @@
|
|
|
1
|
+
import { Component, Input, TemplateRef, Output, EventEmitter, ElementRef, } from '@angular/core';
|
|
2
|
+
import { NgClass, NgIf, NgTemplateOutlet } from '@angular/common';
|
|
3
|
+
import { MarkdownParserComponent } from '../markdown-parser/markdown-parser.component';
|
|
4
|
+
import { MetadataQualityComponent } from '../metadata-quality/metadata-quality.component';
|
|
5
|
+
import { ThumbnailComponent } from '../thumbnail/thumbnail.component';
|
|
6
|
+
import { propagateToDocumentOnly, removeWhitespace, stripHtml, } from '../../../../../../libs/util/shared/src';
|
|
7
|
+
import { NgIconComponent, provideIcons, provideNgIconsConfig, } from '@ng-icons/core';
|
|
8
|
+
import { matLocationSearchingOutline, matEmailOutline, matPhoneOutline, matLocationOnOutline, } from '@ng-icons/material-icons/outline';
|
|
9
|
+
import { matCode } from '@ng-icons/material-icons/baseline';
|
|
10
|
+
import { iconoirDatabase, iconoirMap, iconoirInternet } from '@ng-icons/iconoir';
|
|
11
|
+
import { TranslateModule } from '@ngx-translate/core';
|
|
12
|
+
import { marker } from '@biesbjerg/ngx-translate-extract-marker';
|
|
13
|
+
import { fromEvent, Subscription } from 'rxjs';
|
|
14
|
+
import * as i0 from "@angular/core";
|
|
15
|
+
import * as i1 from "@ngx-translate/core";
|
|
16
|
+
marker('record.kind.dataset');
|
|
17
|
+
marker('record.kind.reuse');
|
|
18
|
+
marker('record.kind.service');
|
|
19
|
+
export class InternalLinkCardComponent {
|
|
20
|
+
set size(value) {
|
|
21
|
+
this._size = value;
|
|
22
|
+
this.cardClass = this.sizeClassMap[value] || '';
|
|
23
|
+
this.thumbnailContainerClass = this.thumbnailSizeClassMap[value] || 'hidden';
|
|
24
|
+
}
|
|
25
|
+
get size() {
|
|
26
|
+
return this._size;
|
|
27
|
+
}
|
|
28
|
+
constructor(elementRef) {
|
|
29
|
+
this.elementRef = elementRef;
|
|
30
|
+
this.linkHref = null;
|
|
31
|
+
this.mdSelect = new EventEmitter();
|
|
32
|
+
this.subscription = new Subscription();
|
|
33
|
+
this.cardClass = '';
|
|
34
|
+
this.thumbnailContainerClass = '';
|
|
35
|
+
this._size = 'M';
|
|
36
|
+
this.sizeClassMap = {
|
|
37
|
+
L: 'min-h-[190px] md:w-[992px] py-3 px-3 flex items-start gap-5',
|
|
38
|
+
M: 'min-h-[140px] md:w-[570px] py-3 px-3 flex items-start gap-4',
|
|
39
|
+
S: 'min-h-[220px] md:w-[370px] py-3 px-3 flex gap-4',
|
|
40
|
+
XS: 'min-h-[108px] md:w-[570px] py-3 px-3 flex gap-4',
|
|
41
|
+
};
|
|
42
|
+
this.thumbnailSizeClassMap = {
|
|
43
|
+
L: 'w-[190px] h-[180px] rounded-lg overflow-hidden shrink-0',
|
|
44
|
+
M: 'w-[110px] h-[140px] rounded-lg overflow-hidden shrink-0',
|
|
45
|
+
S: 'hidden',
|
|
46
|
+
XS: 'hidden',
|
|
47
|
+
};
|
|
48
|
+
this.titleClassMap = {
|
|
49
|
+
L: 'text-xl line-clamp-2',
|
|
50
|
+
M: 'text-base line-clamp-2',
|
|
51
|
+
S: 'text-base line-clamp-3',
|
|
52
|
+
XS: 'text-base mt-3 line-clamp-2',
|
|
53
|
+
};
|
|
54
|
+
}
|
|
55
|
+
ngOnInit() {
|
|
56
|
+
this.abstract = removeWhitespace(stripHtml(this.record?.abstract));
|
|
57
|
+
this.subscription.add(fromEvent(this.elementRef.nativeElement, 'click').subscribe((event) => {
|
|
58
|
+
event.preventDefault();
|
|
59
|
+
propagateToDocumentOnly(event);
|
|
60
|
+
this.mdSelect.emit(this.record);
|
|
61
|
+
}));
|
|
62
|
+
}
|
|
63
|
+
get organization() {
|
|
64
|
+
return this.record.ownerOrganization;
|
|
65
|
+
}
|
|
66
|
+
get contacts() {
|
|
67
|
+
return ((this.record.kind === 'dataset'
|
|
68
|
+
? this.record.contactsForResource
|
|
69
|
+
: this.record.contacts) || []);
|
|
70
|
+
}
|
|
71
|
+
getTitleClass() {
|
|
72
|
+
return (this.titleClassMap[this._size] +
|
|
73
|
+
' ' +
|
|
74
|
+
(this.record.ownerOrganization?.name ? '' : 'mt-3') || '');
|
|
75
|
+
}
|
|
76
|
+
openExternalUrl(event, url) {
|
|
77
|
+
event.stopPropagation();
|
|
78
|
+
window.open(url, '_blank');
|
|
79
|
+
}
|
|
80
|
+
openMailto(event, email) {
|
|
81
|
+
event.stopPropagation();
|
|
82
|
+
window.open(`mailto:${email}`, '_blank');
|
|
83
|
+
}
|
|
84
|
+
copyToClipboard(event, text) {
|
|
85
|
+
event.stopPropagation();
|
|
86
|
+
navigator.clipboard.writeText(text);
|
|
87
|
+
}
|
|
88
|
+
get shouldShowThumbnail() {
|
|
89
|
+
return this.size === 'L' || this.size === 'M';
|
|
90
|
+
}
|
|
91
|
+
getKindInfo() {
|
|
92
|
+
if (!this.record?.kind)
|
|
93
|
+
return { text: '', icon: '' };
|
|
94
|
+
switch (this.record.kind.toLowerCase()) {
|
|
95
|
+
case 'dataset':
|
|
96
|
+
return { text: 'record.kind.dataset', icon: 'iconoirDatabase' };
|
|
97
|
+
case 'reuse':
|
|
98
|
+
return { text: 'record.kind.reuse', icon: 'iconoirMap' };
|
|
99
|
+
case 'service':
|
|
100
|
+
return { text: 'record.kind.service', icon: 'matCode' };
|
|
101
|
+
default:
|
|
102
|
+
return { text: '', icon: '' };
|
|
103
|
+
}
|
|
104
|
+
}
|
|
105
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: InternalLinkCardComponent, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
106
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: InternalLinkCardComponent, isStandalone: true, selector: "gn-ui-internal-link-card", inputs: { record: "record", metadataQualityDisplay: "metadataQualityDisplay", favoriteTemplate: "favoriteTemplate", linkHref: "linkHref", isGeodata: "isGeodata", size: "size" }, outputs: { mdSelect: "mdSelect" }, providers: [
|
|
107
|
+
provideIcons({
|
|
108
|
+
matLocationSearchingOutline,
|
|
109
|
+
matCode,
|
|
110
|
+
iconoirDatabase,
|
|
111
|
+
iconoirMap,
|
|
112
|
+
iconoirInternet,
|
|
113
|
+
matEmailOutline,
|
|
114
|
+
matPhoneOutline,
|
|
115
|
+
matLocationOnOutline,
|
|
116
|
+
}),
|
|
117
|
+
provideNgIconsConfig({
|
|
118
|
+
size: '1.2em',
|
|
119
|
+
}),
|
|
120
|
+
], ngImport: i0, template: "<div\n class=\"rounded-lg group card-shadow cursor-pointer overflow-hidden hover:bg-gray-50\"\n [ngClass]=\"cardClass\"\n>\n <div class=\"flex flex-row justify-between w-full\">\n <div\n *ngIf=\"shouldShowThumbnail\"\n [ngClass]=\"thumbnailContainerClass\"\n class=\"mr-4 flex flex-col\"\n >\n <gn-ui-thumbnail\n class=\"w-full h-full object-cover\"\n [thumbnailUrl]=\"record.overviews?.[0]?.url?.toString() || ''\"\n [fit]=\"'cover'\"\n ></gn-ui-thumbnail>\n </div>\n <div\n class=\"flex flex-col flex-1 relative\"\n [ngClass]=\"{\n 'justify-between': record.ownerOrganization?.name && size !== 'XS',\n }\"\n >\n <div class=\"flex items-center space-x-2\">\n <span\n *ngIf=\"getKindInfo().text\"\n class=\"badge-btn text-white text-xs px-2 py-0.5 font-bold shrink-0 bg-primary leading-tight flex items-center justify-evenly h-6 min-h-6\"\n >\n <ng-icon\n class=\"text-[0.9em] text-white mr-1\"\n [name]=\"getKindInfo().icon\"\n ></ng-icon>\n <span class=\"font-medium text-white text-xs\" translate>\n {{ getKindInfo().text }}\n </span>\n </span>\n <span\n *ngIf=\"isGeodata\"\n class=\"badge-btn text-black text-xs px-2 py-0.5 font-bold shrink-0 bg-primary-white leading-tight flex items-center justify-evenly h-6 min-h-6\"\n [ngClass]=\"size === 'L' ? 'w-[164px]' : 'w-8'\"\n >\n <ng-icon\n class=\"text-[0.9em] text-primary-darkest\"\n name=\"matLocationSearchingOutline\"\n ></ng-icon>\n <ng-container *ngIf=\"size === 'L'\">\n <span\n class=\"font-medium text-primary-darkest text-xs ml-1\"\n translate\n >\n record.metadata.type\n </span>\n </ng-container>\n </span>\n <div class=\"flex items-center\">\n <gn-ui-metadata-quality\n [smaller]=\"true\"\n [metadata]=\"record\"\n [metadataQualityDisplay]=\"metadataQualityDisplay\"\n ></gn-ui-metadata-quality>\n </div>\n <div class=\"absolute top-0 right-0 items-center\">\n <ng-container\n *ngIf=\"size !== 'XS'\"\n [ngTemplateOutlet]=\"favoriteTemplate\"\n [ngTemplateOutletContext]=\"{ $implicit: record }\"\n ></ng-container>\n </div>\n </div>\n <div\n class=\"font-medium text-title group-hover:text-primary overflow-hidden break-words\"\n [ngClass]=\"getTitleClass()\"\n >\n {{ record.title }}\n </div>\n <div\n *ngIf=\"size === 'L'\"\n class=\"mt-1 mb-2 font-normal text-xs text-gray-900 line-clamp-2 overflow-hidden\"\n >\n <gn-ui-markdown-parser\n [textContent]=\"abstract\"\n [whitoutStyles]=\"true\"\n ></gn-ui-markdown-parser>\n </div>\n <div\n *ngIf=\"size !== 'XS' && record.ownerOrganization?.name\"\n class=\"flex items-center justify-evenly bg-gray-50 rounded-lg h-[53px] px-2\"\n >\n <div class=\"flex items-center flex-1 min-w-0\">\n <div\n class=\"w-[45px] h-[45px] rounded-lg overflow-hidden shrink-0 mr-3\"\n >\n <gn-ui-thumbnail\n [thumbnailUrl]=\"\n record.ownerOrganization?.logoUrl?.toString() || ''\n \"\n [fit]=\"'contain'\"\n class=\"w-full h-full rounded-lg\"\n ></gn-ui-thumbnail>\n </div>\n <div *ngIf=\"organization?.name\" class=\"flex-1 w-0 overflow-hidden\">\n <div\n class=\"text-xs text-black font-normal leading-tight truncate\"\n translate\n >\n record.card.metadata.contact\n </div>\n <div class=\"text-xl text-primary-black font-medium truncate\">\n {{ organization.name }}\n </div>\n </div>\n </div>\n <div *ngIf=\"size === 'L'\" class=\"ml-2 flex space-x-2\">\n <div *ngIf=\"organization?.website\" class=\"flex\">\n <button\n [title]=\"organization.website\"\n class=\"w-[40px] h-[32px] flex items-center justify-center rounded-lg border border-[#D4D3D7] px-[8px] py-[4px] hover:bg-primary-lightest\"\n (click)=\"openExternalUrl($event, organization.website)\"\n >\n <ng-icon name=\"iconoirInternet\"></ng-icon>\n </button>\n </div>\n <div *ngIf=\"contacts[0]?.email\" class=\"flex\">\n <button\n [title]=\"contacts[0].email\"\n class=\"w-[40px] h-[32px] flex items-center justify-center rounded-lg border border-[#D4D3D7] px-[8px] py-[4px] hover:bg-primary-lightest\"\n data-cy=\"contact-email\"\n (click)=\"openMailto($event, contacts[0].email)\"\n >\n <ng-icon name=\"matEmailOutline\"></ng-icon>\n </button>\n </div>\n <div *ngIf=\"contacts[0]?.phone\" class=\"flex\">\n <button\n [title]=\"'Copy to clipboard'\"\n class=\"w-[40px] h-[32px] flex items-center justify-center rounded-lg border border-[#D4D3D7] px-[8px] py-[4px] hover:bg-primary-lightest relative group\"\n data-cy=\"contact-phone\"\n (click)=\"copyToClipboard($event, contacts[0].phone)\"\n >\n <ng-icon name=\"matPhoneOutline\"></ng-icon>\n </button>\n </div>\n <div *ngIf=\"contacts[0]?.address\" class=\"flex\">\n <button\n [title]=\"'Copy to clipboard'\"\n class=\"w-[40px] h-[32px] flex items-center justify-center rounded-lg border border-[#D4D3D7] px-[8px] py-[4px] hover:bg-primary-lightest relative group\"\n data-cy=\"contact-phone\"\n (click)=\"copyToClipboard($event, contacts[0].address)\"\n >\n <ng-icon name=\"matLocationOnOutline\"></ng-icon>\n </button>\n </div>\n </div>\n </div>\n </div>\n </div>\n</div>\n", styles: [""], dependencies: [{ kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: ThumbnailComponent, selector: "gn-ui-thumbnail", inputs: ["thumbnailUrl", "fit"], outputs: ["placeholderShown"] }, { kind: "component", type: MetadataQualityComponent, selector: "gn-ui-metadata-quality", inputs: ["metadata", "smaller", "metadataQualityDisplay"] }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: NgIconComponent, selector: "ng-icon", inputs: ["name", "svg", "size", "strokeWidth", "color"] }, { kind: "ngmodule", type: TranslateModule }, { kind: "directive", type: i1.TranslateDirective, selector: "[translate],[ngx-translate]", inputs: ["translate", "translateParams"] }, { kind: "component", type: MarkdownParserComponent, selector: "gn-ui-markdown-parser", inputs: ["textContent", "whitoutStyles"] }] }); }
|
|
121
|
+
}
|
|
122
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: InternalLinkCardComponent, decorators: [{
|
|
123
|
+
type: Component,
|
|
124
|
+
args: [{ selector: 'gn-ui-internal-link-card', standalone: true, imports: [
|
|
125
|
+
NgClass,
|
|
126
|
+
NgIf,
|
|
127
|
+
ThumbnailComponent,
|
|
128
|
+
MetadataQualityComponent,
|
|
129
|
+
NgTemplateOutlet,
|
|
130
|
+
NgIconComponent,
|
|
131
|
+
TranslateModule,
|
|
132
|
+
MarkdownParserComponent,
|
|
133
|
+
], providers: [
|
|
134
|
+
provideIcons({
|
|
135
|
+
matLocationSearchingOutline,
|
|
136
|
+
matCode,
|
|
137
|
+
iconoirDatabase,
|
|
138
|
+
iconoirMap,
|
|
139
|
+
iconoirInternet,
|
|
140
|
+
matEmailOutline,
|
|
141
|
+
matPhoneOutline,
|
|
142
|
+
matLocationOnOutline,
|
|
143
|
+
}),
|
|
144
|
+
provideNgIconsConfig({
|
|
145
|
+
size: '1.2em',
|
|
146
|
+
}),
|
|
147
|
+
], template: "<div\n class=\"rounded-lg group card-shadow cursor-pointer overflow-hidden hover:bg-gray-50\"\n [ngClass]=\"cardClass\"\n>\n <div class=\"flex flex-row justify-between w-full\">\n <div\n *ngIf=\"shouldShowThumbnail\"\n [ngClass]=\"thumbnailContainerClass\"\n class=\"mr-4 flex flex-col\"\n >\n <gn-ui-thumbnail\n class=\"w-full h-full object-cover\"\n [thumbnailUrl]=\"record.overviews?.[0]?.url?.toString() || ''\"\n [fit]=\"'cover'\"\n ></gn-ui-thumbnail>\n </div>\n <div\n class=\"flex flex-col flex-1 relative\"\n [ngClass]=\"{\n 'justify-between': record.ownerOrganization?.name && size !== 'XS',\n }\"\n >\n <div class=\"flex items-center space-x-2\">\n <span\n *ngIf=\"getKindInfo().text\"\n class=\"badge-btn text-white text-xs px-2 py-0.5 font-bold shrink-0 bg-primary leading-tight flex items-center justify-evenly h-6 min-h-6\"\n >\n <ng-icon\n class=\"text-[0.9em] text-white mr-1\"\n [name]=\"getKindInfo().icon\"\n ></ng-icon>\n <span class=\"font-medium text-white text-xs\" translate>\n {{ getKindInfo().text }}\n </span>\n </span>\n <span\n *ngIf=\"isGeodata\"\n class=\"badge-btn text-black text-xs px-2 py-0.5 font-bold shrink-0 bg-primary-white leading-tight flex items-center justify-evenly h-6 min-h-6\"\n [ngClass]=\"size === 'L' ? 'w-[164px]' : 'w-8'\"\n >\n <ng-icon\n class=\"text-[0.9em] text-primary-darkest\"\n name=\"matLocationSearchingOutline\"\n ></ng-icon>\n <ng-container *ngIf=\"size === 'L'\">\n <span\n class=\"font-medium text-primary-darkest text-xs ml-1\"\n translate\n >\n record.metadata.type\n </span>\n </ng-container>\n </span>\n <div class=\"flex items-center\">\n <gn-ui-metadata-quality\n [smaller]=\"true\"\n [metadata]=\"record\"\n [metadataQualityDisplay]=\"metadataQualityDisplay\"\n ></gn-ui-metadata-quality>\n </div>\n <div class=\"absolute top-0 right-0 items-center\">\n <ng-container\n *ngIf=\"size !== 'XS'\"\n [ngTemplateOutlet]=\"favoriteTemplate\"\n [ngTemplateOutletContext]=\"{ $implicit: record }\"\n ></ng-container>\n </div>\n </div>\n <div\n class=\"font-medium text-title group-hover:text-primary overflow-hidden break-words\"\n [ngClass]=\"getTitleClass()\"\n >\n {{ record.title }}\n </div>\n <div\n *ngIf=\"size === 'L'\"\n class=\"mt-1 mb-2 font-normal text-xs text-gray-900 line-clamp-2 overflow-hidden\"\n >\n <gn-ui-markdown-parser\n [textContent]=\"abstract\"\n [whitoutStyles]=\"true\"\n ></gn-ui-markdown-parser>\n </div>\n <div\n *ngIf=\"size !== 'XS' && record.ownerOrganization?.name\"\n class=\"flex items-center justify-evenly bg-gray-50 rounded-lg h-[53px] px-2\"\n >\n <div class=\"flex items-center flex-1 min-w-0\">\n <div\n class=\"w-[45px] h-[45px] rounded-lg overflow-hidden shrink-0 mr-3\"\n >\n <gn-ui-thumbnail\n [thumbnailUrl]=\"\n record.ownerOrganization?.logoUrl?.toString() || ''\n \"\n [fit]=\"'contain'\"\n class=\"w-full h-full rounded-lg\"\n ></gn-ui-thumbnail>\n </div>\n <div *ngIf=\"organization?.name\" class=\"flex-1 w-0 overflow-hidden\">\n <div\n class=\"text-xs text-black font-normal leading-tight truncate\"\n translate\n >\n record.card.metadata.contact\n </div>\n <div class=\"text-xl text-primary-black font-medium truncate\">\n {{ organization.name }}\n </div>\n </div>\n </div>\n <div *ngIf=\"size === 'L'\" class=\"ml-2 flex space-x-2\">\n <div *ngIf=\"organization?.website\" class=\"flex\">\n <button\n [title]=\"organization.website\"\n class=\"w-[40px] h-[32px] flex items-center justify-center rounded-lg border border-[#D4D3D7] px-[8px] py-[4px] hover:bg-primary-lightest\"\n (click)=\"openExternalUrl($event, organization.website)\"\n >\n <ng-icon name=\"iconoirInternet\"></ng-icon>\n </button>\n </div>\n <div *ngIf=\"contacts[0]?.email\" class=\"flex\">\n <button\n [title]=\"contacts[0].email\"\n class=\"w-[40px] h-[32px] flex items-center justify-center rounded-lg border border-[#D4D3D7] px-[8px] py-[4px] hover:bg-primary-lightest\"\n data-cy=\"contact-email\"\n (click)=\"openMailto($event, contacts[0].email)\"\n >\n <ng-icon name=\"matEmailOutline\"></ng-icon>\n </button>\n </div>\n <div *ngIf=\"contacts[0]?.phone\" class=\"flex\">\n <button\n [title]=\"'Copy to clipboard'\"\n class=\"w-[40px] h-[32px] flex items-center justify-center rounded-lg border border-[#D4D3D7] px-[8px] py-[4px] hover:bg-primary-lightest relative group\"\n data-cy=\"contact-phone\"\n (click)=\"copyToClipboard($event, contacts[0].phone)\"\n >\n <ng-icon name=\"matPhoneOutline\"></ng-icon>\n </button>\n </div>\n <div *ngIf=\"contacts[0]?.address\" class=\"flex\">\n <button\n [title]=\"'Copy to clipboard'\"\n class=\"w-[40px] h-[32px] flex items-center justify-center rounded-lg border border-[#D4D3D7] px-[8px] py-[4px] hover:bg-primary-lightest relative group\"\n data-cy=\"contact-phone\"\n (click)=\"copyToClipboard($event, contacts[0].address)\"\n >\n <ng-icon name=\"matLocationOnOutline\"></ng-icon>\n </button>\n </div>\n </div>\n </div>\n </div>\n </div>\n</div>\n" }]
|
|
148
|
+
}], ctorParameters: () => [{ type: i0.ElementRef }], propDecorators: { record: [{
|
|
149
|
+
type: Input
|
|
150
|
+
}], metadataQualityDisplay: [{
|
|
151
|
+
type: Input
|
|
152
|
+
}], favoriteTemplate: [{
|
|
153
|
+
type: Input
|
|
154
|
+
}], linkHref: [{
|
|
155
|
+
type: Input
|
|
156
|
+
}], isGeodata: [{
|
|
157
|
+
type: Input
|
|
158
|
+
}], size: [{
|
|
159
|
+
type: Input
|
|
160
|
+
}], mdSelect: [{
|
|
161
|
+
type: Output
|
|
162
|
+
}] } });
|
|
163
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"internal-link-card.component.js","sourceRoot":"","sources":["../../../../../../../../libs/ui/elements/src/lib/internal-link-card/internal-link-card.component.ts","../../../../../../../../libs/ui/elements/src/lib/internal-link-card/internal-link-card.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  Input,\n  TemplateRef,\n  OnInit,\n  Output,\n  EventEmitter,\n  ElementRef,\n} from '@angular/core'\nimport {\n  CatalogRecord,\n  Organization,\n} from '../../../../../../libs/common/domain/src/lib/model/record'\nimport { NgClass, NgIf, NgTemplateOutlet } from '@angular/common'\nimport { MarkdownParserComponent } from '../markdown-parser/markdown-parser.component'\nimport { MetadataQualityComponent } from '../metadata-quality/metadata-quality.component'\nimport { ThumbnailComponent } from '../thumbnail/thumbnail.component'\nimport {\n  propagateToDocumentOnly,\n  removeWhitespace,\n  stripHtml,\n} from '../../../../../../libs/util/shared/src'\nimport {\n  NgIconComponent,\n  provideIcons,\n  provideNgIconsConfig,\n} from '@ng-icons/core'\nimport {\n  matLocationSearchingOutline,\n  matEmailOutline,\n  matPhoneOutline,\n  matLocationOnOutline,\n} from '@ng-icons/material-icons/outline'\nimport { matCode } from '@ng-icons/material-icons/baseline'\nimport { iconoirDatabase, iconoirMap, iconoirInternet } from '@ng-icons/iconoir'\nimport { TranslateModule } from '@ngx-translate/core'\nimport { marker } from '@biesbjerg/ngx-translate-extract-marker'\nimport { fromEvent, Subscription } from 'rxjs'\n\nmarker('record.kind.dataset')\nmarker('record.kind.reuse')\nmarker('record.kind.service')\n\ntype CardSize = 'L' | 'M' | 'S' | 'XS'\n\n@Component({\n  selector: 'gn-ui-internal-link-card',\n  standalone: true,\n  imports: [\n    NgClass,\n    NgIf,\n    ThumbnailComponent,\n    MetadataQualityComponent,\n    NgTemplateOutlet,\n    NgIconComponent,\n    TranslateModule,\n    MarkdownParserComponent,\n  ],\n  providers: [\n    provideIcons({\n      matLocationSearchingOutline,\n      matCode,\n      iconoirDatabase,\n      iconoirMap,\n      iconoirInternet,\n      matEmailOutline,\n      matPhoneOutline,\n      matLocationOnOutline,\n    }),\n    provideNgIconsConfig({\n      size: '1.2em',\n    }),\n  ],\n  templateUrl: './internal-link-card.component.html',\n  styleUrls: ['./internal-link-card.component.css'],\n})\nexport class InternalLinkCardComponent implements OnInit {\n  @Input() record: CatalogRecord\n  @Input() metadataQualityDisplay: boolean\n  @Input() favoriteTemplate: TemplateRef<{ $implicit: CatalogRecord }>\n  @Input() linkHref: string = null\n  @Input() isGeodata: boolean\n  @Input() set size(value: CardSize) {\n    this._size = value\n    this.cardClass = this.sizeClassMap[value] || ''\n    this.thumbnailContainerClass = this.thumbnailSizeClassMap[value] || 'hidden'\n  }\n  get size(): CardSize {\n    return this._size\n  }\n  @Output() mdSelect = new EventEmitter<CatalogRecord>()\n  subscription = new Subscription()\n\n  abstract: string\n\n  cardClass = ''\n  thumbnailContainerClass = ''\n\n  private _size: CardSize = 'M'\n\n  private readonly sizeClassMap: Record<CardSize, string> = {\n    L: 'min-h-[190px] md:w-[992px] py-3 px-3 flex items-start gap-5',\n    M: 'min-h-[140px] md:w-[570px] py-3 px-3 flex items-start gap-4',\n    S: 'min-h-[220px] md:w-[370px] py-3 px-3 flex gap-4',\n    XS: 'min-h-[108px] md:w-[570px] py-3 px-3 flex gap-4',\n  }\n\n  private readonly thumbnailSizeClassMap: Record<CardSize, string> = {\n    L: 'w-[190px] h-[180px] rounded-lg overflow-hidden shrink-0',\n    M: 'w-[110px] h-[140px] rounded-lg overflow-hidden shrink-0',\n    S: 'hidden',\n    XS: 'hidden',\n  }\n\n  private readonly titleClassMap: Record<CardSize, string> = {\n    L: 'text-xl line-clamp-2',\n    M: 'text-base line-clamp-2',\n    S: 'text-base line-clamp-3',\n    XS: 'text-base mt-3 line-clamp-2',\n  }\n\n  constructor(protected elementRef: ElementRef) {}\n\n  ngOnInit(): void {\n    this.abstract = removeWhitespace(stripHtml(this.record?.abstract))\n    this.subscription.add(\n      fromEvent(this.elementRef.nativeElement, 'click').subscribe(\n        (event: Event) => {\n          event.preventDefault()\n          propagateToDocumentOnly(event)\n          this.mdSelect.emit(this.record)\n        }\n      )\n    )\n  }\n\n  get organization(): Organization {\n    return this.record.ownerOrganization\n  }\n\n  get contacts() {\n    return (\n      (this.record.kind === 'dataset'\n        ? this.record.contactsForResource\n        : this.record.contacts) || []\n    )\n  }\n\n  getTitleClass() {\n    return (\n      this.titleClassMap[this._size] +\n        ' ' +\n        (this.record.ownerOrganization?.name ? '' : 'mt-3') || ''\n    )\n  }\n\n  openExternalUrl(event: Event, url: URL): void {\n    event.stopPropagation()\n    window.open(url, '_blank')\n  }\n\n  openMailto(event: Event, email: string): void {\n    event.stopPropagation()\n    window.open(`mailto:${email}`, '_blank')\n  }\n\n  copyToClipboard(event: Event, text: string): void {\n    event.stopPropagation()\n    navigator.clipboard.writeText(text)\n  }\n\n  get shouldShowThumbnail(): boolean {\n    return this.size === 'L' || this.size === 'M'\n  }\n\n  getKindInfo(): { text: string; icon: string } {\n    if (!this.record?.kind) return { text: '', icon: '' }\n\n    switch (this.record.kind.toLowerCase()) {\n      case 'dataset':\n        return { text: 'record.kind.dataset', icon: 'iconoirDatabase' }\n      case 'reuse':\n        return { text: 'record.kind.reuse', icon: 'iconoirMap' }\n      case 'service':\n        return { text: 'record.kind.service', icon: 'matCode' }\n      default:\n        return { text: '', icon: '' }\n    }\n  }\n}\n","<div\n  class=\"rounded-lg group card-shadow cursor-pointer overflow-hidden hover:bg-gray-50\"\n  [ngClass]=\"cardClass\"\n>\n  <div class=\"flex flex-row justify-between w-full\">\n    <div\n      *ngIf=\"shouldShowThumbnail\"\n      [ngClass]=\"thumbnailContainerClass\"\n      class=\"mr-4 flex flex-col\"\n    >\n      <gn-ui-thumbnail\n        class=\"w-full h-full object-cover\"\n        [thumbnailUrl]=\"record.overviews?.[0]?.url?.toString() || ''\"\n        [fit]=\"'cover'\"\n      ></gn-ui-thumbnail>\n    </div>\n    <div\n      class=\"flex flex-col flex-1 relative\"\n      [ngClass]=\"{\n        'justify-between': record.ownerOrganization?.name && size !== 'XS',\n      }\"\n    >\n      <div class=\"flex items-center space-x-2\">\n        <span\n          *ngIf=\"getKindInfo().text\"\n          class=\"badge-btn text-white text-xs px-2 py-0.5 font-bold shrink-0 bg-primary leading-tight flex items-center justify-evenly h-6 min-h-6\"\n        >\n          <ng-icon\n            class=\"text-[0.9em] text-white mr-1\"\n            [name]=\"getKindInfo().icon\"\n          ></ng-icon>\n          <span class=\"font-medium text-white text-xs\" translate>\n            {{ getKindInfo().text }}\n          </span>\n        </span>\n        <span\n          *ngIf=\"isGeodata\"\n          class=\"badge-btn text-black text-xs px-2 py-0.5 font-bold shrink-0 bg-primary-white leading-tight flex items-center justify-evenly h-6 min-h-6\"\n          [ngClass]=\"size === 'L' ? 'w-[164px]' : 'w-8'\"\n        >\n          <ng-icon\n            class=\"text-[0.9em] text-primary-darkest\"\n            name=\"matLocationSearchingOutline\"\n          ></ng-icon>\n          <ng-container *ngIf=\"size === 'L'\">\n            <span\n              class=\"font-medium text-primary-darkest text-xs ml-1\"\n              translate\n            >\n              record.metadata.type\n            </span>\n          </ng-container>\n        </span>\n        <div class=\"flex items-center\">\n          <gn-ui-metadata-quality\n            [smaller]=\"true\"\n            [metadata]=\"record\"\n            [metadataQualityDisplay]=\"metadataQualityDisplay\"\n          ></gn-ui-metadata-quality>\n        </div>\n        <div class=\"absolute top-0 right-0 items-center\">\n          <ng-container\n            *ngIf=\"size !== 'XS'\"\n            [ngTemplateOutlet]=\"favoriteTemplate\"\n            [ngTemplateOutletContext]=\"{ $implicit: record }\"\n          ></ng-container>\n        </div>\n      </div>\n      <div\n        class=\"font-medium text-title group-hover:text-primary overflow-hidden break-words\"\n        [ngClass]=\"getTitleClass()\"\n      >\n        {{ record.title }}\n      </div>\n      <div\n        *ngIf=\"size === 'L'\"\n        class=\"mt-1 mb-2 font-normal text-xs text-gray-900 line-clamp-2 overflow-hidden\"\n      >\n        <gn-ui-markdown-parser\n          [textContent]=\"abstract\"\n          [whitoutStyles]=\"true\"\n        ></gn-ui-markdown-parser>\n      </div>\n      <div\n        *ngIf=\"size !== 'XS' && record.ownerOrganization?.name\"\n        class=\"flex items-center justify-evenly bg-gray-50 rounded-lg h-[53px] px-2\"\n      >\n        <div class=\"flex items-center flex-1 min-w-0\">\n          <div\n            class=\"w-[45px] h-[45px] rounded-lg overflow-hidden shrink-0 mr-3\"\n          >\n            <gn-ui-thumbnail\n              [thumbnailUrl]=\"\n                record.ownerOrganization?.logoUrl?.toString() || ''\n              \"\n              [fit]=\"'contain'\"\n              class=\"w-full h-full rounded-lg\"\n            ></gn-ui-thumbnail>\n          </div>\n          <div *ngIf=\"organization?.name\" class=\"flex-1 w-0 overflow-hidden\">\n            <div\n              class=\"text-xs text-black font-normal leading-tight truncate\"\n              translate\n            >\n              record.card.metadata.contact\n            </div>\n            <div class=\"text-xl text-primary-black font-medium truncate\">\n              {{ organization.name }}\n            </div>\n          </div>\n        </div>\n        <div *ngIf=\"size === 'L'\" class=\"ml-2 flex space-x-2\">\n          <div *ngIf=\"organization?.website\" class=\"flex\">\n            <button\n              [title]=\"organization.website\"\n              class=\"w-[40px] h-[32px] flex items-center justify-center rounded-lg border border-[#D4D3D7] px-[8px] py-[4px] hover:bg-primary-lightest\"\n              (click)=\"openExternalUrl($event, organization.website)\"\n            >\n              <ng-icon name=\"iconoirInternet\"></ng-icon>\n            </button>\n          </div>\n          <div *ngIf=\"contacts[0]?.email\" class=\"flex\">\n            <button\n              [title]=\"contacts[0].email\"\n              class=\"w-[40px] h-[32px] flex items-center justify-center rounded-lg border border-[#D4D3D7] px-[8px] py-[4px] hover:bg-primary-lightest\"\n              data-cy=\"contact-email\"\n              (click)=\"openMailto($event, contacts[0].email)\"\n            >\n              <ng-icon name=\"matEmailOutline\"></ng-icon>\n            </button>\n          </div>\n          <div *ngIf=\"contacts[0]?.phone\" class=\"flex\">\n            <button\n              [title]=\"'Copy to clipboard'\"\n              class=\"w-[40px] h-[32px] flex items-center justify-center rounded-lg border border-[#D4D3D7] px-[8px] py-[4px] hover:bg-primary-lightest relative group\"\n              data-cy=\"contact-phone\"\n              (click)=\"copyToClipboard($event, contacts[0].phone)\"\n            >\n              <ng-icon name=\"matPhoneOutline\"></ng-icon>\n            </button>\n          </div>\n          <div *ngIf=\"contacts[0]?.address\" class=\"flex\">\n            <button\n              [title]=\"'Copy to clipboard'\"\n              class=\"w-[40px] h-[32px] flex items-center justify-center rounded-lg border border-[#D4D3D7] px-[8px] py-[4px] hover:bg-primary-lightest relative group\"\n              data-cy=\"contact-phone\"\n              (click)=\"copyToClipboard($event, contacts[0].address)\"\n            >\n              <ng-icon name=\"matLocationOnOutline\"></ng-icon>\n            </button>\n          </div>\n        </div>\n      </div>\n    </div>\n  </div>\n</div>\n"]}
|
|
@@ -54,7 +54,7 @@ export class MetadataQualityComponent {
|
|
|
54
54
|
size: '1.2em',
|
|
55
55
|
strokeWidth: '1.5px',
|
|
56
56
|
}),
|
|
57
|
-
], usesOnChanges: true, ngImport: i0, template: "<div *ngIf=\"metadataQualityDisplay\" class=\"
|
|
57
|
+
], usesOnChanges: true, ngImport: i0, template: "<div *ngIf=\"metadataQualityDisplay\" class=\"metadata-quality\">\n <div\n class=\"flex items-center\"\n [class]=\"\n smaller ? 'leading-[8px] min-w-[120px] m-h-[120px]' : 'min-w-[200px]'\n \"\n >\n <gn-ui-progress-bar\n tabindex=\"0\"\n [value]=\"qualityScore\"\n [type]=\"'light'\"\n class=\"flex-grow\"\n ></gn-ui-progress-bar>\n <gn-ui-popover\n [content]=\"popoverItems\"\n theme=\"light-border\"\n [class]=\"smaller ? 'ml-2' : 'ml-2 mt-1'\"\n >\n <ng-icon\n name=\"matInfoOutline\"\n class=\"flex-shrink-0 text-gray-600\"\n ></ng-icon>\n </gn-ui-popover>\n </div>\n</div>\n<ng-template #popoverItems>\n <div class=\"p-2 py-4\">\n <div class=\"mb-4 font-bold\" translate>record.metadata.quality.details</div>\n <gn-ui-metadata-quality-item\n *ngFor=\"let e of items\"\n [name]=\"e.name\"\n [value]=\"e.value\"\n ></gn-ui-metadata-quality-item>\n </div>\n</ng-template>\n", styles: [":host gn-ui-progress-bar{--progress-bar-font-weight: \"normal\"}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: PopoverComponent, selector: "gn-ui-popover", inputs: ["content", "theme"] }, { kind: "component", type: ProgressBarComponent, selector: "gn-ui-progress-bar", inputs: ["value", "type"] }, { kind: "component", type: MetadataQualityItemComponent, selector: "gn-ui-metadata-quality-item", inputs: ["name", "value"] }, { kind: "ngmodule", type: TranslateModule }, { kind: "directive", type: i2.TranslateDirective, selector: "[translate],[ngx-translate]", inputs: ["translate", "translateParams"] }, { kind: "component", type: NgIcon, selector: "ng-icon", inputs: ["name", "svg", "size", "strokeWidth", "color"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
58
58
|
}
|
|
59
59
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MetadataQualityComponent, decorators: [{
|
|
60
60
|
type: Component,
|
|
@@ -73,7 +73,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
73
73
|
size: '1.2em',
|
|
74
74
|
strokeWidth: '1.5px',
|
|
75
75
|
}),
|
|
76
|
-
], template: "<div *ngIf=\"metadataQualityDisplay\" class=\"
|
|
76
|
+
], template: "<div *ngIf=\"metadataQualityDisplay\" class=\"metadata-quality\">\n <div\n class=\"flex items-center\"\n [class]=\"\n smaller ? 'leading-[8px] min-w-[120px] m-h-[120px]' : 'min-w-[200px]'\n \"\n >\n <gn-ui-progress-bar\n tabindex=\"0\"\n [value]=\"qualityScore\"\n [type]=\"'light'\"\n class=\"flex-grow\"\n ></gn-ui-progress-bar>\n <gn-ui-popover\n [content]=\"popoverItems\"\n theme=\"light-border\"\n [class]=\"smaller ? 'ml-2' : 'ml-2 mt-1'\"\n >\n <ng-icon\n name=\"matInfoOutline\"\n class=\"flex-shrink-0 text-gray-600\"\n ></ng-icon>\n </gn-ui-popover>\n </div>\n</div>\n<ng-template #popoverItems>\n <div class=\"p-2 py-4\">\n <div class=\"mb-4 font-bold\" translate>record.metadata.quality.details</div>\n <gn-ui-metadata-quality-item\n *ngFor=\"let e of items\"\n [name]=\"e.name\"\n [value]=\"e.value\"\n ></gn-ui-metadata-quality-item>\n </div>\n</ng-template>\n", styles: [":host gn-ui-progress-bar{--progress-bar-font-weight: \"normal\"}\n"] }]
|
|
77
77
|
}], propDecorators: { metadata: [{
|
|
78
78
|
type: Input
|
|
79
79
|
}], smaller: [{
|
|
@@ -81,4 +81,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
81
81
|
}], metadataQualityDisplay: [{
|
|
82
82
|
type: Input
|
|
83
83
|
}] } });
|
|
84
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
84
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"metadata-quality.component.js","sourceRoot":"","sources":["../../../../../../../../libs/ui/elements/src/lib/metadata-quality/metadata-quality.component.ts","../../../../../../../../libs/ui/elements/src/lib/metadata-quality/metadata-quality.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  Input,\n  OnChanges,\n  SimpleChanges,\n} from '@angular/core'\nimport {\n  MetadataQualityItem,\n  MetadataQualityItemComponent,\n} from '../metadata-quality-item/metadata-quality-item.component'\nimport { CatalogRecord } from '../../../../../../libs/common/domain/src/lib/model/record'\nimport {\n  PopoverComponent,\n  ProgressBarComponent,\n} from '../../../../../../libs/ui/widgets/src'\nimport { CommonModule } from '@angular/common'\nimport { TranslateModule } from '@ngx-translate/core'\nimport { NgIcon } from '@ng-icons/core'\nimport { matInfoOutline } from '@ng-icons/material-icons/outline'\nimport { provideIcons, provideNgIconsConfig } from '@ng-icons/core'\n\n@Component({\n  selector: 'gn-ui-metadata-quality',\n  templateUrl: './metadata-quality.component.html',\n  styleUrls: ['./metadata-quality.component.css'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true,\n  imports: [\n    CommonModule,\n    PopoverComponent,\n    ProgressBarComponent,\n    MetadataQualityItemComponent,\n    TranslateModule,\n    NgIcon,\n  ],\n  providers: [\n    provideIcons({\n      matInfoOutline,\n    }),\n    provideNgIconsConfig({\n      size: '1.2em',\n      strokeWidth: '1.5px',\n    }),\n  ],\n})\nexport class MetadataQualityComponent implements OnChanges {\n  @Input() metadata: Partial<CatalogRecord>\n  @Input() smaller = false\n  @Input() metadataQualityDisplay: boolean\n\n  items: MetadataQualityItem[] = []\n\n  get qualityScore() {\n    const qualityScore = this.metadata?.extras?.qualityScore\n    return typeof qualityScore === 'number'\n      ? qualityScore\n      : this.calculatedQualityScore\n  }\n\n  get calculatedQualityScore(): number {\n    return Math.round(\n      (this.items.filter(({ value }) => value).length * 100) / this.items.length\n    )\n  }\n\n  private add(name: string, value: boolean) {\n    if (this.metadataQualityDisplay?.[name] !== false) {\n      this.items.push({ name, value })\n    }\n  }\n\n  initialize() {\n    const contact = this.metadata?.contacts?.[0]\n    this.items = []\n    this.add('title', !!this.metadata?.title)\n    this.add('description', !!this.metadata?.abstract)\n    this.add('topic', this.metadata?.topics?.length > 0)\n    this.add('keywords', this.metadata?.keywords?.length > 0)\n    this.add('legalConstraints', this.metadata?.legalConstraints?.length > 0)\n    this.add('organisation', !!contact?.organization)\n    this.add('contact', !!contact?.email)\n    this.add('updateFrequency', !!this.metadata?.updateFrequency)\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes['metadata'] || changes['metadataQualityDisplay']) {\n      this.initialize()\n    }\n  }\n}\n","<div *ngIf=\"metadataQualityDisplay\" class=\"metadata-quality\">\n  <div\n    class=\"flex items-center\"\n    [class]=\"\n      smaller ? 'leading-[8px] min-w-[120px] m-h-[120px]' : 'min-w-[200px]'\n    \"\n  >\n    <gn-ui-progress-bar\n      tabindex=\"0\"\n      [value]=\"qualityScore\"\n      [type]=\"'light'\"\n      class=\"flex-grow\"\n    ></gn-ui-progress-bar>\n    <gn-ui-popover\n      [content]=\"popoverItems\"\n      theme=\"light-border\"\n      [class]=\"smaller ? 'ml-2' : 'ml-2 mt-1'\"\n    >\n      <ng-icon\n        name=\"matInfoOutline\"\n        class=\"flex-shrink-0 text-gray-600\"\n      ></ng-icon>\n    </gn-ui-popover>\n  </div>\n</div>\n<ng-template #popoverItems>\n  <div class=\"p-2 py-4\">\n    <div class=\"mb-4 font-bold\" translate>record.metadata.quality.details</div>\n    <gn-ui-metadata-quality-item\n      *ngFor=\"let e of items\"\n      [name]=\"e.name\"\n      [value]=\"e.value\"\n    ></gn-ui-metadata-quality-item>\n  </div>\n</ng-template>\n"]}
|
|
@@ -16,6 +16,7 @@ import { ThumbnailComponent } from './thumbnail/thumbnail.component';
|
|
|
16
16
|
import { TimeSincePipe } from './user-feedback-item/time-since.pipe';
|
|
17
17
|
import { UserPreviewComponent } from './user-preview/user-preview.component';
|
|
18
18
|
import { ApplicationBannerComponent } from './application-banner/application-banner.component';
|
|
19
|
+
import { InternalLinkCardComponent } from './internal-link-card/internal-link-card.component';
|
|
19
20
|
import * as i0 from "@angular/core";
|
|
20
21
|
import * as i1 from "@ngx-translate/core";
|
|
21
22
|
export class UiElementsModule {
|
|
@@ -36,12 +37,14 @@ export class UiElementsModule {
|
|
|
36
37
|
MaxLinesComponent,
|
|
37
38
|
TextInputComponent,
|
|
38
39
|
ImageInputComponent,
|
|
39
|
-
ApplicationBannerComponent
|
|
40
|
+
ApplicationBannerComponent,
|
|
41
|
+
InternalLinkCardComponent], exports: [ThumbnailComponent,
|
|
40
42
|
AvatarComponent,
|
|
41
43
|
UserPreviewComponent,
|
|
42
44
|
MarkdownParserComponent,
|
|
43
45
|
ImageInputComponent,
|
|
44
|
-
ApplicationBannerComponent
|
|
46
|
+
ApplicationBannerComponent,
|
|
47
|
+
InternalLinkCardComponent] }); }
|
|
45
48
|
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: UiElementsModule, providers: [
|
|
46
49
|
provideNgIconsConfig({
|
|
47
50
|
size: '1.5em',
|
|
@@ -61,7 +64,8 @@ export class UiElementsModule {
|
|
|
61
64
|
MaxLinesComponent,
|
|
62
65
|
TextInputComponent,
|
|
63
66
|
ImageInputComponent,
|
|
64
|
-
ApplicationBannerComponent
|
|
67
|
+
ApplicationBannerComponent,
|
|
68
|
+
InternalLinkCardComponent] }); }
|
|
65
69
|
}
|
|
66
70
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: UiElementsModule, decorators: [{
|
|
67
71
|
type: NgModule,
|
|
@@ -86,6 +90,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
86
90
|
TextInputComponent,
|
|
87
91
|
ImageInputComponent,
|
|
88
92
|
ApplicationBannerComponent,
|
|
93
|
+
InternalLinkCardComponent,
|
|
89
94
|
],
|
|
90
95
|
providers: [
|
|
91
96
|
provideNgIconsConfig({
|
|
@@ -100,7 +105,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
100
105
|
MarkdownParserComponent,
|
|
101
106
|
ImageInputComponent,
|
|
102
107
|
ApplicationBannerComponent,
|
|
108
|
+
InternalLinkCardComponent,
|
|
103
109
|
],
|
|
104
110
|
}]
|
|
105
111
|
}] });
|
|
106
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
112
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidWktZWxlbWVudHMubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy91aS9lbGVtZW50cy9zcmMvbGliL3VpLWVsZW1lbnRzLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFFLGdCQUFnQixFQUFFLE1BQU0saUJBQWlCLENBQUE7QUFDaEUsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQTtBQUN4QyxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sZ0JBQWdCLENBQUE7QUFDNUMsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sMkJBQTJCLENBQUE7QUFDNUQsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFBO0FBQzlDLE9BQU8sRUFDTCxjQUFjLEVBQ2Qsa0JBQWtCLEVBQ2xCLGNBQWMsR0FDZixNQUFNLG1DQUFtQyxDQUFBO0FBQzFDLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxjQUFjLEVBQUUsTUFBTSxtQ0FBbUMsQ0FBQTtBQUNyRixPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsZUFBZSxFQUFFLE1BQU0sb0NBQW9DLENBQUE7QUFDdEYsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0scUNBQXFDLENBQUE7QUFDdEUsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sZ0JBQWdCLENBQUE7QUFDckQsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLHFCQUFxQixDQUFBO0FBQ3JELE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSwyQkFBMkIsQ0FBQTtBQUMzRCxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxxQ0FBcUMsQ0FBQTtBQUN6RSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSw2Q0FBNkMsQ0FBQTtBQUNyRixPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSxpQ0FBaUMsQ0FBQTtBQUNwRSxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sc0NBQXNDLENBQUE7QUFDcEUsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sdUNBQXVDLENBQUE7QUFDNUUsT0FBTyxFQUFFLDBCQUEwQixFQUFFLE1BQU0sbURBQW1ELENBQUE7QUFDOUYsT0FBTyxFQUFFLHlCQUF5QixFQUFFLE1BQU0sbURBQW1ELENBQUE7OztBQXlDN0YsTUFBTSxPQUFPLGdCQUFnQjsrR0FBaEIsZ0JBQWdCO2dIQUFoQixnQkFBZ0IsaUJBWFosZUFBZSxFQUFFLG9CQUFvQixhQTFCbEQsWUFBWTtZQUNaLGdCQUFnQjtZQUNoQixlQUFlO1lBQ2YsY0FBYyxzQkFFZCxnQkFBZ0I7WUFDaEIsWUFBWTtZQUNaLGNBQWM7WUFDZCxXQUFXO1lBQ1gsZ0JBQWdCO1lBQ2hCLGdCQUFnQjtZQUNoQix1QkFBdUI7WUFDdkIsa0JBQWtCO1lBQ2xCLGFBQWE7WUFDYixjQUFjO1lBQ2QsaUJBQWlCO1lBQ2pCLGtCQUFrQjtZQUNsQixtQkFBbUI7WUFDbkIsMEJBQTBCO1lBQzFCLHlCQUF5QixhQVN6QixrQkFBa0I7WUFDbEIsZUFBZTtZQUNmLG9CQUFvQjtZQUNwQix1QkFBdUI7WUFDdkIsbUJBQW1CO1lBQ25CLDBCQUEwQjtZQUMxQix5QkFBeUI7Z0hBR2hCLGdCQUFnQixhQWhCaEI7WUFDVCxvQkFBb0IsQ0FBQztnQkFDbkIsSUFBSSxFQUFFLE9BQU87YUFDZCxDQUFDO1NBQ0gsWUF6QkMsWUFBWTtZQUNaLGdCQUFnQjtZQUNoQixlQUFlO1lBQ2YsY0FBYztZQUNkLGVBQWUsQ0FBQyxRQUFRLEVBQUU7WUFDMUIsZ0JBQWdCO1lBQ2hCLFlBQVk7WUFDWixjQUFjO1lBQ2QsV0FBVztZQUVYLGdCQUFnQjtZQUVoQixrQkFBa0I7WUFFbEIsY0FBYztZQUNkLGlCQUFpQjtZQUNqQixrQkFBa0I7WUFDbEIsbUJBQW1CO1lBQ25CLDBCQUEwQjtZQUMxQix5QkFBeUI7OzRGQWtCaEIsZ0JBQWdCO2tCQXZDNUIsUUFBUTttQkFBQztvQkFDUixPQUFPLEVBQUU7d0JBQ1AsWUFBWTt3QkFDWixnQkFBZ0I7d0JBQ2hCLGVBQWU7d0JBQ2YsY0FBYzt3QkFDZCxlQUFlLENBQUMsUUFBUSxFQUFFO3dCQUMxQixnQkFBZ0I7d0JBQ2hCLFlBQVk7d0JBQ1osY0FBYzt3QkFDZCxXQUFXO3dCQUNYLGdCQUFnQjt3QkFDaEIsZ0JBQWdCO3dCQUNoQix1QkFBdUI7d0JBQ3ZCLGtCQUFrQjt3QkFDbEIsYUFBYTt3QkFDYixjQUFjO3dCQUNkLGlCQUFpQjt3QkFDakIsa0JBQWtCO3dCQUNsQixtQkFBbUI7d0JBQ25CLDBCQUEwQjt3QkFDMUIseUJBQXlCO3FCQUMxQjtvQkFDRCxTQUFTLEVBQUU7d0JBQ1Qsb0JBQW9CLENBQUM7NEJBQ25CLElBQUksRUFBRSxPQUFPO3lCQUNkLENBQUM7cUJBQ0g7b0JBQ0QsWUFBWSxFQUFFLENBQUMsZUFBZSxFQUFFLG9CQUFvQixDQUFDO29CQUNyRCxPQUFPLEVBQUU7d0JBQ1Asa0JBQWtCO3dCQUNsQixlQUFlO3dCQUNmLG9CQUFvQjt3QkFDcEIsdUJBQXVCO3dCQUN2QixtQkFBbUI7d0JBQ25CLDBCQUEwQjt3QkFDMUIseUJBQXlCO3FCQUMxQjtpQkFDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbW1vbk1vZHVsZSwgTmdPcHRpbWl6ZWRJbWFnZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbidcbmltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSdcbmltcG9ydCB7IEZvcm1zTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnXG5pbXBvcnQgeyBNYXRUb29sdGlwTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvdG9vbHRpcCdcbmltcG9ydCB7IFJvdXRlck1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL3JvdXRlcidcbmltcG9ydCB7XG4gIEJhZGdlQ29tcG9uZW50LFxuICBUZXh0SW5wdXRDb21wb25lbnQsXG4gIFVpSW5wdXRzTW9kdWxlLFxufSBmcm9tICcuLi8uLi8uLi8uLi8uLi9saWJzL3VpL2lucHV0cy9zcmMnXG5pbXBvcnQgeyBNYXhMaW5lc0NvbXBvbmVudCwgVWlMYXlvdXRNb2R1bGUgfSBmcm9tICcuLi8uLi8uLi8uLi8uLi9saWJzL3VpL2xheW91dC9zcmMnXG5pbXBvcnQgeyBQb3BvdmVyQ29tcG9uZW50LCBVaVdpZGdldHNNb2R1bGUgfSBmcm9tICcuLi8uLi8uLi8uLi8uLi9saWJzL3VpL3dpZGdldHMvc3JjJ1xuaW1wb3J0IHsgVXRpbFNoYXJlZE1vZHVsZSB9IGZyb20gJy4uLy4uLy4uLy4uLy4uL2xpYnMvdXRpbC9zaGFyZWQvc3JjJ1xuaW1wb3J0IHsgcHJvdmlkZU5nSWNvbnNDb25maWcgfSBmcm9tICdAbmctaWNvbnMvY29yZSdcbmltcG9ydCB7IFRyYW5zbGF0ZU1vZHVsZSB9IGZyb20gJ0BuZ3gtdHJhbnNsYXRlL2NvcmUnXG5pbXBvcnQgeyBBdmF0YXJDb21wb25lbnQgfSBmcm9tICcuL2F2YXRhci9hdmF0YXIuY29tcG9uZW50J1xuaW1wb3J0IHsgSW1hZ2VJbnB1dENvbXBvbmVudCB9IGZyb20gJy4vaW1hZ2UtaW5wdXQvaW1hZ2UtaW5wdXQuY29tcG9uZW50J1xuaW1wb3J0IHsgTWFya2Rvd25QYXJzZXJDb21wb25lbnQgfSBmcm9tICcuL21hcmtkb3duLXBhcnNlci9tYXJrZG93bi1wYXJzZXIuY29tcG9uZW50J1xuaW1wb3J0IHsgVGh1bWJuYWlsQ29tcG9uZW50IH0gZnJvbSAnLi90aHVtYm5haWwvdGh1bWJuYWlsLmNvbXBvbmVudCdcbmltcG9ydCB7IFRpbWVTaW5jZVBpcGUgfSBmcm9tICcuL3VzZXItZmVlZGJhY2staXRlbS90aW1lLXNpbmNlLnBpcGUnXG5pbXBvcnQgeyBVc2VyUHJldmlld0NvbXBvbmVudCB9IGZyb20gJy4vdXNlci1wcmV2aWV3L3VzZXItcHJldmlldy5jb21wb25lbnQnXG5pbXBvcnQgeyBBcHBsaWNhdGlvbkJhbm5lckNvbXBvbmVudCB9IGZyb20gJy4vYXBwbGljYXRpb24tYmFubmVyL2FwcGxpY2F0aW9uLWJhbm5lci5jb21wb25lbnQnXG5pbXBvcnQgeyBJbnRlcm5hbExpbmtDYXJkQ29tcG9uZW50IH0gZnJvbSAnLi9pbnRlcm5hbC1saW5rLWNhcmQvaW50ZXJuYWwtbGluay1jYXJkLmNvbXBvbmVudCdcblxuQE5nTW9kdWxlKHtcbiAgaW1wb3J0czogW1xuICAgIENvbW1vbk1vZHVsZSxcbiAgICBNYXRUb29sdGlwTW9kdWxlLFxuICAgIFVpV2lkZ2V0c01vZHVsZSxcbiAgICBVaUxheW91dE1vZHVsZSxcbiAgICBUcmFuc2xhdGVNb2R1bGUuZm9yQ2hpbGQoKSxcbiAgICBVdGlsU2hhcmVkTW9kdWxlLFxuICAgIFJvdXRlck1vZHVsZSxcbiAgICBVaUlucHV0c01vZHVsZSxcbiAgICBGb3Jtc01vZHVsZSxcbiAgICBOZ09wdGltaXplZEltYWdlLFxuICAgIFBvcG92ZXJDb21wb25lbnQsXG4gICAgTWFya2Rvd25QYXJzZXJDb21wb25lbnQsXG4gICAgVGh1bWJuYWlsQ29tcG9uZW50LFxuICAgIFRpbWVTaW5jZVBpcGUsXG4gICAgQmFkZ2VDb21wb25lbnQsXG4gICAgTWF4TGluZXNDb21wb25lbnQsXG4gICAgVGV4dElucHV0Q29tcG9uZW50LFxuICAgIEltYWdlSW5wdXRDb21wb25lbnQsXG4gICAgQXBwbGljYXRpb25CYW5uZXJDb21wb25lbnQsXG4gICAgSW50ZXJuYWxMaW5rQ2FyZENvbXBvbmVudCxcbiAgXSxcbiAgcHJvdmlkZXJzOiBbXG4gICAgcHJvdmlkZU5nSWNvbnNDb25maWcoe1xuICAgICAgc2l6ZTogJzEuNWVtJyxcbiAgICB9KSxcbiAgXSxcbiAgZGVjbGFyYXRpb25zOiBbQXZhdGFyQ29tcG9uZW50LCBVc2VyUHJldmlld0NvbXBvbmVudF0sXG4gIGV4cG9ydHM6IFtcbiAgICBUaHVtYm5haWxDb21wb25lbnQsXG4gICAgQXZhdGFyQ29tcG9uZW50LFxuICAgIFVzZXJQcmV2aWV3Q29tcG9uZW50LFxuICAgIE1hcmtkb3duUGFyc2VyQ29tcG9uZW50LFxuICAgIEltYWdlSW5wdXRDb21wb25lbnQsXG4gICAgQXBwbGljYXRpb25CYW5uZXJDb21wb25lbnQsXG4gICAgSW50ZXJuYWxMaW5rQ2FyZENvbXBvbmVudCxcbiAgXSxcbn0pXG5leHBvcnQgY2xhc3MgVWlFbGVtZW50c01vZHVsZSB7fVxuIl19
|
|
@@ -38,14 +38,14 @@ export class ProgressBarComponent {
|
|
|
38
38
|
}
|
|
39
39
|
}
|
|
40
40
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ProgressBarComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
41
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: ProgressBarComponent, isStandalone: true, selector: "gn-ui-progress-bar", inputs: { value: "value", type: "type" }, ngImport: i0, template: "<ng-container [ngSwitch]=\"type\">\n <!-- Light Theme -->\n <ng-container *ngSwitchCase=\"'light'\">\n <div class=\"flex items-center relative\">\n <div\n class=\"flex-shrink-0 {{ color.text }} text-xs font-medium mr-2\n text-opacity-100 !text-slate-800\"\n >\n {{ progress }}%\n </div>\n <div class=\"flex-grow h-[
|
|
41
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: ProgressBarComponent, isStandalone: true, selector: "gn-ui-progress-bar", inputs: { value: "value", type: "type" }, ngImport: i0, template: "<ng-container [ngSwitch]=\"type\">\n <!-- Light Theme -->\n <ng-container *ngSwitchCase=\"'light'\">\n <div class=\"flex items-center relative\">\n <div\n class=\"flex-shrink-0 {{ color.text }} text-xs font-medium mr-2\n text-opacity-100 !text-slate-800\"\n >\n {{ progress }}%\n </div>\n <div class=\"flex-grow h-[4px] w-[52px] {{ color.outerBar }} rounded-full\">\n <div\n [style.width.%]=\"progress\"\n class=\"{{ color.innerBar }} transition-width duration-500\n ease-in-out rounded-full shadow-sm w-[52px] h-[4px]\"\n ></div>\n </div>\n </div>\n </ng-container>\n\n <!-- Default / Primary / Secondary Themes -->\n <ng-container *ngSwitchDefault>\n <div class=\"flex h-full {{ color.outerBar }} rounded-t-lg rounded-b-lg\">\n <div\n [style.width.%]=\"progress\"\n class=\"flex {{ color.innerBar }} my-1 mx-1 transition-width\n duration-500 ease-in-out rounded-t-md rounded-b-md shadow-xl\"\n >\n <div\n class=\"flex items-center pl-2 py-1 {{ color.text }} font-bold text-4\"\n >\n {{ progress }}%\n </div>\n </div>\n </div>\n </ng-container>\n</ng-container>\n", styles: [".font-bold{font-weight:var(--progress-bar-font-weight, \"bold\")}\n"], dependencies: [{ kind: "directive", type: NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "directive", type: NgSwitchDefault, selector: "[ngSwitchDefault]" }] }); }
|
|
42
42
|
}
|
|
43
43
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ProgressBarComponent, decorators: [{
|
|
44
44
|
type: Component,
|
|
45
|
-
args: [{ selector: 'gn-ui-progress-bar', standalone: true, imports: [NgSwitch, NgSwitchCase, NgSwitchDefault], template: "<ng-container [ngSwitch]=\"type\">\n <!-- Light Theme -->\n <ng-container *ngSwitchCase=\"'light'\">\n <div class=\"flex items-center relative\">\n <div\n class=\"flex-shrink-0 {{ color.text }} text-xs font-medium mr-2\n text-opacity-100 !text-slate-800\"\n >\n {{ progress }}%\n </div>\n <div class=\"flex-grow h-[
|
|
45
|
+
args: [{ selector: 'gn-ui-progress-bar', standalone: true, imports: [NgSwitch, NgSwitchCase, NgSwitchDefault], template: "<ng-container [ngSwitch]=\"type\">\n <!-- Light Theme -->\n <ng-container *ngSwitchCase=\"'light'\">\n <div class=\"flex items-center relative\">\n <div\n class=\"flex-shrink-0 {{ color.text }} text-xs font-medium mr-2\n text-opacity-100 !text-slate-800\"\n >\n {{ progress }}%\n </div>\n <div class=\"flex-grow h-[4px] w-[52px] {{ color.outerBar }} rounded-full\">\n <div\n [style.width.%]=\"progress\"\n class=\"{{ color.innerBar }} transition-width duration-500\n ease-in-out rounded-full shadow-sm w-[52px] h-[4px]\"\n ></div>\n </div>\n </div>\n </ng-container>\n\n <!-- Default / Primary / Secondary Themes -->\n <ng-container *ngSwitchDefault>\n <div class=\"flex h-full {{ color.outerBar }} rounded-t-lg rounded-b-lg\">\n <div\n [style.width.%]=\"progress\"\n class=\"flex {{ color.innerBar }} my-1 mx-1 transition-width\n duration-500 ease-in-out rounded-t-md rounded-b-md shadow-xl\"\n >\n <div\n class=\"flex items-center pl-2 py-1 {{ color.text }} font-bold text-4\"\n >\n {{ progress }}%\n </div>\n </div>\n </div>\n </ng-container>\n</ng-container>\n", styles: [".font-bold{font-weight:var(--progress-bar-font-weight, \"bold\")}\n"] }]
|
|
46
46
|
}], propDecorators: { value: [{
|
|
47
47
|
type: Input
|
|
48
48
|
}], type: [{
|
|
49
49
|
type: Input
|
|
50
50
|
}] } });
|
|
51
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
51
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvZ3Jlc3MtYmFyLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvdWkvd2lkZ2V0cy9zcmMvbGliL3Byb2dyZXNzLWJhci9wcm9ncmVzcy1iYXIuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy91aS93aWRnZXRzL3NyYy9saWIvcHJvZ3Jlc3MtYmFyL3Byb2dyZXNzLWJhci5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQTtBQUNoRCxPQUFPLEVBQUUsUUFBUSxFQUFFLFlBQVksRUFBRSxlQUFlLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQTs7QUFlekUsTUFBTSxPQUFPLG9CQUFvQjtJQVBqQztRQVFXLFVBQUssR0FBRyxDQUFDLENBQUE7UUFDVCxTQUFJLEdBQWtELFNBQVMsQ0FBQTtLQWtDekU7SUFoQ0MsSUFBSSxRQUFRO1FBQ1YsT0FBTyxJQUFJLENBQUMsS0FBSyxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsS0FBSyxHQUFHLEdBQUcsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQTtJQUNuRSxDQUFDO0lBRUQsSUFBSSxLQUFLO1FBQ1AsUUFBUSxJQUFJLENBQUMsSUFBSSxFQUFFLENBQUM7WUFDbEIsS0FBSyxTQUFTO2dCQUNaLE9BQU87b0JBQ0wsUUFBUSxFQUFFLGFBQWE7b0JBQ3ZCLFFBQVEsRUFBRSxhQUFhO29CQUN2QixJQUFJLEVBQUUsZUFBZTtpQkFDdEIsQ0FBQTtZQUNILEtBQUssU0FBUztnQkFDWixPQUFPO29CQUNMLFFBQVEsRUFBRSxZQUFZO29CQUN0QixRQUFRLEVBQUUsb0JBQW9CO29CQUM5QixJQUFJLEVBQUUsWUFBWTtpQkFDbkIsQ0FBQTtZQUNILEtBQUssV0FBVztnQkFDZCxPQUFPO29CQUNMLFFBQVEsRUFBRSxjQUFjO29CQUN4QixRQUFRLEVBQUUsc0JBQXNCO29CQUNoQyxJQUFJLEVBQUUsWUFBWTtpQkFDbkIsQ0FBQTtZQUNILEtBQUssT0FBTztnQkFDVixPQUFPO29CQUNMLFFBQVEsRUFBRSxrQkFBa0I7b0JBQzVCLFFBQVEsRUFBRSxZQUFZO29CQUN0QixJQUFJLEVBQUUsV0FBVztpQkFDbEIsQ0FBQTtRQUNMLENBQUM7SUFDSCxDQUFDOytHQW5DVSxvQkFBb0I7bUdBQXBCLG9CQUFvQix3SENoQmpDLCt1Q0FxQ0EsNkhEdkJZLFFBQVEsNkVBQUUsWUFBWSxxRkFBRSxlQUFlOzs0RkFFdEMsb0JBQW9CO2tCQVBoQyxTQUFTOytCQUNFLG9CQUFvQixjQUdsQixJQUFJLFdBQ1AsQ0FBQyxRQUFRLEVBQUUsWUFBWSxFQUFFLGVBQWUsQ0FBQzs4QkFHekMsS0FBSztzQkFBYixLQUFLO2dCQUNHLElBQUk7c0JBQVosS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgSW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJ1xuaW1wb3J0IHsgTmdTd2l0Y2gsIE5nU3dpdGNoQ2FzZSwgTmdTd2l0Y2hEZWZhdWx0IH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJ1xuXG5pbnRlcmZhY2UgQ29sb3JTY2hlbWUge1xuICBvdXRlckJhcjogc3RyaW5nXG4gIGlubmVyQmFyOiBzdHJpbmdcbiAgdGV4dDogc3RyaW5nXG59XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2duLXVpLXByb2dyZXNzLWJhcicsXG4gIHRlbXBsYXRlVXJsOiAnLi9wcm9ncmVzcy1iYXIuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi9wcm9ncmVzcy1iYXIuY29tcG9uZW50LmNzcyddLFxuICBzdGFuZGFsb25lOiB0cnVlLFxuICBpbXBvcnRzOiBbTmdTd2l0Y2gsIE5nU3dpdGNoQ2FzZSwgTmdTd2l0Y2hEZWZhdWx0XSxcbn0pXG5leHBvcnQgY2xhc3MgUHJvZ3Jlc3NCYXJDb21wb25lbnQge1xuICBASW5wdXQoKSB2YWx1ZSA9IDBcbiAgQElucHV0KCkgdHlwZTogJ3ByaW1hcnknIHwgJ3NlY29uZGFyeScgfCAnZGVmYXVsdCcgfCAnbGlnaHQnID0gJ2RlZmF1bHQnXG5cbiAgZ2V0IHByb2dyZXNzKCkge1xuICAgIHJldHVybiB0aGlzLnZhbHVlID4gMCA/ICh0aGlzLnZhbHVlIDwgMTAwID8gdGhpcy52YWx1ZSA6IDEwMCkgOiAwXG4gIH1cblxuICBnZXQgY29sb3IoKTogQ29sb3JTY2hlbWUge1xuICAgIHN3aXRjaCAodGhpcy50eXBlKSB7XG4gICAgICBjYXNlICdkZWZhdWx0JzpcbiAgICAgICAgcmV0dXJuIHtcbiAgICAgICAgICBvdXRlckJhcjogJ2JnLWdyYXktMjAwJyxcbiAgICAgICAgICBpbm5lckJhcjogJ2JnLWdyYXktMTAwJyxcbiAgICAgICAgICB0ZXh0OiAndGV4dC1ncmF5LTkwMCcsXG4gICAgICAgIH1cbiAgICAgIGNhc2UgJ3ByaW1hcnknOlxuICAgICAgICByZXR1cm4ge1xuICAgICAgICAgIG91dGVyQmFyOiAnYmctcHJpbWFyeScsXG4gICAgICAgICAgaW5uZXJCYXI6ICdiZy1wcmltYXJ5LWxpZ2h0ZXInLFxuICAgICAgICAgIHRleHQ6ICd0ZXh0LXdoaXRlJyxcbiAgICAgICAgfVxuICAgICAgY2FzZSAnc2Vjb25kYXJ5JzpcbiAgICAgICAgcmV0dXJuIHtcbiAgICAgICAgICBvdXRlckJhcjogJ2JnLXNlY29uZGFyeScsXG4gICAgICAgICAgaW5uZXJCYXI6ICdiZy1zZWNvbmRhcnktbGlnaHRlcicsXG4gICAgICAgICAgdGV4dDogJ3RleHQtd2hpdGUnLFxuICAgICAgICB9XG4gICAgICBjYXNlICdsaWdodCc6XG4gICAgICAgIHJldHVybiB7XG4gICAgICAgICAgb3V0ZXJCYXI6ICdiZy1wcmltYXJ5LXdoaXRlJyxcbiAgICAgICAgICBpbm5lckJhcjogJ2JnLXByaW1hcnknLFxuICAgICAgICAgIHRleHQ6ICd0ZXh0LW1haW4nLFxuICAgICAgICB9XG4gICAgfVxuICB9XG59XG4iLCI8bmctY29udGFpbmVyIFtuZ1N3aXRjaF09XCJ0eXBlXCI+XG4gIDwhLS0gTGlnaHQgVGhlbWUgLS0+XG4gIDxuZy1jb250YWluZXIgKm5nU3dpdGNoQ2FzZT1cIidsaWdodCdcIj5cbiAgICA8ZGl2IGNsYXNzPVwiZmxleCBpdGVtcy1jZW50ZXIgcmVsYXRpdmVcIj5cbiAgICAgIDxkaXZcbiAgICAgICAgY2xhc3M9XCJmbGV4LXNocmluay0wIHt7IGNvbG9yLnRleHQgfX0gdGV4dC14cyBmb250LW1lZGl1bSBtci0yXG4gICAgICAgICAgICAgdGV4dC1vcGFjaXR5LTEwMCAhdGV4dC1zbGF0ZS04MDBcIlxuICAgICAgPlxuICAgICAgICB7eyBwcm9ncmVzcyB9fSVcbiAgICAgIDwvZGl2PlxuICAgICAgPGRpdiBjbGFzcz1cImZsZXgtZ3JvdyBoLVs0cHhdIHctWzUycHhdIHt7IGNvbG9yLm91dGVyQmFyIH19IHJvdW5kZWQtZnVsbFwiPlxuICAgICAgICA8ZGl2XG4gICAgICAgICAgW3N0eWxlLndpZHRoLiVdPVwicHJvZ3Jlc3NcIlxuICAgICAgICAgIGNsYXNzPVwie3sgY29sb3IuaW5uZXJCYXIgfX0gdHJhbnNpdGlvbi13aWR0aCBkdXJhdGlvbi01MDBcbiAgICAgICAgICAgICAgIGVhc2UtaW4tb3V0IHJvdW5kZWQtZnVsbCBzaGFkb3ctc20gdy1bNTJweF0gaC1bNHB4XVwiXG4gICAgICAgID48L2Rpdj5cbiAgICAgIDwvZGl2PlxuICAgIDwvZGl2PlxuICA8L25nLWNvbnRhaW5lcj5cblxuICA8IS0tIERlZmF1bHQgLyBQcmltYXJ5IC8gU2Vjb25kYXJ5IFRoZW1lcyAtLT5cbiAgPG5nLWNvbnRhaW5lciAqbmdTd2l0Y2hEZWZhdWx0PlxuICAgIDxkaXYgY2xhc3M9XCJmbGV4IGgtZnVsbCB7eyBjb2xvci5vdXRlckJhciB9fSByb3VuZGVkLXQtbGcgcm91bmRlZC1iLWxnXCI+XG4gICAgICA8ZGl2XG4gICAgICAgIFtzdHlsZS53aWR0aC4lXT1cInByb2dyZXNzXCJcbiAgICAgICAgY2xhc3M9XCJmbGV4IHt7IGNvbG9yLmlubmVyQmFyIH19IG15LTEgbXgtMSB0cmFuc2l0aW9uLXdpZHRoXG4gICAgICAgICAgICAgICBkdXJhdGlvbi01MDAgZWFzZS1pbi1vdXQgcm91bmRlZC10LW1kIHJvdW5kZWQtYi1tZCBzaGFkb3cteGxcIlxuICAgICAgPlxuICAgICAgICA8ZGl2XG4gICAgICAgICAgY2xhc3M9XCJmbGV4IGl0ZW1zLWNlbnRlciBwbC0yIHB5LTEge3sgY29sb3IudGV4dCB9fSBmb250LWJvbGQgdGV4dC00XCJcbiAgICAgICAgPlxuICAgICAgICAgIHt7IHByb2dyZXNzIH19JVxuICAgICAgICA8L2Rpdj5cbiAgICAgIDwvZGl2PlxuICAgIDwvZGl2PlxuICA8L25nLWNvbnRhaW5lcj5cbjwvbmctY29udGFpbmVyPlxuIl19
|
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"": "",
|
|
3
3
|
"Add Layer As": "",
|
|
4
|
+
"Enter to search": "",
|
|
4
5
|
"button.login": "",
|
|
5
6
|
"catalog.figures.datasets": "{count, plural, =0{Datensätze} one{Datensatz} other{Datensätze}}",
|
|
6
7
|
"catalog.figures.organizations": "{count, plural, =0{Organisationen} one{Organisation} other{Organisationen}}",
|
|
@@ -354,8 +355,12 @@
|
|
|
354
355
|
"record.action.duplicating": "",
|
|
355
356
|
"record.action.rollback": "",
|
|
356
357
|
"record.action.view": "Anzeigen",
|
|
358
|
+
"record.card.metadata.contact": "",
|
|
357
359
|
"record.externalViewer.open": "In externem Kartenviewer öffnen",
|
|
358
360
|
"record.feature.limit": "Die Vorschau wurde aufgrund zu vieler Elemente deaktiviert",
|
|
361
|
+
"record.kind.dataset": "",
|
|
362
|
+
"record.kind.reuse": "",
|
|
363
|
+
"record.kind.service": "",
|
|
359
364
|
"record.metadata.about": "Beschreibung",
|
|
360
365
|
"record.metadata.api": "API",
|
|
361
366
|
"record.metadata.api.form.closeButton": "Schließen",
|