@internetarchive/ia-topnav 1.3.5-alpha7 → 1.3.6-alpha.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.
Files changed (84) hide show
  1. package/.eslintrc +16 -16
  2. package/LICENSE +661 -661
  3. package/README.md +147 -147
  4. package/index.d.ts +109 -109
  5. package/index.js +3 -3
  6. package/package.json +61 -61
  7. package/src/assets/img/hamburger.js +38 -38
  8. package/src/assets/img/ia-icon.js +33 -33
  9. package/src/assets/img/icon-audio.js +23 -23
  10. package/src/assets/img/icon-close.js +16 -16
  11. package/src/assets/img/icon-donate-unpadded.js +16 -16
  12. package/src/assets/img/icon-donate.js +15 -15
  13. package/src/assets/img/icon-ellipses.js +15 -15
  14. package/src/assets/img/icon-ia-logo.js +22 -22
  15. package/src/assets/img/icon-images.js +15 -15
  16. package/src/assets/img/icon-search.js +15 -15
  17. package/src/assets/img/icon-software.js +15 -15
  18. package/src/assets/img/icon-texts.js +15 -15
  19. package/src/assets/img/icon-upload-unpadded.js +14 -14
  20. package/src/assets/img/icon-upload.js +15 -15
  21. package/src/assets/img/icon-user.js +15 -15
  22. package/src/assets/img/icon-video.js +15 -15
  23. package/src/assets/img/icon-web.js +15 -15
  24. package/src/assets/img/icon.js +18 -18
  25. package/src/assets/img/icons.js +33 -33
  26. package/src/assets/img/wordmark-stacked.js +13 -13
  27. package/src/data/menus.js +670 -670
  28. package/src/desktop-subnav.js +45 -45
  29. package/src/dropdown-menu.js +109 -110
  30. package/src/ia-topnav.js +314 -315
  31. package/src/lib/formatUrl.js +1 -1
  32. package/src/lib/location-handler.js +5 -5
  33. package/src/lib/query-handler.js +7 -7
  34. package/src/lib/toSentenceCase.js +8 -8
  35. package/src/login-button.js +79 -79
  36. package/src/media-button.js +113 -114
  37. package/src/media-menu.js +133 -133
  38. package/src/media-slider.js +104 -104
  39. package/src/media-subnav.js +112 -112
  40. package/src/more-slider.js +33 -33
  41. package/src/nav-search.js +117 -120
  42. package/src/primary-nav.js +224 -232
  43. package/src/save-page-form.js +59 -59
  44. package/src/search-menu.js +115 -146
  45. package/src/signed-out-dropdown.js +10 -10
  46. package/src/styles/base.js +48 -48
  47. package/src/styles/desktop-subnav.js +37 -37
  48. package/src/styles/dropdown-menu.js +166 -166
  49. package/src/styles/ia-topnav.js +87 -87
  50. package/src/styles/login-button.js +79 -79
  51. package/src/styles/media-button.js +156 -156
  52. package/src/styles/media-menu.js +70 -70
  53. package/src/styles/media-slider.js +81 -81
  54. package/src/styles/media-subnav.js +156 -156
  55. package/src/styles/more-slider.js +15 -15
  56. package/src/styles/nav-search.js +136 -136
  57. package/src/styles/primary-nav.js +300 -300
  58. package/src/styles/save-page-form.js +54 -54
  59. package/src/styles/search-menu.js +99 -104
  60. package/src/styles/signed-out-dropdown.js +31 -31
  61. package/src/styles/user-menu.js +31 -31
  62. package/src/styles/wayback-search.js +48 -48
  63. package/src/styles/wayback-slider.js +30 -30
  64. package/src/tracked-element.js +27 -27
  65. package/src/user-menu.js +42 -42
  66. package/src/wayback-search.js +18 -18
  67. package/src/wayback-slider.js +87 -87
  68. package/test/assets/img/hamburger.test.js +15 -15
  69. package/test/assets/img/user.test.js +15 -15
  70. package/test/data/menus.test.js +19 -19
  71. package/test/dropdown-menu.test.js +25 -25
  72. package/test/ia-icon.test.js +13 -13
  73. package/test/ia-topnav.test.js +273 -273
  74. package/test/login-button.test.js +15 -15
  75. package/test/media-button.test.js +19 -19
  76. package/test/media-menu.test.js +40 -40
  77. package/test/media-slider.test.js +57 -57
  78. package/test/more-slider.test.js +13 -13
  79. package/test/nav-search.test.js +61 -61
  80. package/test/primary-nav.test.js +82 -82
  81. package/test/save-page-form.test.js +35 -35
  82. package/test/search-menu.test.js +49 -49
  83. package/test/user-menu.test.js +33 -33
  84. package/test/wayback-slider.test.js +80 -80
@@ -1,104 +1,104 @@
1
- import { LitElement, html } from 'https://offshoot.prod.archive.org/lit.js';
2
- import './media-subnav.js';
3
- import mediaSliderCSS from './styles/media-slider.js';
4
-
5
- class MediaSlider extends LitElement {
6
- static get styles() {
7
- return mediaSliderCSS;
8
- }
9
-
10
- static get properties() {
11
- return {
12
- baseHost: { type: String },
13
- config: { type: Object },
14
- mediaSliderOpen: { type: Boolean },
15
- menus: { type: Object },
16
- selectedMenuOption: { type: String },
17
- };
18
- }
19
-
20
- constructor() {
21
- super();
22
-
23
- this.config = {};
24
- this.mediaSliderOpen = false;
25
- this.menus = {};
26
- this.selectedMenuOption = 'texts';
27
- }
28
-
29
- shouldUpdate() {
30
- const scrollPane = this.shadowRoot ? this.shadowRoot.querySelector('.information-menu') : null;
31
-
32
- if (scrollPane) {
33
- scrollPane.scrollTop = 0;
34
- }
35
- return true;
36
- }
37
-
38
-
39
- render() {
40
- const sliderDetailsClass = this.mediaSliderOpen ? 'open' : 'closed';
41
-
42
- return html`
43
- <div class="media-slider-container">
44
- <div class="overflow-clip ${sliderDetailsClass}">
45
- <div class="information-menu ${sliderDetailsClass}">
46
- <div class="info-box">
47
- <media-subnav
48
- .baseHost=${this.baseHost}
49
- .config=${this.config}
50
- class="${this.selectedMenuOption === 'audio' ? '' : 'hidden'}"
51
- menu="audio"
52
- .menuItems=${this.menus.audio}
53
- ></media-subnav>
54
- <media-subnav
55
- .baseHost=${this.baseHost}
56
- .config=${this.config}
57
- class="${this.selectedMenuOption === 'images' ? '' : 'hidden'}"
58
- menu="images"
59
- .menuItems=${this.menus.images}
60
- ></media-subnav>
61
- <media-subnav
62
- .baseHost=${this.baseHost}
63
- .config=${this.config}
64
- class="${this.selectedMenuOption === 'software' ? '' : 'hidden'}"
65
- menu="software"
66
- .menuItems=${this.menus.software}
67
- ></media-subnav>
68
- <media-subnav
69
- .baseHost=${this.baseHost}
70
- .config=${this.config}
71
- class="${this.selectedMenuOption === 'texts' ? '' : 'hidden'}"
72
- menu="texts"
73
- .menuItems=${this.menus.texts}
74
- ></media-subnav>
75
- <media-subnav
76
- .baseHost=${this.baseHost}
77
- .config=${this.config}
78
- class="${this.selectedMenuOption === 'video' ? '' : 'hidden'}"
79
- menu="video"
80
- .menuItems=${this.menus.video}
81
- ></media-subnav>
82
- <media-subnav
83
- .baseHost=${this.baseHost}
84
- .config=${this.config}
85
- class="${this.selectedMenuOption === 'web' ? '' : 'hidden'}"
86
- menu="web"
87
- .menuItems=${this.menus.web}
88
- ></media-subnav>
89
- <media-subnav
90
- .baseHost=${this.baseHost}
91
- .config=${this.config}
92
- class="${this.selectedMenuOption === 'more' ? '' : 'hidden'}"
93
- menu="more"
94
- .menuItems=${this.menus.more}
95
- ></media-subnav>
96
- </div>
97
- </div>
98
- </div>
99
- </div>
100
- `;
101
- }
102
- }
103
-
104
- customElements.define('media-slider', MediaSlider);
1
+ import { LitElement, html } from 'https://offshoot.prod.archive.org/lit.js';
2
+ import './media-subnav.js';
3
+ import mediaSliderCSS from './styles/media-slider.js';
4
+
5
+ class MediaSlider extends LitElement {
6
+ static get styles() {
7
+ return mediaSliderCSS;
8
+ }
9
+
10
+ static get properties() {
11
+ return {
12
+ baseHost: { type: String },
13
+ config: { type: Object },
14
+ mediaSliderOpen: { type: Boolean },
15
+ menus: { type: Object },
16
+ selectedMenuOption: { type: String },
17
+ };
18
+ }
19
+
20
+ constructor() {
21
+ super();
22
+
23
+ this.config = {};
24
+ this.mediaSliderOpen = false;
25
+ this.menus = {};
26
+ this.selectedMenuOption = 'texts';
27
+ }
28
+
29
+ shouldUpdate() {
30
+ const scrollPane = this.shadowRoot ? this.shadowRoot.querySelector('.information-menu') : null;
31
+
32
+ if (scrollPane) {
33
+ scrollPane.scrollTop = 0;
34
+ }
35
+ return true;
36
+ }
37
+
38
+
39
+ render() {
40
+ const sliderDetailsClass = this.mediaSliderOpen ? 'open' : 'closed';
41
+
42
+ return html`
43
+ <div class="media-slider-container">
44
+ <div class="overflow-clip ${sliderDetailsClass}">
45
+ <div class="information-menu ${sliderDetailsClass}">
46
+ <div class="info-box">
47
+ <media-subnav
48
+ .baseHost=${this.baseHost}
49
+ .config=${this.config}
50
+ class="${this.selectedMenuOption === 'audio' ? '' : 'hidden'}"
51
+ menu="audio"
52
+ .menuItems=${this.menus.audio}
53
+ ></media-subnav>
54
+ <media-subnav
55
+ .baseHost=${this.baseHost}
56
+ .config=${this.config}
57
+ class="${this.selectedMenuOption === 'images' ? '' : 'hidden'}"
58
+ menu="images"
59
+ .menuItems=${this.menus.images}
60
+ ></media-subnav>
61
+ <media-subnav
62
+ .baseHost=${this.baseHost}
63
+ .config=${this.config}
64
+ class="${this.selectedMenuOption === 'software' ? '' : 'hidden'}"
65
+ menu="software"
66
+ .menuItems=${this.menus.software}
67
+ ></media-subnav>
68
+ <media-subnav
69
+ .baseHost=${this.baseHost}
70
+ .config=${this.config}
71
+ class="${this.selectedMenuOption === 'texts' ? '' : 'hidden'}"
72
+ menu="texts"
73
+ .menuItems=${this.menus.texts}
74
+ ></media-subnav>
75
+ <media-subnav
76
+ .baseHost=${this.baseHost}
77
+ .config=${this.config}
78
+ class="${this.selectedMenuOption === 'video' ? '' : 'hidden'}"
79
+ menu="video"
80
+ .menuItems=${this.menus.video}
81
+ ></media-subnav>
82
+ <media-subnav
83
+ .baseHost=${this.baseHost}
84
+ .config=${this.config}
85
+ class="${this.selectedMenuOption === 'web' ? '' : 'hidden'}"
86
+ menu="web"
87
+ .menuItems=${this.menus.web}
88
+ ></media-subnav>
89
+ <media-subnav
90
+ .baseHost=${this.baseHost}
91
+ .config=${this.config}
92
+ class="${this.selectedMenuOption === 'more' ? '' : 'hidden'}"
93
+ menu="more"
94
+ .menuItems=${this.menus.more}
95
+ ></media-subnav>
96
+ </div>
97
+ </div>
98
+ </div>
99
+ </div>
100
+ `;
101
+ }
102
+ }
103
+
104
+ customElements.define('media-slider', MediaSlider);
@@ -1,112 +1,112 @@
1
- import { html } from 'https://offshoot.prod.archive.org/lit.js';
2
- import TrackedElement from './tracked-element.js';
3
- import './wayback-slider.js';
4
- import './more-slider.js';
5
- import mediaSubnavCSS from './styles/media-subnav.js';
6
- import toSentenceCase from './lib/toSentenceCase.js';
7
- import formatUrl from './lib/formatUrl.js';
8
-
9
- class MediaSubnav extends TrackedElement {
10
- static get styles() {
11
- return mediaSubnavCSS;
12
- }
13
-
14
- static get properties() {
15
- return {
16
- baseHost: { type: String },
17
- config: { type: Object },
18
- menu: { type: String },
19
- menuItems: { type: Object },
20
- };
21
- }
22
-
23
- constructor() {
24
- super();
25
-
26
- this.config = {};
27
- this.menu = '';
28
- this.menuItems = {};
29
-
30
- // Begin properties not monitored by LitElement
31
- this.links = MediaSubnav.defaultLinks;
32
- }
33
-
34
- shouldUpdate() {
35
- if (this.menuItems) {
36
- this.links = this.menuItems;
37
- }
38
- return true;
39
- }
40
-
41
- static get defaultLinks() {
42
- return { iconLinks: [], featuredLinks: [], links: [] };
43
- }
44
-
45
- analyticsEvent(title) {
46
- return `${this.config.eventCategory}|${toSentenceCase(title)}${toSentenceCase(this.menu)}`;
47
- }
48
-
49
- get iconLinks() {
50
- return this.links.iconLinks.map(link => (
51
- html`
52
- <a href="${formatUrl(link.url, this.baseHost)}" @click=${this.trackClick} data-event-click-tracking="${this.analyticsEvent(link.title)}"><img src="${link.icon}" loading="lazy" />${link.title}</a>
53
- `
54
- ));
55
- }
56
-
57
- renderLinks(category) {
58
- return this.links[category].map(link => (
59
- html`
60
- <li><a href="${formatUrl(link.url, this.baseHost)}" @click=${this.trackClick} data-event-click-tracking="${this.analyticsEvent(link.title)}">${link.title}</a></li>
61
- `
62
- ));
63
- }
64
-
65
- render() {
66
- if (!this.menu) {
67
- return html``;
68
- }
69
-
70
- if (this.menuItems) {
71
- this.links = this.menuItems;
72
- }
73
-
74
- if (this.menu === 'web') {
75
- return html`
76
- <wayback-slider
77
- .baseHost=${this.baseHost}
78
- .config=${this.config}
79
- .archiveItLinks=${this.menuItems.archiveItLinks}
80
- .browserExtensionsLinks=${this.menuItems.browserExtensionsLinks}
81
- .mobileAppsLinks=${this.menuItems.mobileAppsLinks}
82
- ></wayback-slider>`;
83
- }
84
-
85
- if (this.menu === 'more') {
86
- return html`
87
- <more-slider .baseHost=${this.baseHost} .config=${this.config} .menuItems=${this.menuItems}>
88
- </more-slider>`;
89
- }
90
-
91
- return html`
92
- <h3>${this.links.heading}</h3>
93
- <div class="icon-links">
94
- ${this.iconLinks}
95
- </div>
96
- <div class="links featured">
97
- <h4>Featured</h4>
98
- <ul>
99
- ${this.renderLinks('featuredLinks')}
100
- </ul>
101
- </div>
102
- <div class="links top">
103
- <h4>Top</h4>
104
- <ul>
105
- ${this.renderLinks('links')}
106
- </ul>
107
- </div>
108
- `;
109
- }
110
- }
111
-
112
- customElements.define('media-subnav', MediaSubnav);
1
+ import { html } from 'https://offshoot.prod.archive.org/lit.js';
2
+ import TrackedElement from './tracked-element.js';
3
+ import './wayback-slider.js';
4
+ import './more-slider.js';
5
+ import mediaSubnavCSS from './styles/media-subnav.js';
6
+ import toSentenceCase from './lib/toSentenceCase.js';
7
+ import formatUrl from './lib/formatUrl.js';
8
+
9
+ class MediaSubnav extends TrackedElement {
10
+ static get styles() {
11
+ return mediaSubnavCSS;
12
+ }
13
+
14
+ static get properties() {
15
+ return {
16
+ baseHost: { type: String },
17
+ config: { type: Object },
18
+ menu: { type: String },
19
+ menuItems: { type: Object },
20
+ };
21
+ }
22
+
23
+ constructor() {
24
+ super();
25
+
26
+ this.config = {};
27
+ this.menu = '';
28
+ this.menuItems = {};
29
+
30
+ // Begin properties not monitored by LitElement
31
+ this.links = MediaSubnav.defaultLinks;
32
+ }
33
+
34
+ shouldUpdate() {
35
+ if (this.menuItems) {
36
+ this.links = this.menuItems;
37
+ }
38
+ return true;
39
+ }
40
+
41
+ static get defaultLinks() {
42
+ return { iconLinks: [], featuredLinks: [], links: [] };
43
+ }
44
+
45
+ analyticsEvent(title) {
46
+ return `${this.config.eventCategory}|${toSentenceCase(title)}${toSentenceCase(this.menu)}`;
47
+ }
48
+
49
+ get iconLinks() {
50
+ return this.links.iconLinks.map(link => (
51
+ html`
52
+ <a href="${formatUrl(link.url, this.baseHost)}" @click=${this.trackClick} data-event-click-tracking="${this.analyticsEvent(link.title)}"><img src="${link.icon}" loading="lazy" />${link.title}</a>
53
+ `
54
+ ));
55
+ }
56
+
57
+ renderLinks(category) {
58
+ return this.links[category].map(link => (
59
+ html`
60
+ <li><a href="${formatUrl(link.url, this.baseHost)}" @click=${this.trackClick} data-event-click-tracking="${this.analyticsEvent(link.title)}">${link.title}</a></li>
61
+ `
62
+ ));
63
+ }
64
+
65
+ render() {
66
+ if (!this.menu) {
67
+ return html``;
68
+ }
69
+
70
+ if (this.menuItems) {
71
+ this.links = this.menuItems;
72
+ }
73
+
74
+ if (this.menu === 'web') {
75
+ return html`
76
+ <wayback-slider
77
+ .baseHost=${this.baseHost}
78
+ .config=${this.config}
79
+ .archiveItLinks=${this.menuItems.archiveItLinks}
80
+ .browserExtensionsLinks=${this.menuItems.browserExtensionsLinks}
81
+ .mobileAppsLinks=${this.menuItems.mobileAppsLinks}
82
+ ></wayback-slider>`;
83
+ }
84
+
85
+ if (this.menu === 'more') {
86
+ return html`
87
+ <more-slider .baseHost=${this.baseHost} .config=${this.config} .menuItems=${this.menuItems}>
88
+ </more-slider>`;
89
+ }
90
+
91
+ return html`
92
+ <h3>${this.links.heading}</h3>
93
+ <div class="icon-links">
94
+ ${this.iconLinks}
95
+ </div>
96
+ <div class="links featured">
97
+ <h4>Featured</h4>
98
+ <ul>
99
+ ${this.renderLinks('featuredLinks')}
100
+ </ul>
101
+ </div>
102
+ <div class="links top">
103
+ <h4>Top</h4>
104
+ <ul>
105
+ ${this.renderLinks('links')}
106
+ </ul>
107
+ </div>
108
+ `;
109
+ }
110
+ }
111
+
112
+ customElements.define('media-subnav', MediaSubnav);
@@ -1,33 +1,33 @@
1
- import { html } from 'https://offshoot.prod.archive.org/lit.js';
2
- import TrackedElement from './tracked-element.js';
3
- import toSentenceCase from './lib/toSentenceCase.js';
4
- import moreSliderCSS from './styles/more-slider.js';
5
- import formatUrl from './lib/formatUrl.js';
6
-
7
- class MoreSlider extends TrackedElement {
8
- static get properties() {
9
- return {
10
- baseHost: { type: String },
11
- config: { type: Object },
12
- menuItems: { type: Array },
13
- };
14
- }
15
-
16
- static get styles() {
17
- return moreSliderCSS;
18
- }
19
-
20
- analyticsEvent(title) {
21
- return `${this.config.eventCategory}|NavMore${toSentenceCase(title)}`;
22
- }
23
-
24
- render() {
25
- return html`
26
- <ul>
27
- ${this.menuItems.map(item => html`<li><a @click=${this.trackClick} href=${formatUrl(item.url, this.baseHost)} data-event-click-tracking="${this.analyticsEvent(item.title)}">${item.title}</a></li>`)}
28
- </ul>
29
- `;
30
- }
31
- }
32
-
33
- customElements.define('more-slider', MoreSlider);
1
+ import { html } from 'https://offshoot.prod.archive.org/lit.js';
2
+ import TrackedElement from './tracked-element.js';
3
+ import toSentenceCase from './lib/toSentenceCase.js';
4
+ import moreSliderCSS from './styles/more-slider.js';
5
+ import formatUrl from './lib/formatUrl.js';
6
+
7
+ class MoreSlider extends TrackedElement {
8
+ static get properties() {
9
+ return {
10
+ baseHost: { type: String },
11
+ config: { type: Object },
12
+ menuItems: { type: Array },
13
+ };
14
+ }
15
+
16
+ static get styles() {
17
+ return moreSliderCSS;
18
+ }
19
+
20
+ analyticsEvent(title) {
21
+ return `${this.config.eventCategory}|NavMore${toSentenceCase(title)}`;
22
+ }
23
+
24
+ render() {
25
+ return html`
26
+ <ul>
27
+ ${this.menuItems.map(item => html`<li><a @click=${this.trackClick} href=${formatUrl(item.url, this.baseHost)} data-event-click-tracking="${this.analyticsEvent(item.title)}">${item.title}</a></li>`)}
28
+ </ul>
29
+ `;
30
+ }
31
+ }
32
+
33
+ customElements.define('more-slider', MoreSlider);