adb-shared 3.0.31 → 3.0.32

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.
@@ -40,7 +40,6 @@ export class ADBNavComponent {
40
40
  this.url = window.location.href;
41
41
  const baseUrl = this.envService.environment.resourceUrl;
42
42
  const url = this.artfakta ? '/assets/links-ap3.json' : '/assets/artportalen/links-ap3.json';
43
- console.log('banana', baseUrl + url);
44
43
  this.subscription.add(this.httpClient.get(baseUrl + url).subscribe(result => {
45
44
  this.navigation = result;
46
45
  }));
@@ -115,4 +114,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.8", ngImpor
115
114
  }], artfakta: [{
116
115
  type: Input
117
116
  }] } });
118
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"adb-nav.component.js","sourceRoot":"","sources":["../../../../../../projects/artdata-shared/src/lib/components/adb-header/adb-nav.component.ts","../../../../../../projects/artdata-shared/src/lib/components/adb-header/adb-nav.component.html"],"names":[],"mappings":"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","sourcesContent":["import { HttpClient } from '@angular/common/http';\r\nimport { Component, EventEmitter, HostBinding, HostListener, Input, OnDestroy, OnInit, Output } from '@angular/core';\r\nimport { TranslateService } from '@ngx-translate/core';\r\nimport { fromEvent, Subscription } from 'rxjs';\r\nimport { throttleTime } from 'rxjs/operators';\r\nimport { EnvironmentService } from './environment.service';\r\n@Component({\r\n    selector: 'adb-nav',\r\n    templateUrl: './adb-nav.component.html'\r\n})\r\nexport class ADBNavComponent implements OnInit, OnDestroy {\r\n    private subscription = new Subscription();\r\n    @Output() loginClicked = new EventEmitter();\r\n    @Output() logoutClicked = new EventEmitter();\r\n    @Output() dropMenuChange = new EventEmitter<boolean>();\r\n    @Input() showPattern = false;\r\n    fullName: string;\r\n    translationFinished = false;\r\n    shrink: boolean;\r\n    lastPosition = 0;\r\n\r\n    @Input() set userName(fullName: string) {\r\n        this.fullName = fullName;\r\n        const splitted = fullName.split(' ');\r\n        if (splitted?.length > 1) {\r\n            const initials = splitted.shift().charAt(0) + splitted.pop().charAt(0);\r\n            this.initials = initials.toUpperCase();\r\n        } else {\r\n            this.initials = this.fullName ? this.fullName.charAt(0).toUpperCase() : this.fullName;\r\n        }\r\n    };\r\n    @Input() artfakta = true;\r\n\r\n    initials: string;\r\n    showMenu = false;\r\n    showUserMenu = false;\r\n    navigation: Navigation;\r\n    url: string;\r\n    expandedLink: string;\r\n    constructor(\r\n        private httpClient: HttpClient,\r\n        private envService: EnvironmentService,\r\n        public trans: TranslateService) {\r\n    }\r\n\r\n    ngOnInit() {\r\n        this.url = window.location.href;\r\n        const baseUrl = this.envService.environment.resourceUrl;\r\n        const url = this.artfakta ? '/assets/links-ap3.json' : '/assets/artportalen/links-ap3.json';\r\n        console.log('banana',baseUrl + url)\r\n        this.subscription.add(this.httpClient.get<Navigation>(baseUrl + url).subscribe(result => {\r\n            this.navigation = result;\r\n        }));\r\n        this.initTranslations(baseUrl);\r\n    }\r\n\r\n    onHideTop(show: boolean): void {\r\n        this.shrink = show; \r\n    }\r\n\r\n    private initTranslations(baseUrl: string): void {\r\n        if (this.trans.store.translations[this.trans.currentLang]) {\r\n            this.loadTranslation(baseUrl, this.trans.currentLang);\r\n        }\r\n        this.subscription.add(this.trans.onLangChange.subscribe((event) => {\r\n            this.translationFinished = false;\r\n            this.loadTranslation(baseUrl, event.lang);\r\n        }));\r\n    }\r\n\r\n    private loadTranslation(baseUrl: string, lang: string): void {\r\n        //TODO: Prepare for diffents lang then en sv (en-GB) or add more files in devcomponentserver :)\r\n        const url = this.artfakta ? baseUrl + `/assets/i18n/${lang}.json` : baseUrl + `/assets/artportalen/i18n/${lang}.json`;\r\n        this.subscription.add(this.httpClient.get(url).subscribe(translations => {\r\n            this.trans.setTranslation(lang, translations, true);\r\n            this.translationFinished = true;\r\n        }));\r\n    }\r\n\r\n    showMenuDropdown(show: boolean): void {\r\n        if (this.showMenu !== show) {\r\n            this.showMenu = show;\r\n            this.dropMenuChange.emit(show);\r\n        }\r\n    }\r\n\r\n    setLanguage(lang): void {\r\n        this.trans.use(lang);\r\n        this.showMenu = false;\r\n        this.dropMenuChange.emit(false);\r\n        //TODO: set localstorage/cookies or probaly event to main app\r\n    }\r\n\r\n    onExpandLink(event: any, transId: string): void {\r\n        event.preventDefault(); event.stopPropagation();\r\n        if (this.expandedLink === transId) {\r\n            this.expandedLink = null;\r\n            return;\r\n        }\r\n        this.expandedLink = transId;\r\n    }\r\n\r\n    login(): void {\r\n        this.loginClicked.emit();\r\n    }\r\n\r\n    logout(): void {\r\n        this.logoutClicked.emit();\r\n    }\r\n\r\n\r\n\r\n\r\n    ngOnDestroy(): void {\r\n        this.subscription.unsubscribe();\r\n    }\r\n}\r\n\r\nexport interface Navigation {\r\n    about: Link;\r\n    artinfo: Link;\r\n    artfakta: Link;\r\n    observations: Link;\r\n    nameAndRelationship: Link;\r\n    createAccountLink: string;\r\n    artfaktaUrl: string;\r\n    artportalenUrl: string;\r\n    supportUrl: string;\r\n}\r\n\r\nexport interface Link {\r\n    transId: string;\r\n    url: string;\r\n}\r\n\r\n","<!-- position-static -->\r\n<div class=\"bg-primary sticky-sm-top p-2\" [attr.id]=\"showPattern&&!showMenu?'pattern':''\" [class.shrink]=\"shrink\" (adbClickOutside)=\"showUserMenu=false;showMenuDropdown(false);\">\r\n    <header id=\"extra-header\">\r\n        <div class=\"d-flex flex-wrap gap-2\">\r\n            <nav class=\"d-flex gap-2 align-items-center\">\r\n                <div class=\"me-5\">\r\n                    <a class=\"text-white text-decoration-none d-flex gap-2\" href=\"https://www.artdatabanken.se/\" target=\"new\">\r\n                        <img style=\"height: 2rem;\" src=\"/assets/images/logo_sm_white.png\">\r\n                        <div class=\"border-end\"></div>\r\n                        <small class=\"align-self-center\">ARTDATABANKEN</small>\r\n                    </a>\r\n                </div>\r\n                <a class=\"text-white fw-bold fs-3\" href=\"/\">ARTFAKTA</a>\r\n            </nav>\r\n            <ng-container *ngIf=\"translationFinished\">\r\n                <div class=\"ms-auto d-flex gap-2\">\r\n                    <div class=\"btn-group d-block no-caret\">\r\n                        <button adbDropdown class=\"px-1 py-0 btn btn-primary btn-sm dropdown-toggle\"><span class=\"far fa-globe\"></span></button>\r\n                        <ul class=\"dropdown-menu dropdown-menu-end py-1 bg-primary\">\r\n                            <li>\r\n                                <button type=\"button\" [class.pe-none]=\"trans.currentLang==='sv'\" (click)=\"setLanguage('sv')\" class=\"btn btn-link py-0 px-2 text-white\">\r\n                                    <span [class.fw-bold]=\"trans.currentLang==='sv'\">{{'ADB_HEADER.IN_SWEDISH'|translate}}</span>\r\n                                </button>\r\n                            </li>\r\n                            <div class=\"dropdown-divider my-1 opacity-25 bg-white\"></div>\r\n                            <li>\r\n                                <button type=\"button\" [class.pe-none]=\"trans.currentLang==='en'\" (click)=\"setLanguage('en')\" class=\"btn btn-link py-0 px-2 text-white\">\r\n                                    <span [class.fw-bold]=\"trans.currentLang==='en'\">{{'ADB_HEADER.IN_ENGLISH'|translate}}</span>\r\n                                </button>\r\n                            </li>\r\n                        </ul>\r\n                    </div>\r\n                    <a class=\"ms-auto text-white d-none d-md-block\" [href]=\"navigation.artportalenUrl\">\r\n                        {{'ADB_HEADER.ARTPORTALEN_TITLE'|translate}}\r\n                    </a>\r\n                    <a class=\"text-white d-none d-md-block\" [href]=\"navigation.supportUrl\">Support</a>\r\n\r\n                </div>\r\n            </ng-container>\r\n        </div>\r\n    </header>\r\n    <header class=\"d-flex align-items-center flex-wrap gap-2\" *ngIf=\"translationFinished\">\r\n        <nav *ngIf=\"navigation\" class=\"d-flex align-items-center gap-3\">\r\n            <a href=\"https://www.artdatabanken.se/\" class=\"home-link\" target=\"new\"><img src=\"/assets/images/logo_sm_white.png\" style=\"height: 2rem;\"></a>\r\n            <a class=\"text-white fw-bold me-3 home-link\" href=\"{{navigation.artfakta.url}}\">\r\n                {{navigation.artfakta.transId|translate}}\r\n            </a>\r\n            <a class=\"text-white d-none d-md-block\" href=\"{{navigation.artinfo.url}}\">\r\n                {{navigation.artinfo.transId|translate}}\r\n            </a>\r\n            <a class=\"text-white d-none d-md-block\" href=\"{{navigation.observations.url}}?lang={{trans.currentLang}}\">\r\n                {{navigation.observations.transId|translate}}\r\n            </a>\r\n            <a class=\"text-white d-none d-md-block\" href=\"{{navigation.nameAndRelationship.url}}?lang={{trans.currentLang}}\">\r\n                {{navigation.nameAndRelationship.transId|translate}}\r\n            </a>\r\n        </nav>\r\n        <div class=\"ms-auto\">\r\n            <div class=\"btn-group no-caret d-none d-md-block\">\r\n                <button type=\"button\" adbDropdown class=\"btn btn-primary btn-sm dropdown-toggle\" [class.initials]=\"initials\" (click)=\"showMenuDropdown(!showMenu)\">\r\n                    <ng-container *ngIf=\"initials\">{{initials}}</ng-container>\r\n                    <ng-container *ngIf=\"!initials\">{{'ADB_HEADER.LOGIN'|translate}}</ng-container>\r\n                </button>\r\n                <ul class=\"dropdown-menu dropdown-menu-end py-1 bg-primary text-white\">\r\n                    <ng-container *ngIf=\"initials\">\r\n                        <li class=\"px-2 pb-1\">\r\n                            <button (click)=\"logout()\" type=\"button\" class=\"btn btn-link p-0 text-white\">\r\n                                <span class=\"fas fa-sign-out-alt me-1\"></span>{{'ADB_HEADER.LOGOUT'|translate}}\r\n                            </button>\r\n                        </li>\r\n                        <hr class=\"my-0\">\r\n                        <li class=\"pt-1 px-2\">\r\n                            <span class=\"fas fa-user me-1\"></span>\r\n                            {{fullName}}\r\n                        </li>\r\n                    </ng-container>\r\n                    <ng-container *ngIf=\"!initials\">\r\n                        <li>\r\n                            <div class=\"text-center \">\r\n                                <button type=\"button\" class=\"btn btn-primary\" (click)=\"login()\" id=\"start-login\">{{'ADB_HEADER.LOGIN'|translate}}</button>\r\n                            </div>\r\n                        </li>\r\n                        <li>\r\n                            <a *ngIf=\"navigation\" class=\"d-block text-center mt-2 text-white\" href=\"{{navigation.createAccountLink}}?lang={{trans.currentLang}}&returnUrl={{url}}\">\r\n                                {{'ADB_HEADER.CREATE_USER'|translate}}\r\n                            </a>\r\n                        </li>\r\n                    </ng-container>\r\n                </ul>\r\n            </div>\r\n            <div class=\"d-block d-md-none\">\r\n                <button type=\"button\" class=\"btn btn-sm py-1 px-2 btn-primary\" (click)=\"showUserMenu = false;showMenuDropdown(!showMenu)\">\r\n                    {{'ADB_HEADER.MENY'|translate}}\r\n                    <i class=\"ms-1 fas\" [ngClass]=\"showMenu?'fa-chevron-up':'fa-chevron-down'\"></i>\r\n                </button>\r\n            </div>\r\n        </div>\r\n    </header>\r\n    <div class=\"mobile-menu d-flex flex-column d-md-none bg-primary text-white\" *ngIf=\"showMenu&&navigation\">\r\n        <div class=\"p-2\">\r\n            <div class=\"d-flex justify-content-between align-items-center gap-2\" *ngIf=\"initials\">\r\n                <span class=\"initials me-2\">{{initials}}</span>\r\n                <button type=\"button\" (click)=\"logout()\" class=\"btn btn-primary\">\r\n                    {{'ADB_HEADER.LOGOUT'|translate}}\r\n                </button>\r\n            </div>\r\n            <div class=\"d-flex justify-content-between gap-2\" *ngIf=\"!initials\">\r\n                <button type=\"button\" (click)=\"login()\" class=\"btn btn-primary\" id=\"login\">\r\n                    {{'ADB_HEADER.LOGIN'|translate}}\r\n                </button>\r\n                <a href=\"{{navigation.createAccountLink}}?lang={{trans.currentLang}}&returnUrl={{url}}\"\r\n                    class=\"btn btn-primary text-white\">\r\n                    {{'ADB_HEADER.CREATE_USER'|translate}}\r\n                </a>\r\n            </div>\r\n        </div>\r\n        <div class=\"px-2\">\r\n            <hr class=\"my-0\">\r\n            <ul class=\"list-unstyled\">\r\n                <li>\r\n                    <a class=\"d-block py-1 text-white\" href=\"{{navigation.artinfo.url}}\">\r\n                        {{navigation.artinfo.transId|translate}}\r\n                    </a>\r\n                    <hr class=\"my-0\">\r\n                </li>\r\n                <li>\r\n                    <a class=\"d-block py-1 text-white\" href=\"{{navigation.observations.url}}?lang={{trans.currentLang}}\">\r\n                        {{navigation.observations.transId|translate}}\r\n                    </a>\r\n                    <hr class=\"my-0\">\r\n                </li>\r\n                <li>\r\n                    <a class=\"d-block py-1 text-white\" href=\"{{navigation.nameAndRelationship.url}}?lang={{trans.currentLang}}\">\r\n                        {{navigation.nameAndRelationship.transId|translate}}\r\n                    </a>\r\n                    <hr class=\"my-0\">\r\n                </li>\r\n                <li>\r\n                    <a class=\"d-block py-1 text-white\" [href]=\"navigation.about.url\">{{navigation.about.transId|translate}}</a>\r\n                    <hr class=\"my-0\">\r\n                </li>\r\n                <li>\r\n                    <a class=\"d-block py-1 text-white\" [href]=\"navigation.artportalenUrl\">\r\n                        {{'ADB_HEADER.ARTPORTALEN_TITLE'|translate}}\r\n                    </a>\r\n                    <hr class=\"my-0\">\r\n                </li>\r\n                <li>\r\n                    <small class=\"d-block text-white py-2\">\r\n                        {{'ADB_HEADER.DEVELOPED_BY'|translate}}\r\n                        <a href=\"https://www.artdatabanken.se/\" class=\"text-white\"><u>{{'ADB_HEADER.ARTDATABANKEN'|translate}}</u></a>\r\n                    </small>\r\n                </li>\r\n            </ul>\r\n        </div>\r\n        <div class=\"mt-auto splash-height\" id=\"pattern\"></div>\r\n    </div>\r\n</div>\r\n<div (onVisible)=\"onHideTop(false)\" (onHidden)=\"onHideTop(true)\" style=\"height:0px\"></div>"]}
117
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"adb-nav.component.js","sourceRoot":"","sources":["../../../../../../projects/artdata-shared/src/lib/components/adb-header/adb-nav.component.ts","../../../../../../projects/artdata-shared/src/lib/components/adb-header/adb-nav.component.html"],"names":[],"mappings":"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","sourcesContent":["import { HttpClient } from '@angular/common/http';\r\nimport { Component, EventEmitter, HostBinding, HostListener, Input, OnDestroy, OnInit, Output } from '@angular/core';\r\nimport { TranslateService } from '@ngx-translate/core';\r\nimport { fromEvent, Subscription } from 'rxjs';\r\nimport { throttleTime } from 'rxjs/operators';\r\nimport { EnvironmentService } from './environment.service';\r\n@Component({\r\n    selector: 'adb-nav',\r\n    templateUrl: './adb-nav.component.html'\r\n})\r\nexport class ADBNavComponent implements OnInit, OnDestroy {\r\n    private subscription = new Subscription();\r\n    @Output() loginClicked = new EventEmitter();\r\n    @Output() logoutClicked = new EventEmitter();\r\n    @Output() dropMenuChange = new EventEmitter<boolean>();\r\n    @Input() showPattern = false;\r\n    fullName: string;\r\n    translationFinished = false;\r\n    shrink: boolean;\r\n    lastPosition = 0;\r\n\r\n    @Input() set userName(fullName: string) {\r\n        this.fullName = fullName;\r\n        const splitted = fullName.split(' ');\r\n        if (splitted?.length > 1) {\r\n            const initials = splitted.shift().charAt(0) + splitted.pop().charAt(0);\r\n            this.initials = initials.toUpperCase();\r\n        } else {\r\n            this.initials = this.fullName ? this.fullName.charAt(0).toUpperCase() : this.fullName;\r\n        }\r\n    };\r\n    @Input() artfakta = true;\r\n\r\n    initials: string;\r\n    showMenu = false;\r\n    showUserMenu = false;\r\n    navigation: Navigation;\r\n    url: string;\r\n    expandedLink: string;\r\n    constructor(\r\n        private httpClient: HttpClient,\r\n        private envService: EnvironmentService,\r\n        public trans: TranslateService) {\r\n    }\r\n\r\n    ngOnInit() {\r\n        this.url = window.location.href;\r\n        const baseUrl = this.envService.environment.resourceUrl;\r\n        const url = this.artfakta ? '/assets/links-ap3.json' : '/assets/artportalen/links-ap3.json';\r\n        this.subscription.add(this.httpClient.get<Navigation>(baseUrl + url).subscribe(result => {\r\n            this.navigation = result;\r\n        }));\r\n        this.initTranslations(baseUrl);\r\n    }\r\n\r\n    onHideTop(show: boolean): void {\r\n        this.shrink = show; \r\n    }\r\n\r\n    private initTranslations(baseUrl: string): void {\r\n        if (this.trans.store.translations[this.trans.currentLang]) {\r\n            this.loadTranslation(baseUrl, this.trans.currentLang);\r\n        }\r\n        this.subscription.add(this.trans.onLangChange.subscribe((event) => {\r\n            this.translationFinished = false;\r\n            this.loadTranslation(baseUrl, event.lang);\r\n        }));\r\n    }\r\n\r\n    private loadTranslation(baseUrl: string, lang: string): void {\r\n        //TODO: Prepare for diffents lang then en sv (en-GB) or add more files in devcomponentserver :)\r\n        const url = this.artfakta ? baseUrl + `/assets/i18n/${lang}.json` : baseUrl + `/assets/artportalen/i18n/${lang}.json`;\r\n        this.subscription.add(this.httpClient.get(url).subscribe(translations => {\r\n            this.trans.setTranslation(lang, translations, true);\r\n            this.translationFinished = true;\r\n        }));\r\n    }\r\n\r\n    showMenuDropdown(show: boolean): void {\r\n        if (this.showMenu !== show) {\r\n            this.showMenu = show;\r\n            this.dropMenuChange.emit(show);\r\n        }\r\n    }\r\n\r\n    setLanguage(lang): void {\r\n        this.trans.use(lang);\r\n        this.showMenu = false;\r\n        this.dropMenuChange.emit(false);\r\n        //TODO: set localstorage/cookies or probaly event to main app\r\n    }\r\n\r\n    onExpandLink(event: any, transId: string): void {\r\n        event.preventDefault(); event.stopPropagation();\r\n        if (this.expandedLink === transId) {\r\n            this.expandedLink = null;\r\n            return;\r\n        }\r\n        this.expandedLink = transId;\r\n    }\r\n\r\n    login(): void {\r\n        this.loginClicked.emit();\r\n    }\r\n\r\n    logout(): void {\r\n        this.logoutClicked.emit();\r\n    }\r\n\r\n\r\n\r\n\r\n    ngOnDestroy(): void {\r\n        this.subscription.unsubscribe();\r\n    }\r\n}\r\n\r\nexport interface Navigation {\r\n    about: Link;\r\n    artinfo: Link;\r\n    artfakta: Link;\r\n    observations: Link;\r\n    nameAndRelationship: Link;\r\n    createAccountLink: string;\r\n    artfaktaUrl: string;\r\n    artportalenUrl: string;\r\n    supportUrl: string;\r\n}\r\n\r\nexport interface Link {\r\n    transId: string;\r\n    url: string;\r\n}\r\n\r\n","<!-- position-static -->\r\n<div class=\"bg-primary sticky-sm-top p-2\" [attr.id]=\"showPattern&&!showMenu?'pattern':''\" [class.shrink]=\"shrink\" (adbClickOutside)=\"showUserMenu=false;showMenuDropdown(false);\">\r\n    <header id=\"extra-header\">\r\n        <div class=\"d-flex flex-wrap gap-2\">\r\n            <nav class=\"d-flex gap-2 align-items-center\">\r\n                <div class=\"me-5\">\r\n                    <a class=\"text-white text-decoration-none d-flex gap-2\" href=\"https://www.artdatabanken.se/\" target=\"new\">\r\n                        <img style=\"height: 2rem;\" src=\"/assets/images/logo_sm_white.png\">\r\n                        <div class=\"border-end\"></div>\r\n                        <small class=\"align-self-center\">ARTDATABANKEN</small>\r\n                    </a>\r\n                </div>\r\n                <a class=\"text-white fw-bold fs-3\" href=\"/\">ARTFAKTA</a>\r\n            </nav>\r\n            <ng-container *ngIf=\"translationFinished\">\r\n                <div class=\"ms-auto d-flex gap-2\">\r\n                    <div class=\"btn-group d-block no-caret\">\r\n                        <button adbDropdown class=\"px-1 py-0 btn btn-primary btn-sm dropdown-toggle\"><span class=\"far fa-globe\"></span></button>\r\n                        <ul class=\"dropdown-menu dropdown-menu-end py-1 bg-primary\">\r\n                            <li>\r\n                                <button type=\"button\" [class.pe-none]=\"trans.currentLang==='sv'\" (click)=\"setLanguage('sv')\" class=\"btn btn-link py-0 px-2 text-white\">\r\n                                    <span [class.fw-bold]=\"trans.currentLang==='sv'\">{{'ADB_HEADER.IN_SWEDISH'|translate}}</span>\r\n                                </button>\r\n                            </li>\r\n                            <div class=\"dropdown-divider my-1 opacity-25 bg-white\"></div>\r\n                            <li>\r\n                                <button type=\"button\" [class.pe-none]=\"trans.currentLang==='en'\" (click)=\"setLanguage('en')\" class=\"btn btn-link py-0 px-2 text-white\">\r\n                                    <span [class.fw-bold]=\"trans.currentLang==='en'\">{{'ADB_HEADER.IN_ENGLISH'|translate}}</span>\r\n                                </button>\r\n                            </li>\r\n                        </ul>\r\n                    </div>\r\n                    <a class=\"ms-auto text-white d-none d-md-block\" [href]=\"navigation.artportalenUrl\">\r\n                        {{'ADB_HEADER.ARTPORTALEN_TITLE'|translate}}\r\n                    </a>\r\n                    <a class=\"text-white d-none d-md-block\" [href]=\"navigation.supportUrl\">Support</a>\r\n\r\n                </div>\r\n            </ng-container>\r\n        </div>\r\n    </header>\r\n    <header class=\"d-flex align-items-center flex-wrap gap-2\" *ngIf=\"translationFinished\">\r\n        <nav *ngIf=\"navigation\" class=\"d-flex align-items-center gap-3\">\r\n            <a href=\"https://www.artdatabanken.se/\" class=\"home-link\" target=\"new\"><img src=\"/assets/images/logo_sm_white.png\" style=\"height: 2rem;\"></a>\r\n            <a class=\"text-white fw-bold me-3 home-link\" href=\"{{navigation.artfakta.url}}\">\r\n                {{navigation.artfakta.transId|translate}}\r\n            </a>\r\n            <a class=\"text-white d-none d-md-block\" href=\"{{navigation.artinfo.url}}\">\r\n                {{navigation.artinfo.transId|translate}}\r\n            </a>\r\n            <a class=\"text-white d-none d-md-block\" href=\"{{navigation.observations.url}}?lang={{trans.currentLang}}\">\r\n                {{navigation.observations.transId|translate}}\r\n            </a>\r\n            <a class=\"text-white d-none d-md-block\" href=\"{{navigation.nameAndRelationship.url}}?lang={{trans.currentLang}}\">\r\n                {{navigation.nameAndRelationship.transId|translate}}\r\n            </a>\r\n        </nav>\r\n        <div class=\"ms-auto\">\r\n            <div class=\"btn-group no-caret d-none d-md-block\">\r\n                <button type=\"button\" adbDropdown class=\"btn btn-primary btn-sm dropdown-toggle\" [class.initials]=\"initials\" (click)=\"showMenuDropdown(!showMenu)\">\r\n                    <ng-container *ngIf=\"initials\">{{initials}}</ng-container>\r\n                    <ng-container *ngIf=\"!initials\">{{'ADB_HEADER.LOGIN'|translate}}</ng-container>\r\n                </button>\r\n                <ul class=\"dropdown-menu dropdown-menu-end py-1 bg-primary text-white\">\r\n                    <ng-container *ngIf=\"initials\">\r\n                        <li class=\"px-2 pb-1\">\r\n                            <button (click)=\"logout()\" type=\"button\" class=\"btn btn-link p-0 text-white\">\r\n                                <span class=\"fas fa-sign-out-alt me-1\"></span>{{'ADB_HEADER.LOGOUT'|translate}}\r\n                            </button>\r\n                        </li>\r\n                        <hr class=\"my-0\">\r\n                        <li class=\"pt-1 px-2\">\r\n                            <span class=\"fas fa-user me-1\"></span>\r\n                            {{fullName}}\r\n                        </li>\r\n                    </ng-container>\r\n                    <ng-container *ngIf=\"!initials\">\r\n                        <li>\r\n                            <div class=\"text-center \">\r\n                                <button type=\"button\" class=\"btn btn-primary\" (click)=\"login()\" id=\"start-login\">{{'ADB_HEADER.LOGIN'|translate}}</button>\r\n                            </div>\r\n                        </li>\r\n                        <li>\r\n                            <a *ngIf=\"navigation\" class=\"d-block text-center mt-2 text-white\" href=\"{{navigation.createAccountLink}}?lang={{trans.currentLang}}&returnUrl={{url}}\">\r\n                                {{'ADB_HEADER.CREATE_USER'|translate}}\r\n                            </a>\r\n                        </li>\r\n                    </ng-container>\r\n                </ul>\r\n            </div>\r\n            <div class=\"d-block d-md-none\">\r\n                <button type=\"button\" class=\"btn btn-sm py-1 px-2 btn-primary\" (click)=\"showUserMenu = false;showMenuDropdown(!showMenu)\">\r\n                    {{'ADB_HEADER.MENY'|translate}}\r\n                    <i class=\"ms-1 fas\" [ngClass]=\"showMenu?'fa-chevron-up':'fa-chevron-down'\"></i>\r\n                </button>\r\n            </div>\r\n        </div>\r\n    </header>\r\n    <div class=\"mobile-menu d-flex flex-column d-md-none bg-primary text-white\" *ngIf=\"showMenu&&navigation\">\r\n        <div class=\"p-2\">\r\n            <div class=\"d-flex justify-content-between align-items-center gap-2\" *ngIf=\"initials\">\r\n                <span class=\"initials me-2\">{{initials}}</span>\r\n                <button type=\"button\" (click)=\"logout()\" class=\"btn btn-primary\">\r\n                    {{'ADB_HEADER.LOGOUT'|translate}}\r\n                </button>\r\n            </div>\r\n            <div class=\"d-flex justify-content-between gap-2\" *ngIf=\"!initials\">\r\n                <button type=\"button\" (click)=\"login()\" class=\"btn btn-primary\" id=\"login\">\r\n                    {{'ADB_HEADER.LOGIN'|translate}}\r\n                </button>\r\n                <a href=\"{{navigation.createAccountLink}}?lang={{trans.currentLang}}&returnUrl={{url}}\"\r\n                    class=\"btn btn-primary text-white\">\r\n                    {{'ADB_HEADER.CREATE_USER'|translate}}\r\n                </a>\r\n            </div>\r\n        </div>\r\n        <div class=\"px-2\">\r\n            <hr class=\"my-0\">\r\n            <ul class=\"list-unstyled\">\r\n                <li>\r\n                    <a class=\"d-block py-1 text-white\" href=\"{{navigation.artinfo.url}}\">\r\n                        {{navigation.artinfo.transId|translate}}\r\n                    </a>\r\n                    <hr class=\"my-0\">\r\n                </li>\r\n                <li>\r\n                    <a class=\"d-block py-1 text-white\" href=\"{{navigation.observations.url}}?lang={{trans.currentLang}}\">\r\n                        {{navigation.observations.transId|translate}}\r\n                    </a>\r\n                    <hr class=\"my-0\">\r\n                </li>\r\n                <li>\r\n                    <a class=\"d-block py-1 text-white\" href=\"{{navigation.nameAndRelationship.url}}?lang={{trans.currentLang}}\">\r\n                        {{navigation.nameAndRelationship.transId|translate}}\r\n                    </a>\r\n                    <hr class=\"my-0\">\r\n                </li>\r\n                <li>\r\n                    <a class=\"d-block py-1 text-white\" [href]=\"navigation.about.url\">{{navigation.about.transId|translate}}</a>\r\n                    <hr class=\"my-0\">\r\n                </li>\r\n                <li>\r\n                    <a class=\"d-block py-1 text-white\" [href]=\"navigation.artportalenUrl\">\r\n                        {{'ADB_HEADER.ARTPORTALEN_TITLE'|translate}}\r\n                    </a>\r\n                    <hr class=\"my-0\">\r\n                </li>\r\n                <li>\r\n                    <small class=\"d-block text-white py-2\">\r\n                        {{'ADB_HEADER.DEVELOPED_BY'|translate}}\r\n                        <a href=\"https://www.artdatabanken.se/\" class=\"text-white\"><u>{{'ADB_HEADER.ARTDATABANKEN'|translate}}</u></a>\r\n                    </small>\r\n                </li>\r\n            </ul>\r\n        </div>\r\n        <div class=\"mt-auto splash-height\" id=\"pattern\"></div>\r\n    </div>\r\n</div>\r\n<div (onVisible)=\"onHideTop(false)\" (onHidden)=\"onHideTop(true)\" style=\"height:0px\"></div>"]}
@@ -435,7 +435,6 @@ class ADBNavComponent {
435
435
  this.url = window.location.href;
436
436
  const baseUrl = this.envService.environment.resourceUrl;
437
437
  const url = this.artfakta ? '/assets/links-ap3.json' : '/assets/artportalen/links-ap3.json';
438
- console.log('banana', baseUrl + url);
439
438
  this.subscription.add(this.httpClient.get(baseUrl + url).subscribe(result => {
440
439
  this.navigation = result;
441
440
  }));