@npo/player 1.10.1 → 1.10.2
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/lib/js/ads/ster.js +107 -0
- package/lib/js/ads/ster.js.map +1 -0
- package/lib/js/ads/ster.test.js +91 -0
- package/lib/js/ads/ster.test.js.map +1 -0
- package/lib/js/api/getstreamobject.js +18 -0
- package/lib/js/api/getstreamobject.js.map +1 -0
- package/lib/js/cdnproviders.js +13 -0
- package/lib/js/cdnproviders.js.map +1 -0
- package/lib/js/checks/safari.js +10 -0
- package/lib/js/checks/safari.js.map +1 -0
- package/lib/js/checks/safari.test.js +21 -0
- package/lib/js/checks/safari.test.js.map +1 -0
- package/lib/js/drm/verifydrm.js +25 -0
- package/lib/js/drm/verifydrm.js.map +1 -0
- package/lib/js/drm/verifydrm.test.js +18 -0
- package/lib/js/drm/verifydrm.test.js.map +1 -0
- package/lib/js/fragments/setfragments.js +66 -0
- package/lib/js/fragments/setfragments.js.map +1 -0
- package/lib/js/playeractions/customerrors.test.js +52 -0
- package/lib/js/playeractions/customerrors.test.js.map +1 -0
- package/lib/js/playeractions/handlers/customerrors.js +57 -0
- package/lib/js/playeractions/handlers/customerrors.js.map +1 -0
- package/lib/js/playeractions/handlers/error.js +15 -0
- package/lib/js/playeractions/handlers/error.js.map +1 -0
- package/lib/js/playeractions/handlers/error.test.js +45 -0
- package/lib/js/playeractions/handlers/error.test.js.map +1 -0
- package/lib/js/playeractions/handlers/handleoffsets.js +45 -0
- package/lib/js/playeractions/handlers/handleoffsets.js.map +1 -0
- package/lib/js/playeractions/handlers/handleoffsets.test.js +50 -0
- package/lib/js/playeractions/handlers/handleoffsets.test.js.map +1 -0
- package/lib/js/playeractions/handlers/processplayerconfig.js +28 -0
- package/lib/js/playeractions/handlers/processplayerconfig.js.map +1 -0
- package/lib/js/playeractions/handlers/resolvekeypress.js +47 -0
- package/lib/js/playeractions/handlers/resolvekeypress.js.map +1 -0
- package/lib/js/playeractions/playeractions.js +5 -0
- package/lib/js/playeractions/playeractions.js.map +1 -0
- package/lib/js/tracking/handlers/eventbinding.js +72 -0
- package/lib/js/tracking/handlers/eventbinding.js.map +1 -0
- package/lib/js/tracking/handlers/eventlogging.js +32 -0
- package/lib/js/tracking/handlers/eventlogging.js.map +1 -0
- package/lib/js/tracking/handlers/playertrackerinit.js +20 -0
- package/lib/js/tracking/handlers/playertrackerinit.js.map +1 -0
- package/lib/js/tracking/handlers/playertrackerstart.js +22 -0
- package/lib/js/tracking/handlers/playertrackerstart.js.map +1 -0
- package/lib/js/tracking/playertracker.js +5 -0
- package/lib/js/tracking/playertracker.js.map +1 -0
- package/lib/js/ui/components/adbutton.js +12 -0
- package/lib/js/ui/components/adbutton.js.map +1 -0
- package/lib/js/ui/components/adlabel.js +8 -0
- package/lib/js/ui/components/adlabel.js.map +1 -0
- package/lib/js/ui/components/buttons.js +86 -0
- package/lib/js/ui/components/buttons.js.map +1 -0
- package/lib/js/ui/components/controlbar.js +58 -0
- package/lib/js/ui/components/controlbar.js.map +1 -0
- package/lib/js/ui/components/ctabar.d.ts +1 -1
- package/lib/js/ui/components/ctabar.js +24 -0
- package/lib/js/ui/components/ctabar.js.map +1 -0
- package/lib/js/ui/components/nativemobile/addFragments.js +8 -0
- package/lib/js/ui/components/nativemobile/addFragments.js.map +1 -0
- package/lib/js/ui/components/nativemobile/buttons.js +43 -0
- package/lib/js/ui/components/nativemobile/buttons.js.map +1 -0
- package/lib/js/ui/components/nativemobile/controlbar.js +52 -0
- package/lib/js/ui/components/nativemobile/controlbar.js.map +1 -0
- package/lib/js/ui/components/nativemobile/ctabar.js +12 -0
- package/lib/js/ui/components/nativemobile/ctabar.js.map +1 -0
- package/lib/js/ui/components/nativemobile/playnext.js +16 -0
- package/lib/js/ui/components/nativemobile/playnext.js.map +1 -0
- package/lib/js/ui/components/nativemobile/titlebar.js +8 -0
- package/lib/js/ui/components/nativemobile/titlebar.js.map +1 -0
- package/lib/js/ui/components/nativemobile/topbar.js +21 -0
- package/lib/js/ui/components/nativemobile/topbar.js.map +1 -0
- package/lib/js/ui/components/playnext.js +10 -0
- package/lib/js/ui/components/playnext.js.map +1 -0
- package/lib/js/ui/components/settingspanel.js +129 -0
- package/lib/js/ui/components/settingspanel.js.map +1 -0
- package/lib/js/ui/components/shared/playnextscreen.js +17 -0
- package/lib/js/ui/components/shared/playnextscreen.js.map +1 -0
- package/lib/js/ui/components/titlebar.js +9 -0
- package/lib/js/ui/components/titlebar.js.map +1 -0
- package/lib/js/ui/components/topbar.js +22 -0
- package/lib/js/ui/components/topbar.js.map +1 -0
- package/lib/js/ui/handlers/listboxhandlers.js +41 -0
- package/lib/js/ui/handlers/listboxhandlers.js.map +1 -0
- package/lib/js/ui/handlers/nicamhandler.js +15 -0
- package/lib/js/ui/handlers/nicamhandler.js.map +1 -0
- package/lib/js/ui/handlers/nicamhandler.test.js +34 -0
- package/lib/js/ui/handlers/nicamhandler.test.js.map +1 -0
- package/lib/js/ui/handlers/playnexthandlers.js +2 -0
- package/lib/js/ui/handlers/playnexthandlers.js.map +1 -0
- package/lib/js/ui/handlers/timecontrolhandlers.js +22 -0
- package/lib/js/ui/handlers/timecontrolhandlers.js.map +1 -0
- package/lib/js/ui/nativemobileuicontainer.js +48 -0
- package/lib/js/ui/nativemobileuicontainer.js.map +1 -0
- package/lib/js/ui/nativemobileuifactory.js +42 -0
- package/lib/js/ui/nativemobileuifactory.js.map +1 -0
- package/lib/js/ui/uicontainer.js +57 -0
- package/lib/js/ui/uicontainer.js.map +1 -0
- package/lib/js/utilities/localizationconfig.js +8 -0
- package/lib/js/utilities/localizationconfig.js.map +1 -0
- package/lib/js/utilities/printversion.js +27 -0
- package/lib/js/utilities/printversion.js.map +1 -0
- package/lib/js/utilities/utilities.js +52 -0
- package/lib/js/utilities/utilities.js.map +1 -0
- package/lib/lang/nl.json +72 -0
- package/lib/npoplayer.js +465 -2
- package/lib/npoplayer.js.map +1 -1
- package/lib/npoplayer.test.js +12 -0
- package/lib/npoplayer.test.js.map +1 -0
- package/lib/package.json +1 -1
- package/lib/types/classes.js +4 -0
- package/lib/types/classes.js.map +1 -0
- package/lib/types/interfaces.js +6 -0
- package/lib/types/interfaces.js.map +1 -0
- package/package.json +1 -1
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
import { PlayerEvent } from 'bitmovin-player';
|
|
2
|
+
export function handleStartOffset(player, offset) {
|
|
3
|
+
if (offset == null || player.isLive()) {
|
|
4
|
+
if (player.isLive()) {
|
|
5
|
+
console.warn('handleStartOffset was called but the player is playing live content.');
|
|
6
|
+
}
|
|
7
|
+
return;
|
|
8
|
+
}
|
|
9
|
+
player.on(PlayerEvent.SourceLoaded, () => {
|
|
10
|
+
player.seek(offset);
|
|
11
|
+
});
|
|
12
|
+
}
|
|
13
|
+
export function shiftToProgramStart(player, timestamp) {
|
|
14
|
+
if (player == null)
|
|
15
|
+
return;
|
|
16
|
+
if (timestamp == null || !player.isLive()) {
|
|
17
|
+
if (!player.isLive()) {
|
|
18
|
+
console.warn('shiftToProgramStart was called but the player is playing VOD content.');
|
|
19
|
+
}
|
|
20
|
+
return;
|
|
21
|
+
}
|
|
22
|
+
player.timeShift(timestamp);
|
|
23
|
+
}
|
|
24
|
+
export function handleLiveOffsetLogic(npoplayer, player, options) {
|
|
25
|
+
if (player == null)
|
|
26
|
+
return;
|
|
27
|
+
if (npoplayer.uiComponents.watchFromStartButton == null)
|
|
28
|
+
return;
|
|
29
|
+
if (options?.liveProgramTime == null) {
|
|
30
|
+
npoplayer.uiComponents.watchFromStartButton.hide();
|
|
31
|
+
return;
|
|
32
|
+
}
|
|
33
|
+
npoplayer.streamOptions.liveProgramTime = options.liveProgramTime;
|
|
34
|
+
if (player.isLive() && options.liveProgramTime > 0) {
|
|
35
|
+
npoplayer.uiComponents.watchFromStartButton.show();
|
|
36
|
+
}
|
|
37
|
+
else {
|
|
38
|
+
npoplayer.uiComponents.watchFromStartButton.hide();
|
|
39
|
+
}
|
|
40
|
+
if (options.liveOffset !== null && options.liveOffset !== false && options.liveProgramTime > 0) {
|
|
41
|
+
npoplayer.uiComponents.watchFromStartButton.hide();
|
|
42
|
+
shiftToProgramStart(player, options.liveProgramTime);
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
//# sourceMappingURL=handleoffsets.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"handleoffsets.js","sourceRoot":"","sources":["../../../../../src/js/playeractions/handlers/handleoffsets.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAkB,MAAM,iBAAiB,CAAA;AAY7D,MAAM,UAAU,iBAAiB,CAAE,MAAiB,EAAE,MAAe;IACjE,IAAI,MAAM,IAAI,IAAI,IAAI,MAAM,CAAC,MAAM,EAAE,EAAE;QACnC,IAAI,MAAM,CAAC,MAAM,EAAE,EAAE;YACjB,OAAO,CAAC,IAAI,CAAC,sEAAsE,CAAC,CAAA;SACvF;QACD,OAAM;KACT;IACD,MAAM,CAAC,EAAE,CAAC,WAAW,CAAC,YAAY,EAAE,GAAG,EAAE;QACrC,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,CAAA;IACvB,CAAC,CAAC,CAAA;AACN,CAAC;AAUD,MAAM,UAAU,mBAAmB,CAAE,MAAwB,EAAE,SAAkB;IAC7E,IAAI,MAAM,IAAI,IAAI;QAAE,OAAM;IAC1B,IAAI,SAAS,IAAI,IAAI,IAAI,CAAC,MAAM,CAAC,MAAM,EAAE,EAAE;QACvC,IAAI,CAAC,MAAM,CAAC,MAAM,EAAE,EAAE;YAClB,OAAO,CAAC,IAAI,CAAC,uEAAuE,CAAC,CAAA;SACxF;QACD,OAAM;KACT;IACD,MAAM,CAAC,SAAS,CAAC,SAAS,CAAC,CAAA;AAC/B,CAAC;AAYD,MAAM,UAAU,qBAAqB,CAAE,SAAoB,EAAE,MAAwB,EAAE,OAAsB;IACzG,IAAI,MAAM,IAAI,IAAI;QAAE,OAAM;IAC1B,IAAI,SAAS,CAAC,YAAY,CAAC,oBAAoB,IAAI,IAAI;QAAE,OAAM;IAC/D,IAAI,OAAO,EAAE,eAAe,IAAI,IAAI,EAAE;QAClC,SAAS,CAAC,YAAY,CAAC,oBAAoB,CAAC,IAAI,EAAE,CAAA;QAClD,OAAM;KACT;IAGD,SAAS,CAAC,aAAa,CAAC,eAAe,GAAG,OAAO,CAAC,eAAe,CAAA;IAEjE,IAAI,MAAM,CAAC,MAAM,EAAE,IAAI,OAAO,CAAC,eAAe,GAAG,CAAC,EAAG;QACjD,SAAS,CAAC,YAAY,CAAC,oBAAoB,CAAC,IAAI,EAAE,CAAA;KACrD;SAAM;QACH,SAAS,CAAC,YAAY,CAAC,oBAAoB,CAAC,IAAI,EAAE,CAAA;KACrD;IAED,IAAI,OAAO,CAAC,UAAU,KAAK,IAAI,IAAI,OAAO,CAAC,UAAU,KAAK,KAAK,IAAI,OAAO,CAAC,eAAe,GAAG,CAAC,EAAE;QAC5F,SAAS,CAAC,YAAY,CAAC,oBAAoB,CAAC,IAAI,EAAE,CAAA;QAClD,mBAAmB,CAAC,MAAM,EAAE,OAAO,CAAC,eAAe,CAAC,CAAA;KACvD;AACL,CAAC"}
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
import { handleStartOffset, shiftToProgramStart } from "./handleoffsets";
|
|
2
|
+
const isLive = () => true;
|
|
3
|
+
const onReady = jest.fn();
|
|
4
|
+
const timeShift = jest.fn();
|
|
5
|
+
const offset = 10;
|
|
6
|
+
const timestamp = 10;
|
|
7
|
+
const player = {
|
|
8
|
+
isLive,
|
|
9
|
+
on: onReady,
|
|
10
|
+
timeShift,
|
|
11
|
+
};
|
|
12
|
+
describe("Test offset handling", () => {
|
|
13
|
+
afterEach(() => {
|
|
14
|
+
jest.resetAllMocks();
|
|
15
|
+
});
|
|
16
|
+
it("should not seek when player is live", () => {
|
|
17
|
+
handleStartOffset(player, offset);
|
|
18
|
+
expect(onReady).not.toBeCalled();
|
|
19
|
+
});
|
|
20
|
+
it("should not seek when offset is undefined", () => {
|
|
21
|
+
handleStartOffset({ ...player, isLive: () => false });
|
|
22
|
+
expect(onReady).not.toBeCalled();
|
|
23
|
+
});
|
|
24
|
+
it("should seek when player is not live and offset is defined", () => {
|
|
25
|
+
handleStartOffset({ ...player, isLive: () => false }, offset);
|
|
26
|
+
expect(onReady).toBeCalled();
|
|
27
|
+
});
|
|
28
|
+
});
|
|
29
|
+
describe("Test programStart shift", () => {
|
|
30
|
+
afterEach(() => {
|
|
31
|
+
jest.resetAllMocks();
|
|
32
|
+
});
|
|
33
|
+
it("should not call timeshift when player is null", () => {
|
|
34
|
+
shiftToProgramStart(null, timestamp);
|
|
35
|
+
expect(timeShift).not.toBeCalled();
|
|
36
|
+
});
|
|
37
|
+
it("should not call timeshift when timestamp is undefined", () => {
|
|
38
|
+
shiftToProgramStart(player);
|
|
39
|
+
expect(timeShift).not.toBeCalled();
|
|
40
|
+
});
|
|
41
|
+
it("should not call timeshift when player is not live", () => {
|
|
42
|
+
shiftToProgramStart({ ...player, isLive: () => false }, timestamp);
|
|
43
|
+
expect(timeShift).not.toBeCalled();
|
|
44
|
+
});
|
|
45
|
+
it("should not call timeshift when player is live and timestamp is set", () => {
|
|
46
|
+
shiftToProgramStart(player, timestamp);
|
|
47
|
+
expect(timeShift).toBeCalled();
|
|
48
|
+
});
|
|
49
|
+
});
|
|
50
|
+
//# sourceMappingURL=handleoffsets.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"handleoffsets.test.js","sourceRoot":"","sources":["../../../../../src/js/playeractions/handlers/handleoffsets.test.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,iBAAiB,EAAE,mBAAmB,EAAE,MAAM,iBAAiB,CAAC;AAEzE,MAAM,MAAM,GAAG,GAAG,EAAE,CAAC,IAAI,CAAC;AAC1B,MAAM,OAAO,GAAG,IAAI,CAAC,EAAE,EAAE,CAAC;AAC1B,MAAM,SAAS,GAAG,IAAI,CAAC,EAAE,EAAE,CAAC;AAE5B,MAAM,MAAM,GAAG,EAAE,CAAC;AAClB,MAAM,SAAS,GAAG,EAAE,CAAC;AAErB,MAAM,MAAM,GAAG;IACX,MAAM;IACN,EAAE,EAAE,OAAO;IACX,SAAS;CACY,CAAC;AAE1B,QAAQ,CAAC,sBAAsB,EAAE,GAAG,EAAE;IAClC,SAAS,CAAC,GAAG,EAAE;QACX,IAAI,CAAC,aAAa,EAAE,CAAC;IACzB,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,qCAAqC,EAAE,GAAG,EAAE;QAC3C,iBAAiB,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;QAElC,MAAM,CAAC,OAAO,CAAC,CAAC,GAAG,CAAC,UAAU,EAAE,CAAC;IACrC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,0CAA0C,EAAE,GAAG,EAAE;QAChD,iBAAiB,CAAC,EAAE,GAAG,MAAM,EAAE,MAAM,EAAE,GAAG,EAAE,CAAC,KAAK,EAAE,CAAC,CAAC;QAEtD,MAAM,CAAC,OAAO,CAAC,CAAC,GAAG,CAAC,UAAU,EAAE,CAAC;IACrC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,2DAA2D,EAAE,GAAG,EAAE;QACjE,iBAAiB,CAAC,EAAE,GAAG,MAAM,EAAE,MAAM,EAAE,GAAG,EAAE,CAAC,KAAK,EAAE,EAAE,MAAM,CAAC,CAAC;QAE9D,MAAM,CAAC,OAAO,CAAC,CAAC,UAAU,EAAE,CAAC;IACjC,CAAC,CAAC,CAAC;AACP,CAAC,CAAC,CAAC;AAEH,QAAQ,CAAC,yBAAyB,EAAE,GAAG,EAAE;IACrC,SAAS,CAAC,GAAG,EAAE;QACX,IAAI,CAAC,aAAa,EAAE,CAAC;IACzB,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,+CAA+C,EAAE,GAAG,EAAE;QACrD,mBAAmB,CAAC,IAAI,EAAE,SAAS,CAAC,CAAC;QAErC,MAAM,CAAC,SAAS,CAAC,CAAC,GAAG,CAAC,UAAU,EAAE,CAAC;IACvC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,uDAAuD,EAAE,GAAG,EAAE;QAC7D,mBAAmB,CAAC,MAAM,CAAC,CAAC;QAE5B,MAAM,CAAC,SAAS,CAAC,CAAC,GAAG,CAAC,UAAU,EAAE,CAAC;IACvC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,mDAAmD,EAAE,GAAG,EAAE;QACzD,mBAAmB,CAAC,EAAE,GAAG,MAAM,EAAE,MAAM,EAAE,GAAG,EAAE,CAAC,KAAK,EAAE,EAAE,SAAS,CAAC,CAAC;QAEnE,MAAM,CAAC,SAAS,CAAC,CAAC,GAAG,CAAC,UAAU,EAAE,CAAC;IACvC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,oEAAoE,EAAE,GAAG,EAAE;QAC1E,mBAAmB,CAAC,MAAM,EAAE,SAAS,CAAC,CAAC;QAEvC,MAAM,CAAC,SAAS,CAAC,CAAC,UAAU,EAAE,CAAC;IACnC,CAAC,CAAC,CAAC;AACP,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import { LogLevel } from "bitmovin-player";
|
|
2
|
+
import { isSafari } from '../../checks/safari';
|
|
3
|
+
export function processPlayerConfig(npoplayer, playerConfig) {
|
|
4
|
+
let processedConfig = playerConfig;
|
|
5
|
+
if (isSafari(npoplayer.isFairPlayDrmSupported())) {
|
|
6
|
+
processedConfig.playback = {
|
|
7
|
+
autoplay: false
|
|
8
|
+
};
|
|
9
|
+
processedConfig.tweaks = {
|
|
10
|
+
fairplay_ignore_duplicate_init_data_key_errors: true
|
|
11
|
+
};
|
|
12
|
+
}
|
|
13
|
+
processedConfig.ui = false;
|
|
14
|
+
if (!processedConfig.remotecontrol)
|
|
15
|
+
processedConfig.remotecontrol = {
|
|
16
|
+
type: 'googlecast',
|
|
17
|
+
receiverApplicationId: 'CC38EB17',
|
|
18
|
+
receiverVersion: 'v3',
|
|
19
|
+
messageNamespace: 'urn:x-cast:com.bitmovin.player.caf'
|
|
20
|
+
};
|
|
21
|
+
if (!processedConfig.logs)
|
|
22
|
+
processedConfig.logs = {
|
|
23
|
+
level: LogLevel.ERROR
|
|
24
|
+
};
|
|
25
|
+
processedConfig.advertising = {};
|
|
26
|
+
return processedConfig;
|
|
27
|
+
}
|
|
28
|
+
//# sourceMappingURL=processplayerconfig.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"processplayerconfig.js","sourceRoot":"","sources":["../../../../../src/js/playeractions/handlers/processplayerconfig.ts"],"names":[],"mappings":"AASA,OAAO,EAAqB,QAAQ,EAAE,MAAM,iBAAiB,CAAC;AAE9D,OAAO,EAAE,QAAQ,EAAE,MAAM,qBAAqB,CAAA;AAE9C,MAAM,UAAU,mBAAmB,CAAC,SAAmB,EAAE,YAAyB;IAE9E,IAAI,eAAe,GAAG,YAAY,CAAA;IAElC,IAAI,QAAQ,CAAC,SAAS,CAAC,sBAAsB,EAAE,CAAC,EAAE;QAE9C,eAAe,CAAC,QAAQ,GAAG;YACvB,QAAQ,EAAE,KAAK;SAClB,CAAA;QAGD,eAAe,CAAC,MAAM,GAAG;YACrB,8CAA8C,EAAE,IAAI;SACvD,CAAA;KACJ;IAED,eAAe,CAAC,EAAE,GAAG,KAAK,CAAA;IAG1B,IAAG,CAAC,eAAe,CAAC,aAAa;QAAE,eAAe,CAAC,aAAa,GAAG;YAC/D,IAAI,EAAE,YAAY;YAClB,qBAAqB,EAAE,UAAU;YACjC,eAAe,EAAE,IAAI;YACrB,gBAAgB,EAAE,oCAAoC;SACzD,CAAA;IAED,IAAG,CAAC,eAAe,CAAC,IAAI;QAAE,eAAe,CAAC,IAAI,GAAG;YAC7C,KAAK,EAAE,QAAQ,CAAC,KAAK;SACxB,CAAA;IAGD,eAAe,CAAC,WAAW,GAAG,EAAE,CAAA;IAEhC,OAAO,eAAe,CAAA;AAC1B,CAAC"}
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
import { ViewMode } from "bitmovin-player";
|
|
2
|
+
export function resolveKeyPress(player, npoplayer, e) {
|
|
3
|
+
switch (e.code) {
|
|
4
|
+
case 'KeyM': {
|
|
5
|
+
const isMuted = player.isMuted() ?? false;
|
|
6
|
+
isMuted ? player.unmute() : player.mute();
|
|
7
|
+
break;
|
|
8
|
+
}
|
|
9
|
+
case 'KeyF': {
|
|
10
|
+
if (player.getViewMode() !== ViewMode.Fullscreen) {
|
|
11
|
+
player.setViewMode(ViewMode.Fullscreen);
|
|
12
|
+
}
|
|
13
|
+
else {
|
|
14
|
+
player.setViewMode(ViewMode.Inline);
|
|
15
|
+
}
|
|
16
|
+
break;
|
|
17
|
+
}
|
|
18
|
+
case 'Space': {
|
|
19
|
+
const isPaused = player.isPaused() ?? false;
|
|
20
|
+
isPaused ? player.play() : player.pause();
|
|
21
|
+
break;
|
|
22
|
+
}
|
|
23
|
+
case 'ArrowUp': {
|
|
24
|
+
const isMuted = player.isMuted() ?? false;
|
|
25
|
+
if (isMuted)
|
|
26
|
+
player.unmute();
|
|
27
|
+
npoplayer.increaseVolume();
|
|
28
|
+
break;
|
|
29
|
+
}
|
|
30
|
+
case 'ArrowDown': {
|
|
31
|
+
const isMuted = player.isMuted() ?? false;
|
|
32
|
+
if (isMuted)
|
|
33
|
+
player.unmute();
|
|
34
|
+
npoplayer.decreaseVolume();
|
|
35
|
+
break;
|
|
36
|
+
}
|
|
37
|
+
case 'ArrowLeft': {
|
|
38
|
+
npoplayer.goBackwards(10);
|
|
39
|
+
break;
|
|
40
|
+
}
|
|
41
|
+
case 'ArrowRight': {
|
|
42
|
+
npoplayer.goForward(10);
|
|
43
|
+
break;
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
//# sourceMappingURL=resolvekeypress.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"resolvekeypress.js","sourceRoot":"","sources":["../../../../../src/js/playeractions/handlers/resolvekeypress.ts"],"names":[],"mappings":"AAAA,OAAO,EAAkB,QAAQ,EAAE,MAAM,iBAAiB,CAAC;AAY3D,MAAM,UAAU,eAAe,CAAC,MAAiB,EAAE,SAAoB,EAAE,CAAgB;IACrF,QAAO,CAAC,CAAC,IAAI,EAAE;QACX,KAAK,MAAM,CAAC,CAAC;YACT,MAAM,OAAO,GAAG,MAAM,CAAC,OAAO,EAAE,IAAI,KAAK,CAAC;YAC1C,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,IAAI,EAAE,CAAC;YAC1C,MAAM;SACT;QACD,KAAK,MAAM,CAAC,CAAC;YACT,IAAI,MAAM,CAAC,WAAW,EAAE,KAAK,QAAQ,CAAC,UAAU,EAAE;gBAC9C,MAAM,CAAC,WAAW,CAAC,QAAQ,CAAC,UAAU,CAAC,CAAC;aAC3C;iBAAM;gBACH,MAAM,CAAC,WAAW,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC;aACvC;YACD,MAAM;SACT;QACD,KAAK,OAAO,CAAC,CAAC;YACV,MAAM,QAAQ,GAAG,MAAM,CAAC,QAAQ,EAAE,IAAI,KAAK,CAAC;YAC5C,QAAQ,CAAC,CAAC,CAAC,MAAM,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC;YAC1C,MAAM;SACT;QACD,KAAK,SAAS,CAAC,CAAC;YACZ,MAAM,OAAO,GAAG,MAAM,CAAC,OAAO,EAAE,IAAI,KAAK,CAAC;YAC1C,IAAI,OAAO;gBAAE,MAAM,CAAC,MAAM,EAAE,CAAC;YAC7B,SAAS,CAAC,cAAc,EAAE,CAAC;YAC3B,MAAM;SACT;QACD,KAAK,WAAW,CAAC,CAAC;YACd,MAAM,OAAO,GAAG,MAAM,CAAC,OAAO,EAAE,IAAI,KAAK,CAAC;YAC1C,IAAI,OAAO;gBAAE,MAAM,CAAC,MAAM,EAAE,CAAC;YAC7B,SAAS,CAAC,cAAc,EAAE,CAAC;YAC3B,MAAM;SACT;QACD,KAAK,WAAW,CAAC,CAAC;YACd,SAAS,CAAC,WAAW,CAAC,EAAE,CAAC,CAAC;YAC1B,MAAM;SACT;QACD,KAAK,YAAY,CAAC,CAAC;YACf,SAAS,CAAC,SAAS,CAAC,EAAE,CAAC,CAAC;YACxB,MAAM;SACT;KACJ;AACL,CAAC"}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
export { resolveKeyPress } from "./handlers/resolvekeypress";
|
|
2
|
+
export { handleStartOffset, handleLiveOffsetLogic, shiftToProgramStart } from "./handlers/handleoffsets";
|
|
3
|
+
export { handlePlayerError } from "./handlers/error";
|
|
4
|
+
export { processPlayerConfig } from "./handlers/processplayerconfig";
|
|
5
|
+
//# sourceMappingURL=playeractions.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"playeractions.js","sourceRoot":"","sources":["../../../../src/js/playeractions/playeractions.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,4BAA4B,CAAC;AAC7D,OAAO,EAAE,iBAAiB,EAAE,qBAAqB,EAAE,mBAAmB,EAAE,MAAM,0BAA0B,CAAC;AACzG,OAAO,EAAE,iBAAiB,EAAE,MAAM,kBAAkB,CAAC;AACrD,OAAO,EAAE,mBAAmB,EAAE,MAAM,gCAAgC,CAAC"}
|
|
@@ -0,0 +1,72 @@
|
|
|
1
|
+
import { PlayerEvent, ViewMode } from 'bitmovin-player';
|
|
2
|
+
import { logEvent } from './eventlogging';
|
|
3
|
+
export function bindPlayerEvents(npoplayer, player) {
|
|
4
|
+
if (player == null)
|
|
5
|
+
return;
|
|
6
|
+
let isNewSource = false;
|
|
7
|
+
const playerEvents = [
|
|
8
|
+
{ event: PlayerEvent.Paused, name: 'pause' },
|
|
9
|
+
{ event: PlayerEvent.SourceLoaded, name: 'load_complete' },
|
|
10
|
+
{ event: PlayerEvent.Ready, name: 'load_complete' },
|
|
11
|
+
{ event: PlayerEvent.StallStarted, name: 'buffering' },
|
|
12
|
+
{ event: PlayerEvent.StallEnded, name: 'buffering_complete' },
|
|
13
|
+
{ event: PlayerEvent.PlaybackFinished, name: 'complete' },
|
|
14
|
+
{ event: PlayerEvent.TimeChanged, name: 'time' },
|
|
15
|
+
{
|
|
16
|
+
event: PlayerEvent.ViewModeChanged,
|
|
17
|
+
name: player?.getViewMode() === ViewMode.Fullscreen
|
|
18
|
+
? 'fullscreen'
|
|
19
|
+
: 'windowed'
|
|
20
|
+
},
|
|
21
|
+
{ event: PlayerEvent.SourceUnloaded, name: 'stop' },
|
|
22
|
+
{ event: PlayerEvent.Destroy, name: 'stop' },
|
|
23
|
+
];
|
|
24
|
+
const logEventHandler = (npoplayer, eventName) => {
|
|
25
|
+
return () => {
|
|
26
|
+
logEvent(npoplayer, eventName);
|
|
27
|
+
};
|
|
28
|
+
};
|
|
29
|
+
const seekHandler = (e) => {
|
|
30
|
+
const data = {
|
|
31
|
+
seek_from: e.position,
|
|
32
|
+
stream_position: e.seekTarget
|
|
33
|
+
};
|
|
34
|
+
logEvent(npoplayer, 'seek', data);
|
|
35
|
+
};
|
|
36
|
+
const handleSourceLoaded = () => {
|
|
37
|
+
isNewSource = true;
|
|
38
|
+
};
|
|
39
|
+
const handlePlay = () => {
|
|
40
|
+
if (!isNewSource) {
|
|
41
|
+
logEvent(npoplayer, 'resume');
|
|
42
|
+
}
|
|
43
|
+
};
|
|
44
|
+
const handlePlaying = () => {
|
|
45
|
+
if (isNewSource) {
|
|
46
|
+
logEvent(npoplayer, 'start');
|
|
47
|
+
isNewSource = false;
|
|
48
|
+
}
|
|
49
|
+
};
|
|
50
|
+
function stopBeforeUnload() {
|
|
51
|
+
logEvent(npoplayer, 'stop');
|
|
52
|
+
}
|
|
53
|
+
player.off(PlayerEvent.SourceLoaded, handleSourceLoaded);
|
|
54
|
+
player.off(PlayerEvent.Seek, seekHandler);
|
|
55
|
+
player.off(PlayerEvent.Play, handlePlay);
|
|
56
|
+
player.off(PlayerEvent.Playing, handlePlaying);
|
|
57
|
+
playerEvents.forEach(({ event, name }) => {
|
|
58
|
+
const handler = logEventHandler(npoplayer, name);
|
|
59
|
+
player.off(event, handler);
|
|
60
|
+
});
|
|
61
|
+
window.removeEventListener('beforeunload', stopBeforeUnload);
|
|
62
|
+
player.on(PlayerEvent.SourceLoaded, handleSourceLoaded);
|
|
63
|
+
player.on(PlayerEvent.Seek, seekHandler);
|
|
64
|
+
player.on(PlayerEvent.Play, handlePlay);
|
|
65
|
+
player.on(PlayerEvent.Playing, handlePlaying);
|
|
66
|
+
playerEvents.forEach(({ event, name }) => {
|
|
67
|
+
const handler = logEventHandler(npoplayer, name);
|
|
68
|
+
player.on(event, handler);
|
|
69
|
+
});
|
|
70
|
+
window.addEventListener('beforeunload', stopBeforeUnload);
|
|
71
|
+
}
|
|
72
|
+
//# sourceMappingURL=eventbinding.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"eventbinding.js","sourceRoot":"","sources":["../../../../../src/js/tracking/handlers/eventbinding.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
export function logEvent(npoplayer, event, data) {
|
|
2
|
+
if (!npoplayer.player || !npoplayer.streamTracker)
|
|
3
|
+
return;
|
|
4
|
+
try {
|
|
5
|
+
npoplayer.player.getCurrentTime();
|
|
6
|
+
}
|
|
7
|
+
catch (e) {
|
|
8
|
+
console.log('Er gaat iets mis met de player API', e);
|
|
9
|
+
}
|
|
10
|
+
const streamOptions = { stream_position: npoplayer.player.getCurrentTime() };
|
|
11
|
+
const eventHandlers = {
|
|
12
|
+
start: npoplayer.streamTracker.start,
|
|
13
|
+
buffering: npoplayer.streamTracker.buffering,
|
|
14
|
+
buffering_complete: npoplayer.streamTracker.buffering_complete,
|
|
15
|
+
complete: npoplayer.streamTracker.complete,
|
|
16
|
+
fullscreen: npoplayer.streamTracker.fullscreen,
|
|
17
|
+
load: npoplayer.streamTracker.load,
|
|
18
|
+
load_complete: npoplayer.streamTracker.load_complete,
|
|
19
|
+
pause: npoplayer.streamTracker.pause,
|
|
20
|
+
resume: npoplayer.streamTracker.resume,
|
|
21
|
+
stop: npoplayer.streamTracker.stop,
|
|
22
|
+
windowed: npoplayer.streamTracker.windowed,
|
|
23
|
+
time: npoplayer.streamTracker.time,
|
|
24
|
+
seek: () => {
|
|
25
|
+
npoplayer.streamTracker?.seek(data);
|
|
26
|
+
}
|
|
27
|
+
};
|
|
28
|
+
const streamTrackerHandler = eventHandlers[event];
|
|
29
|
+
npoplayer.logEmitter.emit('logEvent', event);
|
|
30
|
+
streamTrackerHandler(streamOptions);
|
|
31
|
+
}
|
|
32
|
+
//# sourceMappingURL=eventlogging.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"eventlogging.js","sourceRoot":"","sources":["../../../../../src/js/tracking/handlers/eventlogging.ts"],"names":[],"mappings":"AAYA,MAAM,UAAU,QAAQ,CAAE,SAAoB,EAAE,KAAa,EAAE,IAAU;IACrE,IAAI,CAAC,SAAS,CAAC,MAAM,IAAI,CAAC,SAAS,CAAC,aAAa;QAAE,OAAO;IAE1D,IAAI;QACA,SAAS,CAAC,MAAM,CAAC,cAAc,EAAE,CAAA;KACpC;IAAC,OAAO,CAAC,EAAE;QACR,OAAO,CAAC,GAAG,CAAC,oCAAoC,EAAE,CAAC,CAAC,CAAA;KACvD;IACD,MAAM,aAAa,GAAG,EAAE,eAAe,EAAE,SAAS,CAAC,MAAM,CAAC,cAAc,EAAE,EAAE,CAAA;IAE5E,MAAM,aAAa,GAAiD;QAChE,KAAK,EAAE,SAAS,CAAC,aAAa,CAAC,KAAK;QACpC,SAAS,EAAE,SAAS,CAAC,aAAa,CAAC,SAAS;QAC5C,kBAAkB,EAAE,SAAS,CAAC,aAAa,CAAC,kBAAkB;QAC9D,QAAQ,EAAE,SAAS,CAAC,aAAa,CAAC,QAAQ;QAC1C,UAAU,EAAE,SAAS,CAAC,aAAa,CAAC,UAAU;QAC9C,IAAI,EAAE,SAAS,CAAC,aAAa,CAAC,IAAI;QAClC,aAAa,EAAE,SAAS,CAAC,aAAa,CAAC,aAAa;QACpD,KAAK,EAAE,SAAS,CAAC,aAAa,CAAC,KAAK;QACpC,MAAM,EAAE,SAAS,CAAC,aAAa,CAAC,MAAM;QACtC,IAAI,EAAE,SAAS,CAAC,aAAa,CAAC,IAAI;QAClC,QAAQ,EAAE,SAAS,CAAC,aAAa,CAAC,QAAQ;QAC1C,IAAI,EAAE,SAAS,CAAC,aAAa,CAAC,IAAI;QAElC,IAAI,EAAE,GAAG,EAAE;YACP,SAAS,CAAC,aAAa,EAAE,IAAI,CAAC,IAAI,CAAC,CAAA;QACvC,CAAC;KACJ,CAAA;IAED,MAAM,oBAAoB,GAAG,aAAa,CAAC,KAAK,CAAC,CAAA;IACjD,SAAS,CAAC,UAAU,CAAC,IAAI,CAAC,UAAU,EAAE,KAAK,CAAC,CAAA;IAC5C,oBAAoB,CAAC,aAAa,CAAC,CAAA;AACvC,CAAC"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { newATInternetPlugin, newGovoltePlugin, newPageTracker, newTag } from '@npotag/tag';
|
|
2
|
+
const npoTagPlugins = [
|
|
3
|
+
newGovoltePlugin({ maxRetryCount: 5, delayBetweenRetriesInMs: 3000 }),
|
|
4
|
+
newATInternetPlugin()
|
|
5
|
+
];
|
|
6
|
+
export function initPlayerTracker(npoplayer, _npotag, _npotaginstance) {
|
|
7
|
+
npoplayer.npoTag = {
|
|
8
|
+
npoTagInstance: undefined,
|
|
9
|
+
pageTracker: null,
|
|
10
|
+
heartbeatInterval: undefined
|
|
11
|
+
};
|
|
12
|
+
npoplayer.npoTag.npoTagInstance =
|
|
13
|
+
_npotag != null
|
|
14
|
+
? newTag(_npotag, npoTagPlugins)
|
|
15
|
+
: _npotaginstance;
|
|
16
|
+
if (npoplayer.npoTag.npoTagInstance != null) {
|
|
17
|
+
npoplayer.npoTag.pageTracker = newPageTracker(npoplayer.npoTag.npoTagInstance);
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
//# sourceMappingURL=playertrackerinit.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"playertrackerinit.js","sourceRoot":"","sources":["../../../../../src/js/tracking/handlers/playertrackerinit.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,mBAAmB,EAAE,gBAAgB,EAAE,cAAc,EAAe,MAAM,EAAE,MAAM,aAAa,CAAA;AAIxG,MAAM,aAAa,GAAG;IAClB,gBAAgB,CAAC,EAAE,aAAa,EAAE,CAAC,EAAE,uBAAuB,EAAE,IAAI,EAAE,CAAC;IACrE,mBAAmB,EAAE;CACxB,CAAA;AAWD,MAAM,UAAU,iBAAiB,CAAE,SAAoB,EAAE,OAAoC,EAAE,eAAwB;IACnH,SAAS,CAAC,MAAM,GAAG;QACf,cAAc,EAAE,SAAS;QACzB,WAAW,EAAE,IAAI;QACjB,iBAAiB,EAAE,SAAS;KAC/B,CAAA;IACD,SAAS,CAAC,MAAM,CAAC,cAAc;QACvB,OAAO,IAAI,IAAI;YACX,CAAC,CAAC,MAAM,CAAC,OAAO,EAAE,aAAa,CAAC;YAChC,CAAC,CAAC,eAAe,CAAA;IAC7B,IAAI,SAAS,CAAC,MAAM,CAAC,cAAc,IAAI,IAAI,EAAE;QACzC,SAAS,CAAC,MAAM,CAAC,WAAW,GAAG,cAAc,CACzC,SAAS,CAAC,MAAM,CAAC,cAAc,CAClC,CAAA;KACJ;AACL,CAAC"}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import { newStreamTracker } from '@npotag/tag';
|
|
2
|
+
import { bindPlayerEvents } from './eventbinding';
|
|
3
|
+
import { validatePrid } from '../../utilities/utilities';
|
|
4
|
+
export function startPlayerTracker(playerInstance, duration, version) {
|
|
5
|
+
if (playerInstance.npoTag?.pageTracker == null) {
|
|
6
|
+
console.error('No pageTracker available');
|
|
7
|
+
}
|
|
8
|
+
else if (playerInstance.streamTracker == null) {
|
|
9
|
+
const streamTrackerConfig = {
|
|
10
|
+
stream_length: duration,
|
|
11
|
+
stream_id: validatePrid(playerInstance.streamObject.metadata.prid),
|
|
12
|
+
player_id: 'npoplayer-web',
|
|
13
|
+
av_type: 'video',
|
|
14
|
+
player_version: version,
|
|
15
|
+
sko_player_version: '1.0.0'
|
|
16
|
+
};
|
|
17
|
+
const isLiveConfig = playerInstance.streamObject.stream.isLiveStream ? { isLive: true } : {};
|
|
18
|
+
playerInstance.streamTracker = newStreamTracker(playerInstance.npoTag.pageTracker, streamTrackerConfig, isLiveConfig);
|
|
19
|
+
bindPlayerEvents(playerInstance, playerInstance.player);
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
//# sourceMappingURL=playertrackerstart.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"playertrackerstart.js","sourceRoot":"","sources":["../../../../../src/js/tracking/handlers/playertrackerstart.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,gBAAgB,EAAE,MAAM,aAAa,CAAA;AAC9C,OAAO,EAAE,gBAAgB,EAAE,MAAM,gBAAgB,CAAA;AACjD,OAAO,EAAE,YAAY,EAAE,MAAM,2BAA2B,CAAA;AAWxD,MAAM,UAAU,kBAAkB,CAAE,cAAmB,EAAE,QAAgB,EAAE,OAAe;IACtF,IAAI,cAAc,CAAC,MAAM,EAAE,WAAW,IAAI,IAAI,EAAE;QAC5C,OAAO,CAAC,KAAK,CAAC,0BAA0B,CAAC,CAAA;KAC5C;SAAM,IAAI,cAAc,CAAC,aAAa,IAAI,IAAI,EAAE;QAE7C,MAAM,mBAAmB,GAAG;YACxB,aAAa,EAAE,QAAQ;YACvB,SAAS,EAAE,YAAY,CAAC,cAAc,CAAC,YAAY,CAAC,QAAQ,CAAC,IAAI,CAAC;YAClE,SAAS,EAAE,eAAe;YAC1B,OAAO,EAAE,OAAiB;YAC1B,cAAc,EAAE,OAAO;YACvB,kBAAkB,EAAE,OAAO;SAC9B,CAAC;QACF,MAAM,YAAY,GAAG,cAAc,CAAC,YAAY,CAAC,MAAM,CAAC,YAAY,CAAC,CAAC,CAAC,EAAE,MAAM,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;QAE7F,cAAc,CAAC,aAAa,GAAG,gBAAgB,CAC3C,cAAc,CAAC,MAAM,CAAC,WAAW,EACjC,mBAAmB,EACnB,YAAY,CACf,CAAC;QAEF,gBAAgB,CAAC,cAAc,EAAE,cAAc,CAAC,MAAM,CAAC,CAAA;KAC1D;AACL,CAAC"}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
export { initPlayerTracker } from './handlers/playertrackerinit';
|
|
2
|
+
export { startPlayerTracker } from './handlers/playertrackerstart';
|
|
3
|
+
export { bindPlayerEvents } from './handlers/eventbinding';
|
|
4
|
+
export { logEvent } from './handlers/eventlogging';
|
|
5
|
+
//# sourceMappingURL=playertracker.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"playertracker.js","sourceRoot":"","sources":["../../../../src/js/tracking/playertracker.ts"],"names":[],"mappings":"AAMA,OAAO,EAAE,iBAAiB,EAAE,MAAM,8BAA8B,CAAA;AAChE,OAAO,EAAE,kBAAkB,EAAE,MAAM,+BAA+B,CAAA;AAClE,OAAO,EAAE,gBAAgB,EAAE,MAAM,yBAAyB,CAAA;AAC1D,OAAO,EAAE,QAAQ,EAAE,MAAM,yBAAyB,CAAA"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { Button } from 'bitmovin-player-ui';
|
|
2
|
+
export function createAdButton(npoplayer) {
|
|
3
|
+
npoplayer.uiComponents.adbutton = undefined;
|
|
4
|
+
const adButton = new Button({
|
|
5
|
+
cssClass: 'ui-textbutton ui-sterbutton bmpui-ui-button',
|
|
6
|
+
text: 'Meer info',
|
|
7
|
+
hidden: true
|
|
8
|
+
});
|
|
9
|
+
npoplayer.uiComponents.adbutton = adButton;
|
|
10
|
+
return adButton;
|
|
11
|
+
}
|
|
12
|
+
//# sourceMappingURL=adbutton.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"adbutton.js","sourceRoot":"","sources":["../../../../../src/js/ui/components/adbutton.ts"],"names":[],"mappings":"AAKA,OAAO,EAAE,MAAM,EAAC,MAAM,oBAAoB,CAAA;AAQ1C,MAAM,UAAU,cAAc,CAAE,SAAoB;IAChD,SAAS,CAAC,YAAY,CAAC,QAAQ,GAAG,SAAS,CAAA;IAC3C,MAAM,QAAQ,GAAG,IAAI,MAAM,CAAC;QACxB,QAAQ,EAAE,6CAA6C;QACvD,IAAI,EAAE,WAAW;QACjB,MAAM,EAAE,IAAI;KACf,CAAC,CAAA;IAEF,SAAS,CAAC,YAAY,CAAC,QAAQ,GAAG,QAAQ,CAAA;IAC1C,OAAO,QAAQ,CAAA;AACnB,CAAC"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { Label } from 'bitmovin-player-ui';
|
|
2
|
+
export function createAdLabel(npoplayer) {
|
|
3
|
+
npoplayer.uiComponents.adlabel = undefined;
|
|
4
|
+
const adLabel = new Label({ text: '', cssClass: 'adLabel', hidden: true });
|
|
5
|
+
npoplayer.uiComponents.adlabel = adLabel;
|
|
6
|
+
return adLabel;
|
|
7
|
+
}
|
|
8
|
+
//# sourceMappingURL=adlabel.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"adlabel.js","sourceRoot":"","sources":["../../../../../src/js/ui/components/adlabel.ts"],"names":[],"mappings":"AAKA,OAAO,EAAE,KAAK,EAAC,MAAM,oBAAoB,CAAA;AAQzC,MAAM,UAAU,aAAa,CAAE,SAAoB;IAC/C,SAAS,CAAC,YAAY,CAAC,OAAO,GAAG,SAAS,CAAA;IAC1C,MAAM,OAAO,GAAG,IAAI,KAAK,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,QAAQ,EAAE,SAAS,EAAE,MAAM,EAAE,IAAI,EAAE,CAAC,CAAA;IAC1E,SAAS,CAAC,YAAY,CAAC,OAAO,GAAG,OAAO,CAAA;IACxC,OAAO,OAAO,CAAA;AAClB,CAAC"}
|
|
@@ -0,0 +1,86 @@
|
|
|
1
|
+
import { Button, PlaybackToggleButton, ControlBar } from 'bitmovin-player-ui';
|
|
2
|
+
import { rewind, forward } from '../handlers/timecontrolhandlers';
|
|
3
|
+
export function createMiddleButtons(player) {
|
|
4
|
+
const bigPlayToggleButton = new PlaybackToggleButton({
|
|
5
|
+
cssClass: 'ui-playbacktogglebutton'
|
|
6
|
+
});
|
|
7
|
+
const bigRewindButton = createRewindButton(player);
|
|
8
|
+
const bigForwardButton = createForwardButton(player);
|
|
9
|
+
return new ControlBar({
|
|
10
|
+
components: [bigRewindButton, bigPlayToggleButton, bigForwardButton],
|
|
11
|
+
cssClasses: ['controlbar-middle']
|
|
12
|
+
});
|
|
13
|
+
}
|
|
14
|
+
export function createRewindButton(player) {
|
|
15
|
+
const rewindButton = new Button({
|
|
16
|
+
cssClass: 'ui-rewindbutton bmpui-ui-button'
|
|
17
|
+
});
|
|
18
|
+
rewindButton.onClick.subscribe(() => {
|
|
19
|
+
rewind(player);
|
|
20
|
+
});
|
|
21
|
+
return rewindButton;
|
|
22
|
+
}
|
|
23
|
+
export function createForwardButton(player) {
|
|
24
|
+
const forwardButton = new Button({
|
|
25
|
+
cssClass: 'ui-forwardbutton bmpui-ui-button'
|
|
26
|
+
});
|
|
27
|
+
forwardButton.onClick.subscribe(() => {
|
|
28
|
+
forward(player);
|
|
29
|
+
});
|
|
30
|
+
return forwardButton;
|
|
31
|
+
}
|
|
32
|
+
export function createPlayNextButton(player, npoplayer) {
|
|
33
|
+
const playNextButton = new Button({
|
|
34
|
+
cssClass: 'ui-hugeplaynextbacktogglebutton ui-playNextButton bmpui-ui-button',
|
|
35
|
+
text: 'De volgende aflevering wordt zo afgespeeld...',
|
|
36
|
+
hidden: false
|
|
37
|
+
});
|
|
38
|
+
playNextButton.onClick.subscribe(() => {
|
|
39
|
+
if (player != null) {
|
|
40
|
+
npoplayer.doPlayNext();
|
|
41
|
+
}
|
|
42
|
+
});
|
|
43
|
+
return playNextButton;
|
|
44
|
+
}
|
|
45
|
+
export function createskipIntroButton(player) {
|
|
46
|
+
const skipIntroButton = new Button({
|
|
47
|
+
cssClass: 'ui-textbutton ui-skipintrobutton bmpui-ui-button bmpui-hidden',
|
|
48
|
+
text: 'Intro overslaan',
|
|
49
|
+
hidden: true
|
|
50
|
+
});
|
|
51
|
+
skipIntroButton.onClick.subscribe(() => {
|
|
52
|
+
if (player != null) {
|
|
53
|
+
player.seek(96);
|
|
54
|
+
}
|
|
55
|
+
});
|
|
56
|
+
return skipIntroButton;
|
|
57
|
+
}
|
|
58
|
+
export function createGoBackLiveButton(player) {
|
|
59
|
+
const goBackLiveButton = new Button({
|
|
60
|
+
cssClass: 'ui-textbutton ui-backtolivebutton bmpui-ui-button',
|
|
61
|
+
text: 'Terug naar live',
|
|
62
|
+
hidden: true
|
|
63
|
+
});
|
|
64
|
+
goBackLiveButton.onClick.subscribe(() => {
|
|
65
|
+
if (player != null && player.isLive()) {
|
|
66
|
+
player.timeShift(0);
|
|
67
|
+
}
|
|
68
|
+
});
|
|
69
|
+
return goBackLiveButton;
|
|
70
|
+
}
|
|
71
|
+
export function createWatchFromStartButton(player, npoplayer) {
|
|
72
|
+
const watchFromStartButton = new Button({
|
|
73
|
+
cssClass: 'ui-textbutton ui-watchfromstartbutton bmpui-ui-button',
|
|
74
|
+
text: 'Kijk vanaf het begin',
|
|
75
|
+
hidden: true
|
|
76
|
+
});
|
|
77
|
+
watchFromStartButton.onClick.subscribe(() => {
|
|
78
|
+
if ((player?.isLive()) ?? false)
|
|
79
|
+
npoplayer.watchFromStart();
|
|
80
|
+
if (npoplayer.uiComponents.watchFromStartButton)
|
|
81
|
+
npoplayer.uiComponents.watchFromStartButton.hide();
|
|
82
|
+
});
|
|
83
|
+
npoplayer.uiComponents.watchFromStartButton = watchFromStartButton;
|
|
84
|
+
return watchFromStartButton;
|
|
85
|
+
}
|
|
86
|
+
//# sourceMappingURL=buttons.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"buttons.js","sourceRoot":"","sources":["../../../../../src/js/ui/components/buttons.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,58 @@
|
|
|
1
|
+
import { ControlBar, Container, PlaybackTimeLabel, PlaybackTimeLabelMode, SeekBar, SeekBarLabel, PlaybackToggleButton, VolumeToggleButton, VolumeSlider, Spacer, PictureInPictureToggleButton, AirPlayToggleButton, CastToggleButton, SettingsToggleButton, FullscreenToggleButton } from 'bitmovin-player-ui';
|
|
2
|
+
import { airPlaySupported } from '../../../js/utilities/utilities';
|
|
3
|
+
import { PlayerEvent } from 'bitmovin-player';
|
|
4
|
+
import { createForwardButton, createRewindButton } from './buttons';
|
|
5
|
+
export function createControlBar(npoplayer, settingsPanel) {
|
|
6
|
+
const player = npoplayer.player;
|
|
7
|
+
const rewindButton = createRewindButton(player);
|
|
8
|
+
const forwardButton = createForwardButton(player);
|
|
9
|
+
const seekBar = new SeekBar({ label: new SeekBarLabel() });
|
|
10
|
+
npoplayer.uiComponents.seekBar = seekBar;
|
|
11
|
+
const chromeCastButton = new CastToggleButton({
|
|
12
|
+
hidden: true
|
|
13
|
+
});
|
|
14
|
+
npoplayer.player?.on(PlayerEvent.CastAvailable, () => {
|
|
15
|
+
if (npoplayer.player?.isCastAvailable())
|
|
16
|
+
chromeCastButton.show();
|
|
17
|
+
});
|
|
18
|
+
const controlbar = new ControlBar({
|
|
19
|
+
components: [
|
|
20
|
+
settingsPanel,
|
|
21
|
+
new Container({
|
|
22
|
+
components: [
|
|
23
|
+
new PlaybackTimeLabel({
|
|
24
|
+
timeLabelMode: PlaybackTimeLabelMode.CurrentTime,
|
|
25
|
+
hideInLivePlayback: true,
|
|
26
|
+
cssClasses: ['current-time']
|
|
27
|
+
}),
|
|
28
|
+
seekBar,
|
|
29
|
+
new PlaybackTimeLabel({
|
|
30
|
+
timeLabelMode: PlaybackTimeLabelMode.TotalTime,
|
|
31
|
+
cssClasses: ['total-time']
|
|
32
|
+
})
|
|
33
|
+
],
|
|
34
|
+
cssClasses: ['controlbar-top']
|
|
35
|
+
}),
|
|
36
|
+
new Container({
|
|
37
|
+
components: [
|
|
38
|
+
new PlaybackToggleButton(),
|
|
39
|
+
new VolumeToggleButton(),
|
|
40
|
+
new VolumeSlider(),
|
|
41
|
+
rewindButton,
|
|
42
|
+
forwardButton,
|
|
43
|
+
new Spacer(),
|
|
44
|
+
...(document.pictureInPictureEnabled && /^((?!chrome|android).)*safari/i.test(navigator.userAgent) ? [new PictureInPictureToggleButton()] : []),
|
|
45
|
+
...(airPlaySupported() ? [new AirPlayToggleButton()] : []),
|
|
46
|
+
chromeCastButton,
|
|
47
|
+
new SettingsToggleButton({ settingsPanel }),
|
|
48
|
+
new FullscreenToggleButton()
|
|
49
|
+
],
|
|
50
|
+
cssClasses: ['controlbar-bottom']
|
|
51
|
+
})
|
|
52
|
+
],
|
|
53
|
+
cssClasses: ['ui-controlbar-bottom']
|
|
54
|
+
});
|
|
55
|
+
npoplayer.uiComponents.controlbar = controlbar;
|
|
56
|
+
return controlbar;
|
|
57
|
+
}
|
|
58
|
+
//# sourceMappingURL=controlbar.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"controlbar.js","sourceRoot":"","sources":["../../../../../src/js/ui/components/controlbar.ts"],"names":[],"mappings":"AAAA,OAAO,EACH,UAAU,EACV,SAAS,EACT,iBAAiB,EACjB,qBAAqB,EACrB,OAAO,EACP,YAAY,EACZ,oBAAoB,EACpB,kBAAkB,EAClB,YAAY,EACZ,MAAM,EACN,4BAA4B,EAC5B,mBAAmB,EACnB,gBAAgB,EAChB,oBAAoB,EACpB,sBAAsB,EAEzB,MAAM,oBAAoB,CAAA;AAC3B,OAAO,EAAE,gBAAgB,EAAE,MAAM,iCAAiC,CAAA;AAElE,OAAO,EAAE,WAAW,EAAE,MAAM,iBAAiB,CAAA;AAC7C,OAAO,EAAE,mBAAmB,EAAE,kBAAkB,EAAE,MAAM,WAAW,CAAA;AAEnE,MAAM,UAAU,gBAAgB,CAC5B,SAAoB,EACpB,aAA4B;IAE5B,MAAM,MAAM,GAAG,SAAS,CAAC,MAAM,CAAA;IAE/B,MAAM,YAAY,GAAG,kBAAkB,CAAC,MAAM,CAAC,CAAA;IAC/C,MAAM,aAAa,GAAG,mBAAmB,CAAC,MAAM,CAAC,CAAA;IAEjD,MAAM,OAAO,GAAG,IAAI,OAAO,CAAC,EAAE,KAAK,EAAE,IAAI,YAAY,EAAE,EAAE,CAAC,CAAA;IAC1D,SAAS,CAAC,YAAY,CAAC,OAAO,GAAG,OAAO,CAAA;IAExC,MAAM,gBAAgB,GAAG,IAAI,gBAAgB,CAAC;QAC1C,MAAM,EAAE,IAAI;KACf,CAAC,CAAA;IAEF,SAAS,CAAC,MAAM,EAAE,EAAE,CAAC,WAAW,CAAC,aAAa,EAAE,GAAG,EAAE;QACjD,IAAG,SAAS,CAAC,MAAM,EAAE,eAAe,EAAE;YAAE,gBAAgB,CAAC,IAAI,EAAE,CAAA;IACnE,CAAC,CAAC,CAAA;IAEF,MAAM,UAAU,GAAG,IAAI,UAAU,CAAC;QAC9B,UAAU,EAAE;YACR,aAAa;YACb,IAAI,SAAS,CAAC;gBACV,UAAU,EAAE;oBACR,IAAI,iBAAiB,CAAC;wBAClB,aAAa,EAAE,qBAAqB,CAAC,WAAW;wBAChD,kBAAkB,EAAE,IAAI;wBACxB,UAAU,EAAE,CAAC,cAAc,CAAC;qBAC/B,CAAC;oBACF,OAAO;oBACP,IAAI,iBAAiB,CAAC;wBAClB,aAAa,EAAE,qBAAqB,CAAC,SAAS;wBAC9C,UAAU,EAAE,CAAC,YAAY,CAAC;qBAC7B,CAAC;iBACL;gBACD,UAAU,EAAE,CAAC,gBAAgB,CAAC;aACjC,CAAC;YACF,IAAI,SAAS,CAAC;gBACV,UAAU,EAAE;oBACR,IAAI,oBAAoB,EAAE;oBAC1B,IAAI,kBAAkB,EAAE;oBACxB,IAAI,YAAY,EAAE;oBAClB,YAAY;oBACZ,aAAa;oBACb,IAAI,MAAM,EAAE;oBACZ,GAAG,CAAC,QAAQ,CAAC,uBAAuB,IAAI,gCAAgC,CAAC,IAAI,CAAC,SAAS,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,4BAA4B,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;oBAC/I,GAAG,CAAC,gBAAgB,EAAE,CAAC,CAAC,CAAC,CAAC,IAAI,mBAAmB,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;oBAC1D,gBAAgB;oBAChB,IAAI,oBAAoB,CAAC,EAAE,aAAa,EAAE,CAAC;oBAC3C,IAAI,sBAAsB,EAAE;iBAC/B;gBACD,UAAU,EAAE,CAAC,mBAAmB,CAAC;aACpC,CAAC;SACL;QACD,UAAU,EAAE,CAAC,sBAAsB,CAAC;KACvC,CAAC,CAAA;IAGF,SAAS,CAAC,YAAY,CAAC,UAAU,GAAG,UAAU,CAAA;IAE9C,OAAO,UAAU,CAAA;AACrB,CAAC"}
|
|
@@ -4,6 +4,6 @@ import { type PlayerAPI } from 'bitmovin-player';
|
|
|
4
4
|
import { ButtonConfig } from 'bitmovin-player-ui/dist/js/framework/components/button';
|
|
5
5
|
import { LabelConfig } from 'bitmovin-player-ui/dist/js/framework/components/label';
|
|
6
6
|
export declare function createCTABar(player: PlayerAPI | null, npoplayer: NpoPlayer, variant: string): Container<{
|
|
7
|
-
components: (
|
|
7
|
+
components: (Button<ButtonConfig> | Label<LabelConfig>)[];
|
|
8
8
|
cssClasses: string[];
|
|
9
9
|
}>;
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import { Container } from 'bitmovin-player-ui';
|
|
2
|
+
import { createGoBackLiveButton, createWatchFromStartButton } from './buttons';
|
|
3
|
+
import { createAdButton } from './adbutton';
|
|
4
|
+
import { createAdLabel } from './adlabel';
|
|
5
|
+
export function createCTABar(player, npoplayer, variant) {
|
|
6
|
+
const goBackLiveButton = createGoBackLiveButton(player);
|
|
7
|
+
const watchFromStartButton = createWatchFromStartButton(player, npoplayer);
|
|
8
|
+
let barComponents = [
|
|
9
|
+
watchFromStartButton,
|
|
10
|
+
goBackLiveButton
|
|
11
|
+
];
|
|
12
|
+
if (variant === 'ad') {
|
|
13
|
+
const adLabel = createAdLabel(npoplayer);
|
|
14
|
+
const adButton = createAdButton(npoplayer);
|
|
15
|
+
barComponents.push(adLabel);
|
|
16
|
+
barComponents.push(adButton);
|
|
17
|
+
adLabel.hide();
|
|
18
|
+
}
|
|
19
|
+
return new Container({
|
|
20
|
+
components: barComponents,
|
|
21
|
+
cssClasses: ['controlbar-textbuttons']
|
|
22
|
+
});
|
|
23
|
+
}
|
|
24
|
+
//# sourceMappingURL=ctabar.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ctabar.js","sourceRoot":"","sources":["../../../../../src/js/ui/components/ctabar.ts"],"names":[],"mappings":"AAUA,OAAO,EAAU,SAAS,EAAS,MAAM,oBAAoB,CAAA;AAC7D,OAAO,EACH,sBAAsB,EACtB,0BAA0B,EAC7B,MAAM,WAAW,CAAA;AAClB,OAAO,EAAE,cAAc,EAAE,MAAM,YAAY,CAAA;AAC3C,OAAO,EAAE,aAAa,EAAE,MAAM,WAAW,CAAA;AAczC,MAAM,UAAU,YAAY,CAAE,MAAwB,EAAE,SAAoB,EAAE,OAAe;IACzF,MAAM,gBAAgB,GAAG,sBAAsB,CAAC,MAAM,CAAC,CAAA;IACvD,MAAM,oBAAoB,GAAG,0BAA0B,CAAC,MAAM,EAAE,SAAS,CAAC,CAAA;IAE1E,IAAI,aAAa,GAAkD;QAC/D,oBAAoB;QACpB,gBAAgB;KACnB,CAAA;IAED,IAAI,OAAO,KAAK,IAAI,EAAE;QAClB,MAAM,OAAO,GAAG,aAAa,CAAC,SAAS,CAAC,CAAA;QACxC,MAAM,QAAQ,GAAG,cAAc,CAAC,SAAS,CAAC,CAAA;QAC1C,aAAa,CAAC,IAAI,CAAC,OAAO,CAAC,CAAA;QAC3B,aAAa,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAA;QAC5B,OAAO,CAAC,IAAI,EAAE,CAAA;KACjB;IAED,OAAO,IAAI,SAAS,CAAC;QACjB,UAAU,EAAE,aAAa;QACzB,UAAU,EAAE,CAAC,wBAAwB,CAAC;KACzC,CAAC,CAAA;AACN,CAAC"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { setFragments } from '../../../fragments/setfragments';
|
|
2
|
+
export const addFragments = async (player, uiManager, section) => {
|
|
3
|
+
const fragments = {
|
|
4
|
+
sections: [section],
|
|
5
|
+
};
|
|
6
|
+
setFragments(player, uiManager, fragments);
|
|
7
|
+
};
|
|
8
|
+
//# sourceMappingURL=addFragments.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"addFragments.js","sourceRoot":"","sources":["../../../../../../src/js/ui/components/nativemobile/addFragments.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,YAAY,EAAE,MAAM,iCAAiC,CAAA;AAI9D,MAAM,CAAC,MAAM,YAAY,GAAQ,KAAK,EAAE,MAAiB,EAAE,SAAoB,EAAE,OAAgB,EAAE,EAAE;IACjG,MAAM,SAAS,GAAc;QACzB,QAAQ,EAAE,CAAC,OAAO,CAAC;KACtB,CAAA;IAED,YAAY,CAAC,MAAM,EAAE,SAAS,EAAE,SAAS,CAAC,CAAA;AAC9C,CAAC,CAAA"}
|