-
Notifications
You must be signed in to change notification settings - Fork 26
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
feat: add url template for video player profiles #696
Conversation
✅ Deploy Preview for cld-video-player ready!
To edit notification comments on pull requests, go to your Netlify site configuration. |
✅ Deploy Preview for cld-vp-esm-pages ready!
To edit notification comments on pull requests, go to your Netlify site configuration. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
LGTM 💪
playerWithCustomProfile.source('samples/cld-sample-video'); | ||
}, false); | ||
</code> | ||
</pre> | ||
</div> | ||
|
||
</body> |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I suggest adding another example with a custom profile and overriding configuration code to make sure it works as expected (It could be same page but two different players and i think this is even more favourable)
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
good point, added another example with overrides
src/player.js
Outdated
} | ||
const urlPrefix = unsigned_url_prefix( | ||
null, | ||
initOptions.cloudName || initOptions.cloud_name, |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
initOptions.cloudName || initOptions.cloud_name, | |
initOptions.cloudName ?? initOptions.cloud_name, |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
👍
src/player.js
Outdated
|
||
throw new Error('Custom profiles will be supported soon, please use one of default profiles: "cldDefault", "cldLooping" or "cldAdaptiveStream"'); | ||
const profileUrl = isRawUrl(profile) ? profile : `${urlPrefix}/_applet_/video_service/video_player_profiles/${profile}.json`; | ||
return await fetch(profileUrl, { method: 'GET' }).then(res => res.json()); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think the await here and the async in the function declaration are both redundant, but especially here it is really not needed
return await fetch(profileUrl, { method: 'GET' }).then(res => res.json()); | |
return fetch(profileUrl, { method: 'GET' }).then(res => res.json()); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
changed, I would like to keep entire method as async just in case - so w need to have async declaration on the top but there await can be removed
const urlPrefix = unsigned_url_prefix( | ||
null, | ||
initOptions.cloudName ?? initOptions.cloud_name, | ||
initOptions.private_cdn, | ||
initOptions.cdn_subdomain, | ||
initOptions.secure_cdn_subdomain, | ||
initOptions.cname, | ||
initOptions.secure, | ||
initOptions.secure_distribution, | ||
); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@jakub-roch instead of creating that list can't you use CLOUDINARY_CONFIG_PARAM
, like in getConfig() ?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
* chore: release-manual * chore: release-manual * fix: use videojs events & re-trigger to analytics package with custom… (#639) * fix: use videojs events & re-trigger to analytics package with custom events * fix: import / bump package * Update release-edge.yml * Update release-manual.yml * chore(edge): release 2.0.4-edge.0 (#656) * chore(edge): release 2.0.4-edge.0 * Update CHANGELOG.md --------- Co-authored-by: Tsachi Shlidor <tsachi.shlidor@cloudinary.com> * fix: remove polyfill (#665) * chore(edge): release 2.0.5-edge.0 (#666) * fix: separate edge/master changelogs (#663) * fix: separate edge/master changelogs Co-Authored-By: Tsachi Shlidor <tsachi.shlidor@cloudinary.com> Co-Authored-By: cloudinary-jenkins <jenkins@cloudinary.com> * chore: update changelog-edge --------- Co-authored-by: cloudinary-jenkins <jenkins@cloudinary.com> * fix: fetchLatestRelease * fix: fetchLatestRelease * fix: fetchLatestRelease * fix: fetchLatestRelease * chore(edge): release 2.0.5-edge.1 (#667) * chore(edge): release 2.0.5-edge.1 * Update CHANGELOG-edge.md --------- Co-authored-by: Tsachi Shlidor <tsachi.shlidor@cloudinary.com> * fix: security issue braces (#668) * ME-16623 - creating first VP automation test (#664) * vp test: initial first test * vp test: initial first test * update e2e tests * update e2e * update e2e * update e2e * added eslint to e2e * vp test: initial first test * vp test: initial first test * update validatePageErrors function * update workers number * vp test: initial first test * vp test: initial first test * vp test: change for to for each * vp test: change back to for and update number of workers * vp test: refactor based on review comments * vp test: change timout * vp test: change timout and add logs * vp test: comment out flaky test on CI * vp test: comment out flaky test on CI --------- Co-authored-by: refael-m <refael.mahpud@cloudinary.com> * fix: custom profile docs example (#673) * fix: chapters innerHTML to innerText (#671) * fix: remove braces override (#670) Co-authored-by: Tsachi Shlidor <tsachi.shlidor@cloudinary.com> * chore(edge): release 2.0.5-edge.2 (#669) * vp test: handle flaky tests (#674) * vp test: update number of workers * vp test: update number of workers to 4 * vp test: update workers back to 5 * test: decrease workers to 1 * vp test: update webserver URL * vp test: update webserver URL * vp test: increase number of workers to 6 * vp test: increase number of workers to 6 * vp test: increase number of workers to 5 * vp test: reduce number of workers to 4 * vp test: increase number of workers to 5 * vp test: temp commit * vp test: revert temp commit * vp test: comment out adaptive streaming as it is flaky --------- Co-authored-by: alexeykagansky <alexey.kagansky@cloudinary.com> * vp test: adding workflow and action for CI (#675) * Edit workflow (#676) * fix workflow * Update update_master.yml * Update update_master.yml * Update update_master.yml * Update update_master.yml * Update update_master.yml * Update update_master.yml * Update update_master.yml * Update update_master.yml * Update update_master.yml * Update update_master.yml * Update update_master.yml * Update update_master.yml * Update update_master.yml * fix: profiles docs link (#683) * vp test: adding new test to handle ESM page + small refactoring (#684) * vp test: adding new test to handle ESM page + small refactoring * vp test: remove flaky adaptive streaming * vp test: remove skip from ESM profile page and skip adaptive streaming * feat: new 'player' method with support async loading & profiles (#678) * feat: new 'player' method with support async loading & profiles * feat: new 'player' method with support async loading & profiles * fix: review comments * fix: bump VP size * fix: allow for profile url value * fix: isRawUrl path * feat: custom data video analytics param (#687) * feat: custom data video analytics param * feat: custom data video analytics param * fix: update dependencies (#688) * chore: update dependencies * fix: sass deprecation warnings * fix: bundlewatch * fix: docs for profiles & analytics, analytics options (#689) * fix: docs for profiles & analytics, analytics options * fix: docs for profiles & analytics, analytics options * fix: docs for profiles & analytics, analytics options * fix: bump analytics package version * chore(edge): release 2.0.6-edge.0 (#685) * Publish playwright report to reports repo (#690) * update e2e github flow * update * update * update * update * update * update * update * update * update ssh * update * update * update * added e2e to separate workflow * update * update * update * update * removed if always() from push reports step * vp test: adding error message to ignore errors for ESM pages (#695) * feat: add url template for video player profiles (#696) * feat: add url template for video player profiles * feat: docs profile url * fix: default secure option for new method (#698) * fix: default secure option for new method * fix: docs raw url * chore(edge): release 2.1.1-edge.0 (#697) * feat: add internal analytics about new method & profiles (#699) * feat: add internal analytics about new method & profiles * chore(edge): release 2.1.1-edge.1 (#700) * fix: use cld player profiles package for default profiles (#701) * fix: use cld player profiles package for default profiles * chore(edge): release 2.1.1-edge.2 (#702) * Me 18059 esm tests over preview build (#727) * vp test: support esm test running on preview deploy * vp test: support esm test running on preview deploy increase timeout * vp test: support esm test running on preview deploy revert timeout * vp test: adding waitFor function for checking if preview URL is ready * vp test: adding waitFor function for checking if preview URL is ready * vp test: adding waitFor function for checking if preview URL is ready * vp test: modify changes * vp test: modify changes * vp test: modify waitForDeployPreviewUrl * vp test: modify waitForDeployPreviewUrl * vp test: modify changes * vp test: modify changes * vp test: remove beforeAll * vp test: modify waitForDeployPreviewUrl function * vp test: modify waitForDeployPreviewUrl function * vp test: modify waitForDeployPreviewUrl function * vp test: modify waitForDeployPreviewUrl function adding a print * vp test: modify changes * vp test: adding print to log + increasing timeout * vp test: revert timeout * vp test: adding timeout * vp test: adding test for is deploy URL ready * vp test: revert test * vp test: change assertion * vp test: change assertion * vp test: modify waitForDeployPreviewUrl * vp test: modify waitForDeployPreviewUrl assertion * vp test: adding beforeEach and modify waitForDeployPreviewUrl * vp test: modify waitForDeployPreviewUrl * vp test: adding logs for debugging * vp test: adding logs for debugging * vp test: adding logs for debugging * vp test: adding logs for debugging * vp test: adding logs for debugging * vp test: modify waitForDeployPreviewUrl and revert debugging prints * vp test: modify waitForDeployPreviewUrl * vp test: refactor based on review comments * vp test: remove console log print * fix: one event for internal analytics (#728) * fix: one event for internal analytics * chore(edge): release 2.1.2-edge.0 (#732) * ME-17952: test if video is playing on main page (#733) * vp test: test if video is playing on main page * vp test: rename playVideo to clickPlay * Me 17953 test video on ai highlights graph page (#734) * vp test: test if video is playing on highlight graph page * vp test: test if video is playing on highlight graph page * vp test: remove comment * vp test: refactor based on review. Adding getLinkByName function and support enum for example page names * vp test: refactor based on review adding page manager * vp test: modify test description (#735) * vp test: refactor to support ExampleLinkName enum (#736) * vp test: refactor to support ExampleLinkName enum * vp test: rename file * fix: source analytics (#738) * fix: source analytics * chore: cleanup * chore(edge): release 2.1.2-edge.1 (#739) * feat: allow transcript from url (#737) * feat: allow transcript url * chore: transcript analytics * chore: transcript analytics * chore(edge): release 2.1.2-edge.2 (#740) * feat: auto-fetch transcripts from language (#741) * feat: auto-fetch transcripts from language * chore: update tests * feat: auto-fetch transcripts from language * feat: auto-fetch transcripts from language * chore: esm examples * chore(edge): release 2.1.2-edge.3 (#742) * chore: examples * fix: videojs 8 deprecation warning for videojs.bind (#744) * feat: support srt subtitle format (#743) * feat: support srt subtitle format * chore: add example and usage monitoring * chore: esm examples * chore: esm example * chore: examples * feat: support srt subtitle format * chore(edge): release 2.1.2-edge.4 (#745) * fix: programatic text-tracks in Safari (#747) * fix: programatic text-tracks in Safari * chore: bundlewatch * fix: programatic text-tracks in Safari * chore(edge): release 2.1.2-edge.5 (#748) * me-18308: refactor to use page manager (#749) * vp test: refactor to use page manager * vp test: refactor to use page manager * vp test: remove comment --------- Co-authored-by: Tsachi Shlidor <tsachi.shlidor@cloudinary.com> Co-authored-by: jakub-roch <70572646+jakub-roch@users.noreply.github.com> Co-authored-by: cloudinary-jenkins <jenkins@cloudinary.com> Co-authored-by: ShayLevi <61374483+ShayLevi@users.noreply.github.com> Co-authored-by: refael-m <refael.mahpud@cloudinary.com> Co-authored-by: alexeykagansky <alexey.kagansky@cloudinary.com> Co-authored-by: refael-m <72335192+refael-m@users.noreply.github.com>
videoPlayerWithProfile