-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathYouTubePlayer.coffee
75 lines (61 loc) · 3.04 KB
/
YouTubePlayer.coffee
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
# documentation: https://developers.google.com/youtube/iframe_api_reference
# will resolve when window.onYouTubeIframeAPIReady is called
youTubeReady = new Promise (resolve, reject) ->
window.onYouTubeIframeAPIReady = -> resolve()
# standard youtube iframe api initialization
tag = document.createElement 'script'
tag.src = 'https://www.youtube.com/iframe_api'
# TODO: script async defer?
firstScriptTag = document.getElementsByTagName('script')[0]
firstScriptTag.parentNode.insertBefore tag, firstScriptTag
class exports.YouTubePlayer extends Layer
# events, see https://developers.google.com/youtube/iframe_api_reference#Events
@Events:
Loaded: 'yt-loaded' # occurs when video is queued and ready to play. will provide the player as parameter.
Ready: 'yt-ready'
StateChange: 'yt-stateChange'
PlaybackQualityChange: 'yt-playbackQualityChange'
PlaybackRateChange: 'yt-playbackRateChange'
Error: 'yt-error'
ApiChange: 'yt-apiChange'
# options: { video, playerVars }
# for playerVars, see https://developers.google.com/youtube/player_parameters
constructor: (options={}) ->
# this div will be replaced with youtube iframe
div = document.createElement 'div'
@_playerReady = new Promise (playerResolve, playerReject) =>
youTubeReady.then =>
# player is only accessible on ready event
@_player = new YT.Player(div,
width: @width
height: @height
playerVars: options.playerVars
events:
'onReady': (event) =>
playerResolve event.target
@emit YouTubePlayer.Events.Ready, event
'onStateChange': (event) => @emit YouTubePlayer.Events.StateChange, event
'onPlaybackQualityChange': (event) => @emit YouTubePlayer.Events.PlaybackQualityChange, event
'onPlaybackRateChange': (event) => @emit YouTubePlayer.Events.PlaybackRateChange, event
'onError': (event) =>
playerReject event.data
@emit YouTubePlayer.Events.Error, event
'onApiChange': (event) => @emit YouTubePlayer.Events.ApiChange, event
);
# on size change of the layer, resize the iframe
@on "change:width", -> @_player.width = @width
@on "change:height", -> @_player.height = @height
# calling super causes @define properties being assigned
super options
@_element.appendChild div
@define "video",
get: -> @_video
set: (video) ->
@_video = video
@_playerReady.then =>
@_player.cueVideoById video
@_player.playVideo() if @playerVars?.autoplay
@emit YouTubePlayer.Events.Loaded, @_player
@define "playerVars",
get: -> @_playerVars
set: (value) -> @_playerVars = value