@byuhbll/components 4.0.6 → 4.0.7

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.
@@ -59,8 +59,13 @@ export class HbllHeaderComponent {
59
59
  this.showNavBar = false;
60
60
  this.r2.removeStyle(this.doc.body, 'overflow');
61
61
  };
62
- this.setMobileSidebarHeight = () => (this.mobileSidebarHeight =
63
- window.innerHeight - this.header.nativeElement.getBoundingClientRect().height);
62
+ this.setMobileSidebarHeight = () => {
63
+ const headerHeight = this.header.nativeElement.getBoundingClientRect().height;
64
+ // TODO: remove banner code after banner is removed from beta
65
+ const bannerElement = document.querySelector('#beta-navigation-banner');
66
+ const bannerHeight = bannerElement ? bannerElement.getBoundingClientRect().height || 0 : 0;
67
+ this.mobileSidebarHeight = window.innerHeight - headerHeight - bannerHeight;
68
+ };
64
69
  }
65
70
  get isLoggedIn() {
66
71
  return !!this.name;
@@ -107,4 +112,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.0", ngImpor
107
112
  type: HostListener,
108
113
  args: ['window:resize', ['$event']]
109
114
  }] } });
110
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"hbll-header.component.js","sourceRoot":"","sources":["../../../../../projects/components/src/lib/hbll-header/hbll-header.component.ts","../../../../../projects/components/src/lib/hbll-header/hbll-header.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule, DatePipe, DOCUMENT, LowerCasePipe } from '@angular/common';\nimport { toSignal } from '@angular/core/rxjs-interop';\nimport { HttpClient } from '@angular/common/http';\nimport {\n    AfterViewInit,\n    Component,\n    ElementRef,\n    EventEmitter,\n    HostListener,\n    Input,\n    Output,\n    Renderer2,\n    ViewChild,\n    inject,\n    input,\n    viewChild,\n} from '@angular/core';\nimport { NavBarComponent } from './nav-bar/nav-bar.component';\nimport { libHbllFadeInOut, libHbllSlideInOutRightLeft } from '../animations/animations';\nimport { BreakpointObserver } from '@angular/cdk/layout';\nimport { isScreenSmallSignal } from '../utils';\nimport { LibraryHoursPipe } from './pipes/library-hours.pipe';\nimport { map, of, shareReplay, switchMap } from 'rxjs';\nimport { ExpandCollapseComponent } from '../expand-collapse/expand-collapse.component';\nimport { LibraryHours } from './models/library-hours';\n\nexport const LIBRARY_HOURS_API_URL = 'https://apps.lib.byu.edu/libraryhours/api/hours';\n\n@Component({\n    selector: 'lib-hbll-header',\n    standalone: true,\n    imports: [\n        DatePipe,\n        LowerCasePipe,\n        LibraryHoursPipe,\n        CommonModule,\n        NavBarComponent,\n        ExpandCollapseComponent,\n    ],\n    templateUrl: './hbll-header.component.html',\n    styleUrl: './hbll-header.component.scss',\n    animations: [libHbllSlideInOutRightLeft, libHbllFadeInOut],\n})\nexport class HbllHeaderComponent implements AfterViewInit {\n    private readonly r2 = inject(Renderer2);\n    // TODO: does this increase bundle size more than it's worth? vs fetch?\n    private readonly http = inject(HttpClient);\n    private readonly bo = inject(BreakpointObserver);\n    private doc = inject(DOCUMENT);\n\n    @ViewChild('header') header!: ElementRef;\n\n    // --- API ---\n    // TODO: Convert these to signal inputs: https://github.com/angular/angular/issues/57755\n    @Input() name = '';\n    @Input() mainsitebaseurl = 'https://lib.byu.edu';\n    // TODO: this is a singal input currently because it won't be used by any other applications than Angular ones.\n    showImpersonateButton = input(false);\n    @Output() openImpersonationModal = new EventEmitter<void>();\n    @Output() login = new EventEmitter<void>();\n    @Output() logout = new EventEmitter<void>();\n    // -----------\n    private formatDateForHours = (date: Date) =>\n        `${date.getFullYear()}-${String(date.getMonth() + 1).padStart(2, '0')}-${String(date.getDate()).padStart(2, '0')}`;\n    private accountInfoEl = viewChild<ElementRef>('accountInfo');\n    private hoursEl = viewChild<ElementRef>('hours');\n\n    protected get isLoggedIn() {\n        return !!this.name;\n    }\n\n    // Hours\n    protected libraryHours = toSignal(this.http.get<LibraryHours>(LIBRARY_HOURS_API_URL));\n    protected hoursExceptions$ = of(null).pipe(\n        map(() => {\n            // Get exceptions from today to two months out\n            const today = new Date();\n            const start = this.formatDateForHours(today);\n            const newDate = new Date();\n            newDate.setMonth(today.getMonth() + 2);\n            const stop = this.formatDateForHours(newDate);\n            return [start, stop];\n        }),\n        switchMap(([start, stop]: string[]) =>\n            this.http\n                .get<LibraryHours[]>(`${LIBRARY_HOURS_API_URL}?start=${start}&stop=${stop}`)\n                .pipe(map((res) => res.filter((day) => day.has_exception).slice(0, 5))),\n        ),\n        shareReplay(1),\n    );\n\n    protected showAccountDropdown = false;\n    protected showLibraryHours = false;\n    protected mobileSidebarHeight = 0;\n    protected showNavBar = false;\n    protected isScreenSmall = isScreenSmallSignal(this.bo);\n\n    ngAfterViewInit(): void {\n        this.r2.listen('window', 'click', (e: Event) => {\n            if (!this.accountInfoEl()?.nativeElement.contains(e.target))\n                this.showAccountDropdown = false;\n            if (!this.hoursEl()?.nativeElement.contains(e.target)) this.showLibraryHours = false;\n        });\n        this.setMobileSidebarHeight();\n    }\n\n    protected openSidebarNav = () => {\n        this.showNavBar = true;\n        window.scrollTo(0, 0);\n        this.r2.setStyle(this.doc.body, 'overflow', 'hidden');\n    };\n\n    protected closeSidebarNav = () => {\n        this.showNavBar = false;\n        this.r2.removeStyle(this.doc.body, 'overflow');\n    };\n\n    @HostListener('window:resize', ['$event'])\n    private onResize() {\n        this.setMobileSidebarHeight();\n    }\n\n    private setMobileSidebarHeight = () =>\n        (this.mobileSidebarHeight =\n            window.innerHeight - this.header.nativeElement.getBoundingClientRect().height);\n}\n","<header\n    role=\"banner\"\n    class=\"hbll-header-wrapper\"\n    #header\n    [ngClass]=\"{ 'hbll-header-desktop': !isScreenSmall() }\"\n>\n    <a [href]=\"mainsitebaseurl\">\n        <h1>\n            <img\n                src=\"https://media.lib.byu.edu/web-assets/images/2.0.0/byu-hbll-logo-full.svg\"\n                alt=\"BYU Library Logo\"\n            />\n        </h1>\n    </a>\n    <div id=\"libraryInfo\" class=\"hbll-header-wrapper\">\n        @if (!isScreenSmall()) {\n            <div #hours id=\"mainLibraryHours\" data-testid=\"desktopHours\">\n                <button\n                    (click)=\"showLibraryHours = !showLibraryHours\"\n                    class=\"hbll-header-wrapper\"\n                    data-testid=\"hoursBtn\"\n                >\n                    <ng-container *ngTemplateOutlet=\"hoursTextBlock\"></ng-container>\n                </button>\n                @if (!isScreenSmall() && showLibraryHours) {\n                    <div\n                        @libHbllFadeInOut\n                        id=\"libraryHoursDropdown\"\n                        data-testid=\"libraryHoursDropdown\"\n                    >\n                        <section class=\"hbll-header-section\">\n                            <h2 class=\"hbll-header-header\">Regular Hours</h2>\n                            <div class=\"hbll-header-detail\">\n                                <h3 class=\"hbll-header-item\">Monday - Friday</h3>\n                                <h3 class=\"hbll-header-item\">Saturday</h3>\n                                <h3 class=\"hbll-header-item\">Sunday</h3>\n                            </div>\n                            <div class=\"hbll-header-hours\">\n                                <div class=\"hbll-header-item\">7 a.m - midnight</div>\n                                <div class=\"hbll-header-item\">8 a.m - midnight</div>\n                                <div class=\"hbll-header-item\">Closed*</div>\n                            </div>\n                            <div class=\"hbll-header-hours-note\">\n                                * Family history ONLY 4 p.m. - 8 p.m\n                                <ul>\n                                    <li><span>No checkouts after 11:45 p.m.</span></li>\n                                    <li>\n                                        <span>All services closed 10:45 to noon on Tuesdays</span>\n                                    </li>\n                                </ul>\n                            </div>\n                        </section>\n                        <section class=\"hbll-header-section\">\n                            <h2 class=\"hbll-header-header\">Upcoming Exceptions</h2>\n                            @if (hoursExceptions$ | async; as exceptions) {\n                                <div class=\"hbll-header-detail\" data-testid=\"exceptionsDetail\">\n                                    @for (exception of exceptions; track exception.date) {\n                                        <h3 class=\"hbll-header-item\">\n                                            {{ exception.date | date: 'MMM. d, YYYY' }}\n                                        </h3>\n                                    } @empty {\n                                        No upcoming exceptions\n                                    }\n                                </div>\n                                <div class=\"hbll-header-hours\" data-testid=\"exceptionsHours\">\n                                    @for (exception of exceptions; track exception.date) {\n                                        <div class=\"hbll-header-item\">\n                                            {{ exception.exception_title }}\n                                        </div>\n                                    }\n                                </div>\n                            } @else {\n                                <div class=\"lib-spinner\" data-testid=\"exceptionsSpinner\"></div>\n                            }\n                        </section>\n                        <section class=\"hbll-header-section\">\n                            <h2 class=\"hbll-header-header\">Library Cafe</h2>\n                            <div class=\"hbll-header-detail\">\n                                <h3 class=\"hbll-header-item\">Bagel Bubble</h3>\n                                <h3 class=\"hbll-header-item\">Provecho</h3>\n                            </div>\n                            <div class=\"hbll-header-hours\">\n                                <div class=\"hbll-header-item\">7 a.m - 11 p.m.</div>\n                                <div class=\"hbll-header-item\">10:30 a.m - 2 p.m.</div>\n                            </div>\n                        </section>\n                        <a [href]=\"mainsitebaseurl + '/about/hours'\"\n                            >See all hours\n                            <span class=\"material-symbols-outlined\"> chevron_right </span></a\n                        >\n                    </div>\n                }\n            </div>\n        }\n        <div id=\"accountInfo\" #accountInfo>\n            <button\n                (click)=\"isLoggedIn ? (showAccountDropdown = !showAccountDropdown) : login.emit()\"\n                class=\"hbll-header-wrapper\"\n                id=\"accountBtn\"\n                data-testid=\"accountBtn\"\n            >\n                <span class=\"material-symbols-outlined hbll-header-left-icon\"> person </span>\n                @if (!isScreenSmall()) {\n                    <span class=\"hbll-header-name\" data-testid=\"name\">{{\n                        isLoggedIn ? '&nbsp;' + name : 'Login'\n                    }}</span>\n                }\n                @if (isLoggedIn) {\n                    <span class=\"material-symbols-outlined\" data-testid=\"loginDropdown\">\n                        arrow_drop_down\n                    </span>\n                }\n            </button>\n            @if (isLoggedIn && showAccountDropdown) {\n                <div @libHbllFadeInOut id=\"accountDropdown\" data-testid=\"accountDropdown\">\n                    <a [href]=\"mainsitebaseurl + '/account'\">My Account</a>\n                    <a [href]=\"mainsitebaseurl + '/account'\">My Items</a>\n                    <a [href]=\"mainsitebaseurl + '/account/request'\">Request an item</a>\n                    <a [href]=\"mainsitebaseurl + '/account/saved'\">Saved</a>\n                    <a [href]=\"mainsitebaseurl + '/account/course'\">Courses</a>\n                    <a [href]=\"mainsitebaseurl + '/account/rooms'\">Rooms</a>\n                    <a [href]=\"mainsitebaseurl + '/account/preferences'\">Preferences</a>\n                    @if (showImpersonateButton()) {\n                        <button\n                            (click)=\"openImpersonationModal.emit(); showAccountDropdown = false\"\n                            class=\"hbll-header-impersonate-btn\"\n                        >\n                            Impersonate\n                        </button>\n                    }\n                    <button (click)=\"logout.emit()\" data-testid=\"logout\">Logout</button>\n                </div>\n            }\n        </div>\n        @if (isScreenSmall()) {\n            <div id=\"mobileNav\">\n                <button\n                    class=\"hbll-header-wrapper\"\n                    data-testid=\"mobileNavBtn\"\n                    (click)=\"openSidebarNav()\"\n                >\n                    <span class=\"material-symbols-outlined hbll-header-icon\"> menu </span>\n                </button>\n                @if (showNavBar) {\n                    <div\n                        id=\"navWrapper\"\n                        data-testid=\"mobileNav\"\n                        [@libHbllSlideInOutRightLeft]=\"{\n                            value: '',\n                            params: { xOffset: '400px' },\n                        }\"\n                    >\n                        <button\n                            id=\"closeMobileNavBtn\"\n                            class=\"hbll-header-wrapper\"\n                            data-testid=\"closeMobileNavBtn\"\n                            (click)=\"closeSidebarNav()\"\n                        >\n                            <span class=\"material-symbols-outlined hbll-header-icon\"> close </span>\n                        </button>\n                        <lib-nav-bar\n                            [mainSiteBaseUrl]=\"mainsitebaseurl\"\n                            [height]=\"mobileSidebarHeight\"\n                        />\n                    </div>\n                    <div\n                        @libHbllFadeInOut\n                        (click)=\"showNavBar = false\"\n                        class=\"hbll-nav-backdrop\"\n                        data-testid=\"mobileNavBackdrop\"\n                    ></div>\n                }\n            </div>\n        }\n    </div>\n</header>\n\n@if (!isScreenSmall()) {\n    <div id=\"mainNav\">\n        <lib-nav-bar [mainSiteBaseUrl]=\"mainsitebaseurl\" />\n    </div>\n}\n@if (isScreenSmall()) {\n    <a\n        id=\"mobileLibraryHours\"\n        [href]=\"mainsitebaseurl + '/about/hours'\"\n        class=\"hbll-header-wrapper\"\n        data-testid=\"mobileHours\"\n    >\n        <ng-container *ngTemplateOutlet=\"hoursTextBlock\"></ng-container>\n    </a>\n}\n\n<ng-template #hoursTextBlock>\n    @if (libraryHours()) {\n        <span class=\"material-symbols-outlined hbll-header-left-icon\"> schedule </span>\n        {{\n            libraryHours()?.is_closed\n                ? 'CLOSED'\n                : \"Today's hours: \" +\n                  (libraryHours()!.date | libraryHours: libraryHours()!.open_time) +\n                  ' - ' +\n                  (libraryHours()!.date | libraryHours: libraryHours()!.close_time)\n        }}\n    }\n</ng-template>\n"]}
115
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"hbll-header.component.js","sourceRoot":"","sources":["../../../../../projects/components/src/lib/hbll-header/hbll-header.component.ts","../../../../../projects/components/src/lib/hbll-header/hbll-header.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,QAAQ,EAAE,QAAQ,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAC;AAClF,OAAO,EAAE,QAAQ,EAAE,MAAM,4BAA4B,CAAC;AACtD,OAAO,EAAE,UAAU,EAAE,MAAM,sBAAsB,CAAC;AAClD,OAAO,EAEH,SAAS,EAET,YAAY,EACZ,YAAY,EACZ,KAAK,EACL,MAAM,EACN,SAAS,EACT,SAAS,EACT,MAAM,EACN,KAAK,EACL,SAAS,GACZ,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,eAAe,EAAE,MAAM,6BAA6B,CAAC;AAC9D,OAAO,EAAE,gBAAgB,EAAE,0BAA0B,EAAE,MAAM,0BAA0B,CAAC;AACxF,OAAO,EAAE,kBAAkB,EAAE,MAAM,qBAAqB,CAAC;AACzD,OAAO,EAAE,mBAAmB,EAAE,MAAM,UAAU,CAAC;AAC/C,OAAO,EAAE,gBAAgB,EAAE,MAAM,4BAA4B,CAAC;AAC9D,OAAO,EAAE,GAAG,EAAE,EAAE,EAAE,WAAW,EAAE,SAAS,EAAE,MAAM,MAAM,CAAC;AACvD,OAAO,EAAE,uBAAuB,EAAE,MAAM,8CAA8C,CAAC;;;AAGvF,MAAM,CAAC,MAAM,qBAAqB,GAAG,iDAAiD,CAAC;AAiBvF,MAAM,OAAO,mBAAmB;IAfhC;QAgBqB,OAAE,GAAG,MAAM,CAAC,SAAS,CAAC,CAAC;QACxC,uEAAuE;QACtD,SAAI,GAAG,MAAM,CAAC,UAAU,CAAC,CAAC;QAC1B,OAAE,GAAG,MAAM,CAAC,kBAAkB,CAAC,CAAC;QACzC,QAAG,GAAG,MAAM,CAAC,QAAQ,CAAC,CAAC;QAI/B,cAAc;QACd,wFAAwF;QAC/E,SAAI,GAAG,EAAE,CAAC;QACV,oBAAe,GAAG,qBAAqB,CAAC;QACjD,+GAA+G;QAC/G,0BAAqB,GAAG,KAAK,CAAC,KAAK,CAAC,CAAC;QAC3B,2BAAsB,GAAG,IAAI,YAAY,EAAQ,CAAC;QAClD,UAAK,GAAG,IAAI,YAAY,EAAQ,CAAC;QACjC,WAAM,GAAG,IAAI,YAAY,EAAQ,CAAC;QAC5C,cAAc;QACN,uBAAkB,GAAG,CAAC,IAAU,EAAE,EAAE,CACxC,GAAG,IAAI,CAAC,WAAW,EAAE,IAAI,MAAM,CAAC,IAAI,CAAC,QAAQ,EAAE,GAAG,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,IAAI,MAAM,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,EAAE,CAAC;QAC/G,kBAAa,GAAG,SAAS,CAAa,aAAa,CAAC,CAAC;QACrD,YAAO,GAAG,SAAS,CAAa,OAAO,CAAC,CAAC;QAMjD,QAAQ;QACE,iBAAY,GAAG,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAe,qBAAqB,CAAC,CAAC,CAAC;QAC5E,qBAAgB,GAAG,EAAE,CAAC,IAAI,CAAC,CAAC,IAAI,CACtC,GAAG,CAAC,GAAG,EAAE;YACL,8CAA8C;YAC9C,MAAM,KAAK,GAAG,IAAI,IAAI,EAAE,CAAC;YACzB,MAAM,KAAK,GAAG,IAAI,CAAC,kBAAkB,CAAC,KAAK,CAAC,CAAC;YAC7C,MAAM,OAAO,GAAG,IAAI,IAAI,EAAE,CAAC;YAC3B,OAAO,CAAC,QAAQ,CAAC,KAAK,CAAC,QAAQ,EAAE,GAAG,CAAC,CAAC,CAAC;YACvC,MAAM,IAAI,GAAG,IAAI,CAAC,kBAAkB,CAAC,OAAO,CAAC,CAAC;YAC9C,OAAO,CAAC,KAAK,EAAE,IAAI,CAAC,CAAC;QACzB,CAAC,CAAC,EACF,SAAS,CAAC,CAAC,CAAC,KAAK,EAAE,IAAI,CAAW,EAAE,EAAE,CAClC,IAAI,CAAC,IAAI;aACJ,GAAG,CAAiB,GAAG,qBAAqB,UAAU,KAAK,SAAS,IAAI,EAAE,CAAC;aAC3E,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,aAAa,CAAC,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAC9E,EACD,WAAW,CAAC,CAAC,CAAC,CACjB,CAAC;QAEQ,wBAAmB,GAAG,KAAK,CAAC;QAC5B,qBAAgB,GAAG,KAAK,CAAC;QACzB,wBAAmB,GAAG,CAAC,CAAC;QACxB,eAAU,GAAG,KAAK,CAAC;QACnB,kBAAa,GAAG,mBAAmB,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;QAW7C,mBAAc,GAAG,GAAG,EAAE;YAC5B,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;YACvB,MAAM,CAAC,QAAQ,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;YACtB,IAAI,CAAC,EAAE,CAAC,QAAQ,CAAC,IAAI,CAAC,GAAG,CAAC,IAAI,EAAE,UAAU,EAAE,QAAQ,CAAC,CAAC;QAC1D,CAAC,CAAC;QAEQ,oBAAe,GAAG,GAAG,EAAE;YAC7B,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;YACxB,IAAI,CAAC,EAAE,CAAC,WAAW,CAAC,IAAI,CAAC,GAAG,CAAC,IAAI,EAAE,UAAU,CAAC,CAAC;QACnD,CAAC,CAAC;QAOM,2BAAsB,GAAG,GAAG,EAAE;YAClC,MAAM,YAAY,GAAG,IAAI,CAAC,MAAM,CAAC,aAAa,CAAC,qBAAqB,EAAE,CAAC,MAAM,CAAC;YAE9E,6DAA6D;YAC7D,MAAM,aAAa,GAAG,QAAQ,CAAC,aAAa,CAAC,yBAAyB,CAAC,CAAC;YACxE,MAAM,YAAY,GAAG,aAAa,CAAC,CAAC,CAAC,aAAa,CAAC,qBAAqB,EAAE,CAAC,MAAM,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;YAE3F,IAAI,CAAC,mBAAmB,GAAG,MAAM,CAAC,WAAW,GAAG,YAAY,GAAG,YAAY,CAAC;QAChF,CAAC,CAAC;KACL;IAhEG,IAAc,UAAU;QACpB,OAAO,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC;IACvB,CAAC;IA4BD,eAAe;QACX,IAAI,CAAC,EAAE,CAAC,MAAM,CAAC,QAAQ,EAAE,OAAO,EAAE,CAAC,CAAQ,EAAE,EAAE;YAC3C,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE,EAAE,aAAa,CAAC,QAAQ,CAAC,CAAC,CAAC,MAAM,CAAC;gBACvD,IAAI,CAAC,mBAAmB,GAAG,KAAK,CAAC;YACrC,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,EAAE,aAAa,CAAC,QAAQ,CAAC,CAAC,CAAC,MAAM,CAAC;gBAAE,IAAI,CAAC,gBAAgB,GAAG,KAAK,CAAC;QACzF,CAAC,CAAC,CAAC;QACH,IAAI,CAAC,sBAAsB,EAAE,CAAC;IAClC,CAAC;IAcO,QAAQ;QACZ,IAAI,CAAC,sBAAsB,EAAE,CAAC;IAClC,CAAC;8GA7EQ,mBAAmB;kGAAnB,mBAAmB,+9BC3ChC,8rTA8MA,mrMD9KQ,QAAQ,wCAER,gBAAgB,oDAChB,YAAY,yVACZ,eAAe,iFAKP,CAAC,0BAA0B,EAAE,gBAAgB,CAAC;;2FAEjD,mBAAmB;kBAf/B,SAAS;+BACI,iBAAiB,cACf,IAAI,WACP;wBACL,QAAQ;wBACR,aAAa;wBACb,gBAAgB;wBAChB,YAAY;wBACZ,eAAe;wBACf,uBAAuB;qBAC1B,cAGW,CAAC,0BAA0B,EAAE,gBAAgB,CAAC;8BASrC,MAAM;sBAA1B,SAAS;uBAAC,QAAQ;gBAIV,IAAI;sBAAZ,KAAK;gBACG,eAAe;sBAAvB,KAAK;gBAGI,sBAAsB;sBAA/B,MAAM;gBACG,KAAK;sBAAd,MAAM;gBACG,MAAM;sBAAf,MAAM;gBA0DC,QAAQ;sBADf,YAAY;uBAAC,eAAe,EAAE,CAAC,QAAQ,CAAC","sourcesContent":["import { CommonModule, DatePipe, DOCUMENT, LowerCasePipe } from '@angular/common';\nimport { toSignal } from '@angular/core/rxjs-interop';\nimport { HttpClient } from '@angular/common/http';\nimport {\n    AfterViewInit,\n    Component,\n    ElementRef,\n    EventEmitter,\n    HostListener,\n    Input,\n    Output,\n    Renderer2,\n    ViewChild,\n    inject,\n    input,\n    viewChild,\n} from '@angular/core';\nimport { NavBarComponent } from './nav-bar/nav-bar.component';\nimport { libHbllFadeInOut, libHbllSlideInOutRightLeft } from '../animations/animations';\nimport { BreakpointObserver } from '@angular/cdk/layout';\nimport { isScreenSmallSignal } from '../utils';\nimport { LibraryHoursPipe } from './pipes/library-hours.pipe';\nimport { map, of, shareReplay, switchMap } from 'rxjs';\nimport { ExpandCollapseComponent } from '../expand-collapse/expand-collapse.component';\nimport { LibraryHours } from './models/library-hours';\n\nexport const LIBRARY_HOURS_API_URL = 'https://apps.lib.byu.edu/libraryhours/api/hours';\n\n@Component({\n    selector: 'lib-hbll-header',\n    standalone: true,\n    imports: [\n        DatePipe,\n        LowerCasePipe,\n        LibraryHoursPipe,\n        CommonModule,\n        NavBarComponent,\n        ExpandCollapseComponent,\n    ],\n    templateUrl: './hbll-header.component.html',\n    styleUrl: './hbll-header.component.scss',\n    animations: [libHbllSlideInOutRightLeft, libHbllFadeInOut],\n})\nexport class HbllHeaderComponent implements AfterViewInit {\n    private readonly r2 = inject(Renderer2);\n    // TODO: does this increase bundle size more than it's worth? vs fetch?\n    private readonly http = inject(HttpClient);\n    private readonly bo = inject(BreakpointObserver);\n    private doc = inject(DOCUMENT);\n\n    @ViewChild('header') header!: ElementRef;\n\n    // --- API ---\n    // TODO: Convert these to signal inputs: https://github.com/angular/angular/issues/57755\n    @Input() name = '';\n    @Input() mainsitebaseurl = 'https://lib.byu.edu';\n    // TODO: this is a singal input currently because it won't be used by any other applications than Angular ones.\n    showImpersonateButton = input(false);\n    @Output() openImpersonationModal = new EventEmitter<void>();\n    @Output() login = new EventEmitter<void>();\n    @Output() logout = new EventEmitter<void>();\n    // -----------\n    private formatDateForHours = (date: Date) =>\n        `${date.getFullYear()}-${String(date.getMonth() + 1).padStart(2, '0')}-${String(date.getDate()).padStart(2, '0')}`;\n    private accountInfoEl = viewChild<ElementRef>('accountInfo');\n    private hoursEl = viewChild<ElementRef>('hours');\n\n    protected get isLoggedIn() {\n        return !!this.name;\n    }\n\n    // Hours\n    protected libraryHours = toSignal(this.http.get<LibraryHours>(LIBRARY_HOURS_API_URL));\n    protected hoursExceptions$ = of(null).pipe(\n        map(() => {\n            // Get exceptions from today to two months out\n            const today = new Date();\n            const start = this.formatDateForHours(today);\n            const newDate = new Date();\n            newDate.setMonth(today.getMonth() + 2);\n            const stop = this.formatDateForHours(newDate);\n            return [start, stop];\n        }),\n        switchMap(([start, stop]: string[]) =>\n            this.http\n                .get<LibraryHours[]>(`${LIBRARY_HOURS_API_URL}?start=${start}&stop=${stop}`)\n                .pipe(map((res) => res.filter((day) => day.has_exception).slice(0, 5))),\n        ),\n        shareReplay(1),\n    );\n\n    protected showAccountDropdown = false;\n    protected showLibraryHours = false;\n    protected mobileSidebarHeight = 0;\n    protected showNavBar = false;\n    protected isScreenSmall = isScreenSmallSignal(this.bo);\n\n    ngAfterViewInit(): void {\n        this.r2.listen('window', 'click', (e: Event) => {\n            if (!this.accountInfoEl()?.nativeElement.contains(e.target))\n                this.showAccountDropdown = false;\n            if (!this.hoursEl()?.nativeElement.contains(e.target)) this.showLibraryHours = false;\n        });\n        this.setMobileSidebarHeight();\n    }\n\n    protected openSidebarNav = () => {\n        this.showNavBar = true;\n        window.scrollTo(0, 0);\n        this.r2.setStyle(this.doc.body, 'overflow', 'hidden');\n    };\n\n    protected closeSidebarNav = () => {\n        this.showNavBar = false;\n        this.r2.removeStyle(this.doc.body, 'overflow');\n    };\n\n    @HostListener('window:resize', ['$event'])\n    private onResize() {\n        this.setMobileSidebarHeight();\n    }\n\n    private setMobileSidebarHeight = () => {\n        const headerHeight = this.header.nativeElement.getBoundingClientRect().height;\n\n        // TODO: remove banner code after banner is removed from beta\n        const bannerElement = document.querySelector('#beta-navigation-banner');\n        const bannerHeight = bannerElement ? bannerElement.getBoundingClientRect().height || 0 : 0;\n\n        this.mobileSidebarHeight = window.innerHeight - headerHeight - bannerHeight;\n    };\n}\n","<header\n    role=\"banner\"\n    class=\"hbll-header-wrapper\"\n    #header\n    [ngClass]=\"{ 'hbll-header-desktop': !isScreenSmall() }\"\n>\n    <a [href]=\"mainsitebaseurl\">\n        <h1>\n            <img\n                src=\"https://media.lib.byu.edu/web-assets/images/2.0.0/byu-hbll-logo-full.svg\"\n                alt=\"BYU Library Logo\"\n            />\n        </h1>\n    </a>\n    <div id=\"libraryInfo\" class=\"hbll-header-wrapper\">\n        @if (!isScreenSmall()) {\n            <div #hours id=\"mainLibraryHours\" data-testid=\"desktopHours\">\n                <button\n                    (click)=\"showLibraryHours = !showLibraryHours\"\n                    class=\"hbll-header-wrapper\"\n                    data-testid=\"hoursBtn\"\n                >\n                    <ng-container *ngTemplateOutlet=\"hoursTextBlock\"></ng-container>\n                </button>\n                @if (!isScreenSmall() && showLibraryHours) {\n                    <div\n                        @libHbllFadeInOut\n                        id=\"libraryHoursDropdown\"\n                        data-testid=\"libraryHoursDropdown\"\n                    >\n                        <section class=\"hbll-header-section\">\n                            <h2 class=\"hbll-header-header\">Regular Hours</h2>\n                            <div class=\"hbll-header-detail\">\n                                <h3 class=\"hbll-header-item\">Monday - Friday</h3>\n                                <h3 class=\"hbll-header-item\">Saturday</h3>\n                                <h3 class=\"hbll-header-item\">Sunday</h3>\n                            </div>\n                            <div class=\"hbll-header-hours\">\n                                <div class=\"hbll-header-item\">7 a.m - midnight</div>\n                                <div class=\"hbll-header-item\">8 a.m - midnight</div>\n                                <div class=\"hbll-header-item\">Closed*</div>\n                            </div>\n                            <div class=\"hbll-header-hours-note\">\n                                * Family history ONLY 4 p.m. - 8 p.m\n                                <ul>\n                                    <li><span>No checkouts after 11:45 p.m.</span></li>\n                                    <li>\n                                        <span>All services closed 10:45 to noon on Tuesdays</span>\n                                    </li>\n                                </ul>\n                            </div>\n                        </section>\n                        <section class=\"hbll-header-section\">\n                            <h2 class=\"hbll-header-header\">Upcoming Exceptions</h2>\n                            @if (hoursExceptions$ | async; as exceptions) {\n                                <div class=\"hbll-header-detail\" data-testid=\"exceptionsDetail\">\n                                    @for (exception of exceptions; track exception.date) {\n                                        <h3 class=\"hbll-header-item\">\n                                            {{ exception.date | date: 'MMM. d, YYYY' }}\n                                        </h3>\n                                    } @empty {\n                                        No upcoming exceptions\n                                    }\n                                </div>\n                                <div class=\"hbll-header-hours\" data-testid=\"exceptionsHours\">\n                                    @for (exception of exceptions; track exception.date) {\n                                        <div class=\"hbll-header-item\">\n                                            {{ exception.exception_title }}\n                                        </div>\n                                    }\n                                </div>\n                            } @else {\n                                <div class=\"lib-spinner\" data-testid=\"exceptionsSpinner\"></div>\n                            }\n                        </section>\n                        <section class=\"hbll-header-section\">\n                            <h2 class=\"hbll-header-header\">Library Cafe</h2>\n                            <div class=\"hbll-header-detail\">\n                                <h3 class=\"hbll-header-item\">Bagel Bubble</h3>\n                                <h3 class=\"hbll-header-item\">Provecho</h3>\n                            </div>\n                            <div class=\"hbll-header-hours\">\n                                <div class=\"hbll-header-item\">7 a.m - 11 p.m.</div>\n                                <div class=\"hbll-header-item\">10:30 a.m - 2 p.m.</div>\n                            </div>\n                        </section>\n                        <a [href]=\"mainsitebaseurl + '/about/hours'\"\n                            >See all hours\n                            <span class=\"material-symbols-outlined\"> chevron_right </span></a\n                        >\n                    </div>\n                }\n            </div>\n        }\n        <div id=\"accountInfo\" #accountInfo>\n            <button\n                (click)=\"isLoggedIn ? (showAccountDropdown = !showAccountDropdown) : login.emit()\"\n                class=\"hbll-header-wrapper\"\n                id=\"accountBtn\"\n                data-testid=\"accountBtn\"\n            >\n                <span class=\"material-symbols-outlined hbll-header-left-icon\"> person </span>\n                @if (!isScreenSmall()) {\n                    <span class=\"hbll-header-name\" data-testid=\"name\">{{\n                        isLoggedIn ? '&nbsp;' + name : 'Login'\n                    }}</span>\n                }\n                @if (isLoggedIn) {\n                    <span class=\"material-symbols-outlined\" data-testid=\"loginDropdown\">\n                        arrow_drop_down\n                    </span>\n                }\n            </button>\n            @if (isLoggedIn && showAccountDropdown) {\n                <div @libHbllFadeInOut id=\"accountDropdown\" data-testid=\"accountDropdown\">\n                    <a [href]=\"mainsitebaseurl + '/account'\">My Account</a>\n                    <a [href]=\"mainsitebaseurl + '/account'\">My Items</a>\n                    <a [href]=\"mainsitebaseurl + '/account/request'\">Request an item</a>\n                    <a [href]=\"mainsitebaseurl + '/account/saved'\">Saved</a>\n                    <a [href]=\"mainsitebaseurl + '/account/course'\">Courses</a>\n                    <a [href]=\"mainsitebaseurl + '/account/rooms'\">Rooms</a>\n                    <a [href]=\"mainsitebaseurl + '/account/preferences'\">Preferences</a>\n                    @if (showImpersonateButton()) {\n                        <button\n                            (click)=\"openImpersonationModal.emit(); showAccountDropdown = false\"\n                            class=\"hbll-header-impersonate-btn\"\n                        >\n                            Impersonate\n                        </button>\n                    }\n                    <button (click)=\"logout.emit()\" data-testid=\"logout\">Logout</button>\n                </div>\n            }\n        </div>\n        @if (isScreenSmall()) {\n            <div id=\"mobileNav\">\n                <button\n                    class=\"hbll-header-wrapper\"\n                    data-testid=\"mobileNavBtn\"\n                    (click)=\"openSidebarNav()\"\n                >\n                    <span class=\"material-symbols-outlined hbll-header-icon\"> menu </span>\n                </button>\n                @if (showNavBar) {\n                    <div\n                        id=\"navWrapper\"\n                        data-testid=\"mobileNav\"\n                        [@libHbllSlideInOutRightLeft]=\"{\n                            value: '',\n                            params: { xOffset: '400px' },\n                        }\"\n                    >\n                        <button\n                            id=\"closeMobileNavBtn\"\n                            class=\"hbll-header-wrapper\"\n                            data-testid=\"closeMobileNavBtn\"\n                            (click)=\"closeSidebarNav()\"\n                        >\n                            <span class=\"material-symbols-outlined hbll-header-icon\"> close </span>\n                        </button>\n                        <lib-nav-bar\n                            [mainSiteBaseUrl]=\"mainsitebaseurl\"\n                            [height]=\"mobileSidebarHeight\"\n                        />\n                    </div>\n                    <div\n                        @libHbllFadeInOut\n                        (click)=\"showNavBar = false\"\n                        class=\"hbll-nav-backdrop\"\n                        data-testid=\"mobileNavBackdrop\"\n                    ></div>\n                }\n            </div>\n        }\n    </div>\n</header>\n\n@if (!isScreenSmall()) {\n    <div id=\"mainNav\">\n        <lib-nav-bar [mainSiteBaseUrl]=\"mainsitebaseurl\" />\n    </div>\n}\n@if (isScreenSmall()) {\n    <a\n        id=\"mobileLibraryHours\"\n        [href]=\"mainsitebaseurl + '/about/hours'\"\n        class=\"hbll-header-wrapper\"\n        data-testid=\"mobileHours\"\n    >\n        <ng-container *ngTemplateOutlet=\"hoursTextBlock\"></ng-container>\n    </a>\n}\n\n<ng-template #hoursTextBlock>\n    @if (libraryHours()) {\n        <span class=\"material-symbols-outlined hbll-header-left-icon\"> schedule </span>\n        {{\n            libraryHours()?.is_closed\n                ? 'CLOSED'\n                : \"Today's hours: \" +\n                  (libraryHours()!.date | libraryHours: libraryHours()!.open_time) +\n                  ' - ' +\n                  (libraryHours()!.date | libraryHours: libraryHours()!.close_time)\n        }}\n    }\n</ng-template>\n"]}
@@ -528,8 +528,13 @@ class HbllHeaderComponent {
528
528
  this.showNavBar = false;
529
529
  this.r2.removeStyle(this.doc.body, 'overflow');
530
530
  };
531
- this.setMobileSidebarHeight = () => (this.mobileSidebarHeight =
532
- window.innerHeight - this.header.nativeElement.getBoundingClientRect().height);
531
+ this.setMobileSidebarHeight = () => {
532
+ const headerHeight = this.header.nativeElement.getBoundingClientRect().height;
533
+ // TODO: remove banner code after banner is removed from beta
534
+ const bannerElement = document.querySelector('#beta-navigation-banner');
535
+ const bannerHeight = bannerElement ? bannerElement.getBoundingClientRect().height || 0 : 0;
536
+ this.mobileSidebarHeight = window.innerHeight - headerHeight - bannerHeight;
537
+ };
533
538
  }
534
539
  get isLoggedIn() {
535
540
  return !!this.name;