Skip to content

Commit

Permalink
feat: cleanup, refactor & improve the code for PHP cxl/jw-player
Browse files Browse the repository at this point in the history
* jw-player height tweaks
* [jw-player] add support for sources
	cherry-pick: #236
* [cxl-jw-player] set up api endpoint
	cherry-pick: #234
  • Loading branch information
saas786 authored and anoblet committed Feb 20, 2023
1 parent d6433d6 commit 5698fd1
Show file tree
Hide file tree
Showing 7 changed files with 73 additions and 25 deletions.
4 changes: 0 additions & 4 deletions packages/cxl-ui/scss/cxl-jw-player/cxl-jw-player-shadow.scss
Original file line number Diff line number Diff line change
Expand Up @@ -8,10 +8,6 @@
}
}

:host([captions]) #container {
grid-template-rows: 1fr max-content 1fr;
}

.captions {
h2,
span {
Expand Down
3 changes: 2 additions & 1 deletion packages/cxl-ui/src/components/cxl-jw-player/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -4,10 +4,11 @@

```
<cxl-jw-player
is-public
captions
media-id="fZ0XiGdb"
minimum-search-length="3"
player-id="5CFJNXKb"
library-id="5CFJNXKb"
plugin-path="https://cxl.com/institute/wp-content/plugins/cxl-jwplayer/"
></cxl-jw-player>
```
Expand Down
2 changes: 1 addition & 1 deletion packages/cxl-ui/src/components/cxl-jw-player/index.html.js
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,7 @@ import '@vaadin/text-field';
// eslint-disable-next-line func-names
export const template = function () {
return html`
<div class="grid height-100" id="container">
<div class="cxl-jw-player-container" id="cxl-jw-player-container">
<slot></slot>
${this.captions
? html`
Expand Down
2 changes: 1 addition & 1 deletion packages/cxl-ui/src/components/cxl-jw-player/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -15,14 +15,14 @@ export class CXLJWPlayerElement extends mixin(LitElement, [
]) {
config = {
width: '100%',
height: '100%',
playbackRateControls: [0.25, 0.5, 0.75, 1, 1.25, 1.5, 1.75, 2],
plugins: {
// 'http://192.168.0.101:8080/telemetry-8.20.0.js': {},
},
skin: {
name: 'cxl-institute',
},
stretching: 'uniform',
};

static get styles() {
Expand Down
66 changes: 52 additions & 14 deletions packages/cxl-ui/src/components/cxl-jw-player/mixins/BaseMixin.js
Original file line number Diff line number Diff line change
Expand Up @@ -17,10 +17,18 @@ export function BaseMixin(BaseClass) {

@property({ attribute: 'media-id', type: String }) mediaId;

@property({ attribute: 'player-id', type: String }) playerId;
@property({ attribute: 'media-source', type: String }) mediaSource;

@property({ attribute: 'is-public', type: String }) isPublic;

@property({ attribute: 'library-id', type: String }) libraryId;

@property({ attribute: 'library-source', type: String }) librarySource;

@property({ attribute: 'playlist-id', type: String }) playlistId;

@property({ attribute: 'playlist-source', type: String }) playlistSource;

firstUpdated(_changedProperties) {
super.firstUpdated(_changedProperties);

Expand All @@ -35,39 +43,60 @@ export function BaseMixin(BaseClass) {
}

get __scriptUrl() {
return `https://content.jwplatform.com/libraries/${this.playerId}.js`;
let scriptUrl;

if (this.libraryId && this.isPublic) {
scriptUrl = `https://content.jwplatform.com/libraries/${this.libraryId}.js`;
} else if (this.librarySource) {
scriptUrl = this.librarySource;
} else {
return false;
}

return scriptUrl;
}

__addStyle(style) {
const el = document.createElement('style');
render(style, el);
this.appendChild(el);
}

async __getChapters() {
const playlistItem = this.__jwPlayer.getPlaylistItem();
const { file } = playlistItem.tracks.filter((track) => track.kind === 'chapters')[0];
const chapters = playlistItem.tracks.filter((track) => track.kind === 'chapters');
const { file } = chapters.length > 0 ? chapters[0] : '';
const response = await (await fetch(file)).text();

return parseSync(response);
}

async __getMedia() {
if (!this.mediaId) return false;

const response = await fetch(`https://cdn.jwplayer.com/v2/media/${this.mediaId}`);
const result = await response.json();
let response;

if (this.mediaId && this.isPublic) {
response = await fetch(`https://cdn.jwplayer.com/v2/media/${this.mediaId}`);
} else if (this.mediaSource) {
response = await fetch(this.mediaSource);
} else {
return false;
}

return result;
return response.json();
}

async __getPlaylist() {
if (!this.playlistId) return false;

const response = await fetch(`https://cdn.jwplayer.com/v2/playlists/${this.playlistId}`);
const result = await response.json();
let response;

if (this.playlistId) {
response = await fetch(`https://cdn.jwplayer.com/v2/playlists/${this.playlistId}`);
} else if (this.playlistSource) {
response = await fetch(`https://cdn.jwplayer.com/v2/playlists/${this.playlistId}`);
} else {
return false;
}

return result;
return response.json();
}

async __loadScript() {
Expand Down Expand Up @@ -97,6 +126,15 @@ export function BaseMixin(BaseClass) {
* Each mixin has the ability to hook onto this method.
*/
async __setup() {

// Merge configs from `cxlJWPlayerData`.
if (typeof window.cxlJWPlayerData !== 'undefined') {
// eslint-disable-next-line camelcase
const { media_config } = window.cxlJWPlayerData[this.mediaId];
// eslint-disable-next-line camelcase
this.config = { ...this.config, ...media_config };
}

const jwPlayer = await this.__loadScript();

const el = document.createElement('div');
Expand Down
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
export function SavePositionMixin(BaseClass) {
class Mixin extends BaseClass {
__endpoint = '';
__endpoint;

__nonce;

Expand All @@ -9,6 +9,12 @@ export function SavePositionMixin(BaseClass) {
async __setup() {
await super.__setup();

this.__endpoint = `${window.ajaxurl}?action=jwplayer_save_position`;

if ( typeof window.cxl_pum_vars !== 'undefined' ) {
this.__nonce = window.cxl_pum_vars.nonce;
}

this.__loadPosition();
}

Expand Down
13 changes: 10 additions & 3 deletions packages/storybook/cxl-ui/cxl-jw-player/index.stories.js
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,7 @@ export default {
title: 'CXL UI/cxl-jw-player',
};

const Template = ({ captions, mediaId, minimumSearchLength, playerId, playlistId, pluginPath }) =>
const Template = ({ captions, mediaId, mediaSource, minimumSearchLength, libraryId, librarySource, playlistId, playlistSource, pluginPath }) =>
html`
<style>
#root-inner {
Expand All @@ -22,11 +22,15 @@ const Template = ({ captions, mediaId, minimumSearchLength, playerId, playlistId
}
</style>
<cxl-jw-player
is-public="true"
?captions=${captions}
media-id=${mediaId}
media-source=${mediaSource}
minimum-search-length=${minimumSearchLength}
player-id=${playerId}
library-id=${playerId}
library-source=${playerSource}
playlist-id=${playlistId}
playlist-source=${playlistSource}
plugin-path="${pluginPath}"
></cxl-jw-player>
`;
Expand All @@ -35,11 +39,14 @@ export const Default = Template.bind({});

Object.assign(Default, {
args: {
captions: false,
captions: true,
mediaId: 'fZ0XiGdb',
mediaSource: '',
minimumSearchLength: 3,
playerId: '5CFJNXKb',
playerSource: '',
playlistId: '',
playlistSource: '',
pluginPath: 'https://cxl.com/institute/wp-content/plugins/cxl-jwplayer/',
},
});

0 comments on commit 5698fd1

Please sign in to comment.