@internetarchive/ia-topnav 1.3.9 → 1.3.10-webdev-7394.1
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/.prettierignore +1 -0
- package/README.md +7 -7
- package/demo/app-root.ts +186 -0
- package/demo/index.html +27 -0
- package/dist/demo/app-root.d.ts +8 -0
- package/dist/demo/app-root.js +181 -0
- package/dist/demo/app-root.js.map +1 -0
- package/dist/index.d.ts +2 -0
- package/dist/index.js +3 -0
- package/dist/index.js.map +1 -0
- package/dist/src/assets/img/hamburger.d.ts +7 -0
- package/dist/src/assets/img/hamburger.js +51 -0
- package/dist/src/assets/img/hamburger.js.map +1 -0
- package/dist/src/assets/img/ia-icon.d.ts +7 -0
- package/dist/src/assets/img/ia-icon.js +33 -0
- package/dist/src/assets/img/ia-icon.js.map +1 -0
- package/dist/src/assets/img/icon-audio.d.ts +2 -0
- package/dist/src/assets/img/icon-audio.js +28 -0
- package/dist/src/assets/img/icon-audio.js.map +1 -0
- package/dist/src/assets/img/icon-close.d.ts +2 -0
- package/dist/src/assets/img/icon-close.js +20 -0
- package/dist/src/assets/img/icon-close.js.map +1 -0
- package/dist/src/assets/img/icon-donate-unpadded.d.ts +2 -0
- package/dist/src/assets/img/icon-donate-unpadded.js +19 -0
- package/dist/src/assets/img/icon-donate-unpadded.js.map +1 -0
- package/dist/src/assets/img/icon-donate.d.ts +2 -0
- package/dist/src/assets/img/icon-donate.js +18 -0
- package/dist/src/assets/img/icon-donate.js.map +1 -0
- package/dist/src/assets/img/icon-ellipses.d.ts +2 -0
- package/dist/src/assets/img/icon-ellipses.js +19 -0
- package/dist/src/assets/img/icon-ellipses.js.map +1 -0
- package/dist/src/assets/img/icon-ia-logo.d.ts +2 -0
- package/dist/src/assets/img/icon-ia-logo.js +30 -0
- package/dist/src/assets/img/icon-ia-logo.js.map +1 -0
- package/dist/src/assets/img/icon-images.d.ts +2 -0
- package/dist/src/assets/img/icon-images.js +19 -0
- package/dist/src/assets/img/icon-images.js.map +1 -0
- package/dist/src/assets/img/icon-search.d.ts +2 -0
- package/dist/src/assets/img/icon-search.js +19 -0
- package/dist/src/assets/img/icon-search.js.map +1 -0
- package/dist/src/assets/img/icon-software.d.ts +2 -0
- package/dist/src/assets/img/icon-software.js +18 -0
- package/dist/src/assets/img/icon-software.js.map +1 -0
- package/dist/src/assets/img/icon-texts.d.ts +2 -0
- package/dist/src/assets/img/icon-texts.js +18 -0
- package/dist/src/assets/img/icon-texts.js.map +1 -0
- package/dist/src/assets/img/icon-upload-unpadded.d.ts +2 -0
- package/dist/src/assets/img/icon-upload-unpadded.js +18 -0
- package/dist/src/assets/img/icon-upload-unpadded.js.map +1 -0
- package/dist/src/assets/img/icon-upload.d.ts +2 -0
- package/dist/src/assets/img/icon-upload.js +21 -0
- package/dist/src/assets/img/icon-upload.js.map +1 -0
- package/dist/src/assets/img/icon-user.d.ts +2 -0
- package/dist/src/assets/img/icon-user.js +19 -0
- package/dist/src/assets/img/icon-user.js.map +1 -0
- package/dist/src/assets/img/icon-video.d.ts +2 -0
- package/dist/src/assets/img/icon-video.js +19 -0
- package/dist/src/assets/img/icon-video.js.map +1 -0
- package/dist/src/assets/img/icon-web.d.ts +2 -0
- package/dist/src/assets/img/icon-web.js +19 -0
- package/dist/src/assets/img/icon-web.js.map +1 -0
- package/dist/src/assets/img/icon.d.ts +5 -0
- package/dist/src/assets/img/icon.js +17 -0
- package/dist/src/assets/img/icon.js.map +1 -0
- package/dist/src/assets/img/icons.d.ts +18 -0
- package/dist/src/assets/img/icons.js +33 -0
- package/dist/src/assets/img/icons.js.map +1 -0
- package/dist/src/assets/img/wordmark-stacked.d.ts +2 -0
- package/dist/src/assets/img/wordmark-stacked.js +13 -0
- package/dist/src/assets/img/wordmark-stacked.js.map +1 -0
- package/dist/src/data/menus.d.ts +20 -0
- package/dist/src/data/menus.js +668 -0
- package/dist/src/data/menus.js.map +1 -0
- package/dist/src/desktop-subnav.d.ts +11 -0
- package/dist/src/desktop-subnav.js +55 -0
- package/dist/src/desktop-subnav.js.map +1 -0
- package/dist/src/dropdown-menu.d.ts +19 -0
- package/dist/src/dropdown-menu.js +116 -0
- package/dist/src/dropdown-menu.js.map +1 -0
- package/dist/src/ia-topnav.d.ts +68 -0
- package/dist/src/ia-topnav.js +315 -0
- package/dist/src/ia-topnav.js.map +1 -0
- package/dist/src/lib/formatUrl.d.ts +2 -0
- package/dist/src/lib/formatUrl.js +2 -0
- package/dist/src/lib/formatUrl.js.map +1 -0
- package/dist/src/lib/keyboard-navigation.d.ts +50 -0
- package/dist/src/lib/keyboard-navigation.js +136 -0
- package/dist/src/lib/keyboard-navigation.js.map +1 -0
- package/dist/src/lib/location-handler.d.ts +1 -0
- package/dist/src/lib/location-handler.js +5 -0
- package/dist/src/lib/location-handler.js.map +1 -0
- package/dist/src/lib/makeBooleanString.d.ts +2 -0
- package/dist/src/lib/makeBooleanString.js +12 -0
- package/dist/src/lib/makeBooleanString.js.map +1 -0
- package/dist/src/lib/query-handler.d.ts +4 -0
- package/dist/src/lib/query-handler.js +7 -0
- package/dist/src/lib/query-handler.js.map +1 -0
- package/dist/src/lib/toSentenceCase.d.ts +2 -0
- package/dist/src/lib/toSentenceCase.js +10 -0
- package/dist/src/lib/toSentenceCase.js.map +1 -0
- package/dist/src/login-button.d.ts +16 -0
- package/dist/src/login-button.js +83 -0
- package/dist/src/login-button.js.map +1 -0
- package/dist/src/media-button.d.ts +24 -0
- package/dist/src/media-button.js +119 -0
- package/dist/src/media-button.js.map +1 -0
- package/dist/src/media-menu.d.ts +20 -0
- package/dist/src/media-menu.js +148 -0
- package/dist/src/media-menu.js.map +1 -0
- package/dist/src/media-slider.d.ts +15 -0
- package/dist/src/media-slider.js +139 -0
- package/dist/src/media-slider.js.map +1 -0
- package/dist/src/media-subnav.d.ts +18 -0
- package/dist/src/media-subnav.js +126 -0
- package/dist/src/media-subnav.js.map +1 -0
- package/dist/src/models.d.ts +51 -0
- package/dist/src/models.js +25 -0
- package/dist/src/models.js.map +1 -0
- package/dist/src/more-slider.d.ts +10 -0
- package/dist/src/more-slider.js +50 -0
- package/dist/src/more-slider.js.map +1 -0
- package/dist/src/nav-search.d.ts +19 -0
- package/dist/src/nav-search.js +124 -0
- package/dist/src/nav-search.js.map +1 -0
- package/dist/src/primary-nav.d.ts +45 -0
- package/dist/src/primary-nav.js +280 -0
- package/dist/src/primary-nav.js.map +1 -0
- package/dist/src/save-page-form.d.ts +10 -0
- package/dist/src/save-page-form.js +63 -0
- package/dist/src/save-page-form.js.map +1 -0
- package/dist/src/search-menu.d.ts +20 -0
- package/dist/src/search-menu.js +162 -0
- package/dist/src/search-menu.js.map +1 -0
- package/dist/src/signed-out-dropdown.d.ts +4 -0
- package/dist/src/signed-out-dropdown.js +15 -0
- package/dist/src/signed-out-dropdown.js.map +1 -0
- package/dist/src/styles/base.d.ts +1 -0
- package/dist/src/styles/base.js +48 -0
- package/dist/src/styles/base.js.map +1 -0
- package/dist/src/styles/desktop-subnav.d.ts +2 -0
- package/dist/src/styles/desktop-subnav.js +37 -0
- package/dist/src/styles/desktop-subnav.js.map +1 -0
- package/dist/src/styles/dropdown-menu.d.ts +2 -0
- package/dist/src/styles/dropdown-menu.js +170 -0
- package/dist/src/styles/dropdown-menu.js.map +1 -0
- package/dist/src/styles/ia-topnav.d.ts +2 -0
- package/dist/src/styles/ia-topnav.js +87 -0
- package/dist/src/styles/ia-topnav.js.map +1 -0
- package/dist/src/styles/login-button.d.ts +2 -0
- package/dist/src/styles/login-button.js +82 -0
- package/dist/src/styles/login-button.js.map +1 -0
- package/dist/src/styles/media-button.d.ts +2 -0
- package/dist/src/styles/media-button.js +156 -0
- package/dist/src/styles/media-button.js.map +1 -0
- package/dist/src/styles/media-menu.d.ts +2 -0
- package/dist/src/styles/media-menu.js +66 -0
- package/dist/src/styles/media-menu.js.map +1 -0
- package/dist/src/styles/media-slider.d.ts +2 -0
- package/dist/src/styles/media-slider.js +81 -0
- package/dist/src/styles/media-slider.js.map +1 -0
- package/dist/src/styles/media-subnav.d.ts +2 -0
- package/dist/src/styles/media-subnav.js +159 -0
- package/dist/src/styles/media-subnav.js.map +1 -0
- package/dist/src/styles/more-slider.d.ts +2 -0
- package/dist/src/styles/more-slider.js +15 -0
- package/dist/src/styles/more-slider.js.map +1 -0
- package/dist/src/styles/nav-search.d.ts +2 -0
- package/dist/src/styles/nav-search.js +136 -0
- package/dist/src/styles/nav-search.js.map +1 -0
- package/dist/src/styles/primary-nav.d.ts +2 -0
- package/dist/src/styles/primary-nav.js +310 -0
- package/dist/src/styles/primary-nav.js.map +1 -0
- package/dist/src/styles/save-page-form.d.ts +2 -0
- package/dist/src/styles/save-page-form.js +54 -0
- package/dist/src/styles/save-page-form.js.map +1 -0
- package/dist/src/styles/search-menu.d.ts +2 -0
- package/dist/src/styles/search-menu.js +105 -0
- package/dist/src/styles/search-menu.js.map +1 -0
- package/dist/src/styles/signed-out-dropdown.d.ts +2 -0
- package/dist/src/styles/signed-out-dropdown.js +31 -0
- package/dist/src/styles/signed-out-dropdown.js.map +1 -0
- package/dist/src/styles/user-menu.d.ts +2 -0
- package/dist/src/styles/user-menu.js +31 -0
- package/dist/src/styles/user-menu.js.map +1 -0
- package/dist/src/styles/wayback-search.d.ts +2 -0
- package/dist/src/styles/wayback-search.js +48 -0
- package/dist/src/styles/wayback-search.js.map +1 -0
- package/dist/src/styles/wayback-slider.d.ts +2 -0
- package/dist/src/styles/wayback-slider.js +33 -0
- package/dist/src/styles/wayback-slider.js.map +1 -0
- package/dist/src/tracked-element.d.ts +5 -0
- package/dist/src/tracked-element.js +30 -0
- package/dist/src/tracked-element.js.map +1 -0
- package/dist/src/user-menu.d.ts +10 -0
- package/dist/src/user-menu.js +60 -0
- package/dist/src/user-menu.js.map +1 -0
- package/dist/src/wayback-search.d.ts +4 -0
- package/dist/src/wayback-search.js +14 -0
- package/dist/src/wayback-search.js.map +1 -0
- package/dist/src/wayback-slider.d.ts +18 -0
- package/dist/src/wayback-slider.js +99 -0
- package/dist/src/wayback-slider.js.map +1 -0
- package/dist/test/assets/img/hamburger.test.d.ts +1 -0
- package/dist/test/assets/img/hamburger.test.js +13 -0
- package/dist/test/assets/img/hamburger.test.js.map +1 -0
- package/dist/test/data/menus.test.d.ts +1 -0
- package/dist/test/data/menus.test.js +11 -0
- package/dist/test/data/menus.test.js.map +1 -0
- package/dist/test/dropdown-menu.test.d.ts +1 -0
- package/dist/test/dropdown-menu.test.js +20 -0
- package/dist/test/dropdown-menu.test.js.map +1 -0
- package/dist/test/ia-icon.test.d.ts +1 -0
- package/dist/test/ia-icon.test.js +11 -0
- package/dist/test/ia-icon.test.js.map +1 -0
- package/dist/test/ia-topnav.test.d.ts +1 -0
- package/dist/test/ia-topnav.test.js +232 -0
- package/dist/test/ia-topnav.test.js.map +1 -0
- package/dist/test/login-button.test.d.ts +1 -0
- package/dist/test/login-button.test.js +14 -0
- package/dist/test/login-button.test.js.map +1 -0
- package/dist/test/media-button.test.d.ts +1 -0
- package/dist/test/media-button.test.js +13 -0
- package/dist/test/media-button.test.js.map +1 -0
- package/dist/test/media-menu.test.d.ts +1 -0
- package/dist/test/media-menu.test.js +27 -0
- package/dist/test/media-menu.test.js.map +1 -0
- package/dist/test/media-slider.test.d.ts +1 -0
- package/dist/test/media-slider.test.js +47 -0
- package/dist/test/media-slider.test.js.map +1 -0
- package/dist/test/more-slider.test.d.ts +1 -0
- package/dist/test/more-slider.test.js +17 -0
- package/dist/test/more-slider.test.js.map +1 -0
- package/dist/test/nav-search.test.d.ts +1 -0
- package/dist/test/nav-search.test.js +47 -0
- package/dist/test/nav-search.test.js.map +1 -0
- package/dist/test/primary-nav.test.d.ts +1 -0
- package/dist/test/primary-nav.test.js +55 -0
- package/dist/test/primary-nav.test.js.map +1 -0
- package/dist/test/save-page-form.test.d.ts +1 -0
- package/dist/test/save-page-form.test.js +47 -0
- package/dist/test/save-page-form.test.js.map +1 -0
- package/dist/test/search-menu.test.d.ts +1 -0
- package/dist/test/search-menu.test.js +42 -0
- package/dist/test/search-menu.test.js.map +1 -0
- package/dist/test/user-menu.test.d.ts +1 -0
- package/dist/test/user-menu.test.js +28 -0
- package/dist/test/user-menu.test.js.map +1 -0
- package/dist/test/wayback-slider.test.d.ts +1 -0
- package/dist/test/wayback-slider.test.js +80 -0
- package/dist/test/wayback-slider.test.js.map +1 -0
- package/eslint.config.mjs +53 -0
- package/package.json +47 -37
- package/prettier.config.js +9 -0
- package/src/assets/img/hamburger.ts +49 -0
- package/src/assets/img/{ia-icon.js → ia-icon.ts} +7 -16
- package/src/assets/img/{icon-audio.js → icon-audio.ts} +7 -2
- package/src/assets/img/icon-close.ts +20 -0
- package/src/assets/img/icon-donate-unpadded.ts +19 -0
- package/src/assets/img/icon-donate.ts +18 -0
- package/src/assets/img/icon-ellipses.ts +19 -0
- package/src/assets/img/icon-ia-logo.ts +30 -0
- package/src/assets/img/icon-images.ts +19 -0
- package/src/assets/img/icon-search.ts +19 -0
- package/src/assets/img/icon-software.ts +18 -0
- package/src/assets/img/icon-texts.ts +18 -0
- package/src/assets/img/{icon-upload-unpadded.js → icon-upload-unpadded.ts} +6 -2
- package/src/assets/img/icon-upload.ts +21 -0
- package/src/assets/img/icon-user.ts +19 -0
- package/src/assets/img/icon-video.ts +19 -0
- package/src/assets/img/icon-web.ts +19 -0
- package/src/assets/img/icon.ts +8 -0
- package/src/assets/img/icons.ts +33 -0
- package/src/assets/img/{wordmark-stacked.js → wordmark-stacked.ts} +1 -1
- package/src/data/{menus.js → menus.ts} +172 -135
- package/src/desktop-subnav.ts +49 -0
- package/src/dropdown-menu.ts +106 -0
- package/src/{ia-topnav.js → ia-topnav.ts} +130 -127
- package/src/lib/formatUrl.ts +2 -0
- package/src/lib/{keyboard-navigation.js → keyboard-navigation.ts} +53 -23
- package/src/lib/location-handler.ts +5 -0
- package/src/lib/makeBooleanString.ts +12 -0
- package/src/lib/query-handler.ts +7 -0
- package/src/lib/toSentenceCase.ts +10 -0
- package/src/{login-button.js → login-button.ts} +27 -31
- package/src/{media-button.js → media-button.ts} +39 -49
- package/src/media-menu.ts +143 -0
- package/src/{media-slider.js → media-slider.ts} +53 -41
- package/src/media-subnav.ts +132 -0
- package/src/models.ts +114 -0
- package/src/more-slider.ts +42 -0
- package/src/nav-search.ts +114 -0
- package/src/primary-nav.ts +266 -0
- package/src/save-page-form.ts +59 -0
- package/src/search-menu.ts +156 -0
- package/src/signed-out-dropdown.ts +11 -0
- package/src/styles/{base.js → base.ts} +2 -2
- package/src/styles/{desktop-subnav.js → desktop-subnav.ts} +2 -2
- package/src/styles/{dropdown-menu.js → dropdown-menu.ts} +4 -2
- package/src/styles/{ia-topnav.js → ia-topnav.ts} +1 -1
- package/src/styles/{login-button.js → login-button.ts} +1 -1
- package/src/styles/{media-button.js → media-button.ts} +2 -2
- package/src/styles/{media-menu.js → media-menu.ts} +1 -1
- package/src/styles/{media-slider.js → media-slider.ts} +1 -1
- package/src/styles/media-subnav.ts +159 -0
- package/src/styles/{more-slider.js → more-slider.ts} +1 -1
- package/src/styles/{nav-search.js → nav-search.ts} +2 -2
- package/src/styles/{primary-nav.js → primary-nav.ts} +2 -3
- package/src/styles/{save-page-form.js → save-page-form.ts} +7 -7
- package/src/styles/{search-menu.js → search-menu.ts} +1 -1
- package/src/styles/{signed-out-dropdown.js → signed-out-dropdown.ts} +1 -1
- package/src/styles/{user-menu.js → user-menu.ts} +1 -1
- package/src/styles/{wayback-search.js → wayback-search.ts} +3 -3
- package/src/styles/wayback-slider.ts +33 -0
- package/src/tracked-element.ts +32 -0
- package/src/user-menu.ts +57 -0
- package/src/wayback-search.ts +10 -0
- package/src/wayback-slider.ts +88 -0
- package/ssl/server.crt +22 -0
- package/ssl/server.key +28 -0
- package/test/assets/img/hamburger.test.ts +18 -0
- package/test/data/menus.test.ts +15 -0
- package/test/{dropdown-menu.test.js → dropdown-menu.test.ts} +5 -7
- package/test/{ia-icon.test.js → ia-icon.test.ts} +6 -4
- package/test/ia-topnav.test.ts +344 -0
- package/test/login-button.test.ts +19 -0
- package/test/media-button.test.ts +19 -0
- package/test/{media-menu.test.js → media-menu.test.ts} +14 -12
- package/test/media-slider.test.ts +63 -0
- package/test/more-slider.test.ts +21 -0
- package/test/nav-search.test.ts +70 -0
- package/test/primary-nav.test.ts +94 -0
- package/test/save-page-form.test.ts +62 -0
- package/test/{search-menu.test.js → search-menu.test.ts} +19 -10
- package/test/{user-menu.test.js → user-menu.test.ts} +10 -9
- package/test/wayback-slider.test.ts +97 -0
- package/tsconfig.json +31 -0
- package/web-dev-server.config.mjs +32 -0
- package/web-test-runner.config.mjs +41 -0
- package/.eslintrc +0 -16
- package/index.d.ts +0 -109
- package/src/assets/img/hamburger.js +0 -38
- package/src/assets/img/icon-close.js +0 -16
- package/src/assets/img/icon-donate-unpadded.js +0 -16
- package/src/assets/img/icon-donate.js +0 -15
- package/src/assets/img/icon-ellipses.js +0 -15
- package/src/assets/img/icon-ia-logo.js +0 -22
- package/src/assets/img/icon-images.js +0 -15
- package/src/assets/img/icon-search.js +0 -15
- package/src/assets/img/icon-software.js +0 -15
- package/src/assets/img/icon-texts.js +0 -15
- package/src/assets/img/icon-upload.js +0 -15
- package/src/assets/img/icon-user.js +0 -15
- package/src/assets/img/icon-video.js +0 -15
- package/src/assets/img/icon-web.js +0 -15
- package/src/assets/img/icon.js +0 -18
- package/src/assets/img/icons.js +0 -33
- package/src/desktop-subnav.js +0 -45
- package/src/dropdown-menu.js +0 -110
- package/src/lib/formatUrl.js +0 -1
- package/src/lib/location-handler.js +0 -5
- package/src/lib/query-handler.js +0 -7
- package/src/lib/toSentenceCase.js +0 -8
- package/src/media-menu.js +0 -154
- package/src/media-subnav.js +0 -112
- package/src/more-slider.js +0 -33
- package/src/nav-search.js +0 -111
- package/src/primary-nav.js +0 -258
- package/src/save-page-form.js +0 -59
- package/src/search-menu.js +0 -145
- package/src/signed-out-dropdown.js +0 -10
- package/src/styles/media-subnav.js +0 -156
- package/src/styles/wayback-slider.js +0 -30
- package/src/tracked-element.js +0 -29
- package/src/user-menu.js +0 -56
- package/src/wayback-search.js +0 -18
- package/src/wayback-slider.js +0 -87
- package/test/assets/img/hamburger.test.js +0 -15
- package/test/assets/img/user.test.js +0 -15
- package/test/data/menus.test.js +0 -19
- package/test/ia-topnav.test.js +0 -273
- package/test/login-button.test.js +0 -15
- package/test/media-button.test.js +0 -19
- package/test/media-slider.test.js +0 -57
- package/test/more-slider.test.js +0 -13
- package/test/nav-search.test.js +0 -61
- package/test/primary-nav.test.js +0 -82
- package/test/save-page-form.test.js +0 -35
- package/test/wayback-slider.test.js +0 -80
- /package/{index.js → index.ts} +0 -0
package/test/ia-topnav.test.js
DELETED
|
@@ -1,273 +0,0 @@
|
|
|
1
|
-
import {
|
|
2
|
-
html,
|
|
3
|
-
fixture,
|
|
4
|
-
expect,
|
|
5
|
-
oneEvent,
|
|
6
|
-
fixtureCleanup,
|
|
7
|
-
elementUpdated
|
|
8
|
-
} from '@open-wc/testing';
|
|
9
|
-
|
|
10
|
-
import '../src/ia-topnav';
|
|
11
|
-
|
|
12
|
-
const container = ({
|
|
13
|
-
username = '',
|
|
14
|
-
screenName = '',
|
|
15
|
-
config = {},
|
|
16
|
-
localLinks = true,
|
|
17
|
-
secondIdentitySlotMode = ''
|
|
18
|
-
} = {}) => (
|
|
19
|
-
html`<ia-topnav
|
|
20
|
-
.screenName=${screenName}
|
|
21
|
-
username=${username}
|
|
22
|
-
localLinks=${localLinks}
|
|
23
|
-
.config=${config}
|
|
24
|
-
.secondIdentitySlotMode=${secondIdentitySlotMode}
|
|
25
|
-
></ia-topnav>`
|
|
26
|
-
);
|
|
27
|
-
|
|
28
|
-
const verifyClosed = (instance) => {
|
|
29
|
-
expect(instance.mediaSliderOpen).to.be.false;
|
|
30
|
-
expect(instance.selectedMenuOption).to.equal('');
|
|
31
|
-
};
|
|
32
|
-
|
|
33
|
-
const verifyOpened = (instance, mediatype) => {
|
|
34
|
-
expect(instance.mediaSliderOpen).to.be.true;
|
|
35
|
-
expect(instance.selectedMenuOption).to.equal(mediatype);
|
|
36
|
-
};
|
|
37
|
-
|
|
38
|
-
afterEach(() => {
|
|
39
|
-
fixtureCleanup();
|
|
40
|
-
});
|
|
41
|
-
|
|
42
|
-
describe('<ia-topnav>', () => {
|
|
43
|
-
it('assigns a value to "search in" from outside event', async () => {
|
|
44
|
-
const el = await fixture(container());
|
|
45
|
-
const query = 'atari';
|
|
46
|
-
const searchMenu = el
|
|
47
|
-
.shadowRoot
|
|
48
|
-
.querySelector('search-menu');
|
|
49
|
-
|
|
50
|
-
searchMenu.searchInChanged({
|
|
51
|
-
target: {
|
|
52
|
-
value: query
|
|
53
|
-
}
|
|
54
|
-
});
|
|
55
|
-
await el.updateComplete;
|
|
56
|
-
|
|
57
|
-
expect(el.searchIn).to.equal(query);
|
|
58
|
-
});
|
|
59
|
-
|
|
60
|
-
it('dispatches an analyticsClick event when trackClick event fired', async () => {
|
|
61
|
-
const el = await fixture(container());
|
|
62
|
-
const clickEvent = new MouseEvent('click');
|
|
63
|
-
|
|
64
|
-
setTimeout(() => (
|
|
65
|
-
el
|
|
66
|
-
.shadowRoot
|
|
67
|
-
.querySelector('primary-nav')
|
|
68
|
-
.shadowRoot
|
|
69
|
-
.querySelector('.hamburger')
|
|
70
|
-
.dispatchEvent(clickEvent)
|
|
71
|
-
));
|
|
72
|
-
const response = await oneEvent(el, 'trackClick');
|
|
73
|
-
|
|
74
|
-
expect(response).to.exist;
|
|
75
|
-
});
|
|
76
|
-
|
|
77
|
-
it('dispatches an analyticsSubmit event when trackSubmit event fired', async () => {
|
|
78
|
-
const el = await fixture(container());
|
|
79
|
-
const submitEvent = new Event('submit');
|
|
80
|
-
const form = el
|
|
81
|
-
.shadowRoot
|
|
82
|
-
.querySelector('primary-nav')
|
|
83
|
-
.shadowRoot
|
|
84
|
-
.querySelector('nav-search')
|
|
85
|
-
.shadowRoot
|
|
86
|
-
.querySelector('form');
|
|
87
|
-
|
|
88
|
-
form.addEventListener('submit', e => e.preventDefault());
|
|
89
|
-
form.querySelector('[name=query]').value = 'atari';
|
|
90
|
-
setTimeout(() => form.dispatchEvent(submitEvent));
|
|
91
|
-
const response = await oneEvent(el, 'trackSubmit');
|
|
92
|
-
|
|
93
|
-
expect(response).to.exist;
|
|
94
|
-
});
|
|
95
|
-
|
|
96
|
-
it('closes all menus when close-layer clicked', async () => {
|
|
97
|
-
const el = await fixture(container());
|
|
98
|
-
|
|
99
|
-
el.openMenu = 'media';
|
|
100
|
-
el.selectedMenuOption = 'texts';
|
|
101
|
-
el.mediaSliderOpen = true;
|
|
102
|
-
await el.updateComplete;
|
|
103
|
-
el.closeMenus();
|
|
104
|
-
await el.updateComplete;
|
|
105
|
-
|
|
106
|
-
expect(el.mediaSliderOpen).to.be.false;
|
|
107
|
-
expect(el.openMenu).to.equal('');
|
|
108
|
-
expect(el.selectedMenuOption).to.equal('');
|
|
109
|
-
});
|
|
110
|
-
|
|
111
|
-
it('sets media slider to closed', async () => {
|
|
112
|
-
const el = await fixture(container());
|
|
113
|
-
|
|
114
|
-
el.mediaSliderOpen = true;
|
|
115
|
-
el.selectedMenuOption = 'foo';
|
|
116
|
-
el.closeMediaSlider();
|
|
117
|
-
|
|
118
|
-
verifyClosed(el);
|
|
119
|
-
});
|
|
120
|
-
|
|
121
|
-
it('toggles media slider visibility and starts animation', async () => {
|
|
122
|
-
const el = await fixture(container());
|
|
123
|
-
const mediatype = 'foo';
|
|
124
|
-
|
|
125
|
-
el.selectedMenuOption = mediatype;
|
|
126
|
-
el.openMediaSlider();
|
|
127
|
-
|
|
128
|
-
verifyOpened(el, mediatype);
|
|
129
|
-
});
|
|
130
|
-
|
|
131
|
-
it('closes media slider if selected menu type is the open menu type', async () => {
|
|
132
|
-
const el = await fixture(container());
|
|
133
|
-
const mediatype = 'foo';
|
|
134
|
-
|
|
135
|
-
el.selectedMenuOption = mediatype;
|
|
136
|
-
el.mediaTypeSelected({
|
|
137
|
-
detail: {
|
|
138
|
-
mediatype
|
|
139
|
-
}
|
|
140
|
-
});
|
|
141
|
-
|
|
142
|
-
verifyClosed(el);
|
|
143
|
-
});
|
|
144
|
-
|
|
145
|
-
it('opens media slider menu and starts animation', async () => {
|
|
146
|
-
const el = await fixture(container());
|
|
147
|
-
const mediatype = 'foo';
|
|
148
|
-
|
|
149
|
-
el.mediaTypeSelected({
|
|
150
|
-
detail: {
|
|
151
|
-
mediatype
|
|
152
|
-
}
|
|
153
|
-
});
|
|
154
|
-
|
|
155
|
-
verifyOpened(el, mediatype);
|
|
156
|
-
});
|
|
157
|
-
|
|
158
|
-
it('closes slider when menu closed', async () => {
|
|
159
|
-
const el = await fixture(container());
|
|
160
|
-
|
|
161
|
-
el.openMenu = 'media';
|
|
162
|
-
el.selectedMenuOption = 'foo';
|
|
163
|
-
el.mediaSliderOpen = true;
|
|
164
|
-
await el.updateComplete;
|
|
165
|
-
|
|
166
|
-
el.menuToggled({ detail: { menuName: '' } });
|
|
167
|
-
await el.updateComplete;
|
|
168
|
-
|
|
169
|
-
expect(el.selectedMenuOption).to.equal('');
|
|
170
|
-
});
|
|
171
|
-
|
|
172
|
-
it('toggles search menu tabindex when dropdown open', async () => {
|
|
173
|
-
const el = await fixture(container());
|
|
174
|
-
|
|
175
|
-
el.openMenu = 'search';
|
|
176
|
-
await el.updateComplete;
|
|
177
|
-
|
|
178
|
-
expect(el.shadowRoot.querySelector('search-menu').getAttribute('tabindex')).to.equal('');
|
|
179
|
-
});
|
|
180
|
-
|
|
181
|
-
it('toggles user menu tabindex when dropdown open', async () => {
|
|
182
|
-
const el = await fixture(container({ username: 'shaneriley' }));
|
|
183
|
-
|
|
184
|
-
el.openMenu = 'user';
|
|
185
|
-
await el.updateComplete;
|
|
186
|
-
|
|
187
|
-
expect(el.shadowRoot.querySelector('user-menu').getAttribute('tabindex')).to.equal('');
|
|
188
|
-
});
|
|
189
|
-
|
|
190
|
-
it('toggles signed out menu tabindex when dropdown open', async () => {
|
|
191
|
-
const el = await fixture(container());
|
|
192
|
-
|
|
193
|
-
el.openMenu = 'login';
|
|
194
|
-
await el.updateComplete;
|
|
195
|
-
|
|
196
|
-
expect(el.shadowRoot.querySelector('signed-out-dropdown').getAttribute('tabindex')).to.equal('');
|
|
197
|
-
});
|
|
198
|
-
|
|
199
|
-
it('toggles search menu when search toggle button clicked', async () => {
|
|
200
|
-
const el = await fixture(container());
|
|
201
|
-
el.shadowRoot.querySelector('primary-nav').shadowRoot.querySelector('.search-trigger').click();
|
|
202
|
-
await el.updateComplete;
|
|
203
|
-
|
|
204
|
-
expect(el.openMenu).to.equal('search');
|
|
205
|
-
});
|
|
206
|
-
|
|
207
|
-
it('toggles user menu when search user avatar clicked', async () => {
|
|
208
|
-
const el = await fixture(container({
|
|
209
|
-
username: 'shaneriley',
|
|
210
|
-
screenName: 'shaneriley',
|
|
211
|
-
}));
|
|
212
|
-
|
|
213
|
-
el.shadowRoot.querySelector('primary-nav').shadowRoot.querySelector('.user-menu').click();
|
|
214
|
-
await el.updateComplete;
|
|
215
|
-
|
|
216
|
-
expect(el.openMenu).to.equal('user');
|
|
217
|
-
});
|
|
218
|
-
|
|
219
|
-
it('uses localLinks for archive.org logo link', async () => {
|
|
220
|
-
const el = await fixture(container({ localLinks: false }));
|
|
221
|
-
const logoLink = el
|
|
222
|
-
.shadowRoot
|
|
223
|
-
.querySelector('primary-nav')
|
|
224
|
-
.shadowRoot
|
|
225
|
-
.querySelector('.link-home');
|
|
226
|
-
expect(logoLink.getAttribute('href')).to.match(/\/\/archive\.org/);
|
|
227
|
-
});
|
|
228
|
-
|
|
229
|
-
describe('sets localLinks properly', async () => {
|
|
230
|
-
it('uses localLinks to archive.org links on common child components', async () => {
|
|
231
|
-
const el = await fixture(container({ localLinks: false }));
|
|
232
|
-
const componentSelectors = ['primary-nav', 'media-slider', 'desktop-subnav', 'search-menu'];
|
|
233
|
-
componentSelectors.forEach((selector) => {
|
|
234
|
-
const component = el.shadowRoot.querySelector(selector);
|
|
235
|
-
expect(component.baseHost).to.equal('https://archive.org');
|
|
236
|
-
});
|
|
237
|
-
});
|
|
238
|
-
|
|
239
|
-
it('uses localLinks to archive.org links on the signed out dropdown', async () => {
|
|
240
|
-
const el = await fixture(container({ localLinks: false }));
|
|
241
|
-
const signedOutDropdown = el.shadowRoot.querySelector('signed-out-dropdown');
|
|
242
|
-
expect(signedOutDropdown.baseHost).to.equal('https://archive.org');
|
|
243
|
-
});
|
|
244
|
-
|
|
245
|
-
it('uses localLinks to archive.org links on the user dropdown', async () => {
|
|
246
|
-
const el = await fixture(container({ username: 'foo', localLinks: false }));
|
|
247
|
-
const signedOutDropdown = el.shadowRoot.querySelector('user-menu');
|
|
248
|
-
expect(signedOutDropdown.baseHost).to.equal('https://archive.org');
|
|
249
|
-
});
|
|
250
|
-
});
|
|
251
|
-
|
|
252
|
-
describe('slot pass throughs', () => {
|
|
253
|
-
describe('slot for <primary-nav>', () => {
|
|
254
|
-
it('opens a slot with `secondIdentitySlotMode`', async () => {
|
|
255
|
-
const el = await fixture(container({
|
|
256
|
-
localLinks: false,
|
|
257
|
-
username: 'boop',
|
|
258
|
-
screenName: 'somesuperlongscreenname',
|
|
259
|
-
secondIdentitySlotMode: 'allow'
|
|
260
|
-
}));
|
|
261
|
-
|
|
262
|
-
const slot = el.shadowRoot.querySelector('primary-nav').querySelector('slot');
|
|
263
|
-
expect(slot).to.exist;
|
|
264
|
-
expect(slot.getAttribute('name')).to.equal('opt-sec-logo');
|
|
265
|
-
|
|
266
|
-
el.secondIdentitySlotMode = '';
|
|
267
|
-
await elementUpdated(el);
|
|
268
|
-
const noSlot = el.shadowRoot.querySelector('primary-nav').querySelector('slot');
|
|
269
|
-
expect(noSlot).to.not.exist;
|
|
270
|
-
});
|
|
271
|
-
});
|
|
272
|
-
});
|
|
273
|
-
});
|
|
@@ -1,15 +0,0 @@
|
|
|
1
|
-
import { html, fixture, expect } from '@open-wc/testing';
|
|
2
|
-
import '../src/login-button';
|
|
3
|
-
|
|
4
|
-
const component = html`<login-button></login-button>`;
|
|
5
|
-
|
|
6
|
-
describe('<login-button>', () => {
|
|
7
|
-
it('toggles active class when avatar clicked', async () => {
|
|
8
|
-
const el = await fixture(component);
|
|
9
|
-
|
|
10
|
-
el.shadowRoot.querySelector('.dropdown-toggle').click();
|
|
11
|
-
await el.updateComplete;
|
|
12
|
-
|
|
13
|
-
expect(el.shadowRoot.querySelector('.active')).to.not.be.undefined;
|
|
14
|
-
});
|
|
15
|
-
});
|
|
@@ -1,19 +0,0 @@
|
|
|
1
|
-
import {
|
|
2
|
-
html,
|
|
3
|
-
fixture,
|
|
4
|
-
expect,
|
|
5
|
-
oneEvent,
|
|
6
|
-
} from '@open-wc/testing';
|
|
7
|
-
|
|
8
|
-
import '../src/media-button';
|
|
9
|
-
|
|
10
|
-
describe('<media-button>', () => {
|
|
11
|
-
it('emits an event when button pressed', async () => {
|
|
12
|
-
const el = await fixture(html`<media-button></media-button>`);
|
|
13
|
-
|
|
14
|
-
setTimeout(() => el.shadowRoot.querySelector('.menu-item').click());
|
|
15
|
-
const response = await oneEvent(el, 'mediaTypeSelected');
|
|
16
|
-
|
|
17
|
-
expect(response).to.exist;
|
|
18
|
-
});
|
|
19
|
-
});
|
|
@@ -1,57 +0,0 @@
|
|
|
1
|
-
import { html, fixture, expect } from '@open-wc/testing';
|
|
2
|
-
|
|
3
|
-
import '../src/media-slider';
|
|
4
|
-
import { buildTopNavMenus } from '../../src/data/menus.js';
|
|
5
|
-
|
|
6
|
-
const menus = buildTopNavMenus();
|
|
7
|
-
|
|
8
|
-
const component = (mediaSliderOpen, selectedMenuOption) => (
|
|
9
|
-
html`<media-slider
|
|
10
|
-
?mediaSliderOpen="${mediaSliderOpen}"
|
|
11
|
-
selectedMenuOption="${selectedMenuOption}"
|
|
12
|
-
.menus=${menus}></media-slider>`
|
|
13
|
-
);
|
|
14
|
-
|
|
15
|
-
describe('<media-slider>', () => {
|
|
16
|
-
it('sets default properties', async () => {
|
|
17
|
-
const mediaSlider = await fixture(component(false, ''));
|
|
18
|
-
|
|
19
|
-
expect(mediaSlider.mediaSliderOpen).to.be.false;
|
|
20
|
-
expect(mediaSlider.selectedMenuOption).to.equal('');
|
|
21
|
-
});
|
|
22
|
-
|
|
23
|
-
it('renders a media subnav when texts selected', async () => {
|
|
24
|
-
const mediaSlider = await fixture(component(false, 'texts'));
|
|
25
|
-
const menuHeading = mediaSlider.shadowRoot.querySelector('media-subnav[menu=texts]').shadowRoot.querySelector('h3');
|
|
26
|
-
|
|
27
|
-
expect(menuHeading.innerText).to.equal(menus.texts.heading);
|
|
28
|
-
});
|
|
29
|
-
|
|
30
|
-
it('renders a media subnav when audio selected', async () => {
|
|
31
|
-
const mediaSlider = await fixture(component(false, 'audio'));
|
|
32
|
-
const menuHeading = mediaSlider.shadowRoot.querySelector('media-subnav[menu=audio]').shadowRoot.querySelector('h3');
|
|
33
|
-
|
|
34
|
-
expect(menuHeading.innerText).to.equal(menus.audio.heading);
|
|
35
|
-
});
|
|
36
|
-
|
|
37
|
-
it('renders a media subnav when video selected', async () => {
|
|
38
|
-
const mediaSlider = await fixture(component(false, 'video'));
|
|
39
|
-
const menuHeading = mediaSlider.shadowRoot.querySelector('media-subnav[menu=video]').shadowRoot.querySelector('h3');
|
|
40
|
-
|
|
41
|
-
expect(menuHeading.innerText).to.equal(menus.video.heading);
|
|
42
|
-
});
|
|
43
|
-
|
|
44
|
-
it('renders the Wayback component when web menu selected', async () => {
|
|
45
|
-
const mediaSlider = await fixture(component(false, 'web'));
|
|
46
|
-
const waybackSearch = mediaSlider.shadowRoot.querySelector('media-subnav[menu=web]').shadowRoot.querySelector('wayback-search');
|
|
47
|
-
|
|
48
|
-
expect(waybackSearch).to.not.be.undefined;
|
|
49
|
-
});
|
|
50
|
-
|
|
51
|
-
it('renders the more links component when more menu selected', async () => {
|
|
52
|
-
const mediaSlider = await fixture(component(false, 'more'));
|
|
53
|
-
const moreSlider = mediaSlider.shadowRoot.querySelector('media-subnav[menu=more]').shadowRoot.querySelector('more-slider');
|
|
54
|
-
|
|
55
|
-
expect(moreSlider).to.not.be.undefined;
|
|
56
|
-
});
|
|
57
|
-
});
|
package/test/more-slider.test.js
DELETED
|
@@ -1,13 +0,0 @@
|
|
|
1
|
-
import { html, fixture, expect } from '@open-wc/testing';
|
|
2
|
-
import '../src/more-slider';
|
|
3
|
-
import { buildTopNavMenus } from '../../src/data/menus.js';
|
|
4
|
-
|
|
5
|
-
describe('<more-slider>', () => {
|
|
6
|
-
it('renders links with relative hrefs using baseHost', async () => {
|
|
7
|
-
const menus = buildTopNavMenus();
|
|
8
|
-
const baseHost = 'archive.org';
|
|
9
|
-
const el = await fixture(html`<more-slider .baseHost=${baseHost} .config=${{}} .menuItems=${menus.more}>`);
|
|
10
|
-
|
|
11
|
-
expect(el.shadowRoot.querySelector('a').getAttribute('href')).to.contain(baseHost);
|
|
12
|
-
});
|
|
13
|
-
});
|
package/test/nav-search.test.js
DELETED
|
@@ -1,61 +0,0 @@
|
|
|
1
|
-
import { html, fixture, expect } from '@open-wc/testing';
|
|
2
|
-
import sinon from 'sinon';
|
|
3
|
-
|
|
4
|
-
import '../src/nav-search';
|
|
5
|
-
|
|
6
|
-
const component = html`<nav-search></nav-search>`;
|
|
7
|
-
|
|
8
|
-
describe('<nav-search>', () => {
|
|
9
|
-
it('defaults to closed', async () => {
|
|
10
|
-
const el = await fixture(component);
|
|
11
|
-
|
|
12
|
-
expect(el.open).to.be.false;
|
|
13
|
-
});
|
|
14
|
-
|
|
15
|
-
it('does not allow search form to submit if query empty', async () => {
|
|
16
|
-
const el = await fixture(component);
|
|
17
|
-
|
|
18
|
-
const result = el.search({
|
|
19
|
-
preventDefault: () => {}
|
|
20
|
-
});
|
|
21
|
-
|
|
22
|
-
expect(result).to.be.false;
|
|
23
|
-
});
|
|
24
|
-
|
|
25
|
-
it('redirects to the TV details page when search inside is TV', async () => {
|
|
26
|
-
const query = 'bananas';
|
|
27
|
-
const submitEvent = {
|
|
28
|
-
type: 'submit',
|
|
29
|
-
preventDefault: () => {}
|
|
30
|
-
};
|
|
31
|
-
const locationHandler = sinon.fake();
|
|
32
|
-
const el = await fixture(html`<nav-search .locationHandler=${locationHandler}></nav-search>`);
|
|
33
|
-
|
|
34
|
-
el.searchIn = 'TV';
|
|
35
|
-
|
|
36
|
-
await el.updateComplete;
|
|
37
|
-
|
|
38
|
-
el.shadowRoot.querySelector('[name=query]').value = query;
|
|
39
|
-
el.search(submitEvent);
|
|
40
|
-
|
|
41
|
-
expect(locationHandler.callCount).to.equal(1);
|
|
42
|
-
expect(locationHandler.firstArg).to.contain(`/details/tv?q=${query}`);
|
|
43
|
-
});
|
|
44
|
-
|
|
45
|
-
it('prefills the search query when present in config', async () => {
|
|
46
|
-
const el = await fixture(html`<nav-search searchQuery='bananas'></nav-search>`);
|
|
47
|
-
|
|
48
|
-
expect(el.shadowRoot.querySelector('[name="query"]').value).to.equal('bananas');
|
|
49
|
-
});
|
|
50
|
-
|
|
51
|
-
it('conditionally renders `sin` input based on `searchIn` truthiness', async () => {
|
|
52
|
-
const el = await fixture(component);
|
|
53
|
-
|
|
54
|
-
expect(el.shadowRoot.querySelector('[name="sin"]')).to.be.null;
|
|
55
|
-
|
|
56
|
-
el.searchIn = 'TV';
|
|
57
|
-
await el.updateComplete;
|
|
58
|
-
|
|
59
|
-
expect(el.shadowRoot.querySelector('[name="sin"]')).not.to.be.null;
|
|
60
|
-
});
|
|
61
|
-
});
|
package/test/primary-nav.test.js
DELETED
|
@@ -1,82 +0,0 @@
|
|
|
1
|
-
import {
|
|
2
|
-
html, fixture, expect, fixtureCleanup, elementUpdated
|
|
3
|
-
} from '@open-wc/testing';
|
|
4
|
-
|
|
5
|
-
import '../src/primary-nav';
|
|
6
|
-
|
|
7
|
-
const component = ({
|
|
8
|
-
baseHost, username, screenName, hideSearch, config = {}, secondIdentitySlotMode
|
|
9
|
-
}) => (
|
|
10
|
-
html`
|
|
11
|
-
<primary-nav
|
|
12
|
-
.baseHost=${baseHost}
|
|
13
|
-
.username=${username}
|
|
14
|
-
.screenName=${screenName}
|
|
15
|
-
?hideSearch=${hideSearch}
|
|
16
|
-
.config=${config}
|
|
17
|
-
.secondIdentitySlotMode=${secondIdentitySlotMode}
|
|
18
|
-
></primary-nav>`
|
|
19
|
-
);
|
|
20
|
-
|
|
21
|
-
afterEach(() => {
|
|
22
|
-
fixtureCleanup();
|
|
23
|
-
});
|
|
24
|
-
|
|
25
|
-
describe('<primary-nav>', () => {
|
|
26
|
-
it('renders the login link when no username present', async () => {
|
|
27
|
-
const el = await fixture(component({
|
|
28
|
-
baseHost: 'archive.org',
|
|
29
|
-
username: '',
|
|
30
|
-
}));
|
|
31
|
-
|
|
32
|
-
expect(el.shadowRoot.querySelector('login-button')).to.not.be.undefined;
|
|
33
|
-
});
|
|
34
|
-
|
|
35
|
-
it('does not render search menu toggle and search form if hideSearch true', async () => {
|
|
36
|
-
const el = await fixture(component({
|
|
37
|
-
baseHost: 'archive.org',
|
|
38
|
-
username: 'shaneriley',
|
|
39
|
-
screenName: 'shaneriley',
|
|
40
|
-
hideSearch: true,
|
|
41
|
-
}));
|
|
42
|
-
|
|
43
|
-
expect(el.shadowRoot.querySelector('.search-trigger')).to.equal(null);
|
|
44
|
-
expect(el.shadowRoot.querySelector('nav-search')).to.equal(null);
|
|
45
|
-
});
|
|
46
|
-
|
|
47
|
-
it('truncates a long screenname', async () => {
|
|
48
|
-
const el = await fixture(component({
|
|
49
|
-
baseHost: 'archive.org',
|
|
50
|
-
username: 'boop',
|
|
51
|
-
screenName: 'somesuperlongscreenname'
|
|
52
|
-
}));
|
|
53
|
-
|
|
54
|
-
const usernameSpan = el.shadowRoot.querySelector('.username');
|
|
55
|
-
|
|
56
|
-
expect(usernameSpan.innerText).to.equal('somesuper…');
|
|
57
|
-
});
|
|
58
|
-
|
|
59
|
-
it('opens a slot with `secondIdentitySlotMode`', async () => {
|
|
60
|
-
const el = await fixture(component({
|
|
61
|
-
baseHost: 'archive.org',
|
|
62
|
-
username: 'boop',
|
|
63
|
-
screenName: 'somesuperlongscreenname',
|
|
64
|
-
secondIdentitySlotMode: 'allow'
|
|
65
|
-
}));
|
|
66
|
-
|
|
67
|
-
const brandingBlock = el.shadowRoot.querySelector('div.branding');
|
|
68
|
-
expect(brandingBlock.getAttribute('class')).to.contain('branding second-logo');
|
|
69
|
-
|
|
70
|
-
const slot = brandingBlock.querySelector('slot');
|
|
71
|
-
expect(slot).to.exist;
|
|
72
|
-
expect(slot.getAttribute('name')).to.equal('opt-sec-logo');
|
|
73
|
-
|
|
74
|
-
el.secondIdentitySlotMode = '';
|
|
75
|
-
await elementUpdated(el);
|
|
76
|
-
const noSlotBrandingBlock = el.shadowRoot.querySelector('div.branding');
|
|
77
|
-
expect(noSlotBrandingBlock.getAttribute('class')).to.contain('branding');
|
|
78
|
-
|
|
79
|
-
const noSlot = noSlotBrandingBlock.querySelector('slot');
|
|
80
|
-
expect(noSlot).to.not.exist;
|
|
81
|
-
});
|
|
82
|
-
});
|
|
@@ -1,35 +0,0 @@
|
|
|
1
|
-
import { html, fixture, expect } from '@open-wc/testing';
|
|
2
|
-
|
|
3
|
-
import '../src/save-page-form';
|
|
4
|
-
|
|
5
|
-
const component = html`<save-page-form></save-page-form>`;
|
|
6
|
-
|
|
7
|
-
describe('<save-page-form>', () => {
|
|
8
|
-
it('checks validity of URL value and shows an error when invalid', async () => {
|
|
9
|
-
const el = await fixture(component);
|
|
10
|
-
const urlInput = el.shadowRoot.querySelector('[name="url_preload"]');
|
|
11
|
-
const errorMessage = el.shadowRoot.querySelector('.error');
|
|
12
|
-
const submitEvent = {
|
|
13
|
-
type: 'submit',
|
|
14
|
-
target: el.shadowRoot.querySelector('form'),
|
|
15
|
-
preventDefault: () => {}
|
|
16
|
-
};
|
|
17
|
-
submitEvent.currentTarget = submitEvent.target;
|
|
18
|
-
|
|
19
|
-
urlInput.value = 'archive';
|
|
20
|
-
el.validateURL(submitEvent);
|
|
21
|
-
|
|
22
|
-
await el.updateComplete;
|
|
23
|
-
|
|
24
|
-
expect(el.inputValid).to.be.false;
|
|
25
|
-
expect(errorMessage.getAttribute('class')).to.contain('visible');
|
|
26
|
-
|
|
27
|
-
urlInput.value += '.org';
|
|
28
|
-
el.validateURL(submitEvent);
|
|
29
|
-
|
|
30
|
-
await el.updateComplete;
|
|
31
|
-
|
|
32
|
-
expect(el.inputValid).to.be.true;
|
|
33
|
-
expect(errorMessage.getAttribute('class')).not.to.contain('visible');
|
|
34
|
-
});
|
|
35
|
-
});
|
|
@@ -1,80 +0,0 @@
|
|
|
1
|
-
import { html, fixture, expect } from '@open-wc/testing';
|
|
2
|
-
|
|
3
|
-
import '../src/wayback-slider';
|
|
4
|
-
|
|
5
|
-
const component = ({
|
|
6
|
-
archiveItLinks,
|
|
7
|
-
browserExtensionsLinks,
|
|
8
|
-
config,
|
|
9
|
-
mobileAppsLinks
|
|
10
|
-
}) => (
|
|
11
|
-
html`
|
|
12
|
-
<wayback-slider
|
|
13
|
-
.baseHost='archive.org'
|
|
14
|
-
.config=${config}
|
|
15
|
-
.archiveItLinks=${archiveItLinks}
|
|
16
|
-
.browserExtensionsLinks=${browserExtensionsLinks}
|
|
17
|
-
.mobileAppsLinks=${mobileAppsLinks}
|
|
18
|
-
></wayback-slider>
|
|
19
|
-
`
|
|
20
|
-
);
|
|
21
|
-
|
|
22
|
-
const buildDefaults = () => ({
|
|
23
|
-
config: {},
|
|
24
|
-
archiveItLinks: [{
|
|
25
|
-
url: '1',
|
|
26
|
-
title: 'first'
|
|
27
|
-
}, {
|
|
28
|
-
url: '2',
|
|
29
|
-
title: 'second'
|
|
30
|
-
}],
|
|
31
|
-
browserExtensionsLinks: [{
|
|
32
|
-
url: '3',
|
|
33
|
-
title: 'third'
|
|
34
|
-
}, {
|
|
35
|
-
url: '4',
|
|
36
|
-
title: 'fourth'
|
|
37
|
-
}],
|
|
38
|
-
mobileAppsLinks: [{
|
|
39
|
-
url: '5',
|
|
40
|
-
title: 'fifth'
|
|
41
|
-
}, {
|
|
42
|
-
url: '6',
|
|
43
|
-
title: 'sixth'
|
|
44
|
-
}]
|
|
45
|
-
});
|
|
46
|
-
|
|
47
|
-
describe('<wayback-slider>', () => {
|
|
48
|
-
it('renders the links passed in via the archiveItLinks prop', async () => {
|
|
49
|
-
const options = buildDefaults();
|
|
50
|
-
const el = await fixture(component(options));
|
|
51
|
-
const anchors = el.shadowRoot.querySelectorAll('.archive-it a');
|
|
52
|
-
|
|
53
|
-
options.archiveItLinks.forEach((link, i) => {
|
|
54
|
-
expect(anchors[i].innerText).to.equal(link.title);
|
|
55
|
-
expect(anchors[i].getAttribute('href')).to.contain(link.url);
|
|
56
|
-
});
|
|
57
|
-
});
|
|
58
|
-
|
|
59
|
-
it('renders the links passed in via the browserExtensionsLinks prop', async () => {
|
|
60
|
-
const options = buildDefaults();
|
|
61
|
-
const el = await fixture(component(options));
|
|
62
|
-
const anchors = el.shadowRoot.querySelectorAll('.browser-extensions a');
|
|
63
|
-
|
|
64
|
-
options.browserExtensionsLinks.forEach((link, i) => {
|
|
65
|
-
expect(anchors[i].innerText).to.equal(link.title);
|
|
66
|
-
expect(anchors[i].getAttribute('href')).to.contain(link.url);
|
|
67
|
-
});
|
|
68
|
-
});
|
|
69
|
-
|
|
70
|
-
it('renders the links passed in via the mobileAppsLinks prop', async () => {
|
|
71
|
-
const options = buildDefaults();
|
|
72
|
-
const el = await fixture(component(options));
|
|
73
|
-
const anchors = el.shadowRoot.querySelectorAll('.mobile-apps a');
|
|
74
|
-
|
|
75
|
-
options.mobileAppsLinks.forEach((link, i) => {
|
|
76
|
-
expect(anchors[i].innerText).to.equal(link.title);
|
|
77
|
-
expect(anchors[i].getAttribute('href')).to.contain(link.url);
|
|
78
|
-
});
|
|
79
|
-
});
|
|
80
|
-
});
|
/package/{index.js → index.ts}
RENAMED
|
File without changes
|