@penn-libraries/web 1.0.0-dev.2 → 1.1.0-dev.0
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/dist/cjs/{index-B6HF5D3u.js → index-C0A2bnrZ.js} +76 -3
- package/dist/cjs/index-C0A2bnrZ.js.map +1 -0
- package/dist/cjs/index.cjs.js +1 -1
- package/dist/cjs/loader.cjs.js +2 -2
- package/dist/cjs/pennlibs-allow-tracking.pennlibs-autocomplete.pennlibs-footer.pennlibs-header.entry.cjs.js.map +1 -0
- package/dist/cjs/{pennlibs-chat_6.cjs.entry.js → pennlibs-allow-tracking_4.cjs.entry.js} +264 -121
- package/dist/cjs/pennlibs-allow-tracking_4.cjs.entry.js.map +1 -0
- package/dist/cjs/pennlibs-banner.cjs.entry.js +2 -2
- package/dist/cjs/pennlibs-chat.cjs.entry.js +25 -0
- package/dist/cjs/pennlibs-chat.cjs.entry.js.map +1 -0
- package/dist/cjs/pennlibs-chat.entry.cjs.js.map +1 -0
- package/dist/cjs/pennlibs-fallback-img.cjs.entry.js +22 -0
- package/dist/cjs/pennlibs-fallback-img.cjs.entry.js.map +1 -0
- package/dist/cjs/pennlibs-fallback-img.entry.cjs.js.map +1 -0
- package/dist/cjs/pennlibs-feedback.cjs.entry.js +60 -0
- package/dist/cjs/pennlibs-feedback.cjs.entry.js.map +1 -0
- package/dist/cjs/pennlibs-feedback.entry.cjs.js.map +1 -0
- package/dist/cjs/pennlibs-hero.cjs.entry.js +62 -0
- package/dist/cjs/pennlibs-hero.cjs.entry.js.map +1 -0
- package/dist/cjs/pennlibs-hero.entry.cjs.js.map +1 -0
- package/dist/cjs/web.cjs.js +2 -2
- package/dist/collection/collection-manifest.json +2 -0
- package/dist/collection/components/pennlibs-allow-tracking/pennlibs-allow-tracking.css +110 -0
- package/dist/collection/components/pennlibs-allow-tracking/pennlibs-allow-tracking.js +67 -0
- package/dist/collection/components/pennlibs-allow-tracking/pennlibs-allow-tracking.js.map +1 -0
- package/dist/collection/components/pennlibs-autocomplete/pennlibs-autocomplete.css +79 -0
- package/dist/collection/components/pennlibs-autocomplete/pennlibs-autocomplete.js +309 -0
- package/dist/collection/components/pennlibs-autocomplete/pennlibs-autocomplete.js.map +1 -0
- package/dist/collection/components/pennlibs-banner/pennlibs-banner.js +1 -1
- package/dist/collection/components/pennlibs-chat/pennlibs-chat.js +1 -1
- package/dist/collection/components/pennlibs-fallback-img/pennlibs-fallback-img.js +1 -1
- package/dist/collection/components/pennlibs-footer/pennlibs-footer.js +3 -3
- package/dist/collection/components/pennlibs-header/pennlibs-header.js +1 -1
- package/dist/collection/components/pennlibs-hero/pennlibs-hero.js +1 -1
- package/dist/components/index.d.ts +4 -0
- package/dist/components/index.js +2 -0
- package/dist/components/index.js.map +1 -1
- package/dist/components/pennlibs-allow-tracking.d.ts +11 -0
- package/dist/components/pennlibs-allow-tracking.js +79 -0
- package/dist/components/pennlibs-allow-tracking.js.map +1 -0
- package/dist/components/pennlibs-autocomplete.d.ts +11 -0
- package/dist/components/pennlibs-autocomplete.js +259 -0
- package/dist/components/pennlibs-autocomplete.js.map +1 -0
- package/dist/components/pennlibs-banner.js +1 -1
- package/dist/components/pennlibs-chat.js +1 -1
- package/dist/components/pennlibs-fallback-img.js +1 -1
- package/dist/components/pennlibs-footer.js +3 -3
- package/dist/components/pennlibs-header.js +1 -1
- package/dist/components/pennlibs-hero.js +1 -1
- package/dist/docs.json +102 -2
- package/dist/{web/p-BAQIT3Vo.js → esm/index-CE_ILdTo.js} +76 -3
- package/dist/{web/p-BAQIT3Vo.js.map → esm/index-CE_ILdTo.js.map} +1 -1
- package/dist/esm/index.js +1 -1
- package/dist/esm/loader.js +3 -3
- package/dist/esm/pennlibs-allow-tracking.pennlibs-autocomplete.pennlibs-footer.pennlibs-header.entry.js.map +1 -0
- package/dist/esm/{pennlibs-chat_6.entry.js → pennlibs-allow-tracking_4.entry.js} +263 -118
- package/dist/esm/pennlibs-allow-tracking_4.entry.js.map +1 -0
- package/dist/esm/pennlibs-banner.entry.js +2 -2
- package/dist/esm/pennlibs-chat.entry.js +23 -0
- package/dist/esm/pennlibs-chat.entry.js.map +1 -0
- package/dist/esm/pennlibs-fallback-img.entry.js +20 -0
- package/dist/esm/pennlibs-fallback-img.entry.js.map +1 -0
- package/dist/esm/pennlibs-feedback.entry.js +58 -0
- package/dist/esm/pennlibs-feedback.entry.js.map +1 -0
- package/dist/esm/pennlibs-hero.entry.js +60 -0
- package/dist/esm/pennlibs-hero.entry.js.map +1 -0
- package/dist/esm/web.js +3 -3
- package/dist/types/components/pennlibs-allow-tracking/pennlibs-allow-tracking.d.ts +11 -0
- package/dist/types/components/pennlibs-autocomplete/pennlibs-autocomplete.d.ts +63 -0
- package/dist/types/components.d.ts +47 -0
- package/dist/web/index.esm.js +1 -1
- package/dist/web/p-07ad051f.entry.js +60 -0
- package/dist/web/p-07ad051f.entry.js.map +1 -0
- package/dist/web/{p-e331a309.entry.js → p-20c0bd7a.entry.js} +3 -3
- package/dist/web/p-370e32b1.entry.js +58 -0
- package/dist/web/p-370e32b1.entry.js.map +1 -0
- package/dist/web/p-5e385536.entry.js +20 -0
- package/dist/web/p-5e385536.entry.js.map +1 -0
- package/dist/{esm/index-BAQIT3Vo.js → web/p-CE_ILdTo.js} +76 -3
- package/dist/web/p-CE_ILdTo.js.map +1 -0
- package/dist/web/p-cbae5952.entry.js +23 -0
- package/dist/web/p-cbae5952.entry.js.map +1 -0
- package/dist/web/{p-ffdd436d.entry.js → p-ceaf55b0.entry.js} +263 -118
- package/dist/web/p-ceaf55b0.entry.js.map +1 -0
- package/dist/web/pennlibs-allow-tracking.pennlibs-autocomplete.pennlibs-footer.pennlibs-header.entry.esm.js.map +1 -0
- package/dist/web/pennlibs-chat.entry.esm.js.map +1 -0
- package/dist/web/pennlibs-fallback-img.entry.esm.js.map +1 -0
- package/dist/web/pennlibs-feedback.entry.esm.js.map +1 -0
- package/dist/web/pennlibs-hero.entry.esm.js.map +1 -0
- package/dist/web/web.esm.js +3 -3
- package/hydrate/index.js +361 -9
- package/hydrate/index.mjs +361 -9
- package/package.json +2 -2
- package/readme.md +2 -0
- package/dist/cjs/index-B6HF5D3u.js.map +0 -1
- package/dist/cjs/pennlibs-chat.pennlibs-fallback-img.pennlibs-feedback.pennlibs-footer.pennlibs-header.pennlibs-hero.entry.cjs.js.map +0 -1
- package/dist/cjs/pennlibs-chat_6.cjs.entry.js.map +0 -1
- package/dist/esm/index-BAQIT3Vo.js.map +0 -1
- package/dist/esm/pennlibs-chat.pennlibs-fallback-img.pennlibs-feedback.pennlibs-footer.pennlibs-header.pennlibs-hero.entry.js.map +0 -1
- package/dist/esm/pennlibs-chat_6.entry.js.map +0 -1
- package/dist/web/p-ffdd436d.entry.js.map +0 -1
- package/dist/web/pennlibs-chat.pennlibs-fallback-img.pennlibs-feedback.pennlibs-footer.pennlibs-header.pennlibs-hero.entry.esm.js.map +0 -1
- /package/dist/web/{p-e331a309.entry.js.map → p-20c0bd7a.entry.js.map} +0 -0
|
@@ -1,89 +1,288 @@
|
|
|
1
1
|
'use strict';
|
|
2
2
|
|
|
3
|
-
var index = require('./index-
|
|
3
|
+
var index = require('./index-C0A2bnrZ.js');
|
|
4
4
|
|
|
5
|
-
const
|
|
5
|
+
const pennlibsAllowTrackingCss = ":host {\n background: var(--pl-color-penn-blue);\n display: block;\n margin: 0;\n font-family: var(--pl-font-family);\n font-size: var(--pl-font-size);\n color: var(--pl-color-fg-on-emphasis);\n\n *, *:before, *:after {\n box-sizing: inherit;\n }\n\n & h2 {\n font-size: var(--pl-font-size-xl);\n font-family: var(--pl-font-sans-serif);\n margin-bottom: 0;\n margin-top: 0;\n display: inline-flex;\n flex-wrap: wrap;\n\n & span {\n padding-right: var(--pl-space-xs);\n }\n }\n\n & p {\n margin: 0;\n }\n\n & *:focus {\n box-shadow: 0 0 0 2px var(--pl-color-bg-accent-emphasis), 0 0 0 4px var(--pl-color-bg-accent);\n outline: none;\n }\n\n & a {\n color: var(--pl-color-fg-on-emphasis);\n text-decoration: underline;\n text-underline-offset: var(--pl-link-text-underline-offset);\n\n &:hover {\n text-underline-offset: var(--pl-link-text-underline-offset);\n text-decoration-thickness: 0.1em;\n }\n }\n}\n\n.container {\n padding: var(--pl-space-m) 0;\n}\n\n.pl-viewport-margins {\n width: 100%;\n max-width: var(--pl-viewport-margins-max-width);\n margin: 0 auto;\n padding: 0 var(--pl-viewport-margins-gutter, 1em);\n\n display: flex;\n gap: var(--pl-space-m);\n align-items: center;\n justify-content: space-between;\n\n flex-wrap: wrap;\n\n & div:last-of-type {\n display: flex;\n gap: var(--pl-space-xs);\n }\n}\n\nbutton {\n all: unset;\n display: flex;\n align-items: center;\n gap: 0.5em;\n padding: 0.5em 1.5em;\n font-family: var(--pl-font-family);\n font-weight: 500;\n line-height: 1.4;\n color: var(--pl-color-fg-default);\n background: var(--pl-color-bg-default);\n border-radius: 1em;\n box-sizing: border-box;\n\n &:hover {\n cursor: pointer;\n text-decoration: underline;\n text-underline-offset: var(--pl-link-text-underline-offset);\n text-decoration-thickness: 0.1em;\n }\n}\n\n.stop-sharing {\n background: none;\n color: var(--pl-color-fg-on-emphasis);\n border: solid 1px var(--pl-color-fg-on-emphasis);\n}\n\n.tracking-message {\n display: flex;\n gap: var(--pl-space-xs);\n align-items: center;\n\n & svg {\n flex-shrink: 0;\n }\n}\n\n.tracking-options {\n flex-wrap: wrap;\n}";
|
|
6
6
|
|
|
7
|
-
const
|
|
7
|
+
const AllowTracking = class {
|
|
8
8
|
constructor(hostRef) {
|
|
9
9
|
index.registerInstance(this, hostRef);
|
|
10
|
-
this.
|
|
11
|
-
this.
|
|
10
|
+
this.consentGiven = null;
|
|
11
|
+
this.hide = true;
|
|
12
|
+
this.handleAllow = () => {
|
|
13
|
+
this.setCookie('pennlibs-allow-tracking', 'YES');
|
|
14
|
+
this.consentGiven = 'YES';
|
|
15
|
+
};
|
|
16
|
+
this.handleDoNotTrack = () => {
|
|
17
|
+
this.setCookie('pennlibs-allow-tracking', 'NO');
|
|
18
|
+
this.consentGiven = 'NO';
|
|
19
|
+
};
|
|
20
|
+
this.handleHide = () => {
|
|
21
|
+
this.hide = true;
|
|
22
|
+
};
|
|
12
23
|
}
|
|
13
|
-
|
|
14
|
-
|
|
24
|
+
componentWillLoad() {
|
|
25
|
+
if (navigator.cookieEnabled) {
|
|
26
|
+
this.hide = false;
|
|
27
|
+
}
|
|
28
|
+
const existingConsent = this.getCookie('pennlibs-allow-tracking');
|
|
29
|
+
if (existingConsent) {
|
|
30
|
+
this.consentGiven = existingConsent;
|
|
31
|
+
}
|
|
15
32
|
}
|
|
16
|
-
|
|
17
|
-
|
|
33
|
+
getCookie(name) {
|
|
34
|
+
var _a;
|
|
35
|
+
return ((_a = document.cookie
|
|
36
|
+
.split('; ')
|
|
37
|
+
.find(row => row.startsWith(`${name}=`))) === null || _a === void 0 ? void 0 : _a.split('=')[1]) || null;
|
|
18
38
|
}
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
const pennlibsFallbackImgCss = ":host{font-family:var(--pl-font-family);font-size:var(--pl-font-size);display:flex;align-items:center;justify-content:center;padding:1rem;background:var(--pl-color-bg-subtle);aspect-ratio:3/2}.no-image__img{width:100%;max-width:150px;filter:grayscale(1) opacity(0.3)}";
|
|
23
|
-
|
|
24
|
-
const NoImage = class {
|
|
25
|
-
constructor(hostRef) {
|
|
26
|
-
index.registerInstance(this, hostRef);
|
|
39
|
+
setCookie(name, value) {
|
|
40
|
+
document.cookie = `${name}=${value}; path=/; max-age=31536000`;
|
|
27
41
|
}
|
|
28
42
|
render() {
|
|
29
|
-
|
|
30
|
-
|
|
43
|
+
if (this.hide) {
|
|
44
|
+
return null;
|
|
45
|
+
}
|
|
46
|
+
if (this.consentGiven) {
|
|
47
|
+
return (index.h("div", { class: "container" }, index.h("div", { class: "pl-viewport-margins" }, index.h("div", null, index.h("p", null, "You've ", index.h("strong", null, this.consentGiven === 'YES' ? 'accepted' : 'rejected'), " tracking. You can ", index.h("a", { href: "#" }, "change this setting"), " at anytime.")), index.h("div", null, index.h("button", { onClick: this.handleHide }, "Hide tracking message")))));
|
|
48
|
+
}
|
|
49
|
+
return (index.h("div", { class: "container" }, index.h("div", { class: "pl-viewport-margins" }, index.h("div", { class: "tracking-message" }, index.h(TrackingIcon, null), index.h("p", null, index.h("a", { href: "https://www.library.upenn.edu/about/policies/penn-libraries-privacy-policy" }, "We use anonymized data"), " from your visit such as clicks to gather analytics and understand how we can make improvements.")), index.h("div", { class: "tracking-options" }, index.h("button", { onClick: this.handleAllow }, "Continue sharing"), index.h("button", { onClick: this.handleDoNotTrack, class: "stop-sharing" }, "Stop sharing")))));
|
|
31
50
|
}
|
|
32
|
-
static get assetsDirs() { return ["assets"]; }
|
|
33
51
|
};
|
|
34
|
-
|
|
52
|
+
function TrackingIcon() {
|
|
53
|
+
return (index.h("svg", { xmlns: "http://www.w3.org/2000/svg", width: "24", height: "24", viewBox: "0 0 24 24", fill: "none", stroke: "currentColor", "stroke-width": "2", "stroke-linecap": "round", "stroke-linejoin": "round", class: "lucide lucide-trending-up-down-icon lucide-trending-up-down" }, index.h("path", { d: "M14.828 14.828 21 21" }), index.h("path", { d: "M21 16v5h-5" }), index.h("path", { d: "m21 3-9 9-4-4-6 6" }), index.h("path", { d: "M21 8V3h-5" })));
|
|
54
|
+
}
|
|
55
|
+
AllowTracking.style = pennlibsAllowTrackingCss;
|
|
35
56
|
|
|
36
|
-
const
|
|
57
|
+
const pennlibsAutocompleteCss = ":host {\n display: block;\n border-radius: 1.25rem;\n padding: 0;\n border-top: 0;\n position: relative;\n}\n\n[role=listbox] {\n position: absolute;\n margin-top: var(--pl-space-xs);\n background: var(--pl-color-bg-default);\n border-radius: 1.25rem;\n box-shadow: rgba(140, 149, 159, 0.3) 0px 8px 24px 0px;\n width: 100%;\n overflow: hidden;\n z-index: 1;\n\n display: flex;\n flex-direction: column;\n}\n\np {\n margin: 0;\n font-size: var(--pl-font-size-s);\n color: var(--pl-color-fg-subtle);\n padding: var(--pl-space-xs) calc(var(--pl-space-m) + var(--pl-space-2xs));\n font-size: var(--pl-font-size-s);\n order: 2;\n font-weight: 500;\n background: var(--pl-color-bg-subtle);\n border-radius: 0 0 1.25rem 1.25rem;\n\n display: flex;\n gap: var(--pl-space-s) var(--pl-space-l);\n flex-wrap: wrap;\n}\n\nol {\n list-style: none;\n margin: 0;\n padding: var(--pl-space-xs) 0;\n order: 1;\n}\n\n[role=option] {\n color: var(--pl-color-fg-default);\n padding: var(--pl-space-s) calc(var(--pl-space-m) + var(--pl-space-2xs));\n text-decoration: none;\n font-weight: 700; \n\n &:hover {\n cursor: pointer;\n }\n\n &:hover,\n &:focus {\n text-decoration-thickness: 2px;\n text-underline-offset: 2px;\n text-decoration: underline;\n }\n}\n\n[aria-selected=true] {\n text-decoration-thickness: 2px;\n text-underline-offset: 2px;\n text-decoration: underline;\n}\n\nmark {\n background: none;\n font-weight: 400;\n}\n\n.suggestion--border {\n border-bottom: solid 1px rgb(from var(--pl-color-fg-default) r g b / 0.2);\n padding-bottom: calc(var(--pl-space-2xs) + var(--pl-space-s));\n margin-bottom: var(--pl-space-2xs);\n}";
|
|
37
58
|
|
|
38
|
-
const
|
|
39
|
-
const FEEDBACK_QUESTION = 'Did you find what you need?';
|
|
40
|
-
const FEEDBACK_ERROR_STORAGE_KEY = 'pennlibs-feedback-error';
|
|
41
|
-
const PennlibsFeedback = class {
|
|
59
|
+
const Autocomplete = class {
|
|
42
60
|
constructor(hostRef) {
|
|
43
61
|
index.registerInstance(this, hostRef);
|
|
44
|
-
this.
|
|
45
|
-
this.
|
|
46
|
-
this.
|
|
62
|
+
this.activated = index.createEvent(this, "pl:activated");
|
|
63
|
+
this.showSuggestions = false;
|
|
64
|
+
this.currentIndex = -1;
|
|
65
|
+
this.originalValue = '';
|
|
66
|
+
this.options = [];
|
|
67
|
+
this.handleOptionClick = (index) => {
|
|
68
|
+
this.currentIndex = index;
|
|
69
|
+
this.selectCurrent();
|
|
70
|
+
};
|
|
47
71
|
}
|
|
48
72
|
componentWillLoad() {
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
73
|
+
this.options = this.parseOptionsFromDOM();
|
|
74
|
+
}
|
|
75
|
+
componentDidLoad() {
|
|
76
|
+
this.setupInput();
|
|
77
|
+
}
|
|
78
|
+
disconnectedCallback() {
|
|
79
|
+
if (this.blurTimeout)
|
|
80
|
+
clearTimeout(this.blurTimeout);
|
|
55
81
|
}
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
82
|
+
parseOptionsFromDOM() {
|
|
83
|
+
const listbox = this.findListbox();
|
|
84
|
+
if (!listbox)
|
|
85
|
+
return [];
|
|
86
|
+
const elements = Array.from(listbox.querySelectorAll('[role="option"]'));
|
|
87
|
+
return elements.map((el, i) => this.createOption(el, i));
|
|
88
|
+
}
|
|
89
|
+
findListbox() {
|
|
90
|
+
return Array.from(this.el.children).find(child => child.matches('ol[role="listbox"]'));
|
|
91
|
+
}
|
|
92
|
+
createOption(element, index) {
|
|
93
|
+
var _a;
|
|
94
|
+
return {
|
|
95
|
+
id: element.id || `option-${index}`,
|
|
96
|
+
html: element.innerHTML,
|
|
97
|
+
value: element.getAttribute('data-value') || ((_a = element.textContent) === null || _a === void 0 ? void 0 : _a.trim()) || ''
|
|
98
|
+
};
|
|
99
|
+
}
|
|
100
|
+
getInput() {
|
|
101
|
+
var _a, _b;
|
|
102
|
+
const slot = (_a = this.el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('slot[name="start"]');
|
|
103
|
+
return ((_b = slot === null || slot === void 0 ? void 0 : slot.assignedElements()[0]) === null || _b === void 0 ? void 0 : _b.querySelector('input')) || null;
|
|
104
|
+
}
|
|
105
|
+
isInputFocused() {
|
|
106
|
+
return this.getInput() === document.activeElement;
|
|
107
|
+
}
|
|
108
|
+
isTrackedInput(input) {
|
|
109
|
+
return (input === null || input === void 0 ? void 0 : input.getAttribute('data-pl-autocomplete-input')) === 'true' &&
|
|
110
|
+
this.el.contains(input);
|
|
111
|
+
}
|
|
112
|
+
setupInput() {
|
|
113
|
+
const input = this.getInput();
|
|
114
|
+
if (!input)
|
|
115
|
+
return;
|
|
116
|
+
this.setComboboxAttributes(input);
|
|
117
|
+
input.setAttribute('data-pl-autocomplete-input', 'true');
|
|
118
|
+
}
|
|
119
|
+
setComboboxAttributes(input) {
|
|
120
|
+
input.setAttribute('role', 'combobox');
|
|
121
|
+
input.setAttribute('aria-autocomplete', 'list');
|
|
122
|
+
input.setAttribute('aria-expanded', 'false');
|
|
123
|
+
input.setAttribute('aria-controls', 'listbox');
|
|
124
|
+
}
|
|
125
|
+
handleSlotChange() {
|
|
126
|
+
this.setupInput();
|
|
127
|
+
}
|
|
128
|
+
handleInputEvent(event) {
|
|
129
|
+
const input = event.target;
|
|
130
|
+
if (this.isTrackedInput(input))
|
|
131
|
+
this.openSuggestions();
|
|
132
|
+
}
|
|
133
|
+
handleFocusEvent(event) {
|
|
134
|
+
const input = event.target;
|
|
135
|
+
if (this.isTrackedInput(input))
|
|
136
|
+
this.showSuggestionsPanel();
|
|
137
|
+
}
|
|
138
|
+
handleBlurEvent(event) {
|
|
139
|
+
const input = event.target;
|
|
140
|
+
if (this.isTrackedInput(input))
|
|
141
|
+
this.deferCloseSuggestions();
|
|
142
|
+
}
|
|
143
|
+
handleFocusOut(event) {
|
|
144
|
+
if (this.isFocusLeavingComponent(event))
|
|
145
|
+
this.closeSuggestions();
|
|
146
|
+
}
|
|
147
|
+
handleKeyDown(event) {
|
|
148
|
+
if (!this.isInputFocused())
|
|
149
|
+
return;
|
|
150
|
+
if (event.metaKey || event.ctrlKey)
|
|
151
|
+
return; // Ignore keyboard shortcuts
|
|
152
|
+
const handler = this.keyHandlers()[event.key];
|
|
153
|
+
if (handler) {
|
|
154
|
+
event.preventDefault();
|
|
155
|
+
handler();
|
|
59
156
|
}
|
|
60
|
-
|
|
61
|
-
|
|
157
|
+
}
|
|
158
|
+
keyHandlers() {
|
|
159
|
+
return {
|
|
160
|
+
'Escape': () => this.handleEscape(),
|
|
161
|
+
'ArrowDown': () => this.handleArrowDown(),
|
|
162
|
+
'ArrowUp': () => this.handleArrowUp(),
|
|
163
|
+
'Enter': () => this.handleEnter()
|
|
164
|
+
};
|
|
165
|
+
}
|
|
166
|
+
handleEscape() {
|
|
167
|
+
this.reset();
|
|
168
|
+
this.syncInputState();
|
|
169
|
+
}
|
|
170
|
+
handleArrowDown() {
|
|
171
|
+
if (!this.showSuggestions)
|
|
172
|
+
return;
|
|
173
|
+
this.moveNext();
|
|
174
|
+
this.syncInputState();
|
|
175
|
+
}
|
|
176
|
+
handleArrowUp() {
|
|
177
|
+
if (!this.showSuggestions)
|
|
178
|
+
return;
|
|
179
|
+
this.movePrevious();
|
|
180
|
+
this.syncInputState();
|
|
181
|
+
}
|
|
182
|
+
handleEnter() {
|
|
183
|
+
if (this.canSelect())
|
|
184
|
+
this.selectCurrent();
|
|
185
|
+
}
|
|
186
|
+
// Navigation
|
|
187
|
+
moveNext() {
|
|
188
|
+
const lastIndex = this.options.length - 1;
|
|
189
|
+
this.currentIndex = this.currentIndex < lastIndex ? this.currentIndex + 1 : -1;
|
|
190
|
+
}
|
|
191
|
+
movePrevious() {
|
|
192
|
+
const lastIndex = this.options.length - 1;
|
|
193
|
+
this.currentIndex = this.currentIndex > -1 ? this.currentIndex - 1 : lastIndex;
|
|
194
|
+
}
|
|
195
|
+
canSelect() {
|
|
196
|
+
return this.showSuggestions && this.currentIndex >= 0;
|
|
197
|
+
}
|
|
198
|
+
selectCurrent() {
|
|
199
|
+
if (this.currentIndex < 0)
|
|
200
|
+
return;
|
|
201
|
+
const selectedOption = this.options[this.currentIndex];
|
|
202
|
+
const input = this.getInput();
|
|
203
|
+
if (input) {
|
|
204
|
+
input.value = selectedOption.value;
|
|
205
|
+
this.originalValue = selectedOption.value;
|
|
62
206
|
}
|
|
207
|
+
this.activated.emit({
|
|
208
|
+
index: this.currentIndex,
|
|
209
|
+
value: selectedOption.value
|
|
210
|
+
});
|
|
211
|
+
this.closeSuggestions();
|
|
212
|
+
}
|
|
213
|
+
openSuggestions() {
|
|
214
|
+
if (!this.isInputFocused())
|
|
215
|
+
return;
|
|
216
|
+
const input = this.getInput();
|
|
217
|
+
if (input)
|
|
218
|
+
this.originalValue = input.value;
|
|
219
|
+
this.showSuggestionsPanel();
|
|
220
|
+
this.syncInputState();
|
|
63
221
|
}
|
|
64
|
-
|
|
222
|
+
showSuggestionsPanel() {
|
|
223
|
+
this.showSuggestions = true;
|
|
224
|
+
this.syncInputState();
|
|
225
|
+
}
|
|
226
|
+
closeSuggestions() {
|
|
227
|
+
this.reset();
|
|
228
|
+
this.syncInputState();
|
|
229
|
+
}
|
|
230
|
+
deferCloseSuggestions() {
|
|
231
|
+
this.blurTimeout = setTimeout(() => {
|
|
232
|
+
if (this.isFocusOutsideComponent())
|
|
233
|
+
this.closeSuggestions();
|
|
234
|
+
}, 150);
|
|
235
|
+
}
|
|
236
|
+
reset() {
|
|
237
|
+
this.showSuggestions = false;
|
|
238
|
+
this.currentIndex = -1;
|
|
239
|
+
}
|
|
240
|
+
isFocusLeavingComponent(event) {
|
|
65
241
|
var _a;
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
question: FEEDBACK_QUESTION,
|
|
70
|
-
answer: answer,
|
|
71
|
-
url: window.location.href,
|
|
72
|
-
pageHeading: ((_a = document.querySelector('h1')) === null || _a === void 0 ? void 0 : _a.textContent) || undefined,
|
|
73
|
-
pageTitle: document.title || undefined
|
|
74
|
-
});
|
|
242
|
+
const target = event.relatedTarget;
|
|
243
|
+
return !target ||
|
|
244
|
+
(!this.el.contains(target) && !((_a = this.el.shadowRoot) === null || _a === void 0 ? void 0 : _a.contains(target)));
|
|
75
245
|
}
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
246
|
+
isFocusOutsideComponent() {
|
|
247
|
+
var _a;
|
|
248
|
+
const active = document.activeElement;
|
|
249
|
+
return !((_a = this.el.shadowRoot) === null || _a === void 0 ? void 0 : _a.contains(active)) && active !== this.getInput();
|
|
250
|
+
}
|
|
251
|
+
// Input State Sync
|
|
252
|
+
syncInputState() {
|
|
253
|
+
const input = this.getInput();
|
|
254
|
+
if (!input)
|
|
255
|
+
return;
|
|
256
|
+
this.updateAriaExpanded(input);
|
|
257
|
+
this.updateAriaActiveDescendant(input);
|
|
258
|
+
this.updateInputValue(input);
|
|
259
|
+
}
|
|
260
|
+
updateAriaExpanded(input) {
|
|
261
|
+
input.setAttribute('aria-expanded', this.showSuggestions.toString());
|
|
262
|
+
}
|
|
263
|
+
updateAriaActiveDescendant(input) {
|
|
264
|
+
const hasSelection = this.showSuggestions && this.currentIndex >= 0;
|
|
265
|
+
if (hasSelection && this.options[this.currentIndex]) {
|
|
266
|
+
input.setAttribute('aria-activedescendant', this.options[this.currentIndex].id);
|
|
79
267
|
}
|
|
80
|
-
|
|
81
|
-
|
|
268
|
+
else {
|
|
269
|
+
input.removeAttribute('aria-activedescendant');
|
|
82
270
|
}
|
|
83
|
-
return (index.h("div", { class: "feedback-container" }, index.h("h2", null, FEEDBACK_QUESTION), index.h("button", { onClick: () => this.handleFeedback('yes') }, "\uD83D\uDC4D", index.h("span", null, "Yes", index.h("span", { class: "visually-hidden" }, ", I found what I need."))), index.h("button", { onClick: () => this.handleFeedback('no') }, "\uD83D\uDC4E", index.h("span", null, "No", index.h("span", { class: "visually-hidden" }, ", I didn't find what I need.")))));
|
|
84
271
|
}
|
|
272
|
+
updateInputValue(input) {
|
|
273
|
+
input.value = this.currentIndex >= 0
|
|
274
|
+
? this.options[this.currentIndex].value
|
|
275
|
+
: this.originalValue;
|
|
276
|
+
}
|
|
277
|
+
shouldShowListbox() {
|
|
278
|
+
return this.showSuggestions && this.options.length > 0 && this.isInputFocused();
|
|
279
|
+
}
|
|
280
|
+
render() {
|
|
281
|
+
return (index.h("div", { key: '115c30f765cf21c38e2e5376da41295850ec76e3' }, index.h("slot", { key: '878c10f3b561bf8c85f920b7238227a5b0429204', name: "start" }), this.shouldShowListbox() && (index.h("ol", { key: 'ea491160d597a9c2b553107fb3edad698d652549', role: "listbox", id: "listbox" }, this.options.map((option, index$1) => (index.h("li", { role: "option", id: option.id, "aria-selected": this.currentIndex === index$1 ? 'true' : 'false', tabindex: "-1", onClick: () => this.handleOptionClick(index$1), innerHTML: option.html })))))));
|
|
282
|
+
}
|
|
283
|
+
get el() { return index.getElement(this); }
|
|
85
284
|
};
|
|
86
|
-
|
|
285
|
+
Autocomplete.style = pennlibsAutocompleteCss;
|
|
87
286
|
|
|
88
287
|
const pennlibsFooterCss = ":host {\n font-family: var(--pl-font-family);\n font-size: var(--pl-font-size);\n --padding-bottom: 5.75rem;\n}\n\n@media print {\n :host {\n display: none;\n }\n}\n\n*, *::before, *::after {\n box-sizing: border-box;\n}\n\n.website-footer-wrapper {\n background: var(--pl-color-penn-blue);\n padding-bottom: var(--padding-bottom);\n}\n\n.viewport-margins {\n max-width: var(--pl-viewport-margins-max-width);\n margin: 0 auto;\n padding: 0 var(--pl-viewport-margins-gutter, 1em);\n}\n\n.website-footer {\n background-size: cover;\n color: var(--pl-color-fg-subtle-on-emphasis);\n}\n\n.website-footer a {\n color: var(--pl-color-fg-subtle-on-emphasis);\n}\n\n.website-footer__content {\n padding: 4em 0;\n}\n\n.website-footer__links-container {\n gap: 4em 2em;\n display: grid;\n grid-template-columns: repeat(auto-fill, minmax(12em, 1fr));\n}\n\n.website-footer__heading {\n font-size: 0.8em;\n text-transform: uppercase;\n letter-spacing: 0.075em;\n margin-bottom: 1em;\n opacity: 0.75;\n}\n\n.website-footer__links {\n margin: 0;\n padding: 0;\n list-style: none;\n display: flex;\n flex-direction: column;\n gap: 0.75em;\n}\n\n.website-footer__links a {\n text-decoration: none;\n}\n\n.website-footer__links a:hover {\n text-decoration: underline;\n text-underline-offset: var(--pl-link-text-underline-offset);\n}\n\n.website-footer__footer {\n padding: 1em 0;\n background: rgba(1, 31, 91, 0.65);\n}\n\n.website-footer__links--footer {\n display: flex;\n flex-wrap: wrap;\n gap: 0;\n flex-direction: row;\n margin-left: -0.5em;\n\n @media (max-width: 1080px) {\n display: grid;\n grid-template-columns: repeat(auto-fill, minmax(16em, 1fr));\n }\n}\n\n.website-footer__links--footer a {\n display: inline-block;\n padding: 0.5em 0.75em;\n font-size: 0.875em;\n opacity: 0.875;\n font-weight: 500;\n}\n\n.website-footer__links--footer a:hover {\n text-decoration: underline;\n text-underline-offset: var(--pl-link-text-underline-offset);\n}";
|
|
89
288
|
|
|
@@ -114,12 +313,12 @@ const Footer = class {
|
|
|
114
313
|
}
|
|
115
314
|
render() {
|
|
116
315
|
const footerBackgroundSrc = index.getAssetPath('./assets/footer-bg.webp');
|
|
117
|
-
return (index.h("div", { key: '
|
|
316
|
+
return (index.h("div", { key: '968368b94435f332d852c7599308992195df8792', class: "website-footer-wrapper" }, index.h("footer", { key: '6c709b86bef34533d5350e7040d043fd2dd5caf2', class: "website-footer", style: {
|
|
118
317
|
background: `var(--pl-color-penn-blue) url(${footerBackgroundSrc}) no-repeat 50% 50%`,
|
|
119
318
|
backgroundSize: 'cover',
|
|
120
|
-
} }, index.h("div", { key: '
|
|
319
|
+
} }, index.h("div", { key: 'cfb33794f711d427f8cc64026bc1caff589ff444', class: "viewport-margins" }, index.h("div", { key: '7f7518568ef5884a0014be4e10b4ba6d00b14d9c', class: "website-footer__content" }, index.h("div", { key: '8fb9612358f3c42b3a5621f54cb646c06307776a', class: "website-footer__links-container" }, index.h("section", { key: '1bed43fbe1c161d8d4de0381f71f093bab6a3791' }, index.h("h2", { key: 'bdd5487da839597ce52715eff9fae099301a3f4b', class: "website-footer__heading" }, "Penn Libraries"), index.h("ul", { key: '0579c77c9120b73f67eb5560716cc9194182e645', class: "website-footer__links" }, index.h("li", { key: 'c8cadddc0867b4bded9f22975bc6e80210501737' }, index.h("a", { key: '34a076d9417b0da1a390f9757be5cece974b8658', href: "https://maps.google.com/?q=Van Pelt Library 3420 Walnut Street, Philadelphia, PA 19104-6206" }, "3420 Walnut Street", index.h("br", { key: '159e1ceed4693f7a85489ad4a1ef8f916f505955' }), "Philadelphia, PA 19104-6206")), index.h("li", { key: '3de1e966c16afc1ae5c82d25b1d87e24f27af826' }, index.h("a", { key: '39a6709291115a6f6ead9116171b97c31c6e77d9', href: "tel:(215) 898-7555" }, "(215) 898-7555")), index.h("li", { key: '7236b41454b66bc155bc4a7568f603c70504f01b' }, index.h("a", { key: '49b285935d3240e900079b62c8d90eb564e5707d', href: "https://www.library.upenn.edu/contact-us" }, "Contact us")), index.h("li", { key: '9329fe40a9aef5e1eaa74c6b22b33aee5b94f624' }, index.h("a", { key: 'd2bc79dff8b3a5c01cbc1ece4268b4fdddc56954', href: "https://www.library.upenn.edu/about/hours", target: "_blank" }, "Locations and hours")))), index.h("section", { key: '8b05b90f531f99c6223a7a080baa9472bb00b2b0' }, index.h("h2", { key: 'c950fd6a248e5d673a8a4e050f3aaa84f91c5014', class: "website-footer__heading" }, "Stay in touch"), index.h("ul", { key: '7ce913dd26948c9c1bb6f5ab14f1febc07425836', class: "website-footer__links" }, index.h("li", { key: 'ccd80b1eee71f058caad49e3da56cbf1a8d28aa2' }, index.h("a", { key: 'b09d62df23e341bd9424ff541a842c3b17a24637', href: "https://www.alumni.upenn.edu/libsignup" }, "Newsletter")), index.h("li", { key: '7b7c04fdf9d6673fef77fecd460c110f55700350' }, index.h("a", { key: '08cd159b59ff63471f4075913a644bbd171c5e90', href: "https://www.instagram.com/upennlib/" }, "Instagram")), index.h("li", { key: 'f0fffc02b5a55f41ad9e97b1e35dd7217e4d3aa6' }, index.h("a", { key: '0269c87d87e2b2b3db93fae2d5e33d19cf6a82a1', href: "https://www.facebook.com/PennLibraries/" }, "Facebook")), index.h("li", { key: '3c008831c4c3e5d700d4f16427b3cfd50082a8a6' }, index.h("a", { key: 'db56894184243b375d3f8c7c42458720f70a34f2', href: "https://www.linkedin.com/company/penn-libraries" }, "LinkedIn")))), this.navigationByChildren && [
|
|
121
320
|
this.navigationByChildren.map(section => (index.h("section", null, index.h("h2", { class: "website-footer__heading" }, section.heading), index.h("ul", { class: "website-footer__links" }, section.links.map(link => (index.h("li", null, index.h("a", { href: link.href }, link.label))))))))
|
|
122
|
-
]))), index.h("div", { key: '
|
|
321
|
+
]))), index.h("div", { key: '3a48e365b66300beeb261d3c14e8d98e7565373d', class: "website-footer__footer" }, index.h("div", { key: '699738c3f57f35796a1f4397a6fada44eaaa1683', class: "viewport-margins" }, index.h("ul", { key: 'c88fb2fb6bbc3fc5eb13664f7288d7afe3ec7e57', class: "website-footer__links website-footer__links--footer" }, index.h("li", { key: '8c3ecc9499cb5fdf180906d2d681eba515dae399' }, index.h("a", { key: 'ae916ed72fc00e93f0e9c73b49878c75790a0227', href: "https://www.upenn.edu/" }, "UPenn")), index.h("li", { key: 'c5a51aabc04937e09ae3df7c0fe13fbb9ff9b0d8' }, index.h("a", { key: '359a6693330af0a701ff2e9a13fffb9e5ca573b6', href: "https://www.upenn.edu/about/privacy-policy" }, "Privacy Policy")), index.h("li", { key: '1e323f9c47a94933f48abaf0c1c5fef1479a1395' }, index.h("a", { key: '55dde719bb09dc79fc158f931adaf2b1926120c9', href: "https://accessibility.web-resources.upenn.edu/get-help" }, "Report Accessibility Issues and Get Help")), index.h("li", { key: 'e83955780f877039da38ddd946fd9ab0455812e1' }, index.h("a", { key: '7ed5e27e6f6ea677a35c7f3e78dba2e72f629488', href: "https://www.upenn.edu/about/disclaimer" }, "Disclaimer")), index.h("li", { key: 'cd28d78bec76cc13e0272cbb30e11bcde6459cb9' }, index.h("a", { key: 'a6a64d9949ea4cbbc8f90703d886e83dd9f0df9b', href: "https://www.publicsafety.upenn.edu/contact/" }, "Emergency Services")), index.h("li", { key: 'cbc668f7728653b15748a8488f9694c632884d6f' }, index.h("a", { key: 'b681b57236ee23c3be9c85c4f199ef7f4c66b607', href: "https://www.upenn.edu/about/report-copyright-infringement" }, "Report Copyright Infringement"))))))));
|
|
123
322
|
}
|
|
124
323
|
static get assetsDirs() { return ["assets"]; }
|
|
125
324
|
get hostElement() { return index.getElement(this); }
|
|
@@ -192,73 +391,17 @@ const Header = class {
|
|
|
192
391
|
return (index.h("svg", { xmlns: "http://www.w3.org/2000/svg", height: "24", viewBox: "0 -960 960 960", width: "24" }, index.h("path", { fill: "currentColor", d: "M480-345 240-585l56-56 184 184 184-184 56 56-240 240Z" })));
|
|
193
392
|
}
|
|
194
393
|
render() {
|
|
195
|
-
return (index.h("header", { key: '
|
|
394
|
+
return (index.h("header", { key: '7764d8c5041a19eba4786e6469e6b915066523da', class: `viewport-margins website-header ${this.theme === 'dark' && 'website-header--dark'}` }, index.h("div", { key: 'f7ab412767f5cf4e8d4cb9c1c05e969ece062927', class: "website-header__inner-container" }, index.h("div", { key: '55a8d55b15be439e772c59bd6fb1d6d34cf073f3', class: "website-header__logo-name-container" }, index.h("a", { key: 'edb380951b11d45b9b61b39253eebf0df32131de', href: "https://www.library.upenn.edu/", class: "website-header_logo-link", "aria-label": "Penn Libraries" }, this.theme === 'dark' ? index.h(LogoWhite, null) : index.h(LogoBlue, null)), this.serviceName && (index.h("a", { key: '036d3e3eac035f8eb8c8999892bc3322f5171e05', href: "/", class: "website-header__service-link" }, index.h("span", { key: '8d8ae853e2ce7ef8713226317260c2fdd79ae11b', class: "website-header__service-name" }, this.serviceName), this.serviceLede && index.h("span", { key: '5c878d5bb98689268362d76cdf04db42d7444560', class: "website-header__service-lede" }, this.serviceLede))), index.h("slot", { key: '3370137e9c3099f534c890d7422608fcf8bae09a', name: "name-end" })), this.navigation.length > 0 && (index.h("nav", { key: '50751b716f9600691093ace08e2c90a92a2274c5', class: "website-header__navigation" }, index.h("button", { key: 'e57793641ed5d314f1fec03821586d71cc82d889', class: "website-header__navigation-button", "aria-expanded": `${this.isMenuOpen}`, onClick: () => this.handleToggleMenu() }, this.renderMenuIcon(), " Menu"), this.navigation && (index.h("ol", { key: '8c6f479cf0da87a289593fceab55a4ce1436b146', class: `website-header__navigation-list ${this.isMenuOpen && 'website-header__navigation-list--visible'}` }, this.navigation.map(element => index.h("li", { innerHTML: element.outerHTML })))))), index.h("slot", { key: '04edf00df086103b723f3e2bcf2241aa7a4624f2', name: "end" }))));
|
|
196
395
|
}
|
|
197
396
|
static get assetsDirs() { return ["assets"]; }
|
|
198
397
|
get hostElement() { return index.getElement(this); }
|
|
199
398
|
};
|
|
200
399
|
Header.style = pennlibsHeaderCss;
|
|
201
400
|
|
|
202
|
-
|
|
203
|
-
|
|
204
|
-
const getCurrentImageSource = (pictureElement) => {
|
|
205
|
-
const imgElement = pictureElement.querySelector('img');
|
|
206
|
-
return (imgElement === null || imgElement === void 0 ? void 0 : imgElement.currentSrc) || '';
|
|
207
|
-
};
|
|
208
|
-
const Hero = class {
|
|
209
|
-
constructor(hostRef) {
|
|
210
|
-
index.registerInstance(this, hostRef);
|
|
211
|
-
this.heroPictureElement = null;
|
|
212
|
-
this.heroHeadingElement = null;
|
|
213
|
-
this.heroParagraphElement = null;
|
|
214
|
-
this.heroSrc = "";
|
|
215
|
-
this.lastSrc = "";
|
|
216
|
-
}
|
|
217
|
-
componentWillLoad() {
|
|
218
|
-
const heroPictureElement = this.hostElement.querySelector('picture[hero=art-direction]');
|
|
219
|
-
if (heroPictureElement) {
|
|
220
|
-
this.heroPictureElement = heroPictureElement;
|
|
221
|
-
this.startWatchingCurrentSrc(heroPictureElement);
|
|
222
|
-
}
|
|
223
|
-
const heroHeadingElement = this.hostElement.querySelector('h1[hero=heading]');
|
|
224
|
-
if (heroHeadingElement) {
|
|
225
|
-
this.heroHeadingElement = heroHeadingElement;
|
|
226
|
-
}
|
|
227
|
-
const heroParagraphElement = this.hostElement.querySelector('p[hero=sub-heading]');
|
|
228
|
-
if (heroParagraphElement) {
|
|
229
|
-
this.heroParagraphElement = heroParagraphElement;
|
|
230
|
-
}
|
|
231
|
-
}
|
|
232
|
-
startWatchingCurrentSrc(pictureElement) {
|
|
233
|
-
const checkCurrentSrc = () => {
|
|
234
|
-
const currentSrc = getCurrentImageSource(pictureElement);
|
|
235
|
-
if (currentSrc !== this.lastSrc) {
|
|
236
|
-
this.lastSrc = currentSrc;
|
|
237
|
-
this.heroSrc = currentSrc;
|
|
238
|
-
}
|
|
239
|
-
this.animationFrameId = requestAnimationFrame(checkCurrentSrc);
|
|
240
|
-
};
|
|
241
|
-
this.animationFrameId = requestAnimationFrame(checkCurrentSrc);
|
|
242
|
-
}
|
|
243
|
-
disconnectedCallback() {
|
|
244
|
-
if (this.animationFrameId) {
|
|
245
|
-
cancelAnimationFrame(this.animationFrameId);
|
|
246
|
-
}
|
|
247
|
-
}
|
|
248
|
-
render() {
|
|
249
|
-
return (index.h("div", { key: '284eede0a201fc23f19af63ce875cf82514c007f', class: "hero", style: { backgroundImage: `url(${this.heroSrc})` } }, index.h("div", { key: '6d1643211563e173e20be38fa480d622a2e08d9b', class: "hero__content" }, index.h("slot", { key: 'd5905b079db6367dd6c917588d76c3bc949cc078', name: "start" }), index.h("div", { key: 'ecfbcb172bfb018ede01a1773ce12f135dac60f6', class: "hero__heading-container" }, this.heroHeadingElement && (index.h("div", { key: 'fd285ee37293132a02b03c70eb53b31fde007c7e', class: "viewport-margins" }, index.h("h1", { key: '3d71930c47c9c5d6a64c240847407953f424dac2', class: "hero__heading", innerHTML: this.heroHeadingElement.innerText }), this.heroParagraphElement && index.h("p", { key: '828d2a13daa5ae92c1591d0ea00ee8e91ab4f6cf', class: "hero__sub-heading", innerHTML: this.heroParagraphElement.innerHTML })))))));
|
|
250
|
-
}
|
|
251
|
-
static get assetsDirs() { return ["assets"]; }
|
|
252
|
-
get hostElement() { return index.getElement(this); }
|
|
253
|
-
};
|
|
254
|
-
Hero.style = pennlibsHeroCss;
|
|
255
|
-
|
|
256
|
-
exports.pennlibs_chat = Chat;
|
|
257
|
-
exports.pennlibs_fallback_img = NoImage;
|
|
258
|
-
exports.pennlibs_feedback = PennlibsFeedback;
|
|
401
|
+
exports.pennlibs_allow_tracking = AllowTracking;
|
|
402
|
+
exports.pennlibs_autocomplete = Autocomplete;
|
|
259
403
|
exports.pennlibs_footer = Footer;
|
|
260
404
|
exports.pennlibs_header = Header;
|
|
261
|
-
|
|
262
|
-
//# sourceMappingURL=pennlibs-chat.pennlibs-fallback-img.pennlibs-feedback.pennlibs-footer.pennlibs-header.pennlibs-hero.entry.cjs.js.map
|
|
405
|
+
//# sourceMappingURL=pennlibs-allow-tracking.pennlibs-autocomplete.pennlibs-footer.pennlibs-header.entry.cjs.js.map
|
|
263
406
|
|
|
264
|
-
//# sourceMappingURL=pennlibs-
|
|
407
|
+
//# sourceMappingURL=pennlibs-allow-tracking_4.cjs.entry.js.map
|