@byuhbll/components 4.0.0-alpha.4 → 4.0.0-alpha.40
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/lib/animations/animations.mjs +19 -1
- package/esm2022/lib/checkbox/checkbox.component.mjs +15 -0
- package/esm2022/lib/contact-utils.mjs +41 -0
- package/esm2022/lib/copy-tooltip/copy-tooltip.component.mjs +49 -0
- package/esm2022/lib/expand-collapse/expand-collapse.component.mjs +31 -0
- package/esm2022/lib/hbll-footer/hbll-footer.component.mjs +98 -0
- package/esm2022/lib/hbll-header/hbll-header.component.mjs +81 -31
- package/esm2022/lib/hbll-header/models/library-hours.mjs +2 -0
- package/esm2022/lib/hbll-header/nav-bar/nav-bar.component.mjs +333 -0
- package/esm2022/lib/hbll-header/nav-bar-dropdown/nav-bar-dropdown.component.mjs +29 -0
- package/esm2022/lib/hbll-header/pipes/library-hours.pipe.mjs +31 -0
- package/esm2022/lib/header-with-impersonation/header-with-impersonation.component.mjs +39 -0
- package/esm2022/lib/impersonate-modal/impersonate-modal.component.mjs +190 -0
- package/esm2022/lib/impersonation-banner/impersonation-banner.component.mjs +128 -0
- package/esm2022/lib/impersonation-banner/models/application-access.mjs +7 -0
- package/esm2022/lib/impersonation-banner/models/person-summary.mjs +15 -0
- package/esm2022/lib/models/token-payload.mjs +2 -0
- package/esm2022/lib/multi-select/multi-select.component.mjs +115 -0
- package/esm2022/lib/pipes/hbll-item-type-icon.pipe.mjs +128 -0
- package/esm2022/lib/ss-search-bar/advanced-search/advanced-search.component.mjs +5 -5
- package/esm2022/lib/ss-search-bar/date-range/date-range.component.mjs +3 -3
- package/esm2022/lib/ss-search-bar/ss-search-bar.component.mjs +3 -3
- package/esm2022/lib/utils.mjs +7 -0
- package/esm2022/public-api.mjs +7 -1
- package/fesm2022/byuhbll-components.mjs +1171 -66
- package/fesm2022/byuhbll-components.mjs.map +1 -1
- package/lib/animations/animations.d.ts +1 -0
- package/lib/{hbll-checkbox/hbll-checkbox.component.d.ts → checkbox/checkbox.component.d.ts} +2 -2
- package/lib/contact-utils.d.ts +19 -0
- package/lib/copy-tooltip/copy-tooltip.component.d.ts +12 -0
- package/lib/expand-collapse/expand-collapse.component.d.ts +10 -0
- package/lib/hbll-footer/hbll-footer.component.d.ts +30 -0
- package/lib/hbll-header/hbll-header.component.d.ts +23 -28
- package/lib/hbll-header/models/library-hours.d.ts +10 -0
- package/lib/hbll-header/nav-bar/nav-bar.component.d.ts +30 -0
- package/lib/hbll-header/nav-bar-dropdown/nav-bar-dropdown.component.d.ts +12 -0
- package/lib/hbll-header/pipes/library-hours.pipe.d.ts +7 -0
- package/lib/header-with-impersonation/header-with-impersonation.component.d.ts +20 -0
- package/lib/impersonate-modal/impersonate-modal.component.d.ts +60 -0
- package/lib/impersonation-banner/impersonation-banner.component.d.ts +31 -0
- package/lib/impersonation-banner/models/application-access.d.ts +15 -0
- package/lib/impersonation-banner/models/person-summary.d.ts +33 -0
- package/lib/models/token-payload.d.ts +3 -0
- package/lib/{hbll-multi-select/hbll-multi-select.component.d.ts → multi-select/multi-select.component.d.ts} +1 -1
- package/lib/pipes/hbll-item-type-icon.pipe.d.ts +17 -0
- package/lib/ss-search-bar/advanced-search/advanced-search.component.d.ts +4 -1
- package/lib/utils.d.ts +5 -0
- package/package.json +4 -1
- package/public-api.d.ts +6 -0
- package/styles/scss/_mixins.scss +2 -2
- package/styles/scss/_vars.scss +7 -0
- package/styles/scss/base.scss +39 -7
- package/styles/scss/cta-btn.scss +2 -2
- package/styles/scss/pill-btn.scss +2 -2
- package/styles/scss/shared.scss +8 -0
- package/styles/scss/spinner.scss +20 -0
- package/esm2022/lib/hbll-checkbox/hbll-checkbox.component.mjs +0 -17
- package/esm2022/lib/hbll-multi-select/hbll-multi-select.component.mjs +0 -115
|
@@ -0,0 +1,333 @@
|
|
|
1
|
+
import { CommonModule } from '@angular/common';
|
|
2
|
+
import { Component, computed, inject, input, ViewChildren } from '@angular/core';
|
|
3
|
+
import { NavBarDropdownComponent } from '../nav-bar-dropdown/nav-bar-dropdown.component';
|
|
4
|
+
import { isScreenSmallSignal } from '../../utils';
|
|
5
|
+
import { BreakpointObserver } from '@angular/cdk/layout';
|
|
6
|
+
import * as i0 from "@angular/core";
|
|
7
|
+
import * as i1 from "@angular/common";
|
|
8
|
+
export class NavBarComponent {
|
|
9
|
+
constructor() {
|
|
10
|
+
this.bo = inject(BreakpointObserver);
|
|
11
|
+
this.mainSiteBaseUrl = input.required();
|
|
12
|
+
this.height = input(null);
|
|
13
|
+
// If any section opens up, close all others. Only one section open at a time.
|
|
14
|
+
this.handleDropdownOpenEvent = (title) => {
|
|
15
|
+
this.dropdownComps
|
|
16
|
+
.filter((comp) => comp.title() !== title)
|
|
17
|
+
.forEach((comp) => {
|
|
18
|
+
comp.closeDropdown();
|
|
19
|
+
});
|
|
20
|
+
};
|
|
21
|
+
this.isScreenSmall = isScreenSmallSignal(this.bo);
|
|
22
|
+
this.navInfos = computed(() => {
|
|
23
|
+
return [
|
|
24
|
+
{
|
|
25
|
+
title: 'Materials',
|
|
26
|
+
mainSection: {
|
|
27
|
+
title: 'Formats',
|
|
28
|
+
links: [
|
|
29
|
+
{ label: 'Articles', url: `${this.mainSiteBaseUrl()}/articles` },
|
|
30
|
+
{ label: 'Audio', url: `${this.mainSiteBaseUrl()}/audio` },
|
|
31
|
+
{ label: 'Books', url: `${this.mainSiteBaseUrl()}/books` },
|
|
32
|
+
{ label: 'Video', url: `${this.mainSiteBaseUrl()}/video` },
|
|
33
|
+
],
|
|
34
|
+
auxiliaryLink: {
|
|
35
|
+
label: 'See all formats',
|
|
36
|
+
url: `${this.mainSiteBaseUrl()}/formats`,
|
|
37
|
+
},
|
|
38
|
+
},
|
|
39
|
+
otherSections: [
|
|
40
|
+
{
|
|
41
|
+
title: 'Resource Collections',
|
|
42
|
+
links: [
|
|
43
|
+
{
|
|
44
|
+
label: 'Subject Area Collections',
|
|
45
|
+
url: `${this.mainSiteBaseUrl()}/collections`,
|
|
46
|
+
},
|
|
47
|
+
{ label: 'Databases', url: `${this.mainSiteBaseUrl()}/databases` },
|
|
48
|
+
{ label: 'Journals', url: `${this.mainSiteBaseUrl()}/journals` },
|
|
49
|
+
{
|
|
50
|
+
label: 'Theses & Dissertations',
|
|
51
|
+
url: `${this.mainSiteBaseUrl()}/theses-and-dissertations`,
|
|
52
|
+
},
|
|
53
|
+
],
|
|
54
|
+
},
|
|
55
|
+
{
|
|
56
|
+
title: 'Equipment',
|
|
57
|
+
links: [
|
|
58
|
+
{
|
|
59
|
+
label: 'Available for Checkout',
|
|
60
|
+
url: `${this.mainSiteBaseUrl()}/services?categories=available-for-checkout`,
|
|
61
|
+
},
|
|
62
|
+
{
|
|
63
|
+
label: 'Available with Reservation',
|
|
64
|
+
url: `${this.mainSiteBaseUrl()}/services?categories=available-via-reservation`,
|
|
65
|
+
},
|
|
66
|
+
{
|
|
67
|
+
label: 'Public Computers',
|
|
68
|
+
url: `${this.mainSiteBaseUrl()}/services/public-computers`,
|
|
69
|
+
},
|
|
70
|
+
{
|
|
71
|
+
label: 'Printers and Copying',
|
|
72
|
+
url: `${this.mainSiteBaseUrl()}/services?categories=printing-and-copying`,
|
|
73
|
+
},
|
|
74
|
+
],
|
|
75
|
+
},
|
|
76
|
+
],
|
|
77
|
+
},
|
|
78
|
+
{
|
|
79
|
+
title: 'Places',
|
|
80
|
+
mainSection: {
|
|
81
|
+
title: 'Popular Places',
|
|
82
|
+
links: [
|
|
83
|
+
{
|
|
84
|
+
label: 'Help Desks',
|
|
85
|
+
url: `${this.mainSiteBaseUrl()}/services/help-desks`,
|
|
86
|
+
},
|
|
87
|
+
{
|
|
88
|
+
label: 'Family History',
|
|
89
|
+
url: `${this.mainSiteBaseUrl()}/religion-family-history`,
|
|
90
|
+
},
|
|
91
|
+
{
|
|
92
|
+
label: 'Research and Writing Center',
|
|
93
|
+
url: `${this.mainSiteBaseUrl()}/services/research-and-writing-center`,
|
|
94
|
+
},
|
|
95
|
+
{
|
|
96
|
+
label: 'Special Collections',
|
|
97
|
+
url: `${this.mainSiteBaseUrl()}/special-collections`,
|
|
98
|
+
},
|
|
99
|
+
],
|
|
100
|
+
auxiliaryLink: {
|
|
101
|
+
label: 'View Floor Maps',
|
|
102
|
+
url: 'https://lib.byu.edu/floormaps',
|
|
103
|
+
},
|
|
104
|
+
},
|
|
105
|
+
otherSections: [
|
|
106
|
+
{
|
|
107
|
+
title: 'Spaces',
|
|
108
|
+
links: [
|
|
109
|
+
{
|
|
110
|
+
label: 'Collections & Archives',
|
|
111
|
+
url: `${this.mainSiteBaseUrl()}/services?categories=collections-and-archives`,
|
|
112
|
+
},
|
|
113
|
+
{
|
|
114
|
+
label: 'Group Study Spaces',
|
|
115
|
+
url: `${this.mainSiteBaseUrl()}/services/group-study-rooms`,
|
|
116
|
+
},
|
|
117
|
+
{
|
|
118
|
+
label: 'Individual Study Spaces',
|
|
119
|
+
url: `${this.mainSiteBaseUrl()}/services?categories=individual-study-spaces`,
|
|
120
|
+
},
|
|
121
|
+
{
|
|
122
|
+
label: 'Multimedia Creation Spaces',
|
|
123
|
+
url: `${this.mainSiteBaseUrl()}/services?categories=multimedia-creation`,
|
|
124
|
+
},
|
|
125
|
+
{
|
|
126
|
+
label: 'Video View Spaces',
|
|
127
|
+
url: `${this.mainSiteBaseUrl()}/services?categories=video-viewing`,
|
|
128
|
+
},
|
|
129
|
+
],
|
|
130
|
+
},
|
|
131
|
+
{
|
|
132
|
+
title: 'Rooms',
|
|
133
|
+
links: [
|
|
134
|
+
{
|
|
135
|
+
label: 'Classrooms',
|
|
136
|
+
url: `${this.mainSiteBaseUrl()}/services?categories=classrooms`,
|
|
137
|
+
},
|
|
138
|
+
{
|
|
139
|
+
label: 'Conference Rooms',
|
|
140
|
+
url: `${this.mainSiteBaseUrl()}/services?categories=conference-rooms`,
|
|
141
|
+
},
|
|
142
|
+
{
|
|
143
|
+
label: 'Labs & Centers',
|
|
144
|
+
url: `${this.mainSiteBaseUrl()}/services?categories=labs-and-centers`,
|
|
145
|
+
},
|
|
146
|
+
{
|
|
147
|
+
label: 'Research Rooms',
|
|
148
|
+
url: `${this.mainSiteBaseUrl()}/services?categories=research-rooms`,
|
|
149
|
+
},
|
|
150
|
+
],
|
|
151
|
+
},
|
|
152
|
+
],
|
|
153
|
+
},
|
|
154
|
+
{
|
|
155
|
+
title: 'Experiences',
|
|
156
|
+
mainSection: {
|
|
157
|
+
title: 'Events',
|
|
158
|
+
links: [
|
|
159
|
+
{
|
|
160
|
+
label: 'Concerts & Film Showings',
|
|
161
|
+
url: `${this.mainSiteBaseUrl()}/services/motion-picture-archive-series`,
|
|
162
|
+
},
|
|
163
|
+
{
|
|
164
|
+
label: 'Lectures',
|
|
165
|
+
url: `${this.mainSiteBaseUrl()}/services?categories=lectures`,
|
|
166
|
+
},
|
|
167
|
+
{ label: 'News', url: `${this.mainSiteBaseUrl()}/about/news` },
|
|
168
|
+
],
|
|
169
|
+
auxiliaryLink: {
|
|
170
|
+
label: 'See calendar of events',
|
|
171
|
+
url: `${this.mainSiteBaseUrl()}/events`,
|
|
172
|
+
},
|
|
173
|
+
},
|
|
174
|
+
otherSections: [
|
|
175
|
+
{
|
|
176
|
+
title: 'Learning Opportunities',
|
|
177
|
+
links: [
|
|
178
|
+
{
|
|
179
|
+
label: 'Library Instruction Classes',
|
|
180
|
+
url: `${this.mainSiteBaseUrl()}/library-instruction`,
|
|
181
|
+
},
|
|
182
|
+
{
|
|
183
|
+
label: 'Software Training',
|
|
184
|
+
url: `${this.mainSiteBaseUrl()}/services/software-training`,
|
|
185
|
+
},
|
|
186
|
+
{
|
|
187
|
+
label: 'Family History Classes & Webinars',
|
|
188
|
+
url: `${this.mainSiteBaseUrl()}/services/family-history-classes`,
|
|
189
|
+
},
|
|
190
|
+
],
|
|
191
|
+
},
|
|
192
|
+
{
|
|
193
|
+
title: 'Displays',
|
|
194
|
+
links: [
|
|
195
|
+
{ label: 'Exhibits', url: `${this.mainSiteBaseUrl()}/exhibits` },
|
|
196
|
+
{
|
|
197
|
+
label: 'Galleries',
|
|
198
|
+
url: `${this.mainSiteBaseUrl()}/services?categories=galleries-and-exhibits`,
|
|
199
|
+
},
|
|
200
|
+
],
|
|
201
|
+
},
|
|
202
|
+
],
|
|
203
|
+
},
|
|
204
|
+
{
|
|
205
|
+
title: 'Services',
|
|
206
|
+
mainSection: {
|
|
207
|
+
title: 'Services For',
|
|
208
|
+
links: [
|
|
209
|
+
{
|
|
210
|
+
label: 'Current Students',
|
|
211
|
+
url: `${this.mainSiteBaseUrl()}/services?categories=for-students`,
|
|
212
|
+
},
|
|
213
|
+
{
|
|
214
|
+
label: 'Faculty and Staff',
|
|
215
|
+
url: `${this.mainSiteBaseUrl()}/services?categories=for-faculty`,
|
|
216
|
+
},
|
|
217
|
+
{
|
|
218
|
+
label: 'Retirees',
|
|
219
|
+
url: `${this.mainSiteBaseUrl()}/services?categories=for-retirees`,
|
|
220
|
+
},
|
|
221
|
+
{
|
|
222
|
+
label: 'Visitors and Alumni',
|
|
223
|
+
url: `${this.mainSiteBaseUrl()}/services?categories=for-visitors`,
|
|
224
|
+
},
|
|
225
|
+
],
|
|
226
|
+
auxiliaryLink: {
|
|
227
|
+
label: 'See all Services',
|
|
228
|
+
url: `${this.mainSiteBaseUrl()}/services`,
|
|
229
|
+
},
|
|
230
|
+
},
|
|
231
|
+
otherSections: [
|
|
232
|
+
{
|
|
233
|
+
title: 'Getting Materials',
|
|
234
|
+
links: [
|
|
235
|
+
{
|
|
236
|
+
label: 'Checkout out Materials',
|
|
237
|
+
url: `${this.mainSiteBaseUrl()}/about/checkout-privileges`,
|
|
238
|
+
},
|
|
239
|
+
{
|
|
240
|
+
label: 'Holds & Renewals',
|
|
241
|
+
url: `${this.mainSiteBaseUrl()}/services/holds`,
|
|
242
|
+
},
|
|
243
|
+
{
|
|
244
|
+
label: 'Borrow from another Library (ILL)',
|
|
245
|
+
url: `${this.mainSiteBaseUrl()}/services/interlibrary-loan`,
|
|
246
|
+
},
|
|
247
|
+
],
|
|
248
|
+
},
|
|
249
|
+
{
|
|
250
|
+
title: 'Other',
|
|
251
|
+
links: [
|
|
252
|
+
{
|
|
253
|
+
label: 'Internships, Fellowships and Grants',
|
|
254
|
+
url: `${this.mainSiteBaseUrl()}/services?categories=internships-fellowships-grants`,
|
|
255
|
+
},
|
|
256
|
+
{
|
|
257
|
+
label: 'Programs',
|
|
258
|
+
url: `${this.mainSiteBaseUrl()}/services?categories=programs`,
|
|
259
|
+
},
|
|
260
|
+
{
|
|
261
|
+
label: 'Scholarly Publishing',
|
|
262
|
+
url: `${this.mainSiteBaseUrl()}/services?categories=creating-and-publishing-materials`,
|
|
263
|
+
},
|
|
264
|
+
],
|
|
265
|
+
},
|
|
266
|
+
],
|
|
267
|
+
},
|
|
268
|
+
{
|
|
269
|
+
title: 'Ask Us',
|
|
270
|
+
otherSections: [
|
|
271
|
+
{
|
|
272
|
+
title: 'Get Help',
|
|
273
|
+
links: [
|
|
274
|
+
{
|
|
275
|
+
label: 'Ask a Librarian',
|
|
276
|
+
url: `${this.mainSiteBaseUrl()}/chat?url=${window.location.href}`,
|
|
277
|
+
icon: 'chat_bubble',
|
|
278
|
+
},
|
|
279
|
+
{
|
|
280
|
+
label: 'Library Instruction',
|
|
281
|
+
url: `${this.mainSiteBaseUrl()}/library-instruction`,
|
|
282
|
+
},
|
|
283
|
+
{ label: 'Research Guides', url: `${this.mainSiteBaseUrl()}/guides` },
|
|
284
|
+
{
|
|
285
|
+
label: 'Help & Guidance',
|
|
286
|
+
url: `${this.mainSiteBaseUrl()}/services?categories=help-and-guidance`,
|
|
287
|
+
},
|
|
288
|
+
],
|
|
289
|
+
},
|
|
290
|
+
{
|
|
291
|
+
title: 'Find a...',
|
|
292
|
+
links: [
|
|
293
|
+
{ label: 'Department', url: `${this.mainSiteBaseUrl()}/directory` },
|
|
294
|
+
{
|
|
295
|
+
label: 'Help Desk',
|
|
296
|
+
url: `${this.mainSiteBaseUrl()}/services/help-desks`,
|
|
297
|
+
},
|
|
298
|
+
{
|
|
299
|
+
label: 'Library Employee by Name',
|
|
300
|
+
url: `${this.mainSiteBaseUrl()}/directory`,
|
|
301
|
+
},
|
|
302
|
+
{
|
|
303
|
+
label: 'Subject Librarian',
|
|
304
|
+
url: `${this.mainSiteBaseUrl()}/directory#browse-by-subject`,
|
|
305
|
+
},
|
|
306
|
+
],
|
|
307
|
+
},
|
|
308
|
+
{
|
|
309
|
+
title: 'About the Library',
|
|
310
|
+
links: [
|
|
311
|
+
{
|
|
312
|
+
label: 'General Information',
|
|
313
|
+
url: `${this.mainSiteBaseUrl()}/about`,
|
|
314
|
+
},
|
|
315
|
+
{ label: 'FAQs', url: `${this.mainSiteBaseUrl()}/faq` },
|
|
316
|
+
],
|
|
317
|
+
},
|
|
318
|
+
],
|
|
319
|
+
},
|
|
320
|
+
];
|
|
321
|
+
});
|
|
322
|
+
}
|
|
323
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.0", ngImport: i0, type: NavBarComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
324
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.1.0", type: NavBarComponent, isStandalone: true, selector: "lib-nav-bar", inputs: { mainSiteBaseUrl: { classPropertyName: "mainSiteBaseUrl", publicName: "mainSiteBaseUrl", isSignal: true, isRequired: true, transformFunction: null }, height: { classPropertyName: "height", publicName: "height", isSignal: true, isRequired: false, transformFunction: null } }, viewQueries: [{ propertyName: "dropdownComps", predicate: NavBarDropdownComponent, descendants: true }], ngImport: i0, template: "<nav\n [style]=\"{ height: height() ? height() + 'px' : 'auto' }\"\n [ngClass]=\"{ 'hbll-header-desktop': !isScreenSmall() }\"\n data-testid=\"nav\"\n>\n <ul class=\"hbll-header-nav-bar\">\n <li id=\"navHome\">\n <a [href]=\"mainSiteBaseUrl()\">\n @if (isScreenSmall()) {\n <span class=\"material-symbols-outlined hbll-header-icon\"> home </span>\n }\n Home\n </a>\n </li>\n @for (navInfo of navInfos(); track navInfo.title) {\n <li>\n <lib-nav-bar-dropdown\n [title]=\"navInfo.title\"\n [isSmallScreen]=\"isScreenSmall() ?? true\"\n (openEvent)=\"handleDropdownOpenEvent($event)\"\n >\n <div\n class=\"hbll-header-content\"\n [ngStyle]=\"{\n 'background-color': isScreenSmall() ? '#336cc8' : 'inherit',\n }\"\n >\n @if (navInfo.mainSection) {\n <section>\n <h2>{{ navInfo.mainSection.title }}</h2>\n <ul class=\"hbll-header-main hbll-header-links\">\n @for (link of navInfo.mainSection.links; track link.label) {\n <li>\n <a [href]=\"link.url\">\n {{ link.label }}\n </a>\n </li>\n }\n </ul>\n @if (navInfo.mainSection.auxiliaryLink) {\n <a\n class=\"hbll-header-see-all\"\n [href]=\"navInfo.mainSection.auxiliaryLink.url\"\n >\n {{ navInfo.mainSection.auxiliaryLink.label }}\n <span class=\"material-symbols-outlined hbll-header-icon\">\n chevron_right\n </span>\n </a>\n }\n </section>\n }\n @for (section of navInfo.otherSections; track section.title) {\n <section>\n <h3>{{ section.title }}</h3>\n <ul class=\"hbll-header-links\">\n @for (link of section.links; track link.label) {\n <li>\n <a [href]=\"link.url\">\n {{ link.label }}\n @if (link.icon) {\n <span\n class=\"material-symbols-outlined hbll-header-icon-right\"\n >\n {{ link.icon }}\n </span>\n }\n </a>\n </li>\n }\n </ul>\n </section>\n }\n </div>\n </lib-nav-bar-dropdown>\n </li>\n }\n <li>\n <a id=\"navSearch\" [href]=\"mainSiteBaseUrl() + '/search'\">\n @if (isScreenSmall()) {\n Search\n }\n <span\n class=\"material-symbols-outlined\"\n [ngClass]=\"{ 'hbll-header-icon': isScreenSmall() }\"\n >\n search\n </span>\n </a>\n </li>\n </ul>\n</nav>\n", styles: ["nav.hbll-header-desktop .hbll-header-nav-bar li#navHome a,nav.hbll-header-desktop .hbll-header-nav-bar li #navSearch{color:#002e5d;background-color:#fff;display:flex;justify-content:center;align-items:center;font-size:1.1em;font-weight:500;border:none;padding:.4em 1em;line-height:1.4em}nav.hbll-header-desktop .hbll-header-nav-bar li#navHome a .hbll-header-icon,nav.hbll-header-desktop .hbll-header-nav-bar li #navSearch .hbll-header-icon{font-size:1.3em;margin-bottom:-.1em}nav.hbll-header-desktop .hbll-header-nav-bar li#navHome a:hover,nav.hbll-header-desktop .hbll-header-nav-bar li #navSearch:hover{background-color:#0047ba;color:#fff}*{box-sizing:border-box;text-decoration:none;font-size:1em}*:not(.material-symbols-outlined){font-family:inherit}.hbll-header-icon-right{margin-left:.4em;font-size:1.2em}nav{background-color:#0047ba;position:absolute;overflow-y:scroll;overflow-x:hidden;scrollbar-width:none;width:100vw;max-width:400px;right:0}nav li{list-style-type:none}nav ::-webkit-scrollbar{display:none}nav .hbll-header-nav-bar{display:flex;flex-direction:column;align-items:flex-end;margin:0;padding:0}nav .hbll-header-nav-bar .hbll-header-links{padding:0}nav .hbll-header-nav-bar li{width:100%}nav .hbll-header-nav-bar li#navHome .hbll-header-icon{margin-right:.2em}nav .hbll-header-nav-bar li a{color:#fff;display:flex;align-items:center;width:100%;padding:.6em}nav .hbll-header-nav-bar li #navSearch{justify-content:flex-end;font-size:1.3em}nav .hbll-header-nav-bar li #navSearch .hbll-header-icon{margin-left:.2em}nav .hbll-header-nav-bar li .hbll-header-content{border-bottom:1px solid rgba(255,255,255,.3);padding-bottom:1.4em}nav .hbll-header-nav-bar li .hbll-header-content section{padding-left:3em}nav .hbll-header-nav-bar li .hbll-header-content section:first-of-type{padding-top:1em}nav .hbll-header-nav-bar li .hbll-header-content section h2,nav .hbll-header-nav-bar li .hbll-header-content section h3{font-weight:600;font-size:1.4em;margin-bottom:.4em}nav .hbll-header-nav-bar li .hbll-header-content section+section{margin-top:1.8em}nav .hbll-header-nav-bar li .hbll-header-content section li a{padding:.6em .8em;margin:.2em 0}nav .hbll-header-nav-bar li .hbll-header-content section .hbll-header-see-all{border-top:1px solid rgba(255,255,255,.3);justify-content:flex-end}nav .hbll-header-nav-bar li .hbll-header-content section .hbll-header-no-see-all{margin-bottom:1em}nav .hbll-header-nav-bar li .hbll-header-content section .hbll-header-main{padding-bottom:.4em}nav.hbll-header-desktop{overflow:initial;background-color:#fff;padding:0 2em;position:relative;max-width:100%}nav.hbll-header-desktop .hbll-header-nav-bar{flex-direction:row;align-items:center}nav.hbll-header-desktop .hbll-header-nav-bar .hbll-header-links{background-color:#0047ba;display:flex;flex-direction:column;align-items:flex-start}nav.hbll-header-desktop .hbll-header-nav-bar .hbll-header-links li{width:100%}nav.hbll-header-desktop .hbll-header-nav-bar .hbll-header-links li a{transition:background-color .1s ease-in-out}nav.hbll-header-desktop .hbll-header-nav-bar .hbll-header-links li a:hover{background-color:#fff3;width:100%}nav.hbll-header-desktop .hbll-header-nav-bar li{width:auto;height:100%}nav.hbll-header-desktop .hbll-header-nav-bar li #navSearch{transition:all .2s ease-in-out;font-size:1.2em;background-color:transparent}nav.hbll-header-desktop .hbll-header-nav-bar li #navSearch:hover{background-color:transparent;transform:scale(115%);color:#0047ba}nav.hbll-header-desktop .hbll-header-nav-bar li .hbll-header-content{display:flex;justify-content:center;padding-top:1.4em;padding-right:10%;padding-left:10%}nav.hbll-header-desktop .hbll-header-nav-bar li .hbll-header-content section{padding-top:0;padding-left:5%;width:30em}nav.hbll-header-desktop .hbll-header-nav-bar li .hbll-header-content section+section{border-left:1px solid rgba(255,255,255,.3);margin-top:0}nav.hbll-header-desktop .hbll-header-nav-bar li .hbll-header-content section .hbll-header-see-all{margin-right:1em;transition:color .1s ease-in-out;width:auto}nav.hbll-header-desktop .hbll-header-nav-bar li .hbll-header-content section .hbll-header-see-all:hover{color:#ffffffd9}nav.hbll-header-desktop .hbll-header-nav-bar li .hbll-header-content h2,nav.hbll-header-desktop .hbll-header-nav-bar li .hbll-header-content h3{color:#fff}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "component", type: NavBarDropdownComponent, selector: "lib-nav-bar-dropdown", inputs: ["title", "isSmallScreen"], outputs: ["openEvent"] }] }); }
|
|
325
|
+
}
|
|
326
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.0", ngImport: i0, type: NavBarComponent, decorators: [{
|
|
327
|
+
type: Component,
|
|
328
|
+
args: [{ selector: 'lib-nav-bar', standalone: true, imports: [CommonModule, NavBarDropdownComponent], template: "<nav\n [style]=\"{ height: height() ? height() + 'px' : 'auto' }\"\n [ngClass]=\"{ 'hbll-header-desktop': !isScreenSmall() }\"\n data-testid=\"nav\"\n>\n <ul class=\"hbll-header-nav-bar\">\n <li id=\"navHome\">\n <a [href]=\"mainSiteBaseUrl()\">\n @if (isScreenSmall()) {\n <span class=\"material-symbols-outlined hbll-header-icon\"> home </span>\n }\n Home\n </a>\n </li>\n @for (navInfo of navInfos(); track navInfo.title) {\n <li>\n <lib-nav-bar-dropdown\n [title]=\"navInfo.title\"\n [isSmallScreen]=\"isScreenSmall() ?? true\"\n (openEvent)=\"handleDropdownOpenEvent($event)\"\n >\n <div\n class=\"hbll-header-content\"\n [ngStyle]=\"{\n 'background-color': isScreenSmall() ? '#336cc8' : 'inherit',\n }\"\n >\n @if (navInfo.mainSection) {\n <section>\n <h2>{{ navInfo.mainSection.title }}</h2>\n <ul class=\"hbll-header-main hbll-header-links\">\n @for (link of navInfo.mainSection.links; track link.label) {\n <li>\n <a [href]=\"link.url\">\n {{ link.label }}\n </a>\n </li>\n }\n </ul>\n @if (navInfo.mainSection.auxiliaryLink) {\n <a\n class=\"hbll-header-see-all\"\n [href]=\"navInfo.mainSection.auxiliaryLink.url\"\n >\n {{ navInfo.mainSection.auxiliaryLink.label }}\n <span class=\"material-symbols-outlined hbll-header-icon\">\n chevron_right\n </span>\n </a>\n }\n </section>\n }\n @for (section of navInfo.otherSections; track section.title) {\n <section>\n <h3>{{ section.title }}</h3>\n <ul class=\"hbll-header-links\">\n @for (link of section.links; track link.label) {\n <li>\n <a [href]=\"link.url\">\n {{ link.label }}\n @if (link.icon) {\n <span\n class=\"material-symbols-outlined hbll-header-icon-right\"\n >\n {{ link.icon }}\n </span>\n }\n </a>\n </li>\n }\n </ul>\n </section>\n }\n </div>\n </lib-nav-bar-dropdown>\n </li>\n }\n <li>\n <a id=\"navSearch\" [href]=\"mainSiteBaseUrl() + '/search'\">\n @if (isScreenSmall()) {\n Search\n }\n <span\n class=\"material-symbols-outlined\"\n [ngClass]=\"{ 'hbll-header-icon': isScreenSmall() }\"\n >\n search\n </span>\n </a>\n </li>\n </ul>\n</nav>\n", styles: ["nav.hbll-header-desktop .hbll-header-nav-bar li#navHome a,nav.hbll-header-desktop .hbll-header-nav-bar li #navSearch{color:#002e5d;background-color:#fff;display:flex;justify-content:center;align-items:center;font-size:1.1em;font-weight:500;border:none;padding:.4em 1em;line-height:1.4em}nav.hbll-header-desktop .hbll-header-nav-bar li#navHome a .hbll-header-icon,nav.hbll-header-desktop .hbll-header-nav-bar li #navSearch .hbll-header-icon{font-size:1.3em;margin-bottom:-.1em}nav.hbll-header-desktop .hbll-header-nav-bar li#navHome a:hover,nav.hbll-header-desktop .hbll-header-nav-bar li #navSearch:hover{background-color:#0047ba;color:#fff}*{box-sizing:border-box;text-decoration:none;font-size:1em}*:not(.material-symbols-outlined){font-family:inherit}.hbll-header-icon-right{margin-left:.4em;font-size:1.2em}nav{background-color:#0047ba;position:absolute;overflow-y:scroll;overflow-x:hidden;scrollbar-width:none;width:100vw;max-width:400px;right:0}nav li{list-style-type:none}nav ::-webkit-scrollbar{display:none}nav .hbll-header-nav-bar{display:flex;flex-direction:column;align-items:flex-end;margin:0;padding:0}nav .hbll-header-nav-bar .hbll-header-links{padding:0}nav .hbll-header-nav-bar li{width:100%}nav .hbll-header-nav-bar li#navHome .hbll-header-icon{margin-right:.2em}nav .hbll-header-nav-bar li a{color:#fff;display:flex;align-items:center;width:100%;padding:.6em}nav .hbll-header-nav-bar li #navSearch{justify-content:flex-end;font-size:1.3em}nav .hbll-header-nav-bar li #navSearch .hbll-header-icon{margin-left:.2em}nav .hbll-header-nav-bar li .hbll-header-content{border-bottom:1px solid rgba(255,255,255,.3);padding-bottom:1.4em}nav .hbll-header-nav-bar li .hbll-header-content section{padding-left:3em}nav .hbll-header-nav-bar li .hbll-header-content section:first-of-type{padding-top:1em}nav .hbll-header-nav-bar li .hbll-header-content section h2,nav .hbll-header-nav-bar li .hbll-header-content section h3{font-weight:600;font-size:1.4em;margin-bottom:.4em}nav .hbll-header-nav-bar li .hbll-header-content section+section{margin-top:1.8em}nav .hbll-header-nav-bar li .hbll-header-content section li a{padding:.6em .8em;margin:.2em 0}nav .hbll-header-nav-bar li .hbll-header-content section .hbll-header-see-all{border-top:1px solid rgba(255,255,255,.3);justify-content:flex-end}nav .hbll-header-nav-bar li .hbll-header-content section .hbll-header-no-see-all{margin-bottom:1em}nav .hbll-header-nav-bar li .hbll-header-content section .hbll-header-main{padding-bottom:.4em}nav.hbll-header-desktop{overflow:initial;background-color:#fff;padding:0 2em;position:relative;max-width:100%}nav.hbll-header-desktop .hbll-header-nav-bar{flex-direction:row;align-items:center}nav.hbll-header-desktop .hbll-header-nav-bar .hbll-header-links{background-color:#0047ba;display:flex;flex-direction:column;align-items:flex-start}nav.hbll-header-desktop .hbll-header-nav-bar .hbll-header-links li{width:100%}nav.hbll-header-desktop .hbll-header-nav-bar .hbll-header-links li a{transition:background-color .1s ease-in-out}nav.hbll-header-desktop .hbll-header-nav-bar .hbll-header-links li a:hover{background-color:#fff3;width:100%}nav.hbll-header-desktop .hbll-header-nav-bar li{width:auto;height:100%}nav.hbll-header-desktop .hbll-header-nav-bar li #navSearch{transition:all .2s ease-in-out;font-size:1.2em;background-color:transparent}nav.hbll-header-desktop .hbll-header-nav-bar li #navSearch:hover{background-color:transparent;transform:scale(115%);color:#0047ba}nav.hbll-header-desktop .hbll-header-nav-bar li .hbll-header-content{display:flex;justify-content:center;padding-top:1.4em;padding-right:10%;padding-left:10%}nav.hbll-header-desktop .hbll-header-nav-bar li .hbll-header-content section{padding-top:0;padding-left:5%;width:30em}nav.hbll-header-desktop .hbll-header-nav-bar li .hbll-header-content section+section{border-left:1px solid rgba(255,255,255,.3);margin-top:0}nav.hbll-header-desktop .hbll-header-nav-bar li .hbll-header-content section .hbll-header-see-all{margin-right:1em;transition:color .1s ease-in-out;width:auto}nav.hbll-header-desktop .hbll-header-nav-bar li .hbll-header-content section .hbll-header-see-all:hover{color:#ffffffd9}nav.hbll-header-desktop .hbll-header-nav-bar li .hbll-header-content h2,nav.hbll-header-desktop .hbll-header-nav-bar li .hbll-header-content h3{color:#fff}\n"] }]
|
|
329
|
+
}], propDecorators: { dropdownComps: [{
|
|
330
|
+
type: ViewChildren,
|
|
331
|
+
args: [NavBarDropdownComponent]
|
|
332
|
+
}] } });
|
|
333
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"nav-bar.component.js","sourceRoot":"","sources":["../../../../../../projects/components/src/lib/hbll-header/nav-bar/nav-bar.component.ts","../../../../../../projects/components/src/lib/hbll-header/nav-bar/nav-bar.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport { Component, computed, inject, input, Signal, ViewChildren } from '@angular/core';\nimport { NavBarDropdownComponent } from '../nav-bar-dropdown/nav-bar-dropdown.component';\nimport { isScreenSmallSignal } from '../../utils';\nimport { BreakpointObserver } from '@angular/cdk/layout';\n\ntype NavInfo = {\n    title: string;\n    mainSection?: Section;\n    otherSections: Section[];\n};\n\ntype Section = {\n    title: string;\n    links: Link[];\n    auxiliaryLink?: Link;\n};\n\ntype Link = {\n    label: string;\n    url: string;\n    icon?: string;\n};\n\n@Component({\n    selector: 'lib-nav-bar',\n    standalone: true,\n    imports: [CommonModule, NavBarDropdownComponent],\n    templateUrl: './nav-bar.component.html',\n    styleUrl: './nav-bar.component.scss',\n})\nexport class NavBarComponent {\n    private bo = inject(BreakpointObserver);\n    mainSiteBaseUrl = input.required<string>();\n    height = input<number | null>(null);\n\n    @ViewChildren(NavBarDropdownComponent) dropdownComps!: NavBarDropdownComponent[];\n\n    // If any section opens up, close all others. Only one section open at a time.\n    protected handleDropdownOpenEvent = (title: string) => {\n        this.dropdownComps\n            .filter((comp) => comp.title() !== title)\n            .forEach((comp) => {\n                comp.closeDropdown();\n            });\n    };\n\n    protected isScreenSmall = isScreenSmallSignal(this.bo);\n\n    protected navInfos: Signal<NavInfo[]> = computed(() => {\n        return [\n            {\n                title: 'Materials',\n                mainSection: {\n                    title: 'Formats',\n                    links: [\n                        { label: 'Articles', url: `${this.mainSiteBaseUrl()}/articles` },\n                        { label: 'Audio', url: `${this.mainSiteBaseUrl()}/audio` },\n                        { label: 'Books', url: `${this.mainSiteBaseUrl()}/books` },\n                        { label: 'Video', url: `${this.mainSiteBaseUrl()}/video` },\n                    ],\n                    auxiliaryLink: {\n                        label: 'See all formats',\n                        url: `${this.mainSiteBaseUrl()}/formats`,\n                    },\n                },\n                otherSections: [\n                    {\n                        title: 'Resource Collections',\n                        links: [\n                            {\n                                label: 'Subject Area Collections',\n                                url: `${this.mainSiteBaseUrl()}/collections`,\n                            },\n                            { label: 'Databases', url: `${this.mainSiteBaseUrl()}/databases` },\n                            { label: 'Journals', url: `${this.mainSiteBaseUrl()}/journals` },\n                            {\n                                label: 'Theses & Dissertations',\n                                url: `${this.mainSiteBaseUrl()}/theses-and-dissertations`,\n                            },\n                        ],\n                    },\n                    {\n                        title: 'Equipment',\n                        links: [\n                            {\n                                label: 'Available for Checkout',\n                                url: `${this.mainSiteBaseUrl()}/services?categories=available-for-checkout`,\n                            },\n                            {\n                                label: 'Available with Reservation',\n                                url: `${this.mainSiteBaseUrl()}/services?categories=available-via-reservation`,\n                            },\n                            {\n                                label: 'Public Computers',\n                                url: `${this.mainSiteBaseUrl()}/services/public-computers`,\n                            },\n                            {\n                                label: 'Printers and Copying',\n                                url: `${this.mainSiteBaseUrl()}/services?categories=printing-and-copying`,\n                            },\n                        ],\n                    },\n                ],\n            },\n            {\n                title: 'Places',\n                mainSection: {\n                    title: 'Popular Places',\n                    links: [\n                        {\n                            label: 'Help Desks',\n                            url: `${this.mainSiteBaseUrl()}/services/help-desks`,\n                        },\n                        {\n                            label: 'Family History',\n                            url: `${this.mainSiteBaseUrl()}/religion-family-history`,\n                        },\n                        {\n                            label: 'Research and Writing Center',\n                            url: `${this.mainSiteBaseUrl()}/services/research-and-writing-center`,\n                        },\n                        {\n                            label: 'Special Collections',\n                            url: `${this.mainSiteBaseUrl()}/special-collections`,\n                        },\n                    ],\n                    auxiliaryLink: {\n                        label: 'View Floor Maps',\n                        url: 'https://lib.byu.edu/floormaps',\n                    },\n                },\n                otherSections: [\n                    {\n                        title: 'Spaces',\n                        links: [\n                            {\n                                label: 'Collections & Archives',\n                                url: `${this.mainSiteBaseUrl()}/services?categories=collections-and-archives`,\n                            },\n                            {\n                                label: 'Group Study Spaces',\n                                url: `${this.mainSiteBaseUrl()}/services/group-study-rooms`,\n                            },\n                            {\n                                label: 'Individual Study Spaces',\n                                url: `${this.mainSiteBaseUrl()}/services?categories=individual-study-spaces`,\n                            },\n                            {\n                                label: 'Multimedia Creation Spaces',\n                                url: `${this.mainSiteBaseUrl()}/services?categories=multimedia-creation`,\n                            },\n                            {\n                                label: 'Video View Spaces',\n                                url: `${this.mainSiteBaseUrl()}/services?categories=video-viewing`,\n                            },\n                        ],\n                    },\n                    {\n                        title: 'Rooms',\n                        links: [\n                            {\n                                label: 'Classrooms',\n                                url: `${this.mainSiteBaseUrl()}/services?categories=classrooms`,\n                            },\n                            {\n                                label: 'Conference Rooms',\n                                url: `${this.mainSiteBaseUrl()}/services?categories=conference-rooms`,\n                            },\n                            {\n                                label: 'Labs & Centers',\n                                url: `${this.mainSiteBaseUrl()}/services?categories=labs-and-centers`,\n                            },\n                            {\n                                label: 'Research Rooms',\n                                url: `${this.mainSiteBaseUrl()}/services?categories=research-rooms`,\n                            },\n                        ],\n                    },\n                ],\n            },\n            {\n                title: 'Experiences',\n                mainSection: {\n                    title: 'Events',\n                    links: [\n                        {\n                            label: 'Concerts & Film Showings',\n                            url: `${this.mainSiteBaseUrl()}/services/motion-picture-archive-series`,\n                        },\n                        {\n                            label: 'Lectures',\n                            url: `${this.mainSiteBaseUrl()}/services?categories=lectures`,\n                        },\n                        { label: 'News', url: `${this.mainSiteBaseUrl()}/about/news` },\n                    ],\n                    auxiliaryLink: {\n                        label: 'See calendar of events',\n                        url: `${this.mainSiteBaseUrl()}/events`,\n                    },\n                },\n                otherSections: [\n                    {\n                        title: 'Learning Opportunities',\n                        links: [\n                            {\n                                label: 'Library Instruction Classes',\n                                url: `${this.mainSiteBaseUrl()}/library-instruction`,\n                            },\n                            {\n                                label: 'Software Training',\n                                url: `${this.mainSiteBaseUrl()}/services/software-training`,\n                            },\n                            {\n                                label: 'Family History Classes & Webinars',\n                                url: `${this.mainSiteBaseUrl()}/services/family-history-classes`,\n                            },\n                        ],\n                    },\n                    {\n                        title: 'Displays',\n                        links: [\n                            { label: 'Exhibits', url: `${this.mainSiteBaseUrl()}/exhibits` },\n                            {\n                                label: 'Galleries',\n                                url: `${this.mainSiteBaseUrl()}/services?categories=galleries-and-exhibits`,\n                            },\n                        ],\n                    },\n                ],\n            },\n            {\n                title: 'Services',\n                mainSection: {\n                    title: 'Services For',\n                    links: [\n                        {\n                            label: 'Current Students',\n                            url: `${this.mainSiteBaseUrl()}/services?categories=for-students`,\n                        },\n                        {\n                            label: 'Faculty and Staff',\n                            url: `${this.mainSiteBaseUrl()}/services?categories=for-faculty`,\n                        },\n                        {\n                            label: 'Retirees',\n                            url: `${this.mainSiteBaseUrl()}/services?categories=for-retirees`,\n                        },\n                        {\n                            label: 'Visitors and Alumni',\n                            url: `${this.mainSiteBaseUrl()}/services?categories=for-visitors`,\n                        },\n                    ],\n                    auxiliaryLink: {\n                        label: 'See all Services',\n                        url: `${this.mainSiteBaseUrl()}/services`,\n                    },\n                },\n                otherSections: [\n                    {\n                        title: 'Getting Materials',\n                        links: [\n                            {\n                                label: 'Checkout out Materials',\n                                url: `${this.mainSiteBaseUrl()}/about/checkout-privileges`,\n                            },\n                            {\n                                label: 'Holds & Renewals',\n                                url: `${this.mainSiteBaseUrl()}/services/holds`,\n                            },\n                            {\n                                label: 'Borrow from another Library (ILL)',\n                                url: `${this.mainSiteBaseUrl()}/services/interlibrary-loan`,\n                            },\n                        ],\n                    },\n                    {\n                        title: 'Other',\n                        links: [\n                            {\n                                label: 'Internships, Fellowships and Grants',\n                                url: `${this.mainSiteBaseUrl()}/services?categories=internships-fellowships-grants`,\n                            },\n                            {\n                                label: 'Programs',\n                                url: `${this.mainSiteBaseUrl()}/services?categories=programs`,\n                            },\n                            {\n                                label: 'Scholarly Publishing',\n                                url: `${this.mainSiteBaseUrl()}/services?categories=creating-and-publishing-materials`,\n                            },\n                        ],\n                    },\n                ],\n            },\n            {\n                title: 'Ask Us',\n\n                otherSections: [\n                    {\n                        title: 'Get Help',\n                        links: [\n                            {\n                                label: 'Ask a Librarian',\n                                url: `${this.mainSiteBaseUrl()}/chat?url=${window.location.href}`,\n                                icon: 'chat_bubble',\n                            },\n                            {\n                                label: 'Library Instruction',\n                                url: `${this.mainSiteBaseUrl()}/library-instruction`,\n                            },\n                            { label: 'Research Guides', url: `${this.mainSiteBaseUrl()}/guides` },\n                            {\n                                label: 'Help & Guidance',\n                                url: `${this.mainSiteBaseUrl()}/services?categories=help-and-guidance`,\n                            },\n                        ],\n                    },\n                    {\n                        title: 'Find a...',\n                        links: [\n                            { label: 'Department', url: `${this.mainSiteBaseUrl()}/directory` },\n                            {\n                                label: 'Help Desk',\n                                url: `${this.mainSiteBaseUrl()}/services/help-desks`,\n                            },\n                            {\n                                label: 'Library Employee by Name',\n                                url: `${this.mainSiteBaseUrl()}/directory`,\n                            },\n                            {\n                                label: 'Subject Librarian',\n                                url: `${this.mainSiteBaseUrl()}/directory#browse-by-subject`,\n                            },\n                        ],\n                    },\n                    {\n                        title: 'About the Library',\n                        links: [\n                            {\n                                label: 'General Information',\n                                url: `${this.mainSiteBaseUrl()}/about`,\n                            },\n                            { label: 'FAQs', url: `${this.mainSiteBaseUrl()}/faq` },\n                        ],\n                    },\n                ],\n            },\n        ];\n    });\n}\n","<nav\n    [style]=\"{ height: height() ? height() + 'px' : 'auto' }\"\n    [ngClass]=\"{ 'hbll-header-desktop': !isScreenSmall() }\"\n    data-testid=\"nav\"\n>\n    <ul class=\"hbll-header-nav-bar\">\n        <li id=\"navHome\">\n            <a [href]=\"mainSiteBaseUrl()\">\n                @if (isScreenSmall()) {\n                    <span class=\"material-symbols-outlined hbll-header-icon\"> home </span>\n                }\n                Home\n            </a>\n        </li>\n        @for (navInfo of navInfos(); track navInfo.title) {\n            <li>\n                <lib-nav-bar-dropdown\n                    [title]=\"navInfo.title\"\n                    [isSmallScreen]=\"isScreenSmall() ?? true\"\n                    (openEvent)=\"handleDropdownOpenEvent($event)\"\n                >\n                    <div\n                        class=\"hbll-header-content\"\n                        [ngStyle]=\"{\n                            'background-color': isScreenSmall() ? '#336cc8' : 'inherit',\n                        }\"\n                    >\n                        @if (navInfo.mainSection) {\n                            <section>\n                                <h2>{{ navInfo.mainSection.title }}</h2>\n                                <ul class=\"hbll-header-main hbll-header-links\">\n                                    @for (link of navInfo.mainSection.links; track link.label) {\n                                        <li>\n                                            <a [href]=\"link.url\">\n                                                {{ link.label }}\n                                            </a>\n                                        </li>\n                                    }\n                                </ul>\n                                @if (navInfo.mainSection.auxiliaryLink) {\n                                    <a\n                                        class=\"hbll-header-see-all\"\n                                        [href]=\"navInfo.mainSection.auxiliaryLink.url\"\n                                    >\n                                        {{ navInfo.mainSection.auxiliaryLink.label }}\n                                        <span class=\"material-symbols-outlined hbll-header-icon\">\n                                            chevron_right\n                                        </span>\n                                    </a>\n                                }\n                            </section>\n                        }\n                        @for (section of navInfo.otherSections; track section.title) {\n                            <section>\n                                <h3>{{ section.title }}</h3>\n                                <ul class=\"hbll-header-links\">\n                                    @for (link of section.links; track link.label) {\n                                        <li>\n                                            <a [href]=\"link.url\">\n                                                {{ link.label }}\n                                                @if (link.icon) {\n                                                    <span\n                                                        class=\"material-symbols-outlined hbll-header-icon-right\"\n                                                    >\n                                                        {{ link.icon }}\n                                                    </span>\n                                                }\n                                            </a>\n                                        </li>\n                                    }\n                                </ul>\n                            </section>\n                        }\n                    </div>\n                </lib-nav-bar-dropdown>\n            </li>\n        }\n        <li>\n            <a id=\"navSearch\" [href]=\"mainSiteBaseUrl() + '/search'\">\n                @if (isScreenSmall()) {\n                    Search\n                }\n                <span\n                    class=\"material-symbols-outlined\"\n                    [ngClass]=\"{ 'hbll-header-icon': isScreenSmall() }\"\n                >\n                    search\n                </span>\n            </a>\n        </li>\n    </ul>\n</nav>\n"]}
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
import { Component, EventEmitter, input, Output } from '@angular/core';
|
|
2
|
+
import { CommonModule } from '@angular/common';
|
|
3
|
+
import { ExpandCollapseComponent } from '../../expand-collapse/expand-collapse.component';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
import * as i1 from "@angular/common";
|
|
6
|
+
export class NavBarDropdownComponent {
|
|
7
|
+
constructor() {
|
|
8
|
+
this.title = input.required();
|
|
9
|
+
this.isSmallScreen = input(true);
|
|
10
|
+
this.openEvent = new EventEmitter();
|
|
11
|
+
// Public to be called by parent comp.
|
|
12
|
+
this.closeDropdown = () => (this.isOpen = false);
|
|
13
|
+
this.isOpen = false;
|
|
14
|
+
this.handleClick = () => {
|
|
15
|
+
if (!this.isOpen)
|
|
16
|
+
this.openEvent.emit(this.title());
|
|
17
|
+
this.isOpen = !this.isOpen;
|
|
18
|
+
};
|
|
19
|
+
}
|
|
20
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.0", ngImport: i0, type: NavBarDropdownComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
21
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.1.0", type: NavBarDropdownComponent, isStandalone: true, selector: "lib-nav-bar-dropdown", inputs: { title: { classPropertyName: "title", publicName: "title", isSignal: true, isRequired: true, transformFunction: null }, isSmallScreen: { classPropertyName: "isSmallScreen", publicName: "isSmallScreen", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { openEvent: "openEvent" }, ngImport: i0, template: "<span\n class=\"hbll-header-dropdown-wrapper\"\n data-testid=\"wrapper\"\n [ngClass]=\"{ 'hbll-header-desktop': !isSmallScreen() }\"\n (mouseenter)=\"!isSmallScreen() && (this.isOpen = true)\"\n (mouseleave)=\"!isSmallScreen() && (this.isOpen = false)\"\n>\n <button (click)=\"handleClick()\" data-testid=\"btn\">\n {{ title() }}\n <span class=\"material-symbols-outlined hbll-header-icon\">\n {{ 'keyboard_arrow_' + (isOpen ? 'up' : 'down') }}\n </span>\n </button>\n @if (!isSmallScreen()) {\n @if (isOpen) {\n <div class=\"hbll-header-dropdown\" data-testid=\"dropdown\">\n <ng-container *ngTemplateOutlet=\"content\"></ng-container>\n </div>\n }\n } @else {\n <lib-expand-collapse [isExpanded]=\"isOpen\">\n <ng-container *ngTemplateOutlet=\"content\"></ng-container>\n </lib-expand-collapse>\n }\n</span>\n\n<ng-template #content>\n <ng-content></ng-content>\n</ng-template>\n", styles: [".hbll-header-dropdown-wrapper.hbll-header-desktop button{color:#002e5d;background-color:#fff;display:flex;justify-content:center;align-items:center;font-size:1.1em;font-weight:500;border:none;padding:.4em 1em;line-height:1.4em}.hbll-header-dropdown-wrapper.hbll-header-desktop button .hbll-header-icon{font-size:1.3em;margin-bottom:-.1em}.hbll-header-dropdown-wrapper.hbll-header-desktop button:hover{background-color:#0047ba;color:#fff}*{box-sizing:border-box;text-decoration:none;font-size:1em}*:not(.material-symbols-outlined){font-family:inherit}.hbll-header-dropdown-wrapper button{justify-content:flex-end;font-size:1.3em;color:#fff;display:flex;align-items:center;background-color:#0047ba;width:100%;padding:.6em;border-bottom:1px solid rgba(255,255,255,.3);border-left:none;border-right:none;border-top:none;white-space:nowrap;cursor:pointer}.hbll-header-dropdown-wrapper button .hbll-header-icon{margin-left:.2em}.hbll-header-dropdown-wrapper.hbll-header-desktop:hover button{background-color:#0047ba;color:#fff}.hbll-header-dropdown-wrapper.hbll-header-desktop .hbll-header-dropdown{position:absolute;z-index:11;width:100%;top:100%;left:0;background-color:#0047ba}\n"], dependencies: [{ kind: "component", type: ExpandCollapseComponent, selector: "lib-expand-collapse", inputs: ["isExpanded"] }, { kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }] }); }
|
|
22
|
+
}
|
|
23
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.0", ngImport: i0, type: NavBarDropdownComponent, decorators: [{
|
|
24
|
+
type: Component,
|
|
25
|
+
args: [{ selector: 'lib-nav-bar-dropdown', standalone: true, imports: [ExpandCollapseComponent, CommonModule], template: "<span\n class=\"hbll-header-dropdown-wrapper\"\n data-testid=\"wrapper\"\n [ngClass]=\"{ 'hbll-header-desktop': !isSmallScreen() }\"\n (mouseenter)=\"!isSmallScreen() && (this.isOpen = true)\"\n (mouseleave)=\"!isSmallScreen() && (this.isOpen = false)\"\n>\n <button (click)=\"handleClick()\" data-testid=\"btn\">\n {{ title() }}\n <span class=\"material-symbols-outlined hbll-header-icon\">\n {{ 'keyboard_arrow_' + (isOpen ? 'up' : 'down') }}\n </span>\n </button>\n @if (!isSmallScreen()) {\n @if (isOpen) {\n <div class=\"hbll-header-dropdown\" data-testid=\"dropdown\">\n <ng-container *ngTemplateOutlet=\"content\"></ng-container>\n </div>\n }\n } @else {\n <lib-expand-collapse [isExpanded]=\"isOpen\">\n <ng-container *ngTemplateOutlet=\"content\"></ng-container>\n </lib-expand-collapse>\n }\n</span>\n\n<ng-template #content>\n <ng-content></ng-content>\n</ng-template>\n", styles: [".hbll-header-dropdown-wrapper.hbll-header-desktop button{color:#002e5d;background-color:#fff;display:flex;justify-content:center;align-items:center;font-size:1.1em;font-weight:500;border:none;padding:.4em 1em;line-height:1.4em}.hbll-header-dropdown-wrapper.hbll-header-desktop button .hbll-header-icon{font-size:1.3em;margin-bottom:-.1em}.hbll-header-dropdown-wrapper.hbll-header-desktop button:hover{background-color:#0047ba;color:#fff}*{box-sizing:border-box;text-decoration:none;font-size:1em}*:not(.material-symbols-outlined){font-family:inherit}.hbll-header-dropdown-wrapper button{justify-content:flex-end;font-size:1.3em;color:#fff;display:flex;align-items:center;background-color:#0047ba;width:100%;padding:.6em;border-bottom:1px solid rgba(255,255,255,.3);border-left:none;border-right:none;border-top:none;white-space:nowrap;cursor:pointer}.hbll-header-dropdown-wrapper button .hbll-header-icon{margin-left:.2em}.hbll-header-dropdown-wrapper.hbll-header-desktop:hover button{background-color:#0047ba;color:#fff}.hbll-header-dropdown-wrapper.hbll-header-desktop .hbll-header-dropdown{position:absolute;z-index:11;width:100%;top:100%;left:0;background-color:#0047ba}\n"] }]
|
|
26
|
+
}], propDecorators: { openEvent: [{
|
|
27
|
+
type: Output
|
|
28
|
+
}] } });
|
|
29
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmF2LWJhci1kcm9wZG93bi5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb21wb25lbnRzL3NyYy9saWIvaGJsbC1oZWFkZXIvbmF2LWJhci1kcm9wZG93bi9uYXYtYmFyLWRyb3Bkb3duLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NvbXBvbmVudHMvc3JjL2xpYi9oYmxsLWhlYWRlci9uYXYtYmFyLWRyb3Bkb3duL25hdi1iYXItZHJvcGRvd24uY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxZQUFZLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN2RSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLHVCQUF1QixFQUFFLE1BQU0saURBQWlELENBQUM7OztBQVMxRixNQUFNLE9BQU8sdUJBQXVCO0lBUHBDO1FBUUksVUFBSyxHQUFHLEtBQUssQ0FBQyxRQUFRLEVBQVUsQ0FBQztRQUNqQyxrQkFBYSxHQUFHLEtBQUssQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUNsQixjQUFTLEdBQUcsSUFBSSxZQUFZLEVBQVUsQ0FBQztRQUVqRCxzQ0FBc0M7UUFDdEMsa0JBQWEsR0FBRyxHQUFHLEVBQUUsQ0FBQyxDQUFDLElBQUksQ0FBQyxNQUFNLEdBQUcsS0FBSyxDQUFDLENBQUM7UUFFbEMsV0FBTSxHQUFHLEtBQUssQ0FBQztRQUNmLGdCQUFXLEdBQUcsR0FBRyxFQUFFO1lBQ3pCLElBQUksQ0FBQyxJQUFJLENBQUMsTUFBTTtnQkFBRSxJQUFJLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsS0FBSyxFQUFFLENBQUMsQ0FBQztZQUNwRCxJQUFJLENBQUMsTUFBTSxHQUFHLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQztRQUMvQixDQUFDLENBQUM7S0FDTDs4R0FiWSx1QkFBdUI7a0dBQXZCLHVCQUF1Qix3WUNYcEMsZ2dDQTZCQSxrdENEdEJjLHVCQUF1Qix1RkFBRSxZQUFZOzsyRkFJdEMsdUJBQXVCO2tCQVBuQyxTQUFTOytCQUNJLHNCQUFzQixjQUNwQixJQUFJLFdBQ1AsQ0FBQyx1QkFBdUIsRUFBRSxZQUFZLENBQUM7OEJBT3RDLFNBQVM7c0JBQWxCLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIEV2ZW50RW1pdHRlciwgaW5wdXQsIE91dHB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IEV4cGFuZENvbGxhcHNlQ29tcG9uZW50IH0gZnJvbSAnLi4vLi4vZXhwYW5kLWNvbGxhcHNlL2V4cGFuZC1jb2xsYXBzZS5jb21wb25lbnQnO1xuXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogJ2xpYi1uYXYtYmFyLWRyb3Bkb3duJyxcbiAgICBzdGFuZGFsb25lOiB0cnVlLFxuICAgIGltcG9ydHM6IFtFeHBhbmRDb2xsYXBzZUNvbXBvbmVudCwgQ29tbW9uTW9kdWxlXSxcbiAgICB0ZW1wbGF0ZVVybDogJy4vbmF2LWJhci1kcm9wZG93bi5jb21wb25lbnQuaHRtbCcsXG4gICAgc3R5bGVVcmw6ICcuL25hdi1iYXItZHJvcGRvd24uY29tcG9uZW50LnNjc3MnLFxufSlcbmV4cG9ydCBjbGFzcyBOYXZCYXJEcm9wZG93bkNvbXBvbmVudCB7XG4gICAgdGl0bGUgPSBpbnB1dC5yZXF1aXJlZDxzdHJpbmc+KCk7XG4gICAgaXNTbWFsbFNjcmVlbiA9IGlucHV0KHRydWUpO1xuICAgIEBPdXRwdXQoKSBvcGVuRXZlbnQgPSBuZXcgRXZlbnRFbWl0dGVyPHN0cmluZz4oKTtcblxuICAgIC8vIFB1YmxpYyB0byBiZSBjYWxsZWQgYnkgcGFyZW50IGNvbXAuXG4gICAgY2xvc2VEcm9wZG93biA9ICgpID0+ICh0aGlzLmlzT3BlbiA9IGZhbHNlKTtcblxuICAgIHByb3RlY3RlZCBpc09wZW4gPSBmYWxzZTtcbiAgICBwcm90ZWN0ZWQgaGFuZGxlQ2xpY2sgPSAoKSA9PiB7XG4gICAgICAgIGlmICghdGhpcy5pc09wZW4pIHRoaXMub3BlbkV2ZW50LmVtaXQodGhpcy50aXRsZSgpKTtcbiAgICAgICAgdGhpcy5pc09wZW4gPSAhdGhpcy5pc09wZW47XG4gICAgfTtcbn1cbiIsIjxzcGFuXG4gICAgY2xhc3M9XCJoYmxsLWhlYWRlci1kcm9wZG93bi13cmFwcGVyXCJcbiAgICBkYXRhLXRlc3RpZD1cIndyYXBwZXJcIlxuICAgIFtuZ0NsYXNzXT1cInsgJ2hibGwtaGVhZGVyLWRlc2t0b3AnOiAhaXNTbWFsbFNjcmVlbigpIH1cIlxuICAgIChtb3VzZWVudGVyKT1cIiFpc1NtYWxsU2NyZWVuKCkgJiYgKHRoaXMuaXNPcGVuID0gdHJ1ZSlcIlxuICAgIChtb3VzZWxlYXZlKT1cIiFpc1NtYWxsU2NyZWVuKCkgJiYgKHRoaXMuaXNPcGVuID0gZmFsc2UpXCJcbj5cbiAgICA8YnV0dG9uIChjbGljayk9XCJoYW5kbGVDbGljaygpXCIgZGF0YS10ZXN0aWQ9XCJidG5cIj5cbiAgICAgICAge3sgdGl0bGUoKSB9fVxuICAgICAgICA8c3BhbiBjbGFzcz1cIm1hdGVyaWFsLXN5bWJvbHMtb3V0bGluZWQgaGJsbC1oZWFkZXItaWNvblwiPlxuICAgICAgICAgICAge3sgJ2tleWJvYXJkX2Fycm93XycgKyAoaXNPcGVuID8gJ3VwJyA6ICdkb3duJykgfX1cbiAgICAgICAgPC9zcGFuPlxuICAgIDwvYnV0dG9uPlxuICAgIEBpZiAoIWlzU21hbGxTY3JlZW4oKSkge1xuICAgICAgICBAaWYgKGlzT3Blbikge1xuICAgICAgICAgICAgPGRpdiBjbGFzcz1cImhibGwtaGVhZGVyLWRyb3Bkb3duXCIgZGF0YS10ZXN0aWQ9XCJkcm9wZG93blwiPlxuICAgICAgICAgICAgICAgIDxuZy1jb250YWluZXIgKm5nVGVtcGxhdGVPdXRsZXQ9XCJjb250ZW50XCI+PC9uZy1jb250YWluZXI+XG4gICAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgfVxuICAgIH0gQGVsc2Uge1xuICAgICAgICA8bGliLWV4cGFuZC1jb2xsYXBzZSBbaXNFeHBhbmRlZF09XCJpc09wZW5cIj5cbiAgICAgICAgICAgIDxuZy1jb250YWluZXIgKm5nVGVtcGxhdGVPdXRsZXQ9XCJjb250ZW50XCI+PC9uZy1jb250YWluZXI+XG4gICAgICAgIDwvbGliLWV4cGFuZC1jb2xsYXBzZT5cbiAgICB9XG48L3NwYW4+XG5cbjxuZy10ZW1wbGF0ZSAjY29udGVudD5cbiAgICA8bmctY29udGVudD48L25nLWNvbnRlbnQ+XG48L25nLXRlbXBsYXRlPlxuIl19
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
import { DatePipe } from '@angular/common';
|
|
2
|
+
import { Pipe } from '@angular/core';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
export class LibraryHoursPipe {
|
|
5
|
+
transform(date, time) {
|
|
6
|
+
let newTime = null;
|
|
7
|
+
try {
|
|
8
|
+
newTime = new DatePipe('en-US').transform(new Date(date + 'T' + time), 'ha');
|
|
9
|
+
}
|
|
10
|
+
catch (e) {
|
|
11
|
+
return newTime;
|
|
12
|
+
}
|
|
13
|
+
if (newTime === '12AM')
|
|
14
|
+
newTime = 'Midnight';
|
|
15
|
+
else if (newTime) {
|
|
16
|
+
newTime = newTime.replace('AM', ' a.m.');
|
|
17
|
+
newTime = newTime.replace('PM', ' p.m.');
|
|
18
|
+
}
|
|
19
|
+
return newTime;
|
|
20
|
+
}
|
|
21
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.0", ngImport: i0, type: LibraryHoursPipe, deps: [], target: i0.ɵɵFactoryTarget.Pipe }); }
|
|
22
|
+
static { this.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "18.1.0", ngImport: i0, type: LibraryHoursPipe, isStandalone: true, name: "libraryHours" }); }
|
|
23
|
+
}
|
|
24
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.0", ngImport: i0, type: LibraryHoursPipe, decorators: [{
|
|
25
|
+
type: Pipe,
|
|
26
|
+
args: [{
|
|
27
|
+
name: 'libraryHours',
|
|
28
|
+
standalone: true,
|
|
29
|
+
}]
|
|
30
|
+
}] });
|
|
31
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGlicmFyeS1ob3Vycy5waXBlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY29tcG9uZW50cy9zcmMvbGliL2hibGwtaGVhZGVyL3BpcGVzL2xpYnJhcnktaG91cnMucGlwZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDM0MsT0FBTyxFQUFFLElBQUksRUFBaUIsTUFBTSxlQUFlLENBQUM7O0FBTXBELE1BQU0sT0FBTyxnQkFBZ0I7SUFDekIsU0FBUyxDQUFDLElBQVksRUFBRSxJQUFZO1FBQ2hDLElBQUksT0FBTyxHQUFHLElBQUksQ0FBQztRQUNuQixJQUFJLENBQUM7WUFDRCxPQUFPLEdBQUcsSUFBSSxRQUFRLENBQUMsT0FBTyxDQUFDLENBQUMsU0FBUyxDQUFDLElBQUksSUFBSSxDQUFDLElBQUksR0FBRyxHQUFHLEdBQUcsSUFBSSxDQUFDLEVBQUUsSUFBSSxDQUFDLENBQUM7UUFDakYsQ0FBQztRQUFDLE9BQU8sQ0FBQyxFQUFFLENBQUM7WUFDVCxPQUFPLE9BQU8sQ0FBQztRQUNuQixDQUFDO1FBQ0QsSUFBSSxPQUFPLEtBQUssTUFBTTtZQUFFLE9BQU8sR0FBRyxVQUFVLENBQUM7YUFDeEMsSUFBSSxPQUFPLEVBQUUsQ0FBQztZQUNmLE9BQU8sR0FBRyxPQUFPLENBQUMsT0FBTyxDQUFDLElBQUksRUFBRSxPQUFPLENBQUMsQ0FBQztZQUN6QyxPQUFPLEdBQUcsT0FBTyxDQUFDLE9BQU8sQ0FBQyxJQUFJLEVBQUUsT0FBTyxDQUFDLENBQUM7UUFDN0MsQ0FBQztRQUNELE9BQU8sT0FBTyxDQUFDO0lBQ25CLENBQUM7OEdBZFEsZ0JBQWdCOzRHQUFoQixnQkFBZ0I7OzJGQUFoQixnQkFBZ0I7a0JBSjVCLElBQUk7bUJBQUM7b0JBQ0YsSUFBSSxFQUFFLGNBQWM7b0JBQ3BCLFVBQVUsRUFBRSxJQUFJO2lCQUNuQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERhdGVQaXBlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IFBpcGUsIFBpcGVUcmFuc2Zvcm0gfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuQFBpcGUoe1xuICAgIG5hbWU6ICdsaWJyYXJ5SG91cnMnLFxuICAgIHN0YW5kYWxvbmU6IHRydWUsXG59KVxuZXhwb3J0IGNsYXNzIExpYnJhcnlIb3Vyc1BpcGUgaW1wbGVtZW50cyBQaXBlVHJhbnNmb3JtIHtcbiAgICB0cmFuc2Zvcm0oZGF0ZTogc3RyaW5nLCB0aW1lOiBzdHJpbmcpOiBzdHJpbmcgfCBudWxsIHtcbiAgICAgICAgbGV0IG5ld1RpbWUgPSBudWxsO1xuICAgICAgICB0cnkge1xuICAgICAgICAgICAgbmV3VGltZSA9IG5ldyBEYXRlUGlwZSgnZW4tVVMnKS50cmFuc2Zvcm0obmV3IERhdGUoZGF0ZSArICdUJyArIHRpbWUpLCAnaGEnKTtcbiAgICAgICAgfSBjYXRjaCAoZSkge1xuICAgICAgICAgICAgcmV0dXJuIG5ld1RpbWU7XG4gICAgICAgIH1cbiAgICAgICAgaWYgKG5ld1RpbWUgPT09ICcxMkFNJykgbmV3VGltZSA9ICdNaWRuaWdodCc7XG4gICAgICAgIGVsc2UgaWYgKG5ld1RpbWUpIHtcbiAgICAgICAgICAgIG5ld1RpbWUgPSBuZXdUaW1lLnJlcGxhY2UoJ0FNJywgJyBhLm0uJyk7XG4gICAgICAgICAgICBuZXdUaW1lID0gbmV3VGltZS5yZXBsYWNlKCdQTScsICcgcC5tLicpO1xuICAgICAgICB9XG4gICAgICAgIHJldHVybiBuZXdUaW1lO1xuICAgIH1cbn1cbiJdfQ==
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
import { Component, computed, EventEmitter, input, Output } from '@angular/core';
|
|
2
|
+
import { HbllHeaderComponent } from '../hbll-header/hbll-header.component';
|
|
3
|
+
import { ImpersonationBannerComponent } from '../impersonation-banner/impersonation-banner.component';
|
|
4
|
+
import { defaultOidcBaseUri, defaultOidcDefaultIdp, ImpersonateModalComponent, } from '../impersonate-modal/impersonate-modal.component';
|
|
5
|
+
import { jwtDecode } from 'jwt-decode';
|
|
6
|
+
import * as i0 from "@angular/core";
|
|
7
|
+
export class HeaderWithImpersonationComponent {
|
|
8
|
+
constructor() {
|
|
9
|
+
this.accessTokenPayload = input.required();
|
|
10
|
+
this.oidcBaseUri = input(defaultOidcBaseUri);
|
|
11
|
+
this.oidcDefaultIdp = input(defaultOidcDefaultIdp);
|
|
12
|
+
this.mainSiteBaseUrl = input('https://lib.byu.edu');
|
|
13
|
+
this.login = new EventEmitter();
|
|
14
|
+
this.logout = new EventEmitter();
|
|
15
|
+
this.endImpersonation = new EventEmitter();
|
|
16
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
17
|
+
this.parsedToken = computed(() => this.accessTokenPayload().token ? jwtDecode(this.accessTokenPayload().token) : null);
|
|
18
|
+
this.name = computed(() => (this.parsedToken() ? this.parsedToken()['given_name'] : ''));
|
|
19
|
+
this.showImpersonateButton = computed(() => this.parsedToken()
|
|
20
|
+
? !!(!this.isImpersonating() &&
|
|
21
|
+
this.parsedToken()['resource_access']['realm-management']?.['roles']?.includes('impersonation'))
|
|
22
|
+
: false);
|
|
23
|
+
this.showImpersonationModal = false;
|
|
24
|
+
this.isImpersonating = computed(() => !!this.parsedToken()?.['impersonator']);
|
|
25
|
+
}
|
|
26
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.0", ngImport: i0, type: HeaderWithImpersonationComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
27
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.1.0", type: HeaderWithImpersonationComponent, isStandalone: true, selector: "lib-header-with-impersonation", inputs: { accessTokenPayload: { classPropertyName: "accessTokenPayload", publicName: "accessTokenPayload", isSignal: true, isRequired: true, transformFunction: null }, oidcBaseUri: { classPropertyName: "oidcBaseUri", publicName: "oidcBaseUri", isSignal: true, isRequired: false, transformFunction: null }, oidcDefaultIdp: { classPropertyName: "oidcDefaultIdp", publicName: "oidcDefaultIdp", isSignal: true, isRequired: false, transformFunction: null }, mainSiteBaseUrl: { classPropertyName: "mainSiteBaseUrl", publicName: "mainSiteBaseUrl", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { login: "login", logout: "logout", endImpersonation: "endImpersonation" }, ngImport: i0, template: "<lib-impersonation-banner\n [accessTokenPayload]=\"accessTokenPayload()\"\n (endImpersonation)=\"endImpersonation.emit()\"\n></lib-impersonation-banner>\n<lib-hbll-header\n [name]=\"name()\"\n [showImpersonateButton]=\"showImpersonateButton()\"\n (openImpersonationModal)=\"showImpersonationModal = true\"\n (login)=\"login.emit()\"\n (logout)=\"logout.emit()\"\n [mainsitebaseurl]=\"mainSiteBaseUrl()\"\n/>\n<lib-impersonate-modal\n [showModal]=\"showImpersonationModal\"\n [oidcBaseUri]=\"oidcBaseUri()\"\n [oidcDefaultIdp]=\"oidcDefaultIdp()\"\n [accessTokenPayload]=\"accessTokenPayload()\"\n (dismiss)=\"showImpersonationModal = false\"\n (init)=\"showImpersonationModal = true\"\n></lib-impersonate-modal>\n", styles: [""], dependencies: [{ kind: "component", type: HbllHeaderComponent, selector: "lib-hbll-header", inputs: ["name", "mainsitebaseurl", "showImpersonateButton"], outputs: ["openImpersonationModal", "login", "logout"] }, { kind: "component", type: ImpersonationBannerComponent, selector: "lib-impersonation-banner", inputs: ["accessTokenPayload", "personBaseUri", "libraryApiBaseUri"], outputs: ["endImpersonation"] }, { kind: "component", type: ImpersonateModalComponent, selector: "lib-impersonate-modal", inputs: ["showModal", "oidcBaseUri", "oidcDefaultIdp", "accessTokenPayload"], outputs: ["dismiss", "init"] }] }); }
|
|
28
|
+
}
|
|
29
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.0", ngImport: i0, type: HeaderWithImpersonationComponent, decorators: [{
|
|
30
|
+
type: Component,
|
|
31
|
+
args: [{ selector: 'lib-header-with-impersonation', standalone: true, imports: [HbllHeaderComponent, ImpersonationBannerComponent, ImpersonateModalComponent], template: "<lib-impersonation-banner\n [accessTokenPayload]=\"accessTokenPayload()\"\n (endImpersonation)=\"endImpersonation.emit()\"\n></lib-impersonation-banner>\n<lib-hbll-header\n [name]=\"name()\"\n [showImpersonateButton]=\"showImpersonateButton()\"\n (openImpersonationModal)=\"showImpersonationModal = true\"\n (login)=\"login.emit()\"\n (logout)=\"logout.emit()\"\n [mainsitebaseurl]=\"mainSiteBaseUrl()\"\n/>\n<lib-impersonate-modal\n [showModal]=\"showImpersonationModal\"\n [oidcBaseUri]=\"oidcBaseUri()\"\n [oidcDefaultIdp]=\"oidcDefaultIdp()\"\n [accessTokenPayload]=\"accessTokenPayload()\"\n (dismiss)=\"showImpersonationModal = false\"\n (init)=\"showImpersonationModal = true\"\n></lib-impersonate-modal>\n" }]
|
|
32
|
+
}], propDecorators: { login: [{
|
|
33
|
+
type: Output
|
|
34
|
+
}], logout: [{
|
|
35
|
+
type: Output
|
|
36
|
+
}], endImpersonation: [{
|
|
37
|
+
type: Output
|
|
38
|
+
}] } });
|
|
39
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGVhZGVyLXdpdGgtaW1wZXJzb25hdGlvbi5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb21wb25lbnRzL3NyYy9saWIvaGVhZGVyLXdpdGgtaW1wZXJzb25hdGlvbi9oZWFkZXItd2l0aC1pbXBlcnNvbmF0aW9uLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NvbXBvbmVudHMvc3JjL2xpYi9oZWFkZXItd2l0aC1pbXBlcnNvbmF0aW9uL2hlYWRlci13aXRoLWltcGVyc29uYXRpb24uY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxRQUFRLEVBQUUsWUFBWSxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQVUsTUFBTSxlQUFlLENBQUM7QUFDekYsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sc0NBQXNDLENBQUM7QUFDM0UsT0FBTyxFQUFFLDRCQUE0QixFQUFFLE1BQU0sd0RBQXdELENBQUM7QUFDdEcsT0FBTyxFQUNILGtCQUFrQixFQUNsQixxQkFBcUIsRUFDckIseUJBQXlCLEdBQzVCLE1BQU0sa0RBQWtELENBQUM7QUFFMUQsT0FBTyxFQUFFLFNBQVMsRUFBYyxNQUFNLFlBQVksQ0FBQzs7QUFTbkQsTUFBTSxPQUFPLGdDQUFnQztJQVA3QztRQVFJLHVCQUFrQixHQUFHLEtBQUssQ0FBQyxRQUFRLEVBQWdCLENBQUM7UUFDcEQsZ0JBQVcsR0FBRyxLQUFLLENBQUMsa0JBQWtCLENBQUMsQ0FBQztRQUN4QyxtQkFBYyxHQUFHLEtBQUssQ0FBQyxxQkFBcUIsQ0FBQyxDQUFDO1FBQzlDLG9CQUFlLEdBQUcsS0FBSyxDQUFDLHFCQUFxQixDQUFDLENBQUM7UUFFckMsVUFBSyxHQUFHLElBQUksWUFBWSxFQUFRLENBQUM7UUFDakMsV0FBTSxHQUFHLElBQUksWUFBWSxFQUFRLENBQUM7UUFDbEMscUJBQWdCLEdBQUcsSUFBSSxZQUFZLEVBQVEsQ0FBQztRQUV0RCw4REFBOEQ7UUFDcEQsZ0JBQVcsR0FBc0QsUUFBUSxDQUFDLEdBQUcsRUFBRSxDQUNyRixJQUFJLENBQUMsa0JBQWtCLEVBQUUsQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsa0JBQWtCLEVBQUUsQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUN0RixDQUFDO1FBQ1EsU0FBSSxHQUFHLFFBQVEsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxDQUFDLElBQUksQ0FBQyxXQUFXLEVBQUUsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLFdBQVcsRUFBRyxDQUFDLFlBQVksQ0FBQyxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDO1FBQ3JGLDBCQUFxQixHQUFHLFFBQVEsQ0FBQyxHQUFHLEVBQUUsQ0FDNUMsSUFBSSxDQUFDLFdBQVcsRUFBRTtZQUNkLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FDRSxDQUFDLElBQUksQ0FBQyxlQUFlLEVBQUU7Z0JBQ3ZCLElBQUksQ0FBQyxXQUFXLEVBQUcsQ0FBQyxpQkFBaUIsQ0FBQyxDQUFDLGtCQUFrQixDQUFDLEVBQUUsQ0FBQyxPQUFPLENBQUMsRUFBRSxRQUFRLENBQzNFLGVBQWUsQ0FDbEIsQ0FDSjtZQUNILENBQUMsQ0FBQyxLQUFLLENBQ2QsQ0FBQztRQUNRLDJCQUFzQixHQUFHLEtBQUssQ0FBQztRQUNqQyxvQkFBZSxHQUFHLFFBQVEsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLFdBQVcsRUFBRSxFQUFFLENBQUMsY0FBYyxDQUFDLENBQUMsQ0FBQztLQUNwRjs4R0EzQlksZ0NBQWdDO2tHQUFoQyxnQ0FBZ0MsMndCQ2xCN0MscXZCQW9CQSwwREROYyxtQkFBbUIsa0xBQUUsNEJBQTRCLDBLQUFFLHlCQUF5Qjs7MkZBSTdFLGdDQUFnQztrQkFQNUMsU0FBUzsrQkFDSSwrQkFBK0IsY0FDN0IsSUFBSSxXQUNQLENBQUMsbUJBQW1CLEVBQUUsNEJBQTRCLEVBQUUseUJBQXlCLENBQUM7OEJBVTdFLEtBQUs7c0JBQWQsTUFBTTtnQkFDRyxNQUFNO3NCQUFmLE1BQU07Z0JBQ0csZ0JBQWdCO3NCQUF6QixNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBjb21wdXRlZCwgRXZlbnRFbWl0dGVyLCBpbnB1dCwgT3V0cHV0LCBTaWduYWwgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEhibGxIZWFkZXJDb21wb25lbnQgfSBmcm9tICcuLi9oYmxsLWhlYWRlci9oYmxsLWhlYWRlci5jb21wb25lbnQnO1xuaW1wb3J0IHsgSW1wZXJzb25hdGlvbkJhbm5lckNvbXBvbmVudCB9IGZyb20gJy4uL2ltcGVyc29uYXRpb24tYmFubmVyL2ltcGVyc29uYXRpb24tYmFubmVyLmNvbXBvbmVudCc7XG5pbXBvcnQge1xuICAgIGRlZmF1bHRPaWRjQmFzZVVyaSxcbiAgICBkZWZhdWx0T2lkY0RlZmF1bHRJZHAsXG4gICAgSW1wZXJzb25hdGVNb2RhbENvbXBvbmVudCxcbn0gZnJvbSAnLi4vaW1wZXJzb25hdGUtbW9kYWwvaW1wZXJzb25hdGUtbW9kYWwuY29tcG9uZW50JztcbmltcG9ydCB7IFRva2VuUGF5bG9hZCB9IGZyb20gJy4uL21vZGVscy90b2tlbi1wYXlsb2FkJztcbmltcG9ydCB7IGp3dERlY29kZSwgSnd0UGF5bG9hZCB9IGZyb20gJ2p3dC1kZWNvZGUnO1xuXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogJ2xpYi1oZWFkZXItd2l0aC1pbXBlcnNvbmF0aW9uJyxcbiAgICBzdGFuZGFsb25lOiB0cnVlLFxuICAgIGltcG9ydHM6IFtIYmxsSGVhZGVyQ29tcG9uZW50LCBJbXBlcnNvbmF0aW9uQmFubmVyQ29tcG9uZW50LCBJbXBlcnNvbmF0ZU1vZGFsQ29tcG9uZW50XSxcbiAgICB0ZW1wbGF0ZVVybDogJy4vaGVhZGVyLXdpdGgtaW1wZXJzb25hdGlvbi5jb21wb25lbnQuaHRtbCcsXG4gICAgc3R5bGVVcmw6ICcuL2hlYWRlci13aXRoLWltcGVyc29uYXRpb24uY29tcG9uZW50LnNjc3MnLFxufSlcbmV4cG9ydCBjbGFzcyBIZWFkZXJXaXRoSW1wZXJzb25hdGlvbkNvbXBvbmVudCB7XG4gICAgYWNjZXNzVG9rZW5QYXlsb2FkID0gaW5wdXQucmVxdWlyZWQ8VG9rZW5QYXlsb2FkPigpO1xuICAgIG9pZGNCYXNlVXJpID0gaW5wdXQoZGVmYXVsdE9pZGNCYXNlVXJpKTtcbiAgICBvaWRjRGVmYXVsdElkcCA9IGlucHV0KGRlZmF1bHRPaWRjRGVmYXVsdElkcCk7XG4gICAgbWFpblNpdGVCYXNlVXJsID0gaW5wdXQoJ2h0dHBzOi8vbGliLmJ5dS5lZHUnKTtcblxuICAgIEBPdXRwdXQoKSBsb2dpbiA9IG5ldyBFdmVudEVtaXR0ZXI8dm9pZD4oKTtcbiAgICBAT3V0cHV0KCkgbG9nb3V0ID0gbmV3IEV2ZW50RW1pdHRlcjx2b2lkPigpO1xuICAgIEBPdXRwdXQoKSBlbmRJbXBlcnNvbmF0aW9uID0gbmV3IEV2ZW50RW1pdHRlcjx2b2lkPigpO1xuXG4gICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9uby1leHBsaWNpdC1hbnlcbiAgICBwcm90ZWN0ZWQgcGFyc2VkVG9rZW46IFNpZ25hbDwoSnd0UGF5bG9hZCAmIFJlY29yZDxzdHJpbmcsIGFueT4pIHwgbnVsbD4gPSBjb21wdXRlZCgoKSA9PlxuICAgICAgICB0aGlzLmFjY2Vzc1Rva2VuUGF5bG9hZCgpLnRva2VuID8gand0RGVjb2RlKHRoaXMuYWNjZXNzVG9rZW5QYXlsb2FkKCkudG9rZW4pIDogbnVsbCxcbiAgICApO1xuICAgIHByb3RlY3RlZCBuYW1lID0gY29tcHV0ZWQoKCkgPT4gKHRoaXMucGFyc2VkVG9rZW4oKSA/IHRoaXMucGFyc2VkVG9rZW4oKSFbJ2dpdmVuX25hbWUnXSA6ICcnKSk7XG4gICAgcHJvdGVjdGVkIHNob3dJbXBlcnNvbmF0ZUJ1dHRvbiA9IGNvbXB1dGVkKCgpID0+XG4gICAgICAgIHRoaXMucGFyc2VkVG9rZW4oKVxuICAgICAgICAgICAgPyAhIShcbiAgICAgICAgICAgICAgICAgICF0aGlzLmlzSW1wZXJzb25hdGluZygpICYmXG4gICAgICAgICAgICAgICAgICB0aGlzLnBhcnNlZFRva2VuKCkhWydyZXNvdXJjZV9hY2Nlc3MnXVsncmVhbG0tbWFuYWdlbWVudCddPy5bJ3JvbGVzJ10/LmluY2x1ZGVzKFxuICAgICAgICAgICAgICAgICAgICAgICdpbXBlcnNvbmF0aW9uJyxcbiAgICAgICAgICAgICAgICAgIClcbiAgICAgICAgICAgICAgKVxuICAgICAgICAgICAgOiBmYWxzZSxcbiAgICApO1xuICAgIHByb3RlY3RlZCBzaG93SW1wZXJzb25hdGlvbk1vZGFsID0gZmFsc2U7XG4gICAgcHJpdmF0ZSBpc0ltcGVyc29uYXRpbmcgPSBjb21wdXRlZCgoKSA9PiAhIXRoaXMucGFyc2VkVG9rZW4oKT8uWydpbXBlcnNvbmF0b3InXSk7XG59XG4iLCI8bGliLWltcGVyc29uYXRpb24tYmFubmVyXG4gICAgW2FjY2Vzc1Rva2VuUGF5bG9hZF09XCJhY2Nlc3NUb2tlblBheWxvYWQoKVwiXG4gICAgKGVuZEltcGVyc29uYXRpb24pPVwiZW5kSW1wZXJzb25hdGlvbi5lbWl0KClcIlxuPjwvbGliLWltcGVyc29uYXRpb24tYmFubmVyPlxuPGxpYi1oYmxsLWhlYWRlclxuICAgIFtuYW1lXT1cIm5hbWUoKVwiXG4gICAgW3Nob3dJbXBlcnNvbmF0ZUJ1dHRvbl09XCJzaG93SW1wZXJzb25hdGVCdXR0b24oKVwiXG4gICAgKG9wZW5JbXBlcnNvbmF0aW9uTW9kYWwpPVwic2hvd0ltcGVyc29uYXRpb25Nb2RhbCA9IHRydWVcIlxuICAgIChsb2dpbik9XCJsb2dpbi5lbWl0KClcIlxuICAgIChsb2dvdXQpPVwibG9nb3V0LmVtaXQoKVwiXG4gICAgW21haW5zaXRlYmFzZXVybF09XCJtYWluU2l0ZUJhc2VVcmwoKVwiXG4vPlxuPGxpYi1pbXBlcnNvbmF0ZS1tb2RhbFxuICAgIFtzaG93TW9kYWxdPVwic2hvd0ltcGVyc29uYXRpb25Nb2RhbFwiXG4gICAgW29pZGNCYXNlVXJpXT1cIm9pZGNCYXNlVXJpKClcIlxuICAgIFtvaWRjRGVmYXVsdElkcF09XCJvaWRjRGVmYXVsdElkcCgpXCJcbiAgICBbYWNjZXNzVG9rZW5QYXlsb2FkXT1cImFjY2Vzc1Rva2VuUGF5bG9hZCgpXCJcbiAgICAoZGlzbWlzcyk9XCJzaG93SW1wZXJzb25hdGlvbk1vZGFsID0gZmFsc2VcIlxuICAgIChpbml0KT1cInNob3dJbXBlcnNvbmF0aW9uTW9kYWwgPSB0cnVlXCJcbj48L2xpYi1pbXBlcnNvbmF0ZS1tb2RhbD5cbiJdfQ==
|