Skip to content

Commit

Permalink
v1.2.0. Fixed the "black bars" - check the readme for the rest of the…
Browse files Browse the repository at this point in the history
… changelog.
  • Loading branch information
mike-zarandona committed Jul 30, 2014
1 parent 89c4c45 commit 946e995
Show file tree
Hide file tree
Showing 3 changed files with 63 additions and 25 deletions.
33 changes: 21 additions & 12 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -65,22 +65,31 @@ Call the plugin on the placeholder element:


## Options
Name | Description
---- | -----------
**videoID** | The video ID of the YouTube video. This option will be ignored if the `data-videoid` attribute is present. (E.g.: *aBcDeFg12345*)
**previewSize** | Preview image size pulled from YouTube. This option will be ignored if the `customPreviewImage` attribute is present. Available sizes from smallest to largest: `thumb-default`, `thumb-1`, `thumb-2`, `thumb-3`, `default`, `medium`, `high`, `hd` *(default)*
**customPreviewImage** | Custom defined preview image URL. This option overrides `options.previewSize`.
**showInfo** | Display video information (top bar).
**showControls** | Display YouTube player controls.
**loop** | Play video as a loop.
**colorScheme** | Display YouTube player user interface.
**showRelated** | Display YouTube related videos on video end.
**useFitVids** | Call FitVids.js on `.pretty-embed` instances once the video(s) is/are loaded.
Name | Description
---- | -----------
**videoID** | The video ID of the YouTube video. This option will be ignored if the `data-videoid` attribute is present. (E.g.: *aBcDeFg12345*)
**previewSize** | Preview image size pulled from YouTube. This option will be ignored if the `customPreviewImage` attribute is present. Available sizes from smallest to largest: `thumb-default`, `thumb-1`, `thumb-2`, `thumb-3`, `default`, `medium`, `high`, `hd` *(default)*
**customPreviewImage** | Custom defined preview image URL. This option overrides `options.previewSize`.
**showInfo** | Display video information (top bar).
**showControls** | Display YouTube player controls.
**loop** | Play video as a loop.
**closedCaptions** | Displays closed captions (if available).
**localization** | Changes the localization. Accepts an [ISO 639-1 two-letter language code](http://www.loc.gov/standards/iso639-2/php/code_list.php).
**colorScheme** | Display YouTube player user interface.
**showRelated** | Display YouTube related videos on video end.
**useFitVids** | Call FitVids.js on `.pretty-embed` instances once the video(s) is/are loaded.



## Changelog

### v1.2.0
- Fixed those annoying "black bars" that would show up on the sides of the video once playing
- Fixed an issue which would cause HTML5 `data-pe-` attributes to break
- Removed the background-color from `.pretty-embed`, because be more flexible, ya know?
- New option: `closedCaptions` to turn on closed captions (if available)
- New option: `localization` which accepts an [ISO 639-1 two-letter language code](http://www.loc.gov/standards/iso639-2/php/code_list.php)

### v1.1.0
- Better multiple instance handling
- Fixed duplicate appended styles on multiple instances
Expand All @@ -96,7 +105,7 @@ Name | Description


## Thanks
Thanks to the contributors and suggestions from around the web ([@k-risc](https://github.com/k-risc))
Thanks to the contributors and suggestions from around the web

Thanks to alexanderdickson for [waitForImages](https://github.com/alexanderdickson/waitForImages), which this plugin leverages for dynamic image previews.

Expand Down
51 changes: 40 additions & 11 deletions jquery.prettyembed.js
Original file line number Diff line number Diff line change
Expand Up @@ -2,9 +2,9 @@
**********************************************************
* prettyEmbed.js | https://github.com/mike-zarandona/prettyembed.js
*
* Version: v1.1.0
* Version: v1.2.0
* Author: Mike Zarandona
* Release: June 30 2014
* Release: July 30 2014
*
* Reqs: jQuery | http://jquery.com
* waitForImages | https://github.com/alexanderdickson/waitForImages
Expand All @@ -19,6 +19,7 @@
* showInfo: true,
* showControls: true,
* loop: false,
* closedCaptions: false,
* colorScheme: 'dark',
* showRelated: false,
*
Expand All @@ -40,7 +41,7 @@
if ( $('#pretty-embed-style').length === 0 ) {
var styles = $('<style />', {
id: 'pretty-embed-style',
html: '.pretty-embed{position:relative;background-color:#000;cursor:pointer;display:block}.pretty-embed img{width:100%;height:auto}.pretty-embed iframe{border:0 solid transparent}.pretty-embed:after{display:block;content:"";position:absolute;top:50%;margin-top:-19px;left:50%;margin-left:-27px;width:54px;height:38px;background-image:url();-webkit-background-size:cover;background-size:cover}.pretty-embed.play:after{display:none}.pretty-embed:hover:after{background-image:url()}'
html: '.pretty-embed{position:relative;cursor:pointer;display:block}.pretty-embed img{width:100%;height:auto}.pretty-embed iframe{border:0 solid transparent}.pretty-embed:after{display:block;content:"";position:absolute;top:50%;margin-top:-19px;left:50%;margin-left:-27px;width:54px;height:38px;background-image:url();-webkit-background-size:cover;background-size:cover}.pretty-embed.play:after{display:none}.pretty-embed:hover:after{background-image:url()}'
}).appendTo('head');
}

Expand All @@ -56,7 +57,7 @@

// if no selector, only fire on .pretty-embed
if ( $(this).length === 0 ) { elem = $('.pretty-embed'); }
else { elem = $(this).add('.pretty-embed'); }
else { elem = $(this); }

// Main setup loop
elem.each(function() {
Expand All @@ -71,6 +72,8 @@
thisShowInfo,
thisShowControls,
thisLoop,
thisClosedCaptions,
thisLocalization,
thisColorScheme,
thisShowRelated;

Expand Down Expand Up @@ -104,6 +107,16 @@
else if ( options.loop !== undefined ) { thisLoop = options.loop; }
else { thisLoop = undefined; }

// closed captions
if ( $(this).attr('data-pe-closed-captions') !== undefined ) { thisClosedCaptions = $(this).attr('data-pe-closed-captions'); }
else if ( options.closedCaptions !== undefined ) { thisClosedCaptions = options.closedCaptions; }
else { thisClosedCaptions = undefined; }

// localization
if ( $(this).attr('data-pe-localization') !== undefined ) { thisLocalization = $(this).attr('data-pe-localization'); }
else if ( options.localization !== undefined ) { thisLocalization = options.localization; }
else { thisLocalization = undefined; }

// color scheme
if ( $(this).attr('data-pe-color-scheme') !== undefined ) { thisColorScheme = $(this).attr('data-pe-color-scheme'); }
else if ( options.colorScheme !== undefined ) { thisColorScheme = options.colorScheme; }
Expand All @@ -128,6 +141,8 @@
.attr('data-pe-show-info', thisShowInfo)
.attr('data-pe-show-controls', thisShowControls)
.attr('data-pe-loop', thisLoop)
.attr('data-pe-closed-captions', thisClosedCaptions)
.attr('data-pe-localization', thisLocalization)
.attr('data-pe-color-scheme', thisColorScheme)
.attr('data-pe-show-related', thisShowRelated);

Expand All @@ -136,7 +151,7 @@
}

// Write the options.customPreviewImage OR choose a size
if ( thisCustomPreviewImage !== undefined ) {
if ( thisCustomPreviewImage !== undefined && thisCustomPreviewImage !== '' ) {
$(this).html('<img src="' + thisCustomPreviewImage + '" width="100%" alt="YouTube Video Preview" />');
}
else {
Expand Down Expand Up @@ -203,8 +218,8 @@
* obj = the current object referenced passed from $(this)
*/
function clickEventRunner(obj) {
var wrapperWidth = obj.outerWidth(true),
wrapperHeight = obj.outerHeight(true),
var wrapperWidth = obj.find('img').outerWidth(true),
wrapperHeight = obj.find('img').outerHeight(true),
playerOptions = '',
thisVideoID = '';

Expand All @@ -219,19 +234,32 @@

// Assemble the player options string
// showInfo
if ( (obj.attr('data-pe-show-info') === false) || (options.showInfo === false) ) { playerOptions += '&showinfo=0'; }
if ( (obj.attr('data-pe-show-info') === 'false') || (options.showInfo === false) ) { playerOptions += '&showinfo=0'; }

// showControls
if ( (obj.attr('data-pe-show-controls') === false) || (options.showControls === false) ) { playerOptions += '&controls=0'; }
if ( (obj.attr('data-pe-show-controls') === 'false') || (options.showControls === false) ) { playerOptions += '&controls=0'; }

// loop
if ( (obj.attr('data-pe-loop') === true) || (options.loop === true) ) { playerOptions += '&loop=1'; }
if ( (obj.attr('data-pe-loop') === 'true') || (options.loop === true) ) { playerOptions += '&loop=1'; }

// closed captions
if ( (obj.attr('data-pe-closed-captions') === 'true') || (options.closedCaptions === true) ) { playerOptions += '&cc_load_policy=1'; }

// localization
if ( (obj.attr('data-pe-localization') !== undefined) || (options.localization !== undefined) ) {
if ( obj.attr('data-pe-localization') !== undefined ) {
playerOptions += '&hl=' + obj.attr('data-pe-localization');
}
else if ( options.localization !== undefined ) {
playerOptions += '&hl=' + options.localization;
}
}

// colorScheme
if ( (obj.attr('data-pe-color-scheme') == 'light') || (options.colorScheme == 'light') ) { playerOptions += '&theme=light'; }

// showRelated
if ( (obj.attr('data-pe-show-related') === false) || (options.showRelated === false) ) { playerOptions += '&rel=0'; } else { playerOptions += '&rel=1'; }
if ( (obj.attr('data-pe-show-related') === 'false') || (options.showRelated === false) ) { playerOptions += '&rel=0'; } else { playerOptions += '&rel=1'; }

// Write the YouTube video iFrame into the element at the exact dimensions it is now
obj.html('<iframe width="' + wrapperWidth + '" height="' + wrapperHeight + '" style="border:none;" src="//www.youtube.com/embed/' + thisVideoID + '?autoplay=1' + playerOptions + '"></iframe>')
Expand Down Expand Up @@ -271,6 +299,7 @@
showInfo: true,
showControls: true,
loop: false,
closedCaptions: false,

colorScheme: 'dark',
showRelated: false,
Expand Down
Loading

0 comments on commit 946e995

Please sign in to comment.