diff options
author | Stuart Knightley | 2012-03-19 09:46:38 -0700 |
---|---|---|
committer | Stuart Knightley | 2012-03-19 09:46:38 -0700 |
commit | eb5cda3ce03b35c3335b91c34ead0cdf290b243e (patch) | |
tree | c0dd72e2d805e04c6650c2e767d2847ee51a6171 /node_modules/montage/ui/youtube-player.reel/youtube-player.js | |
parent | 222562c734396403c18c90a1ca395a36c4d49da4 (diff) | |
download | ninja-eb5cda3ce03b35c3335b91c34ead0cdf290b243e.tar.gz |
Update Youtube player to HTML5
Diffstat (limited to 'node_modules/montage/ui/youtube-player.reel/youtube-player.js')
-rw-r--r-- | node_modules/montage/ui/youtube-player.reel/youtube-player.js | 38 |
1 files changed, 21 insertions, 17 deletions
diff --git a/node_modules/montage/ui/youtube-player.reel/youtube-player.js b/node_modules/montage/ui/youtube-player.reel/youtube-player.js index 2f7709d7..462dca58 100644 --- a/node_modules/montage/ui/youtube-player.reel/youtube-player.js +++ b/node_modules/montage/ui/youtube-player.reel/youtube-player.js | |||
@@ -1,10 +1,9 @@ | |||
1 | //data="https://www.youtube.com/v/u1zgFlCw8Aw?version=3&enablejsapi=1&playerapiid=ytplayer" | ||
2 | /* <copyright> | 1 | /* <copyright> |
3 | This file contains proprietary software owned by Motorola Mobility, Inc.<br/> | 2 | This file contains proprietary software owned by Motorola Mobility, Inc.<br/> |
4 | No rights, expressed or implied, whatsoever to this software are provided by Motorola Mobility, Inc. hereunder.<br/> | 3 | No rights, expressed or implied, whatsoever to this software are provided by Motorola Mobility, Inc. hereunder.<br/> |
5 | (c) Copyright 2011 Motorola Mobility, Inc. All Rights Reserved. | 4 | (c) Copyright 2011 Motorola Mobility, Inc. All Rights Reserved. |
6 | </copyright> */ | 5 | </copyright> */ |
7 | /*global require,exports*/ | 6 | /*global require,exports,YT */ |
8 | var Montage = require("montage").Montage, | 7 | var Montage = require("montage").Montage, |
9 | Component = require("ui/component").Component; | 8 | Component = require("ui/component").Component; |
10 | 9 | ||
@@ -31,7 +30,6 @@ var YoutubePlayer = exports.YoutubePlayer = Montage.create(Component, { | |||
31 | return this._player; | 30 | return this._player; |
32 | }, | 31 | }, |
33 | set: function(value) { | 32 | set: function(value) { |
34 | // TODO don't allow this to be changed | ||
35 | if (this._player !== value) { | 33 | if (this._player !== value) { |
36 | this._player = value; | 34 | this._player = value; |
37 | } | 35 | } |
@@ -127,30 +125,36 @@ var YoutubePlayer = exports.YoutubePlayer = Montage.create(Component, { | |||
127 | value: function() { | 125 | value: function() { |
128 | // Create the callback if it doesn't exist, and make it dispatch | 126 | // Create the callback if it doesn't exist, and make it dispatch |
129 | // an event on the document instead | 127 | // an event on the document instead |
130 | if (!window.onYouTubePlayerReady) { | 128 | if (!window.onYouTubePlayerAPIReady) { |
131 | window.onYouTubePlayerReady = function(playerId) { | 129 | window.onYouTubePlayerAPIReady = function() { |
132 | var event = document.createEvent("CustomEvent"); | 130 | var event = document.createEvent("CustomEvent"); |
133 | event.initEvent("youtubePlayerReady", true, true); | 131 | event.initEvent("youtubePlayerApiReady", true, true); |
134 | event.playerId = playerId; | ||
135 | document.dispatchEvent(event); | 132 | document.dispatchEvent(event); |
136 | }; | 133 | }; |
137 | } | 134 | } |
138 | 135 | ||
139 | document.addEventListener("youtubePlayerReady", this, false); | 136 | this._element.src += (this._videoId ? "/" + this._videoId : "") + "?enablejsapi=1"; |
140 | 137 | ||
141 | // If there's no videoId set one the doesn't exist | 138 | if (typeof YT !== "undefined" && YT.Player) { |
142 | this._player.data = "https://www.youtube.com/v/" + (this._videoId || "xxxxxxxxxxx") + "?version=3&enablejsapi=1&playerapiid=" + this.uuid; | 139 | this.handleYoutubePlayerApiReady(); |
140 | } else { | ||
141 | document.addEventListener("youtubePlayerApiReady", this, false); | ||
142 | } | ||
143 | } | 143 | } |
144 | }, | 144 | }, |
145 | 145 | ||
146 | handleYoutubePlayerReady: { | 146 | handleYoutubePlayerApiReady: { |
147 | value: function(event) { | 147 | value: function(event) { |
148 | if (event.playerId !== this.uuid) { | 148 | console.log("handleYoutubePlayerApiReady"); |
149 | return; | 149 | document.removeEventListener("youtubePlayerApiReady", this); |
150 | } | 150 | |
151 | 151 | var self = this; | |
152 | this._ready = true; | 152 | this.player = new YT.Player(this._element, { events: { |
153 | this.needsDraw = true; | 153 | onReady: function(event) { |
154 | self._ready = true; | ||
155 | self.needsDraw = true; | ||
156 | } | ||
157 | }}); | ||
154 | } | 158 | } |
155 | }, | 159 | }, |
156 | 160 | ||