@npo/player 1.22.4 → 1.23.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/README.md +1 -1
- package/lib/js/ads/ster.js +23 -21
- package/lib/js/ads/ster.test.js +17 -17
- package/lib/js/api/getstreamobject.js +7 -7
- package/lib/js/api/getstreamobject.test.js +3 -3
- package/lib/js/markers/updateLiveMarkers.d.ts +3 -3
- package/lib/js/markers/updateLiveMarkers.js +14 -15
- package/lib/js/markers/updateLiveMarkers.test.js +11 -12
- package/lib/js/playeractions/customerrors.test.js +33 -33
- package/lib/js/playeractions/handlers/customerrors.js +48 -48
- package/lib/js/playeractions/handlers/error.js +1 -1
- package/lib/js/playeractions/handlers/error.test.js +11 -11
- package/lib/js/playeractions/handlers/handleoffsets.d.ts +2 -2
- package/lib/js/playeractions/handlers/handleoffsets.js +6 -6
- package/lib/js/playeractions/handlers/handleoffsets.test.js +12 -12
- package/lib/js/playeractions/handlers/mediasessionactions.d.ts +1 -1
- package/lib/js/playeractions/handlers/mediasessionactions.js +20 -15
- package/lib/js/playeractions/handlers/processplayerconfig.d.ts +2 -2
- package/lib/js/playeractions/handlers/processplayerconfig.js +4 -4
- package/lib/js/playeractions/handlers/processsourceconfig.d.ts +2 -1
- package/lib/js/playeractions/handlers/processsourceconfig.js +52 -46
- package/lib/js/playeractions/handlers/removereplayclass.d.ts +1 -1
- package/lib/js/playeractions/handlers/removereplayclass.test.d.ts +1 -1
- package/lib/js/playeractions/handlers/removereplayclass.test.js +7 -6
- package/lib/js/playeractions/playeractions.d.ts +4 -5
- package/lib/js/playeractions/playeractions.js +4 -5
- package/lib/js/settings/settings.user-agent.d.ts +1 -0
- package/lib/js/settings/settings.user-agent.js +1 -0
- package/lib/js/tracking/handlers/eventbinding.js +9 -9
- package/lib/js/tracking/handlers/eventlogging.js +2 -2
- package/lib/js/tracking/handlers/eventlogging.test.js +2 -2
- package/lib/js/tracking/handlers/playertrackerinit.d.ts +1 -1
- package/lib/js/tracking/handlers/playertrackerinit.js +5 -11
- package/lib/js/tracking/handlers/playertrackerstart.d.ts +1 -1
- package/lib/js/tracking/handlers/playertrackerstart.js +5 -10
- package/lib/js/utilities/utilities.element.d.ts +10 -0
- package/lib/js/utilities/utilities.element.js +8 -0
- package/lib/js/utilities/utilities.element.test.js +25 -0
- package/lib/js/utilities/utilities.jwt.d.ts +3 -0
- package/lib/js/utilities/utilities.jwt.js +22 -0
- package/lib/js/utilities/utilities.jwt.test.js +32 -0
- package/lib/js/utilities/utilities.locale.d.ts +2 -0
- package/lib/js/utilities/utilities.locale.js +4 -0
- package/lib/js/utilities/utilities.locale.test.js +10 -0
- package/lib/js/utilities/utilities.module.d.ts +1 -0
- package/lib/js/utilities/utilities.module.js +4 -0
- package/lib/js/utilities/utilities.module.test.js +19 -0
- package/lib/js/utilities/utilities.stream.d.ts +7 -0
- package/lib/js/utilities/utilities.stream.js +10 -0
- package/lib/js/utilities/utilities.stream.test.js +32 -0
- package/lib/js/utilities/utilities.text.d.ts +1 -0
- package/lib/js/utilities/utilities.text.js +3 -0
- package/lib/js/utilities/utilities.text.test.js +18 -0
- package/lib/js/utilities/utilities.time.d.ts +1 -0
- package/lib/js/utilities/utilities.time.js +3 -0
- package/lib/js/utilities/utilities.time.test.js +8 -0
- package/lib/js/utilities/utilities.url.d.ts +3 -0
- package/lib/js/utilities/utilities.url.js +29 -0
- package/lib/js/utilities/utilities.url.test.js +46 -0
- package/lib/js/utilities/utilities.user-agent.d.ts +3 -0
- package/lib/js/utilities/utilities.user-agent.js +13 -0
- package/lib/js/utilities/utilities.user-agent.test.js +60 -0
- package/lib/js/utilities/utilities.version.d.ts +1 -0
- package/lib/js/utilities/{printversion.js → utilities.version.js} +8 -8
- package/lib/js/utilities/utilities.version.test.js +26 -0
- package/lib/lang/nl.json +2 -1
- package/lib/npoplayer-bridge.test.d.ts +1 -1
- package/lib/npoplayer-bridge.test.js +6 -5
- package/lib/npoplayer.d.ts +14 -10
- package/lib/npoplayer.js +116 -124
- package/lib/npoplayer.test.js +3 -3
- package/lib/package.json +19 -12
- package/lib/services/a11y/setup.d.ts +2 -0
- package/lib/services/a11y/setup.js +18 -0
- package/lib/services/a11y/setup.test.js +109 -0
- package/lib/services/avTypeHandlers/getAVType.d.ts +2 -0
- package/lib/services/avTypeHandlers/getAVType.js +9 -0
- package/lib/services/avTypeHandlers/getAVType.test.js +18 -0
- package/lib/services/drmHandlers/constants.d.ts +15 -0
- package/lib/services/drmHandlers/constants.js +13 -0
- package/lib/services/drmHandlers/decideprofile.d.ts +2 -0
- package/lib/services/drmHandlers/decideprofile.js +51 -0
- package/lib/services/drmHandlers/decideprofile.test.js +34 -0
- package/lib/services/drmHandlers/drmhandlers.d.ts +2 -0
- package/lib/services/drmHandlers/drmhandlers.js +2 -0
- package/lib/services/drmHandlers/utils.d.ts +5 -0
- package/lib/services/drmHandlers/utils.js +26 -0
- package/lib/services/drmHandlers/utils.test.js +74 -0
- package/lib/services/drmHandlers/verifydrm.d.ts +2 -0
- package/lib/services/drmHandlers/verifydrm.js +40 -0
- package/lib/services/drmHandlers/verifydrm.test.js +89 -0
- package/lib/services/eventListenerHandlers/removeEventListeners.d.ts +2 -0
- package/lib/services/eventListenerHandlers/removeEventListeners.js +18 -0
- package/lib/services/eventListenerHandlers/removeEventListeners.test.js +27 -0
- package/lib/services/keyboardHandlers/resolvekeypress.d.ts +2 -0
- package/lib/services/keyboardHandlers/resolvekeypress.js +49 -0
- package/lib/{js/playeractions/handlers → services/keyboardHandlers}/resolvekeypress.test.js +21 -13
- package/lib/services/liveStreamHandlers/handleLiveStreamControls.d.ts +6 -0
- package/lib/services/liveStreamHandlers/handleLiveStreamControls.js +35 -0
- package/lib/services/localStorageHandlers/localStorageHandlers.d.ts +4 -0
- package/lib/services/localStorageHandlers/localStorageHandlers.js +33 -0
- package/lib/services/localStorageHandlers/localStorageHandlers.test.js +109 -0
- package/lib/services/npoPlayerAPI/npoPlayerAPI.d.ts +30 -0
- package/lib/services/npoPlayerAPI/npoPlayerAPI.js +91 -0
- package/lib/services/npoPlayerAPI/npoPlayerAPI.test.js +51 -0
- package/lib/services/segmentHandlers/addSegmentEventListeners.d.ts +2 -0
- package/lib/services/segmentHandlers/addSegmentEventListeners.js +14 -0
- package/lib/services/segmentHandlers/addSegmentEventListeners.test.js +43 -0
- package/lib/services/segmentHandlers/convertFragmentToSegment.d.ts +2 -0
- package/lib/services/segmentHandlers/convertFragmentToSegment.js +8 -0
- package/lib/services/segmentHandlers/convertFragmentToSegment.test.js +17 -0
- package/lib/services/segmentHandlers/handleSegmentSeek.d.ts +5 -0
- package/lib/services/segmentHandlers/handleSegmentSeek.js +15 -0
- package/lib/services/segmentHandlers/handleSegmentSeek.test.js +73 -0
- package/lib/services/segmentHandlers/handleSegmentTimeChanged.d.ts +2 -0
- package/lib/services/segmentHandlers/handleSegmentTimeChanged.js +21 -0
- package/lib/services/segmentHandlers/handleSegmentTimeChanged.test.d.ts +1 -0
- package/lib/services/segmentHandlers/handleSegmentTimeChanged.test.js +34 -0
- package/lib/services/segmentHandlers/initSegment.d.ts +7 -0
- package/lib/services/segmentHandlers/initSegment.js +10 -0
- package/lib/services/segmentHandlers/initSegment.test.d.ts +1 -0
- package/lib/services/segmentHandlers/initSegment.test.js +36 -0
- package/lib/services/segmentHandlers/setSegmentMarkers.d.ts +2 -0
- package/lib/services/segmentHandlers/setSegmentMarkers.js +25 -0
- package/lib/services/segmentHandlers/setSegmentMarkers.test.d.ts +1 -0
- package/lib/services/segmentHandlers/setSegmentMarkers.test.js +32 -0
- package/lib/services/services.d.ts +14 -0
- package/lib/services/services.js +47 -0
- package/lib/src/js/markers/updateLiveMarkers.d.ts +3 -3
- package/lib/src/js/playeractions/handlers/handleoffsets.d.ts +2 -2
- package/lib/src/js/playeractions/handlers/mediasessionactions.d.ts +1 -1
- package/lib/src/js/playeractions/handlers/processplayerconfig.d.ts +2 -2
- package/lib/src/js/playeractions/handlers/processsourceconfig.d.ts +2 -1
- package/lib/src/js/playeractions/handlers/removereplayclass.d.ts +1 -1
- package/lib/src/js/playeractions/handlers/removereplayclass.test.d.ts +1 -1
- package/lib/src/js/playeractions/playeractions.d.ts +4 -5
- package/lib/src/js/settings/settings.user-agent.d.ts +1 -0
- package/lib/src/js/tracking/handlers/playertrackerinit.d.ts +1 -1
- package/lib/src/js/tracking/handlers/playertrackerstart.d.ts +1 -1
- package/lib/src/js/utilities/utilities.element.d.ts +10 -0
- package/lib/src/js/utilities/utilities.element.test.d.ts +1 -0
- package/lib/src/js/utilities/utilities.jwt.d.ts +3 -0
- package/lib/src/js/utilities/utilities.jwt.test.d.ts +1 -0
- package/lib/src/js/utilities/utilities.locale.d.ts +2 -0
- package/lib/src/js/utilities/utilities.locale.test.d.ts +1 -0
- package/lib/src/js/utilities/utilities.module.d.ts +1 -0
- package/lib/src/js/utilities/utilities.module.test.d.ts +1 -0
- package/lib/src/js/utilities/utilities.stream.d.ts +7 -0
- package/lib/src/js/utilities/utilities.stream.test.d.ts +1 -0
- package/lib/src/js/utilities/utilities.text.d.ts +1 -0
- package/lib/src/js/utilities/utilities.text.test.d.ts +1 -0
- package/lib/src/js/utilities/utilities.time.d.ts +1 -0
- package/lib/src/js/utilities/utilities.time.test.d.ts +1 -0
- package/lib/src/js/utilities/utilities.url.d.ts +3 -0
- package/lib/src/js/utilities/utilities.url.test.d.ts +1 -0
- package/lib/src/js/utilities/utilities.user-agent.d.ts +3 -0
- package/lib/src/js/utilities/utilities.user-agent.test.d.ts +1 -0
- package/lib/src/js/utilities/utilities.version.d.ts +1 -0
- package/lib/src/js/utilities/utilities.version.test.d.ts +1 -0
- package/lib/src/npoplayer-bridge.test.d.ts +1 -1
- package/lib/src/npoplayer.d.ts +14 -10
- package/lib/src/services/a11y/setup.d.ts +2 -0
- package/lib/src/services/a11y/setup.test.d.ts +1 -0
- package/lib/src/services/avTypeHandlers/getAVType.d.ts +2 -0
- package/lib/src/services/avTypeHandlers/getAVType.test.d.ts +1 -0
- package/lib/src/services/drmHandlers/constants.d.ts +15 -0
- package/lib/src/services/drmHandlers/decideprofile.d.ts +2 -0
- package/lib/src/services/drmHandlers/decideprofile.test.d.ts +1 -0
- package/lib/src/services/drmHandlers/drmhandlers.d.ts +2 -0
- package/lib/src/services/drmHandlers/utils.d.ts +5 -0
- package/lib/src/services/drmHandlers/utils.test.d.ts +1 -0
- package/lib/src/services/drmHandlers/verifydrm.d.ts +2 -0
- package/lib/src/services/drmHandlers/verifydrm.test.d.ts +1 -0
- package/lib/src/services/eventListenerHandlers/removeEventListeners.d.ts +2 -0
- package/lib/src/services/eventListenerHandlers/removeEventListeners.test.d.ts +1 -0
- package/lib/src/services/keyboardHandlers/resolvekeypress.d.ts +2 -0
- package/lib/src/services/keyboardHandlers/resolvekeypress.test.d.ts +1 -0
- package/lib/src/services/liveStreamHandlers/handleLiveStreamControls.d.ts +6 -0
- package/lib/src/services/localStorageHandlers/localStorageHandlers.d.ts +4 -0
- package/lib/src/services/localStorageHandlers/localStorageHandlers.test.d.ts +1 -0
- package/lib/src/services/npoPlayerAPI/npoPlayerAPI.d.ts +30 -0
- package/lib/src/services/npoPlayerAPI/npoPlayerAPI.test.d.ts +1 -0
- package/lib/src/services/segmentHandlers/addSegmentEventListeners.d.ts +2 -0
- package/lib/src/services/segmentHandlers/addSegmentEventListeners.test.d.ts +1 -0
- package/lib/src/services/segmentHandlers/convertFragmentToSegment.d.ts +2 -0
- package/lib/src/services/segmentHandlers/convertFragmentToSegment.test.d.ts +1 -0
- package/lib/src/services/segmentHandlers/handleSegmentSeek.d.ts +5 -0
- package/lib/src/services/segmentHandlers/handleSegmentSeek.test.d.ts +1 -0
- package/lib/src/services/segmentHandlers/handleSegmentTimeChanged.d.ts +2 -0
- package/lib/src/services/segmentHandlers/handleSegmentTimeChanged.test.d.ts +1 -0
- package/lib/src/services/segmentHandlers/initSegment.d.ts +7 -0
- package/lib/src/services/segmentHandlers/initSegment.test.d.ts +1 -0
- package/lib/src/services/segmentHandlers/setSegmentMarkers.d.ts +2 -0
- package/lib/src/services/segmentHandlers/setSegmentMarkers.test.d.ts +1 -0
- package/lib/src/services/services.d.ts +14 -0
- package/lib/src/types/events.d.ts +91 -0
- package/lib/src/types/interfaces.d.ts +39 -15
- package/lib/{js → src}/ui/components/adbutton.d.ts +1 -1
- package/lib/{js → src}/ui/components/adlabel.d.ts +1 -1
- package/lib/{js → src}/ui/components/audio/controlbar.d.ts +1 -1
- package/lib/{js → src}/ui/components/buttons.d.ts +3 -3
- package/lib/src/ui/components/controlbar.d.ts +3 -0
- package/lib/{js → src}/ui/components/ctabar.d.ts +2 -2
- package/lib/src/ui/components/nativemobile/controlbar.d.ts +3 -0
- package/lib/src/ui/components/nativemobile/topbar.d.ts +3 -0
- package/lib/{js → src}/ui/components/playnext.d.ts +1 -1
- package/lib/src/{js/ui → ui}/components/seekbar.d.ts +1 -1
- package/lib/src/{js/ui → ui}/components/settingspanel.d.ts +1 -1
- package/lib/{js → src}/ui/components/titlebar.d.ts +1 -1
- package/lib/src/ui/components/topbar.d.ts +3 -0
- package/lib/src/ui/handlers/accessibilityhandler.test.d.ts +1 -0
- package/lib/src/ui/handlers/domhandlers.d.ts +3 -0
- package/lib/src/ui/handlers/domhandlers.test.d.ts +1 -0
- package/lib/{js → src}/ui/handlers/nicamhandler.d.ts +2 -2
- package/lib/src/ui/handlers/nicamhandler.test.d.ts +1 -0
- package/lib/{js → src}/ui/handlers/playnextstreen.test.d.ts +1 -1
- package/lib/src/{js/ui → ui}/handlers/streamhandler.d.ts +2 -2
- package/lib/{js → src}/ui/nativemobileuicontainer.d.ts +1 -1
- package/lib/src/ui/nativemobileuifactory.test.d.ts +1 -0
- package/lib/{js → src}/ui/uicontainer.d.ts +2 -3
- package/lib/tests/mocks/mockNpoplayer.js +18 -15
- package/lib/tests/mocks/mockPlayerAPI.d.ts +3 -0
- package/lib/tests/mocks/mockPlayerAPI.js +181 -0
- package/lib/tests/mocks/mockPlayerContext.d.ts +2 -0
- package/lib/tests/mocks/mockPlayerContext.js +40 -0
- package/lib/types/events.d.ts +91 -0
- package/lib/types/events.js +1 -0
- package/lib/types/interfaces.d.ts +39 -15
- package/lib/types/interfaces.js +12 -0
- package/lib/{src/js/ui → ui}/components/adbutton.d.ts +1 -1
- package/lib/{src/js/ui → ui}/components/adlabel.d.ts +1 -1
- package/lib/{src/js/ui → ui}/components/audio/controlbar.d.ts +1 -1
- package/lib/{js/ui → ui}/components/audio/controlbar.js +2 -2
- package/lib/{src/js/ui → ui}/components/buttons.d.ts +3 -3
- package/lib/{js/ui → ui}/components/buttons.js +7 -7
- package/lib/ui/components/controlbar.d.ts +3 -0
- package/lib/{js/ui → ui}/components/controlbar.js +5 -2
- package/lib/{src/js/ui → ui}/components/ctabar.d.ts +3 -3
- package/lib/{js/ui → ui}/components/ctabar.js +4 -6
- package/lib/{js/ui → ui}/components/nativemobile/buttons.js +8 -6
- package/lib/ui/components/nativemobile/controlbar.d.ts +3 -0
- package/lib/{js/ui → ui}/components/nativemobile/controlbar.js +6 -4
- package/lib/{js/ui → ui}/components/nativemobile/ctabar.js +1 -1
- package/lib/ui/components/nativemobile/topbar.d.ts +3 -0
- package/lib/{js/ui → ui}/components/nativemobile/topbar.js +6 -3
- package/lib/{src/js/ui → ui}/components/playnext.d.ts +1 -1
- package/lib/{js/ui → ui}/components/playnext.js +1 -1
- package/lib/{js/ui → ui}/components/seekbar.d.ts +1 -1
- package/lib/{js/ui → ui}/components/seekbar.js +1 -1
- package/lib/{js/ui → ui}/components/settingspanel.d.ts +1 -1
- package/lib/{js/ui → ui}/components/settingspanel.js +23 -40
- package/lib/{src/js/ui → ui}/components/titlebar.d.ts +1 -1
- package/lib/ui/components/topbar.d.ts +3 -0
- package/lib/{js/ui → ui}/components/topbar.js +8 -4
- package/lib/{js/ui → ui}/handlers/accessibilityhandler.js +10 -10
- package/lib/ui/handlers/accessibilityhandler.test.d.ts +1 -0
- package/lib/ui/handlers/domhandlers.d.ts +3 -0
- package/lib/ui/handlers/domhandlers.js +7 -0
- package/lib/ui/handlers/domhandlers.test.d.ts +1 -0
- package/lib/ui/handlers/domhandlers.test.js +51 -0
- package/lib/{js/ui → ui}/handlers/listboxhandlers.js +7 -7
- package/lib/{src/js/ui → ui}/handlers/nicamhandler.d.ts +2 -2
- package/lib/{js/ui → ui}/handlers/nicamhandler.js +31 -10
- package/lib/ui/handlers/nicamhandler.test.d.ts +1 -0
- package/lib/{js/ui → ui}/handlers/nicamhandler.test.js +4 -3
- package/lib/{js/ui → ui}/handlers/playnextscreen.js +1 -1
- package/lib/{src/js/ui → ui}/handlers/playnextstreen.test.d.ts +1 -1
- package/lib/{js/ui → ui}/handlers/playnextstreen.test.js +5 -3
- package/lib/{js/ui → ui}/handlers/streamhandler.d.ts +2 -2
- package/lib/ui/handlers/streamhandler.js +51 -0
- package/lib/{src/js/ui → ui}/nativemobileuicontainer.d.ts +1 -1
- package/lib/{js/ui → ui}/nativemobileuicontainer.js +8 -13
- package/lib/{js/ui → ui}/nativemobileuifactory.js +20 -23
- package/lib/ui/nativemobileuifactory.test.d.ts +1 -0
- package/lib/{js/ui → ui}/nativemobileuifactory.test.js +8 -6
- package/lib/{src/js/ui → ui}/uicontainer.d.ts +2 -3
- package/lib/{js/ui → ui}/uicontainer.js +31 -45
- package/package.json +19 -12
- package/src/{scss → style}/components/_controlbars.scss +4 -0
- package/src/{scss → style}/components/_icons.scss +6 -0
- package/src/style/components/_poster.scss +3 -0
- package/src/{scss → style}/components/_settingspanel.scss +15 -1
- package/src/{scss → style}/components/_subtitles.scss +25 -16
- package/src/{scss → style}/npoplayer.css +30 -20
- package/src/{scss → style}/npoplayer.scss +3 -0
- package/src/{scss → style}/variants/_player-small.scss +9 -8
- package/lib/js/checks/apple.d.ts +0 -2
- package/lib/js/checks/apple.js +0 -19
- package/lib/js/checks/apple.test.js +0 -20
- package/lib/js/drm/drm.d.ts +0 -2
- package/lib/js/drm/drm.js +0 -2
- package/lib/js/drm/handlers/decideprofile.d.ts +0 -3
- package/lib/js/drm/handlers/decideprofile.js +0 -53
- package/lib/js/drm/handlers/decideprofile.test.js +0 -33
- package/lib/js/drm/handlers/verifydrm.d.ts +0 -4
- package/lib/js/drm/handlers/verifydrm.js +0 -24
- package/lib/js/drm/handlers/verifydrm.test.js +0 -17
- package/lib/js/fragments/removefragments.d.ts +0 -2
- package/lib/js/fragments/removefragments.js +0 -5
- package/lib/js/fragments/removefragments.test.js +0 -26
- package/lib/js/fragments/setfragments.d.ts +0 -6
- package/lib/js/fragments/setfragments.js +0 -78
- package/lib/js/fragments/setfragments.test.js +0 -72
- package/lib/js/playeractions/handlers/resolvekeypress.d.ts +0 -3
- package/lib/js/playeractions/handlers/resolvekeypress.js +0 -52
- package/lib/js/ui/components/controlbar.d.ts +0 -3
- package/lib/js/ui/components/nativemobile/addFragments.d.ts +0 -1
- package/lib/js/ui/components/nativemobile/addFragments.js +0 -7
- package/lib/js/ui/components/nativemobile/controlbar.d.ts +0 -3
- package/lib/js/ui/components/nativemobile/topbar.d.ts +0 -3
- package/lib/js/ui/components/topbar.d.ts +0 -3
- package/lib/js/ui/handlers/domhandlers.d.ts +0 -3
- package/lib/js/ui/handlers/domhandlers.js +0 -7
- package/lib/js/ui/handlers/domhandlers.test.js +0 -50
- package/lib/js/ui/handlers/streamhandler.js +0 -40
- package/lib/js/utilities/printversion.d.ts +0 -1
- package/lib/js/utilities/utilities.d.ts +0 -16
- package/lib/js/utilities/utilities.js +0 -78
- package/lib/js/utilities/utilities.test.js +0 -50
- package/lib/src/js/checks/apple.d.ts +0 -2
- package/lib/src/js/drm/drm.d.ts +0 -2
- package/lib/src/js/drm/handlers/decideprofile.d.ts +0 -3
- package/lib/src/js/drm/handlers/verifydrm.d.ts +0 -4
- package/lib/src/js/fragments/removefragments.d.ts +0 -2
- package/lib/src/js/fragments/setfragments.d.ts +0 -6
- package/lib/src/js/playeractions/handlers/resolvekeypress.d.ts +0 -3
- package/lib/src/js/ui/components/controlbar.d.ts +0 -3
- package/lib/src/js/ui/components/nativemobile/addFragments.d.ts +0 -1
- package/lib/src/js/ui/components/nativemobile/controlbar.d.ts +0 -3
- package/lib/src/js/ui/components/nativemobile/topbar.d.ts +0 -3
- package/lib/src/js/ui/components/topbar.d.ts +0 -3
- package/lib/src/js/ui/handlers/domhandlers.d.ts +0 -3
- package/lib/src/js/utilities/printversion.d.ts +0 -1
- package/lib/src/js/utilities/utilities.d.ts +0 -16
- /package/lib/js/{utilities/localizationconfig.d.ts → settings/localization.d.ts} +0 -0
- /package/lib/js/{utilities/localizationconfig.js → settings/localization.js} +0 -0
- /package/lib/js/{checks/apple.test.d.ts → utilities/utilities.element.test.d.ts} +0 -0
- /package/lib/js/{drm/handlers/decideprofile.test.d.ts → utilities/utilities.jwt.test.d.ts} +0 -0
- /package/lib/js/{drm/handlers/verifydrm.test.d.ts → utilities/utilities.locale.test.d.ts} +0 -0
- /package/lib/js/{fragments/removefragments.test.d.ts → utilities/utilities.module.test.d.ts} +0 -0
- /package/lib/js/{fragments/setfragments.test.d.ts → utilities/utilities.stream.test.d.ts} +0 -0
- /package/lib/js/{playeractions/handlers/resolvekeypress.test.d.ts → utilities/utilities.text.test.d.ts} +0 -0
- /package/lib/js/{ui/handlers/accessibilityhandler.test.d.ts → utilities/utilities.time.test.d.ts} +0 -0
- /package/lib/js/{ui/handlers/domhandlers.test.d.ts → utilities/utilities.url.test.d.ts} +0 -0
- /package/lib/js/{ui/handlers/nicamhandler.test.d.ts → utilities/utilities.user-agent.test.d.ts} +0 -0
- /package/lib/js/{ui/nativemobileuifactory.test.d.ts → utilities/utilities.version.test.d.ts} +0 -0
- /package/lib/{js/utilities/utilities.test.d.ts → services/a11y/setup.test.d.ts} +0 -0
- /package/lib/{src/js/checks/apple.test.d.ts → services/avTypeHandlers/getAVType.test.d.ts} +0 -0
- /package/lib/{src/js/drm/handlers → services/drmHandlers}/decideprofile.test.d.ts +0 -0
- /package/lib/{src/js/drm/handlers/verifydrm.test.d.ts → services/drmHandlers/utils.test.d.ts} +0 -0
- /package/lib/{src/js/fragments/removefragments.test.d.ts → services/drmHandlers/verifydrm.test.d.ts} +0 -0
- /package/lib/{src/js/fragments/setfragments.test.d.ts → services/eventListenerHandlers/removeEventListeners.test.d.ts} +0 -0
- /package/lib/{src/js/playeractions/handlers → services/keyboardHandlers}/resolvekeypress.test.d.ts +0 -0
- /package/lib/{src/js/ui/handlers/accessibilityhandler.test.d.ts → services/localStorageHandlers/localStorageHandlers.test.d.ts} +0 -0
- /package/lib/{src/js/ui/handlers/domhandlers.test.d.ts → services/npoPlayerAPI/npoPlayerAPI.test.d.ts} +0 -0
- /package/lib/{src/js/ui/handlers/nicamhandler.test.d.ts → services/segmentHandlers/addSegmentEventListeners.test.d.ts} +0 -0
- /package/lib/{src/js/ui/nativemobileuifactory.test.d.ts → services/segmentHandlers/convertFragmentToSegment.test.d.ts} +0 -0
- /package/lib/{src/js/utilities/utilities.test.d.ts → services/segmentHandlers/handleSegmentSeek.test.d.ts} +0 -0
- /package/lib/src/js/{utilities/localizationconfig.d.ts → settings/localization.d.ts} +0 -0
- /package/lib/{js → src}/ui/components/nativemobile/buttons.d.ts +0 -0
- /package/lib/{js → src}/ui/components/nativemobile/ctabar.d.ts +0 -0
- /package/lib/{js → src}/ui/components/nativemobile/titlebar.d.ts +0 -0
- /package/lib/{js → src}/ui/handlers/accessibilityhandler.d.ts +0 -0
- /package/lib/{js → src}/ui/handlers/listboxhandlers.d.ts +0 -0
- /package/lib/{js → src}/ui/handlers/playnextscreen.d.ts +0 -0
- /package/lib/{js → src}/ui/handlers/timecontrolhandlers.d.ts +0 -0
- /package/lib/{js → src}/ui/nativemobileuifactory.d.ts +0 -0
- /package/lib/{js/ui → ui}/components/adbutton.js +0 -0
- /package/lib/{js/ui → ui}/components/adlabel.js +0 -0
- /package/lib/{src/js/ui → ui}/components/nativemobile/buttons.d.ts +0 -0
- /package/lib/{src/js/ui → ui}/components/nativemobile/ctabar.d.ts +0 -0
- /package/lib/{src/js/ui → ui}/components/nativemobile/titlebar.d.ts +0 -0
- /package/lib/{js/ui → ui}/components/nativemobile/titlebar.js +0 -0
- /package/lib/{js/ui → ui}/components/titlebar.js +0 -0
- /package/lib/{src/js/ui → ui}/handlers/accessibilityhandler.d.ts +0 -0
- /package/lib/{js/ui → ui}/handlers/accessibilityhandler.test.js +0 -0
- /package/lib/{src/js/ui → ui}/handlers/listboxhandlers.d.ts +0 -0
- /package/lib/{src/js/ui → ui}/handlers/playnextscreen.d.ts +0 -0
- /package/lib/{src/js/ui → ui}/handlers/timecontrolhandlers.d.ts +0 -0
- /package/lib/{js/ui → ui}/handlers/timecontrolhandlers.js +0 -0
- /package/lib/{src/js/ui → ui}/nativemobileuifactory.d.ts +0 -0
- /package/src/{scss → style}/components/_advert.scss +0 -0
- /package/src/{scss → style}/components/_audio.scss +0 -0
- /package/src/{scss → style}/components/_buffering.scss +0 -0
- /package/src/{scss → style}/components/_error.scss +0 -0
- /package/src/{scss → style}/components/_hugeplaybacktogglebutton.scss +0 -0
- /package/src/{scss → style}/components/_metadata.scss +0 -0
- /package/src/{scss → style}/components/_nicam.scss +0 -0
- /package/src/{scss → style}/components/_playnext.scss +0 -0
- /package/src/{scss → style}/components/_replay.scss +0 -0
- /package/src/{scss → style}/components/_seekbar.scss +0 -0
- /package/src/{scss → style}/components/_seekbarthumbnail.scss +0 -0
- /package/src/{scss → style}/components/_textbuttons.scss +0 -0
- /package/src/{scss → style}/components/_volumeslider.scss +0 -0
- /package/src/{scss → style}/components/audio/_bottombar.scss +0 -0
- /package/src/{scss → style}/components/audio/_buffering.scss +0 -0
- /package/src/{scss → style}/components/audio/_errors.scss +0 -0
- /package/src/{scss → style}/components/audio/_metadata.scss +0 -0
- /package/src/{scss → style}/components/audio/_playbutton.scss +0 -0
- /package/src/{scss → style}/components/audio/_poster.scss +0 -0
- /package/src/{scss → style}/components/audio/_replay.scss +0 -0
- /package/src/{scss → style}/components/audio/_seekbar.scss +0 -0
- /package/src/{scss → style}/components/audio/_topbar.scss +0 -0
- /package/src/{scss → style}/components/audio/_vars.scss +0 -0
- /package/src/{scss → style}/components/audio/_volumeslider.scss +0 -0
- /package/src/{scss → style}/variants/_player-audio.scss +0 -0
- /package/src/{scss → style}/variants/_player-base.scss +0 -0
- /package/src/{scss → style}/variants/_player-debug.scss +0 -0
- /package/src/{scss → style}/variants/_player-large.scss +0 -0
- /package/src/{scss → style}/variants/_player-medium.scss +0 -0
- /package/src/{scss → style}/variants/_player-native-mobile.scss +0 -0
- /package/src/{scss → style}/vars/_audio.scss +0 -0
- /package/src/{scss → style}/vars/_colors.scss +0 -0
- /package/src/{scss → style}/vars/_fonts.scss +0 -0
- /package/src/{scss → style}/vars/_icons.scss +0 -0
|
@@ -0,0 +1,109 @@
|
|
|
1
|
+
import { PlayerEvent } from 'bitmovin-player';
|
|
2
|
+
import { addAccessibilityAttributes } from '../../ui/handlers/accessibilityhandler';
|
|
3
|
+
import { setupAccessibilityAttributes } from './setup';
|
|
4
|
+
import { mockNpoPlayer } from '../../../tests/mocks/mockNpoplayer';
|
|
5
|
+
jest.mock('bitmovin-player', () => ({
|
|
6
|
+
PlayerEvent: {
|
|
7
|
+
SourceLoaded: 'sourceLoaded',
|
|
8
|
+
AdBreakFinished: 'adBreakFinished',
|
|
9
|
+
AdError: 'adError'
|
|
10
|
+
}
|
|
11
|
+
}));
|
|
12
|
+
jest.mock('../../ui/handlers/accessibilityhandler');
|
|
13
|
+
describe('setupAccessibilityAttributes', () => {
|
|
14
|
+
let playerContext;
|
|
15
|
+
let mockEnableSubtitles;
|
|
16
|
+
let mockAddEventListener;
|
|
17
|
+
let mockRemoveEventListener;
|
|
18
|
+
let mockPlayerAPI;
|
|
19
|
+
beforeEach(() => {
|
|
20
|
+
mockEnableSubtitles = jest.fn();
|
|
21
|
+
mockAddEventListener = jest.fn();
|
|
22
|
+
mockRemoveEventListener = jest.fn();
|
|
23
|
+
mockPlayerAPI = {
|
|
24
|
+
on: mockAddEventListener,
|
|
25
|
+
off: mockRemoveEventListener,
|
|
26
|
+
enableSubtitles: mockEnableSubtitles,
|
|
27
|
+
subtitles: {
|
|
28
|
+
list: jest.fn().mockReturnValue([{ id: 1, enabled: false }]),
|
|
29
|
+
enable: jest.fn()
|
|
30
|
+
}
|
|
31
|
+
};
|
|
32
|
+
playerContext = {
|
|
33
|
+
player: mockPlayerAPI,
|
|
34
|
+
npoplayer: {
|
|
35
|
+
...mockNpoPlayer,
|
|
36
|
+
streamOptions: {
|
|
37
|
+
enableSubtitles: false
|
|
38
|
+
},
|
|
39
|
+
userPreferences: {
|
|
40
|
+
subtitles_enabled: 'false'
|
|
41
|
+
},
|
|
42
|
+
container: document.createElement('div'),
|
|
43
|
+
streamObject: {},
|
|
44
|
+
playerConfig: {},
|
|
45
|
+
initPlayer: () => { },
|
|
46
|
+
loadStream: () => Promise.resolve(),
|
|
47
|
+
createUIManager: async () => { },
|
|
48
|
+
doError: () => { },
|
|
49
|
+
play: async () => { },
|
|
50
|
+
pause: () => { },
|
|
51
|
+
setVolume: () => { },
|
|
52
|
+
increaseVolume: () => { },
|
|
53
|
+
decreaseVolume: () => { },
|
|
54
|
+
goForward: () => { },
|
|
55
|
+
goBackwards: () => { },
|
|
56
|
+
watchFromStart: () => { },
|
|
57
|
+
showPlayNextScreen: () => { },
|
|
58
|
+
updateMarkers: () => { },
|
|
59
|
+
cancelPlayNextScreen: () => { },
|
|
60
|
+
hidePlayNextScreen: () => { },
|
|
61
|
+
doPlayNext: () => { },
|
|
62
|
+
destroy: () => false,
|
|
63
|
+
unload: () => {
|
|
64
|
+
return true;
|
|
65
|
+
},
|
|
66
|
+
printVersion: () => { }
|
|
67
|
+
}
|
|
68
|
+
};
|
|
69
|
+
});
|
|
70
|
+
afterEach(() => {
|
|
71
|
+
jest.clearAllMocks();
|
|
72
|
+
});
|
|
73
|
+
it('should enable subtitles if playerContext.npoplayer.userPreferences.subtitles_enabled is "true"', () => {
|
|
74
|
+
playerContext.npoplayer.userPreferences.subtitles_enabled = 'true';
|
|
75
|
+
setupAccessibilityAttributes(playerContext);
|
|
76
|
+
const triggerFunction = mockAddEventListener.mock.calls[0][1];
|
|
77
|
+
triggerFunction();
|
|
78
|
+
expect(mockEnableSubtitles).toHaveBeenCalled();
|
|
79
|
+
});
|
|
80
|
+
it('should enable subtitles if streamOptions.enableSubtitles is true', () => {
|
|
81
|
+
playerContext.npoplayer.streamOptions.enableSubtitles = true;
|
|
82
|
+
setupAccessibilityAttributes(playerContext);
|
|
83
|
+
const triggerFunction = mockAddEventListener.mock.calls[0][1];
|
|
84
|
+
triggerFunction();
|
|
85
|
+
expect(mockEnableSubtitles).toHaveBeenCalled();
|
|
86
|
+
});
|
|
87
|
+
it('should set up event listeners for specified events', () => {
|
|
88
|
+
setupAccessibilityAttributes(playerContext);
|
|
89
|
+
expect(mockAddEventListener).toHaveBeenCalledTimes(3);
|
|
90
|
+
expect(mockAddEventListener).toHaveBeenCalledWith(PlayerEvent.SourceLoaded, expect.any(Function));
|
|
91
|
+
expect(mockAddEventListener).toHaveBeenCalledWith(PlayerEvent.AdBreakFinished, expect.any(Function));
|
|
92
|
+
expect(mockAddEventListener).toHaveBeenCalledWith(PlayerEvent.AdError, expect.any(Function));
|
|
93
|
+
});
|
|
94
|
+
it('should remove event listeners after they are triggered', () => {
|
|
95
|
+
setupAccessibilityAttributes(playerContext);
|
|
96
|
+
const triggerFunction = mockAddEventListener.mock.calls[0][1];
|
|
97
|
+
triggerFunction();
|
|
98
|
+
expect(mockRemoveEventListener).toHaveBeenCalledTimes(3);
|
|
99
|
+
expect(mockRemoveEventListener).toHaveBeenCalledWith(PlayerEvent.SourceLoaded, triggerFunction);
|
|
100
|
+
expect(mockRemoveEventListener).toHaveBeenCalledWith(PlayerEvent.AdBreakFinished, triggerFunction);
|
|
101
|
+
expect(mockRemoveEventListener).toHaveBeenCalledWith(PlayerEvent.AdError, triggerFunction);
|
|
102
|
+
});
|
|
103
|
+
it('should call addAccessibilityAttributes with the correct parameters', () => {
|
|
104
|
+
setupAccessibilityAttributes(playerContext);
|
|
105
|
+
const triggerFunction = mockAddEventListener.mock.calls[0][1];
|
|
106
|
+
triggerFunction();
|
|
107
|
+
expect(addAccessibilityAttributes).toHaveBeenCalledWith(playerContext.npoplayer.container, playerContext.npoplayer.streamObject.metadata);
|
|
108
|
+
});
|
|
109
|
+
});
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { getAVType } from './getAVType';
|
|
2
|
+
describe('getAVType', () => {
|
|
3
|
+
it('should return "video" for "video"', () => {
|
|
4
|
+
expect(getAVType('video')).toBe('video');
|
|
5
|
+
});
|
|
6
|
+
it('should return "audio" for "audio"', () => {
|
|
7
|
+
expect(getAVType('audio')).toBe('audio');
|
|
8
|
+
});
|
|
9
|
+
it('should return "video" for "vod"', () => {
|
|
10
|
+
expect(getAVType('vod')).toBe('video');
|
|
11
|
+
});
|
|
12
|
+
it('should return "audio" for "aod"', () => {
|
|
13
|
+
expect(getAVType('aod')).toBe('audio');
|
|
14
|
+
});
|
|
15
|
+
it('should return "undefined" for an unknown type', () => {
|
|
16
|
+
expect(getAVType('dummy')).toBe(undefined);
|
|
17
|
+
});
|
|
18
|
+
});
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
export declare const appleDRM: string[];
|
|
2
|
+
export declare const openDRM: string[];
|
|
3
|
+
export declare enum DRM_TYPES {
|
|
4
|
+
FAIRPLAY = "fairplay",
|
|
5
|
+
WIDEVINE = "widevine",
|
|
6
|
+
PLAYREADY = "playready"
|
|
7
|
+
}
|
|
8
|
+
export declare enum STREAM_TYPES {
|
|
9
|
+
DASH = "dash",
|
|
10
|
+
HLS = "hls"
|
|
11
|
+
}
|
|
12
|
+
export type DRMInfo = {
|
|
13
|
+
supportedDRM: string[];
|
|
14
|
+
preferredDRM: string;
|
|
15
|
+
};
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
export const appleDRM = ['com.apple.fps.1_0', 'com.apple.fps.2_0'];
|
|
2
|
+
export const openDRM = ['com.widevine.alpha', 'com.microsoft.playready'];
|
|
3
|
+
export var DRM_TYPES;
|
|
4
|
+
(function (DRM_TYPES) {
|
|
5
|
+
DRM_TYPES["FAIRPLAY"] = "fairplay";
|
|
6
|
+
DRM_TYPES["WIDEVINE"] = "widevine";
|
|
7
|
+
DRM_TYPES["PLAYREADY"] = "playready";
|
|
8
|
+
})(DRM_TYPES || (DRM_TYPES = {}));
|
|
9
|
+
export var STREAM_TYPES;
|
|
10
|
+
(function (STREAM_TYPES) {
|
|
11
|
+
STREAM_TYPES["DASH"] = "dash";
|
|
12
|
+
STREAM_TYPES["HLS"] = "hls";
|
|
13
|
+
})(STREAM_TYPES || (STREAM_TYPES = {}));
|
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
import { DRM_TYPES, STREAM_TYPES } from './constants';
|
|
2
|
+
import { getBestDRMForDash, getBestDRMForHls } from './utils';
|
|
3
|
+
export async function decideProfile(playerContext, preferredDRM = '') {
|
|
4
|
+
if (!playerContext.player) {
|
|
5
|
+
console.error('No player detected');
|
|
6
|
+
return { profileName: '', drm: '' };
|
|
7
|
+
}
|
|
8
|
+
const player = playerContext.player;
|
|
9
|
+
const supportedTech = player.getSupportedTech();
|
|
10
|
+
const supportedDRM = await player.getSupportedDRM();
|
|
11
|
+
const isSafari = /^((?!chrome|android).)*safari/i.test(navigator.userAgent);
|
|
12
|
+
if ((isSafari && supportedTech.some((tech) => tech.streaming === 'hls') && supportedDRM.includes(DRM_TYPES.FAIRPLAY)) ||
|
|
13
|
+
preferredDRM === DRM_TYPES.FAIRPLAY) {
|
|
14
|
+
return { profileName: STREAM_TYPES.HLS, drm: DRM_TYPES.FAIRPLAY };
|
|
15
|
+
}
|
|
16
|
+
const { bestWithDRM, bestDRM } = determineBestWithDRM(supportedTech, { supportedDRM, preferredDRM });
|
|
17
|
+
const bestWithoutDRM = determineBestWithoutDRM(supportedTech);
|
|
18
|
+
return bestWithDRM ? { profileName: bestWithDRM, drm: bestDRM } : { profileName: bestWithoutDRM, drm: bestDRM };
|
|
19
|
+
}
|
|
20
|
+
function determineBestWithDRM(supportedTech, drmInfo) {
|
|
21
|
+
let bestWithDRM = '';
|
|
22
|
+
let bestDRM = '';
|
|
23
|
+
const techMap = {
|
|
24
|
+
dash: { drm: DRM_TYPES.WIDEVINE, stream: STREAM_TYPES.DASH },
|
|
25
|
+
hls: { drm: DRM_TYPES.FAIRPLAY, stream: STREAM_TYPES.HLS },
|
|
26
|
+
whep: {
|
|
27
|
+
drm: drmInfo.preferredDRM === DRM_TYPES.FAIRPLAY ? DRM_TYPES.FAIRPLAY : '',
|
|
28
|
+
stream: drmInfo.preferredDRM === DRM_TYPES.FAIRPLAY ? STREAM_TYPES.HLS : STREAM_TYPES.DASH
|
|
29
|
+
}
|
|
30
|
+
};
|
|
31
|
+
for (const tech of supportedTech) {
|
|
32
|
+
if (bestWithDRM)
|
|
33
|
+
continue;
|
|
34
|
+
if (techMap[tech.streaming]) {
|
|
35
|
+
const { drm, stream } = techMap[tech.streaming];
|
|
36
|
+
if (drmInfo.preferredDRM !== drm) {
|
|
37
|
+
bestDRM =
|
|
38
|
+
tech.streaming === STREAM_TYPES.DASH ? getBestDRMForDash(drmInfo) : getBestDRMForHls(drmInfo);
|
|
39
|
+
if (bestDRM)
|
|
40
|
+
bestWithDRM = stream;
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
return { bestWithDRM, bestDRM };
|
|
45
|
+
}
|
|
46
|
+
function determineBestWithoutDRM(supportedTech) {
|
|
47
|
+
for (const tech of supportedTech) {
|
|
48
|
+
return tech.streaming;
|
|
49
|
+
}
|
|
50
|
+
return '';
|
|
51
|
+
}
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import { decideProfile } from './decideprofile';
|
|
2
|
+
import { mockNpoPlayer } from '../../../tests/mocks/mockNpoplayer';
|
|
3
|
+
import { STREAM_TYPES, DRM_TYPES } from './constants';
|
|
4
|
+
describe('decideProfile', () => {
|
|
5
|
+
let mockPlayer;
|
|
6
|
+
const mockNpoplayer = mockNpoPlayer;
|
|
7
|
+
let mockPlayerContext;
|
|
8
|
+
beforeEach(() => {
|
|
9
|
+
jest.clearAllMocks();
|
|
10
|
+
mockPlayer = {
|
|
11
|
+
getSupportedTech: jest.fn().mockReturnValue([{ streaming: STREAM_TYPES.DASH }, { streaming: STREAM_TYPES.HLS }]),
|
|
12
|
+
getSupportedDRM: jest
|
|
13
|
+
.fn()
|
|
14
|
+
.mockResolvedValue(['com.widevine.alpha', 'com.microsoft.playready', 'com.apple.fps.1_0'])
|
|
15
|
+
};
|
|
16
|
+
mockPlayerContext = { player: mockPlayer, npoplayer: mockNpoplayer };
|
|
17
|
+
});
|
|
18
|
+
afterEach(() => {
|
|
19
|
+
jest.clearAllMocks();
|
|
20
|
+
});
|
|
21
|
+
it('should return profile with dash streaming and widevine DRM', async () => {
|
|
22
|
+
const result = await decideProfile(mockPlayerContext);
|
|
23
|
+
expect(result).toEqual({ profileName: STREAM_TYPES.DASH, drm: DRM_TYPES.WIDEVINE });
|
|
24
|
+
});
|
|
25
|
+
it('should return profile with hls streaming and fairplay DRM on Safari', async () => {
|
|
26
|
+
Object.defineProperty(window.navigator, 'userAgent', { value: 'Safari', configurable: true });
|
|
27
|
+
const result = await decideProfile(mockPlayerContext, DRM_TYPES.FAIRPLAY);
|
|
28
|
+
expect(result).toEqual({ profileName: STREAM_TYPES.HLS, drm: DRM_TYPES.FAIRPLAY });
|
|
29
|
+
});
|
|
30
|
+
it('should return profile with hls streaming and fairplay DRM when preferred DRM is Fairplay', async () => {
|
|
31
|
+
const result = await decideProfile(mockPlayerContext, DRM_TYPES.FAIRPLAY);
|
|
32
|
+
expect(result).toEqual({ profileName: STREAM_TYPES.HLS, drm: DRM_TYPES.FAIRPLAY });
|
|
33
|
+
});
|
|
34
|
+
});
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
import { type DRMInfo } from './constants';
|
|
2
|
+
export declare function isSupportedAppleDRM(drm: string): boolean;
|
|
3
|
+
export declare function isSupportedOpenDRM(drm: string): boolean;
|
|
4
|
+
export declare function getBestDRMForDash(drmInfo: DRMInfo): string;
|
|
5
|
+
export declare function getBestDRMForHls(drmInfo: DRMInfo): string;
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import { appleDRM, openDRM, DRM_TYPES } from './constants';
|
|
2
|
+
export function isSupportedAppleDRM(drm) {
|
|
3
|
+
return appleDRM.includes(drm);
|
|
4
|
+
}
|
|
5
|
+
export function isSupportedOpenDRM(drm) {
|
|
6
|
+
return openDRM.includes(drm);
|
|
7
|
+
}
|
|
8
|
+
export function getBestDRMForDash(drmInfo) {
|
|
9
|
+
for (const drm of drmInfo.supportedDRM) {
|
|
10
|
+
if (isSupportedOpenDRM(drm) && !drmInfo.preferredDRM) {
|
|
11
|
+
return 'widevine';
|
|
12
|
+
}
|
|
13
|
+
if (isSupportedAppleDRM(drm) && drmInfo.preferredDRM === DRM_TYPES.FAIRPLAY) {
|
|
14
|
+
return DRM_TYPES.FAIRPLAY;
|
|
15
|
+
}
|
|
16
|
+
}
|
|
17
|
+
return '';
|
|
18
|
+
}
|
|
19
|
+
export function getBestDRMForHls(drmInfo) {
|
|
20
|
+
for (const drm of drmInfo.supportedDRM) {
|
|
21
|
+
if (isSupportedAppleDRM(drm) && (drmInfo.preferredDRM === DRM_TYPES.FAIRPLAY || !drmInfo.preferredDRM)) {
|
|
22
|
+
return DRM_TYPES.FAIRPLAY;
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
return '';
|
|
26
|
+
}
|
|
@@ -0,0 +1,74 @@
|
|
|
1
|
+
import { isSupportedAppleDRM, isSupportedOpenDRM, getBestDRMForDash, getBestDRMForHls } from './utils';
|
|
2
|
+
import { DRM_TYPES } from './constants';
|
|
3
|
+
const appleFps1 = 'com.apple.fps.1_0';
|
|
4
|
+
const appleFps2 = 'com.apple.fps.2_0';
|
|
5
|
+
const widevine = 'com.widevine.alpha';
|
|
6
|
+
const playready = 'com.microsoft.playready';
|
|
7
|
+
describe('DRM Functions', () => {
|
|
8
|
+
describe('isSupportedAppleDRM', () => {
|
|
9
|
+
it('should return true for supported Apple DRM', () => {
|
|
10
|
+
expect(isSupportedAppleDRM(appleFps1)).toBe(true);
|
|
11
|
+
expect(isSupportedAppleDRM(appleFps2)).toBe(true);
|
|
12
|
+
});
|
|
13
|
+
it('should return false for unsupported Apple DRM', () => {
|
|
14
|
+
expect(isSupportedAppleDRM(widevine)).toBe(false);
|
|
15
|
+
expect(isSupportedAppleDRM(playready)).toBe(false);
|
|
16
|
+
});
|
|
17
|
+
});
|
|
18
|
+
describe('isSupportedOpenDRM', () => {
|
|
19
|
+
it('should return true for supported Open DRM', () => {
|
|
20
|
+
expect(isSupportedOpenDRM(widevine)).toBe(true);
|
|
21
|
+
expect(isSupportedOpenDRM(playready)).toBe(true);
|
|
22
|
+
});
|
|
23
|
+
it('should return false for unsupported Open DRM', () => {
|
|
24
|
+
expect(isSupportedOpenDRM(appleFps1)).toBe(false);
|
|
25
|
+
expect(isSupportedOpenDRM(appleFps2)).toBe(false);
|
|
26
|
+
});
|
|
27
|
+
});
|
|
28
|
+
describe('getBestDRMForDash', () => {
|
|
29
|
+
it('should return widevine for supported open DRM and no preferred DRM', () => {
|
|
30
|
+
const drmInfo = {
|
|
31
|
+
supportedDRM: [widevine],
|
|
32
|
+
preferredDRM: ''
|
|
33
|
+
};
|
|
34
|
+
expect(getBestDRMForDash(drmInfo)).toBe('widevine');
|
|
35
|
+
});
|
|
36
|
+
it('should return fairplay for supported Apple DRM and preferred DRM is fairplay', () => {
|
|
37
|
+
const drmInfo = {
|
|
38
|
+
supportedDRM: [appleFps1],
|
|
39
|
+
preferredDRM: DRM_TYPES.FAIRPLAY
|
|
40
|
+
};
|
|
41
|
+
expect(getBestDRMForDash(drmInfo)).toBe(DRM_TYPES.FAIRPLAY);
|
|
42
|
+
});
|
|
43
|
+
it('should return empty string for no matching DRM', () => {
|
|
44
|
+
const drmInfo = {
|
|
45
|
+
supportedDRM: ['com.other.drm'],
|
|
46
|
+
preferredDRM: ''
|
|
47
|
+
};
|
|
48
|
+
expect(getBestDRMForDash(drmInfo)).toBe('');
|
|
49
|
+
});
|
|
50
|
+
});
|
|
51
|
+
describe('getBestDRMForHls', () => {
|
|
52
|
+
it('should return fairplay for supported Apple DRM and preferred DRM is fairplay', () => {
|
|
53
|
+
const drmInfo = {
|
|
54
|
+
supportedDRM: [appleFps1],
|
|
55
|
+
preferredDRM: DRM_TYPES.FAIRPLAY
|
|
56
|
+
};
|
|
57
|
+
expect(getBestDRMForHls(drmInfo)).toBe(DRM_TYPES.FAIRPLAY);
|
|
58
|
+
});
|
|
59
|
+
it('should return fairplay for supported Apple DRM and no preferred DRM', () => {
|
|
60
|
+
const drmInfo = {
|
|
61
|
+
supportedDRM: [appleFps2],
|
|
62
|
+
preferredDRM: ''
|
|
63
|
+
};
|
|
64
|
+
expect(getBestDRMForHls(drmInfo)).toBe(DRM_TYPES.FAIRPLAY);
|
|
65
|
+
});
|
|
66
|
+
it('should return empty string for no matching DRM', () => {
|
|
67
|
+
const drmInfo = {
|
|
68
|
+
supportedDRM: ['com.other.drm'],
|
|
69
|
+
preferredDRM: ''
|
|
70
|
+
};
|
|
71
|
+
expect(getBestDRMForHls(drmInfo)).toBe('');
|
|
72
|
+
});
|
|
73
|
+
});
|
|
74
|
+
});
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
import { convertJwtToBase64, convertBase64ToObject } from '../../js/utilities/utilities.jwt';
|
|
2
|
+
import { getStreamObject } from '../../js/api/getstreamobject';
|
|
3
|
+
export async function verifyDRM(playerContext, payload) {
|
|
4
|
+
try {
|
|
5
|
+
const { player, npoplayer: { streamObject, sourceConfig } } = playerContext;
|
|
6
|
+
const { stream } = streamObject;
|
|
7
|
+
if (stream.drmToken) {
|
|
8
|
+
const drmJsonTimestamp = getDRMTokenTimestamp(stream.drmToken);
|
|
9
|
+
const currentTime = Math.trunc(Date.now() / 1000);
|
|
10
|
+
if (drmJsonTimestamp >= currentTime) {
|
|
11
|
+
await player.load(sourceConfig);
|
|
12
|
+
return;
|
|
13
|
+
}
|
|
14
|
+
console.warn('DRM token window verstreken; item wordt herladen met een nieuwe token.');
|
|
15
|
+
await refreshDRMToken(playerContext, payload);
|
|
16
|
+
return;
|
|
17
|
+
}
|
|
18
|
+
await loadPlayer(playerContext, sourceConfig);
|
|
19
|
+
}
|
|
20
|
+
catch (error) {
|
|
21
|
+
console.error(`Error verifying DRM in verifyDRM function: ${error}`);
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
async function loadPlayer(playerContext, sourceConfig) {
|
|
25
|
+
await playerContext.player.load(sourceConfig);
|
|
26
|
+
}
|
|
27
|
+
function getDRMTokenTimestamp(drmToken) {
|
|
28
|
+
const drmBase64 = convertJwtToBase64(drmToken);
|
|
29
|
+
return convertBase64ToObject(drmBase64).iat;
|
|
30
|
+
}
|
|
31
|
+
async function refreshDRMToken(playerContext, payload) {
|
|
32
|
+
const backupStreamObject = await getStreamObject(playerContext.npoplayer, payload);
|
|
33
|
+
const newDrmToken = backupStreamObject.stream.drmToken;
|
|
34
|
+
const clonedStreamObject = {
|
|
35
|
+
...playerContext.npoplayer.streamObject,
|
|
36
|
+
stream: { ...playerContext.npoplayer.streamObject.stream, drmToken: newDrmToken }
|
|
37
|
+
};
|
|
38
|
+
playerContext.npoplayer.streamObject = clonedStreamObject;
|
|
39
|
+
await loadPlayer(playerContext, playerContext.npoplayer.sourceConfig);
|
|
40
|
+
}
|
|
@@ -0,0 +1,89 @@
|
|
|
1
|
+
import { verifyDRM } from './verifydrm';
|
|
2
|
+
import { mockNpoPlayer } from '../../../tests/mocks/mockNpoplayer';
|
|
3
|
+
import { convertBase64ToObject, convertJwtToBase64 } from '../../js/utilities/utilities.jwt';
|
|
4
|
+
import { getStreamObject } from '../../js/api/getstreamobject';
|
|
5
|
+
jest.mock('../../js/utilities/utilities.jwt', () => ({
|
|
6
|
+
convertBase64ToObject: jest.fn(),
|
|
7
|
+
convertJwtToBase64: jest.fn()
|
|
8
|
+
}));
|
|
9
|
+
jest.mock('../../js/api/getstreamobject', () => ({
|
|
10
|
+
getStreamObject: jest.fn()
|
|
11
|
+
}));
|
|
12
|
+
let mockPlayer;
|
|
13
|
+
const mockNpoplayer = mockNpoPlayer;
|
|
14
|
+
let mockPlayerContext;
|
|
15
|
+
beforeEach(() => {
|
|
16
|
+
jest.clearAllMocks();
|
|
17
|
+
mockPlayer = {
|
|
18
|
+
streamObject: { stream: { drmToken: undefined } },
|
|
19
|
+
load: jest.fn()
|
|
20
|
+
};
|
|
21
|
+
mockPlayerContext = { player: mockPlayer, npoplayer: mockNpoplayer };
|
|
22
|
+
});
|
|
23
|
+
afterEach(() => {
|
|
24
|
+
jest.clearAllMocks();
|
|
25
|
+
});
|
|
26
|
+
const payload = {
|
|
27
|
+
baseURL: 'url',
|
|
28
|
+
jwt: 'jwt',
|
|
29
|
+
data: { data: 'data' }
|
|
30
|
+
};
|
|
31
|
+
describe('Test DRM verification', () => {
|
|
32
|
+
it('should call player.load when the drmToken is not null and drmJsonTimestamp is greater than currentTime', async () => {
|
|
33
|
+
const currentTime = Math.trunc(Date.now() / 1000);
|
|
34
|
+
const drmToken = 'token';
|
|
35
|
+
const drmJsonTimestamp = currentTime + 10;
|
|
36
|
+
const sourceConfig = {};
|
|
37
|
+
mockNpoPlayer.streamObject.stream = {
|
|
38
|
+
avType: '',
|
|
39
|
+
drmType: '',
|
|
40
|
+
streamProfile: '',
|
|
41
|
+
sourceProfile: '',
|
|
42
|
+
streamURL: '',
|
|
43
|
+
drmToken: drmToken
|
|
44
|
+
};
|
|
45
|
+
mockPlayerContext.npoplayer.sourceConfig = sourceConfig;
|
|
46
|
+
jest.spyOn(global.Date, 'now').mockImplementation(() => currentTime * 1000);
|
|
47
|
+
convertJwtToBase64.mockReturnValue(JSON.stringify({ iat: drmJsonTimestamp }));
|
|
48
|
+
convertBase64ToObject.mockReturnValue({ iat: drmJsonTimestamp });
|
|
49
|
+
await verifyDRM(mockPlayerContext, payload);
|
|
50
|
+
expect(mockPlayerContext.player.load).toHaveBeenCalledWith(sourceConfig);
|
|
51
|
+
});
|
|
52
|
+
it('should call refreshDRMToken when the drmToken is not null and drmJsonTimestamp is less than currentTime', async () => {
|
|
53
|
+
const currentTime = Math.trunc(Date.now() / 1000);
|
|
54
|
+
const drmToken = 'token';
|
|
55
|
+
const drmJsonTimestamp = currentTime - 10;
|
|
56
|
+
const sourceConfig = {};
|
|
57
|
+
mockNpoPlayer.streamObject.stream = {
|
|
58
|
+
avType: '',
|
|
59
|
+
drmType: '',
|
|
60
|
+
streamProfile: '',
|
|
61
|
+
sourceProfile: '',
|
|
62
|
+
streamURL: '',
|
|
63
|
+
drmToken: drmToken
|
|
64
|
+
};
|
|
65
|
+
mockPlayerContext.npoplayer.sourceConfig = sourceConfig;
|
|
66
|
+
jest.spyOn(global.Date, 'now').mockImplementation(() => currentTime * 1000);
|
|
67
|
+
convertJwtToBase64.mockReturnValue(JSON.stringify({ iat: drmJsonTimestamp }));
|
|
68
|
+
convertBase64ToObject.mockReturnValue({ iat: drmJsonTimestamp });
|
|
69
|
+
getStreamObject.mockResolvedValue({ stream: { drmToken: 'newToken' } });
|
|
70
|
+
jest.spyOn(mockPlayerContext.player, 'load').mockResolvedValue(undefined);
|
|
71
|
+
await verifyDRM(mockPlayerContext, payload);
|
|
72
|
+
expect(getStreamObject).toHaveBeenCalledWith(mockPlayerContext.npoplayer, payload);
|
|
73
|
+
expect(mockPlayerContext.player.load).toHaveBeenCalledWith(sourceConfig);
|
|
74
|
+
});
|
|
75
|
+
it('should call loadPlayer when the drmToken is null', async () => {
|
|
76
|
+
const sourceConfig = {};
|
|
77
|
+
mockNpoPlayer.streamObject.stream = {
|
|
78
|
+
avType: '',
|
|
79
|
+
drmType: '',
|
|
80
|
+
streamProfile: '',
|
|
81
|
+
sourceProfile: '',
|
|
82
|
+
streamURL: '',
|
|
83
|
+
drmToken: undefined
|
|
84
|
+
};
|
|
85
|
+
mockPlayerContext.npoplayer.sourceConfig = sourceConfig;
|
|
86
|
+
await verifyDRM(mockPlayerContext, payload);
|
|
87
|
+
expect(mockPlayerContext.player.load).toHaveBeenCalledWith(sourceConfig);
|
|
88
|
+
});
|
|
89
|
+
});
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { PlayerEvent } from 'bitmovin-player';
|
|
2
|
+
export const removeEventListeners = (playerContext) => {
|
|
3
|
+
const { eventListeners } = playerContext.npoplayer;
|
|
4
|
+
if (eventListeners) {
|
|
5
|
+
const { segmentHandleTimeChangedCallback, segmentSeekFunctionCallback, liveStreamHandleTimeChangedCallback } = eventListeners;
|
|
6
|
+
const eventMapping = [
|
|
7
|
+
{ event: PlayerEvent.TimeChanged, callback: liveStreamHandleTimeChangedCallback },
|
|
8
|
+
{ event: PlayerEvent.TimeChanged, callback: segmentHandleTimeChangedCallback },
|
|
9
|
+
{ event: PlayerEvent.Seek, callback: segmentSeekFunctionCallback }
|
|
10
|
+
];
|
|
11
|
+
for (const { event, callback } of eventMapping) {
|
|
12
|
+
if (callback) {
|
|
13
|
+
playerContext.player.off(event, callback);
|
|
14
|
+
}
|
|
15
|
+
}
|
|
16
|
+
playerContext.npoplayer.eventListeners = undefined;
|
|
17
|
+
}
|
|
18
|
+
};
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
import { PlayerEvent } from 'bitmovin-player';
|
|
2
|
+
import { mockPlayerContext } from '../../../tests/mocks/mockPlayerContext';
|
|
3
|
+
import { removeEventListeners } from './removeEventListeners';
|
|
4
|
+
describe('removeEventListeners', () => {
|
|
5
|
+
let context;
|
|
6
|
+
beforeEach(() => {
|
|
7
|
+
context = { ...mockPlayerContext };
|
|
8
|
+
jest.clearAllMocks();
|
|
9
|
+
});
|
|
10
|
+
it('should remove TimeChanged event listener if exists', () => {
|
|
11
|
+
removeEventListeners(context);
|
|
12
|
+
if (context.npoplayer.eventListeners) {
|
|
13
|
+
expect(context.player.off).toHaveBeenCalledWith(PlayerEvent.TimeChanged, context.npoplayer.eventListeners.segmentHandleTimeChangedCallback);
|
|
14
|
+
expect(context.player.off).toHaveBeenCalledWith(PlayerEvent.TimeChanged, context.npoplayer.eventListeners.liveStreamHandleTimeChangedCallback);
|
|
15
|
+
}
|
|
16
|
+
});
|
|
17
|
+
it('should remove Seek event listener if exists', () => {
|
|
18
|
+
removeEventListeners(context);
|
|
19
|
+
if (context.npoplayer.eventListeners) {
|
|
20
|
+
expect(context.player.off).toHaveBeenCalledWith(PlayerEvent.Seek, context.npoplayer.eventListeners.segmentSeekFunctionCallback);
|
|
21
|
+
}
|
|
22
|
+
});
|
|
23
|
+
it('should reset EventListeners in playerContext', () => {
|
|
24
|
+
removeEventListeners(context);
|
|
25
|
+
expect(context.npoplayer.eventListeners).toBeUndefined();
|
|
26
|
+
});
|
|
27
|
+
});
|
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
import { ViewMode } from '../../types/interfaces';
|
|
2
|
+
export function resolveKeyPress(playerContext, e) {
|
|
3
|
+
const isMuted = playerContext.player.isMuted() ?? false;
|
|
4
|
+
const isPaused = playerContext.player.isPaused() ?? false;
|
|
5
|
+
const viewMode = playerContext.player.getViewMode();
|
|
6
|
+
if (['Space', 'ArrowUp', 'ArrowDown'].includes(e.code))
|
|
7
|
+
e.preventDefault();
|
|
8
|
+
const actions = {
|
|
9
|
+
KeyM: () => (isMuted ? playerContext.player.unmute() : playerContext.player.mute()),
|
|
10
|
+
KeyF: () => viewMode === ViewMode.Fullscreen
|
|
11
|
+
? playerContext.player.setViewMode(ViewMode.Inline)
|
|
12
|
+
: playerContext.player.setViewMode(ViewMode.Fullscreen),
|
|
13
|
+
Space: () => {
|
|
14
|
+
if (isPaused) {
|
|
15
|
+
playerContext.player.play().catch((error) => {
|
|
16
|
+
console.error('Failed to play:', error);
|
|
17
|
+
});
|
|
18
|
+
}
|
|
19
|
+
else {
|
|
20
|
+
playerContext.player.pause();
|
|
21
|
+
}
|
|
22
|
+
},
|
|
23
|
+
ArrowUp: () => {
|
|
24
|
+
if (isMuted)
|
|
25
|
+
playerContext.player.unmute();
|
|
26
|
+
playerContext.npoplayer.increaseVolume();
|
|
27
|
+
},
|
|
28
|
+
ArrowDown: () => {
|
|
29
|
+
if (isMuted)
|
|
30
|
+
playerContext.player.unmute();
|
|
31
|
+
playerContext.npoplayer.decreaseVolume();
|
|
32
|
+
},
|
|
33
|
+
ArrowLeft: () => playerContext.npoplayer.goBackwards(10),
|
|
34
|
+
ArrowRight: () => playerContext.npoplayer.goForward(10),
|
|
35
|
+
Escape: () => {
|
|
36
|
+
const { settingsPanels } = playerContext.npoplayer.uiComponents;
|
|
37
|
+
if (settingsPanels && settingsPanels.length > 0) {
|
|
38
|
+
for (const panel of settingsPanels) {
|
|
39
|
+
if (panel.isShown()) {
|
|
40
|
+
panel.hide();
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
};
|
|
46
|
+
const action = actions[e.code];
|
|
47
|
+
if (action)
|
|
48
|
+
action();
|
|
49
|
+
}
|