Skip to content
Browse files

Merge branch 'develop'

  • Loading branch information...
2 parents 672bcc4 + 3b06553 commit dd68d3c56dbf3c49324b4303146f68ef752a9128 @jbuck jbuck committed Jun 27, 2011
Showing with 3,486 additions and 1,180 deletions.
  1. +1 −0 AUTHORS
  2. +70 −14 Makefile
  3. +3 −281 demos/semantic_video/index.html
  4. +85 −0 demos/semantic_video/popcorn.applyclass.js
  5. +1 −2 demos/semantic_video/style.css
  6. +1 −1 demos/semantic_video/xml/webMadeMovies.xml
  7. +61 −0 effects/applyclass/popcorn.applyclass.html
  8. +80 −0 effects/applyclass/popcorn.applyclass.js
  9. +36 −0 effects/applyclass/style.css
  10. +0 −1 parsers/parserSBV/popcorn.parserSBV.unit.html
  11. +1 −1 parsers/parserSBV/popcorn.parserSBV.unit.js
  12. +1 −2 parsers/parserSRT/popcorn.parserSRT.unit.html
  13. +2 −2 parsers/parserSRT/popcorn.parserSRT.unit.js
  14. +0 −1 parsers/parserSSA/popcorn.parserSSA.unit.html
  15. +1 −1 parsers/parserSSA/popcorn.parserSSA.unit.js
  16. +0 −1 parsers/parserTTML/popcorn.parserTTML.unit.html
  17. +1 −1 parsers/parserTTML/popcorn.parserTTML.unit.js
  18. +0 −1 parsers/parserTTXT/popcorn.parserTTXT.unit.html
  19. +1 −1 parsers/parserTTXT/popcorn.parserTTXT.unit.js
  20. +1 −2 parsers/parserVTT/popcorn.parserVTT.unit.html
  21. +2 −2 parsers/parserVTT/popcorn.parserVTT.unit.js
  22. +4 −6 parsers/parserXML/popcorn.parserXML.unit.js
  23. +1 −1 players/baseplayer/popcorn.baseplayer.html
  24. +16 −14 players/baseplayer/popcorn.baseplayer.js
  25. +27 −0 players/baseplayer/popcorn.baseplayer.unit.html
  26. +15 −12 players/baseplayer/popcorn.baseplayer.unit.js
  27. +1 −1 players/sequence
  28. +2 −2 players/youtube/popcorn.youtube.html
  29. +18 −3 players/youtube/popcorn.youtube.js
  30. +3 −0 players/youtube/popcorn.youtube.unit.html
  31. +34 −4 players/youtube/popcorn.youtube.unit.js
  32. 0 plugins/attribution/popcorn.attribution.html
  33. +66 −47 plugins/attribution/popcorn.attribution.js
  34. 0 plugins/attribution/popcorn.attribution.unit.html
  35. +13 −7 plugins/attribution/popcorn.attribution.unit.js
  36. 0 plugins/code/popcorn.code.html
  37. +3 −4 plugins/code/popcorn.code.js
  38. 0 plugins/code/popcorn.code.unit.html
  39. +6 −6 plugins/code/popcorn.code.unit.js
  40. 0 plugins/facebook/popcorn.facebook.html
  41. +1 −1 plugins/facebook/popcorn.facebook.js
  42. 0 plugins/facebook/popcorn.facebook.unit.html
  43. +11 −8 plugins/facebook/popcorn.facebook.unit.js
  44. +32 −31 plugins/flickr/popcorn.flickr.html
  45. +96 −42 plugins/flickr/popcorn.flickr.js
  46. 0 plugins/flickr/popcorn.flickr.unit.html
  47. +42 −22 plugins/flickr/popcorn.flickr.unit.js
  48. 0 plugins/footnote/popcorn.footnote.html
  49. 0 plugins/footnote/popcorn.footnote.js
  50. 0 plugins/footnote/popcorn.footnote.unit.html
  51. +5 −5 plugins/footnote/popcorn.footnote.unit.js
  52. 0 plugins/gml/popcorn.gml.html
  53. +8 −8 plugins/gml/popcorn.gml.js
  54. 0 plugins/gml/popcorn.gml.unit.html
  55. +5 −5 plugins/gml/popcorn.gml.unit.js
  56. 0 plugins/googlefeed/popcorn.googlefeed.html
  57. +96 −54 plugins/googlefeed/popcorn.googlefeed.js
  58. +0 −1 plugins/googlefeed/popcorn.googlefeed.unit.html
  59. +20 −19 plugins/googlefeed/popcorn.googlefeed.unit.js
  60. 0 plugins/googlemap/popcorn.googlemap.html
  61. +2 −1 plugins/googlemap/popcorn.googlemap.js
  62. 0 plugins/googlemap/popcorn.googlemap.unit.html
  63. +27 −26 plugins/googlemap/popcorn.googlemap.unit.js
  64. 0 plugins/googlenews/popcorn.googlenews.html
  65. +1 −1 plugins/googlenews/popcorn.googlenews.js
  66. 0 plugins/googlenews/popcorn.googlenews.unit.html
  67. +5 −5 plugins/googlenews/popcorn.googlenews.unit.js
  68. 0 plugins/image/popcorn.image.html
  69. +1 −1 plugins/image/popcorn.image.js
  70. 0 plugins/image/popcorn.image.unit.html
  71. +6 −6 plugins/image/popcorn.image.unit.js
  72. +6 −4 plugins/index.html
  73. 0 plugins/lastfm/popcorn.lastfm.html
  74. 0 plugins/lastfm/popcorn.lastfm.js
  75. 0 plugins/lastfm/popcorn.lastfm.unit.html
  76. 0 plugins/lastfm/popcorn.lastfm.unit.js
  77. 0 plugins/linkedin/popcorn.linkedin.html
  78. 0 plugins/linkedin/popcorn.linkedin.js
  79. 0 plugins/linkedin/popcorn.linkedin.unit.html
  80. +16 −16 plugins/linkedin/popcorn.linkedin.unit.js
  81. 0 plugins/lowerthird/popcorn.lowerthird.html
  82. +1 −1 plugins/lowerthird/popcorn.lowerthird.js
  83. 0 plugins/lowerthird/popcorn.lowerthird.unit.html
  84. +6 −6 plugins/lowerthird/popcorn.lowerthird.unit.js
  85. 0 plugins/mustache/popcorn.mustache.html
  86. +33 −17 plugins/mustache/popcorn.mustache.js
  87. 0 plugins/mustache/popcorn.mustache.unit.html
  88. +10 −10 plugins/mustache/popcorn.mustache.unit.js
  89. 0 plugins/openmap/popcorn.openmap.html
  90. 0 plugins/openmap/popcorn.openmap.js
  91. 0 plugins/openmap/popcorn.openmap.unit.html
  92. +6 −6 plugins/openmap/popcorn.openmap.unit.js
  93. 0 plugins/pause/popcorn.pause.html
  94. +2 −5 plugins/pause/popcorn.pause.js
  95. 0 plugins/pause/popcorn.pause.unit.html
  96. 0 plugins/pause/popcorn.pause.unit.js
  97. +70 −0 plugins/processing/popcorn.processing.html
  98. +155 −0 plugins/processing/popcorn.processing.js
  99. +41 −0 plugins/processing/popcorn.processing.unit.html
  100. +136 −0 plugins/processing/popcorn.processing.unit.js
  101. +121 −0 plugins/processing/test.pjs
  102. +81 −0 plugins/processing/test2.pjs
  103. 0 plugins/subtitle/popcorn.subtitle.html
  104. +89 −49 plugins/subtitle/popcorn.subtitle.js
  105. 0 plugins/subtitle/popcorn.subtitle.unit.html
  106. +42 −11 plugins/subtitle/popcorn.subtitle.unit.js
  107. 0 plugins/tagthisperson/popcorn.tagthisperson.html
  108. +1 −1 plugins/tagthisperson/popcorn.tagthisperson.js
  109. 0 plugins/tagthisperson/popcorn.tagthisperson.unit.html
  110. 0 plugins/tagthisperson/popcorn.tagthisperson.unit.js
  111. +11 −0 plugins/timeline/popcorn.timeline.css
  112. +99 −0 plugins/timeline/popcorn.timeline.html
  113. +141 −0 plugins/timeline/popcorn.timeline.js
  114. +43 −0 plugins/timeline/popcorn.timeline.unit.html
  115. +65 −0 plugins/timeline/popcorn.timeline.unit.js
  116. 0 plugins/twitter/popcorn.twitter.html
  117. +1 −1 plugins/twitter/popcorn.twitter.js
  118. 0 plugins/twitter/popcorn.twitter.unit.html
  119. 0 plugins/twitter/popcorn.twitter.unit.js
  120. 0 plugins/webpage/popcorn.webpage.js
  121. 0 plugins/webpage/popcorn.webpage.unit.html
  122. 0 plugins/webpage/popcorn.webpage.unit.js
  123. 0 plugins/wikipedia/popcorn.wikipedia.html
  124. +62 −21 plugins/wikipedia/popcorn.wikipedia.js
  125. 0 plugins/wikipedia/popcorn.wikipedia.unit.html
  126. +27 −21 plugins/wikipedia/popcorn.wikipedia.unit.js
  127. 0 plugins/wordriver/popcorn.wordriver.html
  128. +35 −4 plugins/wordriver/popcorn.wordriver.js
  129. 0 plugins/wordriver/popcorn.wordriver.unit.html
  130. +11 −3 plugins/wordriver/popcorn.wordriver.unit.js
  131. +348 −184 popcorn.js
  132. +40 −10 readme.md
  133. +872 −153 test/popcorn.unit.js
View
1 AUTHORS
@@ -18,3 +18,4 @@ Mohammed Buttu
Cole Gillespie
Nick Doiron
Bobby Richter
+Jon Buckley
View
84 Makefile
@@ -5,9 +5,10 @@ DIST_DIR = ${PREFIX}/dist
PLUGINS_DIR = ${PREFIX}/plugins
PARSERS_DIR = ${PREFIX}/parsers
PLAYERS_DIR = ${PREFIX}/players
+EFFECTS_DIR = $(PREFIX)/effects
-#Version
-VERSION ?= $(error Specify a version for your release (e.g., VERSION=0.5))
+# Version number used in naming release files. Defaults to git commit sha.
+VERSION ?= $(shell git show -s --pretty=format:%h)
RHINO ?= java -jar ${BUILD_DIR}/js.jar
@@ -38,15 +39,34 @@ PARSERS_MIN = ${DIST_DIR}/popcorn.parsers.min.js
PLAYERS_DIST = ${DIST_DIR}/popcorn.players.js
PLAYERS_MIN = ${DIST_DIR}/popcorn.players.min.js
+# effects
+EFFECTS_DIST = $(DIST_DIR)/popcorn.effects.js
+EFFECTS_MIN = $(DIST_DIR)/popcorn.effects.min.js
+
# Grab all popcorn.<plugin-name>.js files from plugins dir
PLUGINS_SRC := $(filter-out %unit.js, $(shell find ${PLUGINS_DIR} -name 'popcorn.*.js' -print))
-# Grab all popcorn.<plugin-name>.js files from plugins dir
+# Grab all popcorn.<plugin-name>.js files from parsers dir
PARSERS_SRC := $(filter-out %unit.js, $(shell find ${PARSERS_DIR} -name 'popcorn.*.js' -print))
# Grab all popcorn.<player-name>.js files from players dir
PLAYERS_SRC := $(filter-out %unit.js, $(shell find ${PLAYERS_DIR} -name 'popcorn.*.js' -print))
+# Grab all popcorn.<effect-name>.js files from players dir
+EFFECTS_SRC := $(filter-out %unit.js, $(shell find $(EFFECTS_DIR) -name 'popcorn.*.js' -print))
+
+# Grab all popcorn.<player-name>.unit.js files from plugins dir
+PLUGINS_UNIT := $(shell find ${PLUGINS_DIR} -name 'popcorn.*.unit.js' -print)
+
+# Grab all popcorn.<player-name>.unit.js files from parsers dir
+PARSERS_UNIT := $(shell find ${PARSERS_DIR} -name 'popcorn.*.unit.js' -print)
+
+# Grab all popcorn.<player-name>.unit.js files from players dir
+PLAYERS_UNIT := $(shell find ${PLAYERS_DIR} -name 'popcorn.*.unit.js' -print)
+
+# Grab all popcorn.<effects>.unit.js files from players dir
+EFFECTS_UNIT := $(shell find $(EFFECTS_DIR) -name 'popcorn.*.unit.js' -print)
+
# popcorn + plugins
POPCORN_COMPLETE_LIST := --js ${POPCORN_SRC} \
$(shell for js in ${PLUGINS_SRC} ; do echo --js $$js ; done) \
@@ -59,7 +79,10 @@ POPCORN_COMPLETE_MIN = ${DIST_DIR}/popcorn-complete.min.js
add_license = cat ${PREFIX}/LICENSE_HEADER | sed -e 's/@VERSION/${VERSION}/' > $(2) ; \
cat $(1) >> $(2)
-all: setup lint lint-plugins lint-parsers lint-players popcorn plugins parsers players complete min
+# Run the file through jslint
+run_lint = @@$(RHINO) build/jslint-check.js $(1)
+
+all: setup lint lint-plugins lint-parsers lint-players lint-effects popcorn plugins parsers players effects complete min
@@echo "Popcorn build complete."
${DIST_DIR}:
@@ -71,15 +94,15 @@ ${POPCORN_DIST}: ${POPCORN_SRC} | ${DIST_DIR}
@@echo "Building" ${POPCORN_DIST}
@@$(call add_license, $(POPCORN_SRC), $(POPCORN_DIST))
-min: ${POPCORN_MIN} ${PLUGINS_MIN} ${PARSERS_MIN} ${PLAYERS_MIN} ${POPCORN_COMPLETE_MIN}
+min: ${POPCORN_MIN} ${PLUGINS_MIN} ${PARSERS_MIN} ${PLAYERS_MIN} $(EFFECTS_MIN) ${POPCORN_COMPLETE_MIN}
${POPCORN_MIN}: ${POPCORN_DIST}
@@echo "Building" ${POPCORN_MIN}
@@$(call compile, --js ${POPCORN_DIST}, ${POPCORN_MIN}.tmp)
@@$(call add_license, ${POPCORN_MIN}.tmp, ${POPCORN_MIN})
@@rm ${POPCORN_MIN}.tmp
-${POPCORN_COMPLETE_MIN}: update ${POPCORN_SRC} ${PLUGINS_SRC} ${PARSERS_SRC} ${DIST_DIR}
+${POPCORN_COMPLETE_MIN}: update ${POPCORN_SRC} ${PLUGINS_SRC} ${PARSERS_SRC} $(EFFECTS_SRC) ${DIST_DIR}
@@echo "Building" ${POPCORN_COMPLETE_MIN}
@@$(call compile, ${POPCORN_COMPLETE_LIST}, ${POPCORN_COMPLETE_MIN}.tmp)
@@$(call add_license, ${POPCORN_COMPLETE_MIN}.tmp, ${POPCORN_COMPLETE_MIN})
@@ -115,27 +138,60 @@ ${PLAYERS_DIST}: ${PLAYERS_SRC} ${DIST_DIR}
@@echo "Building ${PLAYERS_DIST}"
@@cat ${PLAYERS_SRC} > ${PLAYERS_DIST}
-complete: update ${POPCORN_SRC} ${PARSERS_SRC} ${PLUGINS_SRC} ${PLAYERS_SRC} ${DIST_DIR}
- @@echo "Building popcorn + plugins + parsers + players..."
- @@cat ${POPCORN_SRC} ${PLUGINS_SRC} ${PARSERS_SRC} ${PLAYERS_SRC} > ${POPCORN_COMPLETE_DIST}.tmp
+effects: $(EFFECTS_DIST)
+
+$(EFFECTS_MIN): $(EFFECTS_DIST)
+ @@echo "Building" $(EFFECTS_MIN)
+ @@$(call compile, $(shell for js in $(EFFECTS_SRC) ; do echo --js $$js ; done), $(EFFECTS_MIN))
+
+$(EFFECTS_DIST): $(EFFECTS_SRC) $(DIST_DIR)
+ @@echo "Building $(EFFECTS_DIST)"
+ @@cat $(EFFECTS_SRC) > $(EFFECTS_DIST)
+
+complete: update ${POPCORN_SRC} ${PARSERS_SRC} ${PLUGINS_SRC} ${PLAYERS_SRC} $(EFFECTS_SRC) ${DIST_DIR}
+ @@echo "Building popcorn + plugins + parsers + players + effects..."
+ @@cat ${POPCORN_SRC} ${PLUGINS_SRC} ${PARSERS_SRC} ${PLAYERS_SRC} $(EFFECTS_SRC) > ${POPCORN_COMPLETE_DIST}.tmp
@@$(call add_license, ${POPCORN_COMPLETE_DIST}.tmp, ${POPCORN_COMPLETE_DIST})
@@rm ${POPCORN_COMPLETE_DIST}.tmp
lint:
@@echo "Checking Popcorn against JSLint..."
- @@${RHINO} build/jslint-check.js popcorn.js
+ @@$(call run_lint,popcorn.js)
lint-plugins:
@@echo "Checking all plugins against JSLint..."
- @@${RHINO} build/jslint-check.js ${PLUGINS_SRC}
+ @@$(call run_lint,$(PLUGINS_SRC))
lint-parsers:
@@echo "Checking all parsers against JSLint..."
- @@${RHINO} build/jslint-check.js ${PARSERS_SRC}
+ @@$(call run_lint,$(PARSERS_SRC))
lint-players:
@@echo "Checking all players against JSLint..."
- @@${RHINO} build/jslint-check.js ${PLAYERS_SRC}
+ @@$(call run_lint,$(PLAYERS_SRC))
+
+lint-effects:
+ @@echo "Checking all effects against JSLint..."
+ @@$(call run_lint,$(EFFECTS_SRC))
+
+lint-plugin-tests:
+ @@echo "Checking plugin unit tests against JSLint..."
+ @@$(call run_lint,$(PLUGINS_UNIT))
+
+lint-parser-tests:
+ @@echo "Checking parser unit tests against JSLint..."
+ @@$(call run_lint,$(PARSERS_UNIT))
+
+lint-effects-tests:
+ @@echo "Checking effectsr unit tests against JSLint..."
+ @@$(call run_lint,$(EFFECTS_UNIT))
+
+lint-player-tests:
+ @@echo "Checking player unit tests against JSLint..."
+ @@$(call run_lint,$(PLAYERS_UNIT))
+
+lint-unit-tests: lint-plugin-tests lint-parser-tests lint-player-tests lint-effects-tests
+ @@echo "completed"
# Create a mirror copy of the tree in dist/ using popcorn-complete.js
# in place of popcorn.js.
@@ -157,6 +213,7 @@ testing: complete
$(call overwrite_js, ${TESTING_MIRROR}/plugins)
$(call overwrite_js, ${TESTING_MIRROR}/players)
$(call overwrite_js, ${TESTING_MIRROR}/parsers)
+ $(call overwrite_js, ${TESTING_MIRROR}/effects)
@@cp ${POPCORN_COMPLETE_DIST} ${TESTING_MIRROR}/popcorn.js
clean:
@@ -176,4 +233,3 @@ update:
${SEQUENCE_SRC}:
@@echo "Setting-up submodules..."
@@git submodule init
-
View
284 demos/semantic_video/index.html
@@ -17,6 +17,7 @@
<script src="../../plugins/flickr/popcorn.flickr.js"></script>
<script src="../../plugins/attribution/popcorn.attribution.js"></script>
<script src="../../plugins/lastfm/popcorn.lastfm.js"></script>
+ <script src="popcorn.applyclass.js"></script>
<script src="../../parsers/parserXML/popcorn.parserXML.js"></script>
@@ -108,290 +109,11 @@
<div class="left-content">
<!-- Start Video Div -->
<div id="videoContainer" class="video-div">
- <div id="credits" style="display:none">
- <div id="credit_inner">
- </div>
- </div>
- <script>
-/*
- ////////////////////////////////////////////////////////////////////////////
- // Credits
- ////////////////////////////////////////////////////////////////////////////
-
- $("#credits")
- .width(530)
- .height(299);
- var displayCredits = function() {
- $("#credits").show();
- $("#choices").animate({ right:'+=200px' }, 1000);
- add( [
- {
- text: "Play Again",
- click:function() {
- killCol(0);
- $('video')[0].currentTime=0;
- }
- },
- {
- text: "People",
- next :[
- {
- text: "Steve Song", href: "http://www.google.ca/"
- },
- {
- text: "Jeffrey Warren"
- },
- {
- text: "Michael Adeyeye"
- },
- {
- text: "Charlie Schmidt"
- },
- {
- text: "Jonathan Zittrain"
- },
- {
- text: "Mona Kasra"
- },
- {
- text: "Noah Workman"
- },
- {
- text: "Wilken Sanches"
- },
- {
- text: "Keechang Kim"
- },
- {
- text: "Celine Celines"
- }
- ]
- },
- {
- text: "Places",
- next: [
- {
- text: "Sao Paulo", href: "http://en.wikipedia.org/wiki/S%C3%A3o_Paulo"
- },
- {
- text: "Cape Town", href: "http://en.wikipedia.org/wiki/Cape_Town"
- },
- {
- text: "Grande Isle, Louisiana", href: "http://en.wikipedia.org/wiki/Grand_Isle,_Louisiana"
- },
- {
- text: "MIT Media Lab", href: "http://www.media.mit.edu/"
- },
- {
- text: "Austin, Texas", href: "http://en.wikipedia.org/wiki/Austin,_Texas"
- },
- {
- text: "New York, New York", href: "http://en.wikipedia.org/wiki/New_York_City"
- },
- {
- text: "Seoul, Republic of South Korea", href: "http://en.wikipedia.org/wiki/Seoul"
- },
- {
- text: "Montreal, Quebec", href: "http://en.wikipedia.org/wiki/Montreal"
- },
- {
- text: "Harvard Law School", href: "http://www.law.harvard.edu/index.html"
- }
- ]
- },
- {
- text: "Articles",
- next: [
- {
- text: "The Internet", href: "http://en.wikipedia.org/wiki/internet"
- },
- {
- text: "The Village Telco", href: "http://en.wikipedia.org/wiki/Village_telco"
- },
- {
- text: "Deepwater Horizon Oil Spill", href: "http://en.wikipedia.org/wiki/Deepwater_Horizon_oil_spill"
- },
- {
- text: "Jonathan Zittrain", href: "http://en.wikipedia.org/wiki/Jonathan_Zittrain"
- },
- {
- text: "Compuserve", href: "http://en.wikipedia.org/wiki/Compuserve"
- },
- {
- text: "AOL", href: "http://en.wikipedia.org/wiki/AOL"
- },
- {
- text: "Prodigy", href: "http://en.wikipedia.org/wiki/Prodigy_%28online_service%29"
- },
- {
- text: "Internet Protocol", href: "http://en.wikipedia.org/wiki/Internet_Protocol"
- },
- {
- text: "Tim Berners-Lee", href: "http://en.wikipedia.org/wiki/Tim_Berners-Lee"
- },
- {
- text: "World Wide Web", href: "http://en.wikipedia.org/wiki/World_wide_web"
- },
- {
- text: "Wikipedia", href: "http://en.wikipedia.org/wiki/Wikipedia"
- },
- {
- text: "Open Standards", href: "http://en.wikipedia.org/wiki/Open_Standards"
- }
- ]
- },
- {
- text: "Developers",
- next: [
- {
- text: "Brett Gaylor",
- next: [
- { text: "Twitter", href: "http://twitter.com/remixmanifesto"},
- { text: "Email", href: "mailto:brett@eyesteelfilm.com"}
- ]
- },
- {
- text: "Scott Downe",
- next: [{ text: "Email", href: "mailto:scott.downe@senecac.on.ca" }]
- },
-
- {
- text: "Nick Cammarata",
- next: [
- { text: "Twitter", href: "http://twitter.com/nicklovescode"},
- { text: "Email", href: "mailto:nick@nickcammarata.com"}
- ]
- },
- {
- text: "Anna Sobiepanek",
- next: [
- { text: "Twitter", href: "http://twitter.com/annasob"},
- { text: "Email", href: "mailto:anna.sobiepanek@gmail.com"}
- ]
- },
- {
- text: "Daniel Hodgin",
- next: [
- { text: "Twitter", href: "http://twitter.com/dhhodgin"},
- { text: "Email", href: "mailto:daniel.hodgin@senecac.on.ca"}
- ]
- },
- {
- text: "David Humphrey",
- next: [
- { text: "Twitter", href: "http://twitter.com/humphd"},
- { text: "Email", href: "mailto:david.humphrey@senecac.on.ca"}
- ]
- }
- ]
- },
- {
- text: "Sources",
- next: [
-
- ]
- }
- ]);
- };
- var removeCredits = function() {
- $("#choices").css("right","-200px");
- $("#credits").hide();
- };
- var colIndex = 0;
- var killCol = function(index, callback) {
- $(".column").each(function() {
- if ($(this).attr("colindex")>index) {
- $(this).addClass("removing").animate( { left: -$(this).outerWidth() + "px" }, 1200, function() {
- $(this).remove();
- });
- }
- });
- if (callback) {
- callback();
- }
- };
-
- var add = function(items) {
- colIndex++;
- var ul = $("<ul></ul>")
- .addClass('column')
- .attr('colindex',parseInt(colIndex, 10));
- $.each(items, function(i, val) {
- var li = $(document.createElement('li'))
- .append($(document.createElement('a'))
- .text(val.text)
- .attr("href",val.href||"#")
- .attr("target",val.href?"_blank":""))
- .appendTo(ul)
- .addClass('play')
- .click(function() {
- if (val.href) {
- return true;
- }
- var colIndex2 = $(this).parent().attr('colindex');
- if (colIndex>colIndex2) {
- killCol(colIndex2);
- colIndex = colIndex2;
- }
- var hasClass = $(this).hasClass('selected');
- if (!hasClass) {
- if (val.click) {
- val.click();
- }
- if (val.next) {
- add(val.next);
- }
- }
- $(this)
- .parent()
- .find('.selected')
- .removeClass('selected');
- if (!hasClass) {
- $(this).addClass('selected');
- }
- });
- });
- var width = 0;
- $(".column:not(.removing)").each(function() {
- width+=$(this).outerWidth();
- });
- ul
- .appendTo("#credit_inner")
- .css("z-index",1000 - colIndex)
- .css("left",-ul.outerWidth())
- .animate({
- left: width + "px"
- },750);
- };*/
- </script>
<video id="webmademovies" width="530" height="299" data-timeline-sources="xml/webMadeMovies.xml" controls loop>
- <source src="http://webmademovies.etherworks.ca/popcorndemo/wmmjuly6.ogv" type='video/ogg; codecs="theora, vorbis"'>
- <source src="http://webmademovies.etherworks.ca/popcorndemo/wmmjuly6.mp4" type='video/mp4; codecs="avc1.42E01E, mp4a.40.2"'>
+ <source src="http://videos.mozilla.org/serv/webmademovies/wmmjuly6.ogv" type='video/ogg; codecs="theora, vorbis"'>
+ <source src="http://videos.mozilla.org/serv/webmademovies/wmmjuly6.mp4" type='video/mp4; codecs="avc1.42E01E, mp4a.40.2"'>
</video>
<div id="overlaydiv" style="position:absolute;top:1px;left:1px"></div>
- <script>
- /*overlayDiv = document.getElementById("overlaydiv");
- var createImage = function(src) {
- var image = document.createElement('img');
- image.setAttribute('src', src);
- image.setAttribute('style', "display:none");
- overlayDiv.appendChild(image);
- return image;
- };
- popcorn.VideoManager.prototype.loaded = function() {
- for (var i in this.commandObjects) {
- if (this.commandObjects[i].name === 'flickr' || this.commandObjects[i].name === 'footnote' || this.commandObjects[i].name === 'location' || this.commandObjects[i].name === 'twitter' || this.commandObjects[i].name === 'wiki' || this.commandObjects[i].name === 'lastfm') {
- this.commandObjects[i].extension.image = createImage("images/overlay/" + this.commandObjects[i].name + ".png");
- this.commandObjects[i].extension.onIn = function() {
- this.image.setAttribute('style', "display:inline");
- };
- this.commandObjects[i].extension.onOut = function() {
- this.image.setAttribute('style', "display:none");
- };
- }
- }
- };*/
- </script>
<!-- Start Video Info -->
<div class="video-info">
<!-- Start Choose Language -->
View
85 demos/semantic_video/popcorn.applyclass.js
@@ -0,0 +1,85 @@
+// EFFECT: applyclass
+
+(function (Popcorn) {
+
+ /**
+ * apply css class to jquery selector
+ * selector is relative to plugin target's id
+ * so .overlay is actually jQuery( "#target .overlay")
+ *
+ * @param {Object} options
+ *
+ * Example:
+ var p = Popcorn('#video')
+ .footnote({
+ start: 5, // seconds
+ end: 15, // seconds
+ text: 'This video made exclusively for drumbeat.org',
+ target: 'footnotediv',
+ effect: 'applyclass',
+ applyclass: 'selector: class'
+ })
+ *
+ */
+
+ Popcorn.compose( "applyclass", {
+
+ manifest: {
+ about: {
+ name: "Popcorn applyclass Effect",
+ version: "0.1",
+ author: "@scottdowne",
+ website: "scottdowne.wordpress.com"
+ },
+ options: {}
+ },
+ _setup: function( options ) {
+
+ options.classes = {};
+ options.applyclass = options.applyclass || "";
+
+ var classes = options.applyclass.replace( /\s/g, "" ).split( "," ),
+ item = [],
+ idx = 0, len = classes.length;
+
+ for ( ; idx < len; idx++ ) {
+
+ item = classes[ idx ].split( ":" );
+
+ if ( item[ 0 ] ) {
+ options.classes[ item[ 0 ] ] = item[ 1 ] || "";
+ }
+ }
+ },
+ start: function( event, options ) {
+
+ var idx = 0, len = 0, elements;
+
+ Popcorn.forEach( options.classes, function( key, val ) {
+
+ elements = [];
+
+ if ( key === "parent" ) {
+
+ var item = document.querySelectorAll("#" + options.target )[ 0 ];
+
+ item && item.parentNode && elements.push( item.parentNode );
+ } else {
+
+ elements = document.querySelectorAll("#" + options.target + " " + key );
+ }
+
+ for ( idx = 0, len = elements.length; idx < len; idx++ ) {
+
+ var element = elements[ idx ];
+ element.classList.toggle( val );
+
+ setTimeout( function() {
+
+ element.classList.toggle( val );
+ }, 250 );
+ }
+ });
+ }
+ });
+})( Popcorn );
View
3 demos/semantic_video/style.css
@@ -423,9 +423,8 @@ border: 1px solid #d9d9d9;
margin-bottom: 15px;
}
-.overlay{
+.applyoverlay{
z-index: 9001;
-display: none;
top: 0px;
left: 0px;
opacity: 0.2;
View
2 demos/semantic_video/xml/webMadeMovies.xml
@@ -81,7 +81,7 @@
</articles>
</manifest>
- <timeline>
+ <timeline applyclass="applyoverlay: .overlay, hover: parent" effect="applyclass">
<footnotes>
<footnote in="00:00:00" out="00:14:00" target="footnotediv">Look around the page as info is updated!</footnote>
View
61 effects/applyclass/popcorn.applyclass.html
@@ -0,0 +1,61 @@
+<!DOCTYPE html>
+<html>
+<head>
+ <title>Popcorn flash effect Demo</title>
+
+ <script src="../../popcorn.js"></script>
+ <script src="../../plugins/footnote/popcorn.footnote.js"></script>
+ <script src="popcorn.applyclass.js"></script>
+ <link href="style.css" rel="stylesheet" type="text/css" />
+ <script>
+ document.addEventListener( "DOMContentLoaded", function () {
+
+ var p = Popcorn( "#video" )
+ .play()
+ .footnote({
+ start: 5, // seconds
+ end: 15, // seconds
+ target: "footnotediv",
+ text: "This video made exclusively for drumbeat.org",
+ effect: "applyclass",
+ applyclass: "test1, test2"
+ })
+ .footnote({
+ start: 20, // seconds
+ end: 45, // seconds
+ target: "footnotediv",
+ text: "Visit webmademovies.org for more details",
+ effect: "applyclass",
+ applyclass: "applyoverlay: .overlay, hover: parent"
+ });
+ }, false);
+
+ </script>
+</head>
+<body>
+ <h1 id="qunit-header">Popcorn flash effect Demo</h1>
+ <p> A footnote with a css class displaying This video made exclusively for drumbeat.org' will appear at 5 seconds and disappear at 15 seconds.</p>
+ <p> A footnote with a css class displaying 'Visit webmademovies.org for more details' will appear at 20 seconds and disappear at 45 seconds.</p>
+ <div>
+ <video id='video'
+ controls preload='none'
+ width='250px'
+ poster="../../test/poster.png">
+
+ <source id='mp4'
+ src="../../test/trailer.mp4"
+ type='video/mp4; codecs="avc1, mp4a"'>
+
+ <source id='ogv'
+ src="../../test/trailer.ogv"
+ type='video/ogg; codecs="theora, vorbis"'>
+
+ <p>Your user agent does not support the HTML5 Video element.</p>
+
+ </video>
+ </div>
+ <section>
+ <div id="footnotediv"><div class="overlay"></div></div>
+ </section>
+</body>
+</html>
View
80 effects/applyclass/popcorn.applyclass.js
@@ -0,0 +1,80 @@
+// EFFECT: applyclass
+
+(function (Popcorn) {
+
+ /**
+ * apply css class to jquery selector
+ * selector is relative to plugin target's id
+ * so .overlay is actually jQuery( "#target .overlay")
+ *
+ * @param {Object} options
+ *
+ * Example:
+ var p = Popcorn('#video')
+ .footnote({
+ start: 5, // seconds
+ end: 15, // seconds
+ text: 'This video made exclusively for drumbeat.org',
+ target: 'footnotediv',
+ effect: 'applyclass',
+ applyclass: 'selector: class'
+ })
+ *
+ */
+
+ var toggleClass = function( event, options ) {
+
+ var idx = 0, len = 0, elements;
+
+ Popcorn.forEach( options.classes, function( key, val ) {
+
+ elements = [];
+
+ if ( key === "parent" ) {
+
+ elements[ 0 ] = document.querySelectorAll("#" + options.target )[ 0 ].parentNode;
+ } else {
+
+ elements = document.querySelectorAll("#" + options.target + " " + key );
+ }
+
+ for ( idx = 0, len = elements.length; idx < len; idx++ ) {
+
+ elements[ idx ].classList.toggle( val );
+ }
+ });
+ };
+
+ Popcorn.compose( "applyclass", {
+
+ manifest: {
+ about: {
+ name: "Popcorn applyclass Effect",
+ version: "0.1",
+ author: "@scottdowne",
+ website: "scottdowne.wordpress.com"
+ },
+ options: {}
+ },
+ _setup: function( options ) {
+
+ options.classes = {};
+ options.applyclass = options.applyclass || "";
+
+ var classes = options.applyclass.replace( /\s/g, "" ).split( "," ),
+ item = [],
+ idx = 0, len = classes.length;
+
+ for ( ; idx < len; idx++ ) {
+
+ item = classes[ idx ].split( ":" );
+
+ if ( item[ 0 ] ) {
+ options.classes[ item[ 0 ] ] = item[ 1 ] || "";
+ }
+ }
+ },
+ start: toggleClass,
+ end: toggleClass
+ });
+})( Popcorn );
View
36 effects/applyclass/style.css
@@ -0,0 +1,36 @@
+.applyoverlay {
+ z-index: 9001;
+ top: 0px;
+ left: 0px;
+ opacity: 0.2;
+ filter: alpha(opacity=20);
+ height: 100%;
+ width: 100%;
+ background: red;
+ position: absolute;
+}
+
+section {
+ display: inline-block;
+}
+
+section.hover {
+ -webkit-box-shadow: -1px 1px 1px #bdc7c6;
+ -moz-box-shadow: -1px 1px 1px #bdc7c6;
+ box-shadow: -1px 1px 1px #bdc7c6;
+ border: 1px solid #333;
+ -moz-transform: scale(1.02);-webkit-transform: scale(1.02);
+ z-index: 999;
+ background: #FFF;
+}
+
+.test1 {
+ background: green
+}
+
+.test2 {
+ -webkit-box-shadow: -1px 1px 1px #bdc7c6;
+ -moz-box-shadow: -1px 1px 1px #bdc7c6;
+ box-shadow: -1px 1px 1px #bdc7c6;
+ border: 1px solid #333;
+}
View
1 parsers/parserSBV/popcorn.parserSBV.unit.html
@@ -26,7 +26,6 @@ <h2 id="qunit-userAgent"></h2>
<video id='video'
controls
width= '250px'
- data-timeline-sources="data/data.sbv"
poster="../../test/poster.png">
<source id='mp4'
View
2 parsers/parserSBV/popcorn.parserSBV.unit.js
@@ -29,7 +29,7 @@ test( "Popcorn 0.3 SBV Parser Plugin", function () {
}
}
- poppercorn.parseSBV( document.getElementById( "video" ).getAttribute( "data-timeline-sources" ) );
+ poppercorn.parseSBV( "data/data.sbv" );
expect(expects);
View
3 parsers/parserSRT/popcorn.parserSRT.unit.html
@@ -26,7 +26,6 @@ <h2 id="qunit-userAgent"></h2>
<video id='video'
controls
width="250px"
- data-timeline-sources="./data/unit.srt"
poster="../../test/poster.png">
<source id='mp4'
@@ -41,4 +40,4 @@ <h2 id="qunit-userAgent"></h2>
</video>
</body>
-</html>
+</html>
View
4 parsers/parserSRT/popcorn.parserSRT.unit.js
@@ -74,7 +74,7 @@ test("Popcorn 0.3 SRT Parser Plugin", function () {
}
}
- poppercorn.parseSRT( document.getElementById( 'video' ).getAttribute( 'data-timeline-sources' ) );
+ poppercorn.parseSRT( "data/unit.srt" );
expects = expectedSubs.length*4+1;
expect( expects );
@@ -105,4 +105,4 @@ test("Popcorn 0.3 SRT Parser Plugin", function () {
}, 500);
-});
+});
View
1 parsers/parserSSA/popcorn.parserSSA.unit.html
@@ -26,7 +26,6 @@ <h2 id="qunit-userAgent"></h2>
<video id='video'
controls
width= '250px'
- data-timeline-sources="data/data.ssa"
poster="../../test/poster.png">
<source id='mp4'
View
2 parsers/parserSSA/popcorn.parserSSA.unit.js
@@ -29,7 +29,7 @@ test( "Popcorn 0.3 SSA/ASS Parser Plugin", function () {
}
}
- poppercorn.parseSSA( document.getElementById( "video" ).getAttribute( "data-timeline-sources" ) );
+ poppercorn.parseSSA( "data/data.ssa" );
expect( expects );
stop( 5000 );
View
1 parsers/parserTTML/popcorn.parserTTML.unit.html
@@ -26,7 +26,6 @@ <h2 id="qunit-userAgent"></h2>
<video id='video'
controls
width= '250px'
- data-timeline-sources="data/unit.ttml"
poster="../../test/poster.png">
<source id='mp4'
View
2 parsers/parserTTML/popcorn.parserTTML.unit.js
@@ -73,7 +73,7 @@ test( "Popcorn 0.3 TTML Parser Plugin", function () {
}
}
- poppercorn.parseTTML( document.getElementById( 'video' ).getAttribute( "data-timeline-sources" ) );
+ poppercorn.parseTTML( "data/unit.ttml" );
expect( expects );
stop( 5000 );
View
1 parsers/parserTTXT/popcorn.parserTTXT.unit.html
@@ -26,7 +26,6 @@ <h2 id="qunit-userAgent"></h2>
<video id='video'
controls
width= '250px'
- data-timeline-sources="data/unit.TTXT"
poster="../../test/poster.png">
<source id='mp4'
View
2 parsers/parserTTXT/popcorn.parserTTXT.unit.js
@@ -29,7 +29,7 @@ test("Popcorn 0.3 TTXT Parser Plugin", function () {
}
}
- poppercorn.parseTTXT(document.getElementById('video').getAttribute('data-timeline-sources'));
+ poppercorn.parseTTXT( "data/unit.TTXT" );
expects = subs.length*3+1;
expect(expects);
View
3 parsers/parserVTT/popcorn.parserVTT.unit.html
@@ -26,7 +26,6 @@ <h2 id="qunit-userAgent"></h2>
<video id='video'
controls
width= '250px'
- data-timeline-sources="data/unit.vtt"
poster="../../test/poster.png">
<source id='mp4'
@@ -41,4 +40,4 @@ <h2 id="qunit-userAgent"></h2>
</video>
</body>
-</html>
+</html>
View
4 parsers/parserVTT/popcorn.parserVTT.unit.js
@@ -38,7 +38,7 @@ test( "Popcorn 0.3 WebSRT/VTT Parser Plugin", function () {
}
}
- poppercorn.parseVTT( document.getElementById( 'video' ).getAttribute( 'data-timeline-sources' ) );
+ poppercorn.parseVTT( "data/unit.vtt" );
expect( expects );
stop( 5000 );
@@ -64,4 +64,4 @@ test( "Popcorn 0.3 WebSRT/VTT Parser Plugin", function () {
}, 500);
-});
+});
View
10 parsers/parserXML/popcorn.parserXML.unit.js
@@ -53,11 +53,9 @@ test("Popcorn 0.1 XML Parser Plugin", function () {
end: function ( event, options ) {}
});
- poppercorn.parseXML("data/unit.XML");
+ poppercorn.parseXML( "data/unit.XML", function() {
- // interval used to wait for data to be parsed
- interval = setInterval( function() {
- poppercorn.currentTime(5).play().currentTime(6);
- }, 2000);
-
+ poppercorn.currentTime(5);
+ });
});
+
View
2 players/baseplayer/popcorn.baseplayer.html
@@ -87,4 +87,4 @@
This demo showcases basic functionality of a player. It is a shell of an HTMLMediaElement with basic timing routines.<br />
At 2 seconds, the phrase "2 seconds reached" will appear beside 'Event Output'<br />
</body>
-</html>
+</html>
View
30 players/baseplayer/popcorn.baseplayer.js
@@ -6,6 +6,7 @@
Popcorn.baseplayer.init = function() {
this.readyState = 0;
this.currentTime = 0;
+ this.baselineTime = new Date();
this.duration = 0;
this.paused = 1;
this.ended = 0;
@@ -45,19 +46,20 @@
},
timeupdate: function() {
- // The player was paused since the last time update
- if ( this.paused ) {
- return;
- }
// So we can refer to the instance when setTimeout is run
var self = this;
- this.currentTime += 0.015;
- this.dispatchEvent( "timeupdate" );
- setTimeout( function() {
+ if( !this.paused ) {
+ this.currentTime += ( new Date() - this.baselineTime ) / 1000;
+ this.dispatchEvent( "timeupdate" );
+ }
+
+ this.baselineTime = new Date();
+
+ setTimeout(function() {
self.timeupdate.call( self );
- }, 15 );
+ }, 50 );
},
// By default, assumes this.resource is a DOM Element
@@ -68,11 +70,11 @@
// Add an event listener to the object
addEventListener: function( evtName, fn ) {
- if ( !this._events[evtName] ) {
- this._events[evtName] = [];
+ if ( !this._events[ evtName ] ) {
+ this._events[ evtName ] = [];
}
- this._events[evtName].push( fn );
+ this._events[ evtName ].push( fn );
return fn;
},
@@ -94,7 +96,7 @@
}
}
- Popcorn.forEach( this._events[eventName], function( val ) {
+ Popcorn.forEach( this._events[ eventName ], function( val ) {
val.call( self, evt, self );
});
},
@@ -127,13 +129,13 @@
if ( elem.currentStyle ) {
// IE syntax
- return elem.currentStyle[prop];
+ return elem.currentStyle[ prop ];
} else if ( global.getComputedStyle ) {
// Firefox, Chrome et. al
return doc.defaultView.getComputedStyle( elem, null ).getPropertyValue( prop );
} else {
// Fallback, just in case
- return elem.style[prop];
+ return elem.style[ prop ];
}
}
};
View
27 players/baseplayer/popcorn.baseplayer.unit.html
@@ -32,6 +32,15 @@
height: 250px;
background: #FFAAAA;
}
+
+ #video {
+ position: absolute;
+ left:620px;
+ top: 260px;
+ width: 300px;
+ height: 175px;
+ background: #FFAAAA;
+ }
</style>
</head>
<body>
@@ -43,5 +52,23 @@ <h2 id="qunit-userAgent"></h2>
<div id="qunit-fixture"> </div>
<span id="player_1">This is a container for the player, auto-sized for testing purposes.</span>
+ <div >
+ <video id='video'
+ controls
+ width= '250px'
+ poster="../../test/poster.png">
+
+ <source id='mp4'
+ src="../../test/trailer.mp4"
+ type='video/mp4; codecs="avc1, mp4a"'>
+
+ <source id='ogv'
+ src="../../test/trailer.ogv"
+ type='video/ogg; codecs="theora, vorbis"'>
+
+ <p>Your user agent does not support the HTML5 Video element.</p>
+
+ </video>
+ </div>
</body>
</html>
View
27 players/baseplayer/popcorn.baseplayer.unit.js
@@ -55,7 +55,7 @@ test( "API", function () {
stop( 10000 );
Popcorn.forEach( members, function ( type, prop ) {
- ok( typeof player[prop] === type, "player." + prop + " is type: " + type );
+ ok( typeof player[ prop ] === type, "player." + prop + " is type: " + type );
plus();
});
});
@@ -78,18 +78,18 @@ test( "Default Functionality", function () {
}
}
- player._resource = document.getElementById('player_1');
+ player._resource = document.getElementById( 'player_1' );
dimensions = player.getBoundingClientRect();
Popcorn.forEach( expectedVals, function() {
- expects+= 2;
+ expects += 2;
});
expect( expects );
stop( 1000 );
Popcorn.forEach( expectedVals, function( val, prop ) {
- equals( player.getStyle( prop ), val+'px', "Style '" + prop + "' correctly got" );
+ equals( player.getStyle( prop ), val + 'px', "Style '" + prop + "' correctly got" );
plus();
equals( dimensions[prop], val, "Bounding Client " + prop + " works" );
@@ -119,16 +119,16 @@ test( "Default Functionality", function () {
player.pause();
});
-
player.play();
});
test( "Extension and Method Overriding", function () {
- var expects = 4,
+ var expects = 5,
count = 0,
player = Popcorn.baseplayer(),
playerForPopcorn = Popcorn.baseplayer(),
+ player2 = Popcorn("#video"),
popcorn;
function plus() {
@@ -137,7 +137,7 @@ test( "Extension and Method Overriding", function () {
}
}
- expect(expects);
+ expect( expects );
stop( 4000 );
Popcorn.extend( player, {
@@ -150,7 +150,7 @@ test( "Extension and Method Overriding", function () {
plus();
// Must dispatch event so event listeners can work!
- this.dispatchEvent("timeupdate");
+ this.dispatchEvent( "timeupdate" );
// We don't want to cue custom timing loop using setTimeout because we only want this to run once
}
@@ -162,12 +162,15 @@ test( "Extension and Method Overriding", function () {
});
popcorn = Popcorn( playerForPopcorn )
- .exec( 2, function() {
- ok( true, "Exec triggereed from popcorn after 2 seconds" );
- plus();
- });
+ .exec( 2, function() {
+ ok( Math.abs( player2.currentTime() - playerForPopcorn.currentTime ) < 0.2, "Time update is within a reasonable range" );
+ plus();
+ ok( true, "Exec triggereed from popcorn after 2 seconds" );
+ plus();
+ });
player.load();
+ player2.play();
player.play();
// Each player will define its own criteria for when readyState should be changed
2 players/sequence
@@ -1 +1 @@
-Subproject commit ab2f0e346f9945eecc2e97b27aa35ab3c876bd62
+Subproject commit 01eb7df20bc9e58c9cab108789f7b4ea7c347925
View
4 players/youtube/popcorn.youtube.html
@@ -22,7 +22,7 @@
var paused = true,
popcorn;
- popcorn = Popcorn( Popcorn.youtube( 'video', 'http://www.youtube.com/watch?v=9oar9glUCL0', { width: 400 } ) );
+ popcorn = Popcorn( Popcorn.youtube( 'video', 'http://www.youtube.com/watch?v=9oar9glUCL0', { width: 400, controls: 0, annotations: 3 } ) );
popcorn = popcorn
.footnote({
@@ -102,7 +102,7 @@
paused = true;
element( 'btn-play-pause' ).innerHTML = 'Play';
})
- .mute()
+ popcorn.mute()
.play();
// Setup UI after loaded
View
21 players/youtube/popcorn.youtube.js 100644 → 100755
@@ -120,13 +120,17 @@ var onYouTubePlayerReady;
this.offsetParent = container.offsetParent;
flashvars = {
- playerapiid: this.playerId
+ playerapiid: this.playerId,
+ controls: this.controls,
+ iv_load_policy: this.iv_load_policy
};
+
params = {
allowscriptaccess: 'always',
allowfullscreen: 'true',
// This is so we can overlay html on top of Flash
wmode: 'transparent'
+
};
attributes = {
@@ -147,6 +151,7 @@ var onYouTubePlayerReady;
// Video hadn't loaded yet when ctor was called
vid.video = document.getElementById( playerId );
vid.duration = vid.video.getDuration();
+
// Issue load event
vid.dispatchEvent( 'load' );
@@ -174,12 +179,19 @@ var onYouTubePlayerReady;
this.loadStarted = false;
this.loadedData = false;
this.fullyLoaded = false;
+ this.paused = false;
// If supplied as number, append 'px' on end
// If suppliied as '###' or '###px', convert to number and append 'px' back on end
options.width = options.width && (+options.width)+"px";
options.height = options.height && (+options.height)+"px";
+ // show controls on video. Integer value - 1 is for show, 0 is for hide
+ this.controls = +options.controls === 0 || +options.controls === 1 ? options.controls : 1;
+
+ // show video annotations, 1 is show, 3 is hide
+ this.iv_load_policy = +options.annotations === 1 || +options.annotations === 3 ? options.annotations : 1;
+
this._target = document.getElementById( elementId );
this._container = document.createElement( "div" );
this._container.id = this.playerId;
@@ -361,7 +373,10 @@ var onYouTubePlayerReady;
// Prevent Youtube's behaviour to start playing video after seeking.
if ( !playing ) {
+ this.video.paused = true;
this.video.pauseVideo();
+ } else {
+ this.video.paused = false;
}
// Data need to be loaded again.
@@ -463,7 +478,7 @@ var onYouTubePlayerReady;
},
startTimeUpdater: function() {
- var state = this.video.getPlayerState(),
+ var state = typeof this.video.getPlayerState != "function" ? this.readyState : this.video.getPlayerState(),
self = this,
seeked = 0;
@@ -474,7 +489,7 @@ var onYouTubePlayerReady;
seeked = 1;
} else {
this.previousCurrentTime = this.currentTime;
- this.currentTime = this.video.getCurrentTime();
+ this.currentTime = typeof this.video.getCurrentTime != "function" ? this.currentTime : this.video.getCurrentTime();
}
if ( this.volume !== this.previousVolume ) {
View
3 players/youtube/popcorn.youtube.unit.html
@@ -28,6 +28,9 @@ <h2 id="qunit-userAgent"></h2>
Therefore, if failures occur for the first time, just run it again. Likely,
failures would disappear the second time.
</p>
+ <p>
+ There will be two separate youtube videos visible after the completion of these tests.
+ </p>
<div id="video" style="width: 360px; height: 300px" ></div>
<div id="video2" style="width: 360px; height: 300px" ></div>
<div id="video3" style="width: 360px; height: 300px" ></div>
View
38 players/youtube/popcorn.youtube.unit.js
@@ -1,6 +1,4 @@
test( "Popcorn YouTube Plugin Event Tests", function() {
-
- var popcorn = Popcorn( Popcorn.youtube( 'video', "http://www.youtube.com/e/ac7KhViaVqc" ) );
function plus(){
if ( ++count == expects ) {
@@ -27,13 +25,14 @@ test( "Popcorn YouTube Plugin Event Tests", function() {
'ended'
];
- var count = 0,
+ var popcorn = Popcorn( Popcorn.youtube( 'video', "http://www.youtube.com/e/ac7KhViaVqc" ) ),
+ count = 0,
eventCount = 0,
added = [],
set1Executed = false,
set2Executed = false,
set3Executed = false,
- expects = expectedEvents.length + 5,
+ expects = expectedEvents.length + 6,
listeners = [];
stop( 15000 );
@@ -45,6 +44,8 @@ test( "Popcorn YouTube Plugin Event Tests", function() {
popcorn.exec(2, function() {
ok( popcorn.currentTime() >= 2, "Check time synchronization." );
plus();
+ ok( popcorn.video.paused == false, "Video is not paused" );
+ plus();
});
popcorn.exec(49, function() {
ok( popcorn.currentTime() >= 49, "Check time synchronization." );
@@ -236,3 +237,32 @@ test( "Popcorn YouTube Plugin Url Regex Test", function() {
start();
});
+test( "Controls and Annotations toggling", function() {
+
+ QUnit.reset();
+
+ expect( 6 );
+
+ var popcorn = Popcorn( Popcorn.youtube( "video", "http://www.youtube.com/watch?v=9oar9glUCL0" ) ),
+ targetDiv = document.getElementById( "video" );
+ testTarget = targetDiv.querySelector( "object" ).querySelector( "param:nth-of-type( 4 )" );
+
+ ok( /controls=1/.test( testTarget.value ), "controls are defaulted to 1 ( displayed )" );
+ ok( /iv_load_policy=1/.test( testTarget.value ), "annotations ( iv_load_policy ) are defaulted to ( enabled )" );
+
+ targetDiv.innerHTML = "";
+
+ popcorn = Popcorn( Popcorn.youtube( "video", "http://www.youtube.com/watch?v=9oar9glUCL0", { controls: 1, annotations: 1 } ) );
+ testTarget = targetDiv.querySelector( "object" ).querySelector( "param:nth-of-type( 4 )" );
+ ok( /controls=1/.test( testTarget.value ), "controls is set to 1 ( displayed )" );
+ ok( /iv_load_policy=1/.test( testTarget.value ), "annotations ( iv_load_policy ) is set to 1 ( enabled )" );
+
+ targetDiv.innerHTML = "";
+
+ popcorn = Popcorn( Popcorn.youtube( "video", "http://www.youtube.com/watch?v=9oar9glUCL0", { controls: 0, annotations: 3 } ) );
+ testTarget = targetDiv.querySelector( "object" ).querySelector( "param:nth-of-type( 4 )" );
+ ok( /controls=0/.test( testTarget.value ), "controls is set to 0 ( hidden )" );
+ ok( /iv_load_policy=3/.test( testTarget.value ), "annotations ( iv_load_policy ) is set to 3 ( hidden )" );
+
+});
+
View
0 plugins/attribution/popcorn.attribution.html 100644 → 100755
File mode changed.
View
113 plugins/attribution/popcorn.attribution.js 100644 → 100755
@@ -1,6 +1,6 @@
// PLUGIN: Attribution
-(function (Popcorn) {
+(function( Popcorn ) {
/**
* Attribution popcorn plug-in
@@ -28,56 +28,68 @@
*
*/
Popcorn.plugin( "attribution" , (function(){
- var licenses = {
- "cc-by": '',
- "cc-by-sa": '',
- "cc-by-nd": '',
- "cc-by-nc": '',
- "cc-by-nc-sa": '',
- "cc-by-nc-nd": ''
- };
+
+ var
+ common = "",
+ licenses = {
+ "cc-by": common + "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",
+ "cc-by-sa": common + "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",
+ "cc-by-nd": common + "grSURBVHja7FpNbBvHFf72R0YdROz6lBZsAQrogczFtB37aFF1AqR1bC1h2Jc0NXUqEKEgmTZqWkimaMupS9ilicJJA7fRojkHWvkH6B/MpRqgNSWLKzgAeSjAPURoe5IipYeKuzs97O5wl1xSFCWljeNnjHa5M/Ptzjdv3nvzxgwhJMAwzKd4KnsuhBCGAUAA4P4f74FlWbAsC47jwLIcOJYFy9lXlgXDsGAZBgzDAAzjoICAgJgEJjFhmlYxDMO6mgYMw4RpGrTOJCZtTwhxPobePwlyfvQCAIABQBxyOY6zCss17znOqmM5m2QGDMO6+bXJsYk1LTINwy7ue8NLsmmalFg30U8SyTwAL7kcD95ztcrd+XsoFosol8vY3Nj0AA0GBnHixAmMfHsEZ86+AsPkwLK6NSEGCwaMPZeu5WMSayXAXkNMd3KXFyuQP5RRrVY9zyORCMRzIo4eP7IrMvYLnwFA/vDg9+B5npLK87xVOB4lZQG5azmsrq72BBgMBjHx0wkMD5+EbhgwDB26bhdDh64bVMP9NLlVi//5j3/hVuEWatUaACAWiyEajQIAVFWFoigAgHAkjPHkOL729ed2RMB+4p8fvWAR/OfSn8BzfJNYfgADPI/M1DTkOZl2EAQBoigiFApheHgYAFAqlaBpGmRZxvr6Om0rxkX8eOJHOPjMQei6joauQ9cb0HXdazIcgk3blruI/mzjMyTHU9jY2IAoisjn8wiFQp5BaJqGdDoNWZYRCARwNXe1ZxL2G58S/OAvDzDgEDvAY4Af8JArCAJSqRSSySQEQegIKEkS0uk0JTocCeM379/GVw4ehK430Gg0qCb7ktxij6feuoRatYZEIoHZ2dnmsrNNi1vTJUnC2NgYwpEwrly73BMBnfA7jW2n+OdHL4AFAM62wTzHgee8mhuNRlGpVJDJZLqSCwCJRAL1ep0usVq1huu5Gx5bztKIhGkW+5+bwOXFCmrVGkRRxMSbb247mEQiAVEUUavWsLxY6cnm7ie+IywAsE5YxnEoKQsecovFYtuy6SaCIKBYLFKS5TkZpdICOI73J5l1wj54SJY/tL4hn88j8vzzrfGlr0PM5/Oevt2kG34n2Qm+h2BLgy0tzl3LUaJmZ2e31dpuJDt9cz/P2bG0TS5jx9SsHWEwaJJsL/9qtYpYLNY2uWNjY1Tzx8bGPHWhUAixWKwtEvATP/xvhYZ8Sz/4Xg22B393/h6NFlKpFNXCfkQQBDrjq6uruHvnHt2wWCR3NhGO+L1fkiTf+259Oklr25deftm39IsPwIqDHW0qFouUnGQySRspioJCoUCdVywWQyaT8a0bHR1FKpWidstxesUHRbxy5rStvbZpMJskOyaC4H+30Xj31+/uOaa10WAYsAyDcrlshViiSJe3oigYGRnxdFIUBYqiIJlMIh6Pt9WtrKxQryyKIiRJQrlctnaArItUNMltRuVNLFVVfZ2No7mJRKKt3q9PJ2lt6zYHbvm7Vu8Ln5oIZ8DODu3w4cO0QTqdpvanXq9Tp3fx4kVks1m6bOr1Oubm5jwxMgB6v7mx2TQH9Orw2m4iIpEIFEWBpmme5+5wqjW00jQNiqIgEolsO3A//FMvvehb+sH3aLDbubTaGWfGEokEQqEQJdpxOI6WOnWiKLY5nmb4Rf9s+2HiORHVmSrS6TTm5uZ6GoyjDOI5sS/8927f3jN8jwb/P8rR40cQjoQhy3JbtNBp8LIsIxwJ95Q32G98L8HEuyty2xlHmyVJwvr6OlRVxdDQELLZbDPWtbfJ7jr3smrGr/RPTx/3k59NIBAIQJIkxONxiuWOgzVNQzwex82bNxEIBDCeHO958J3wW81Ov/jURDgfPBgYxObGJlZWVmiDTCZDX37o0CHPi506VVXb6hxxsAYDgyDEtR0GgTOn9q+2j3s28CwKt27iF2/nIMsyZFlGNBpFNBqFIAhQFIUqQz/JmP3Gp3774aOHOHDgALKXspDnZAiCgLW1tZ7CNFmWUSgUaFt3HQAMDQ1B0zScevEUbuSv4z9bW2g0ttDQG2g0dBhOXsI0YBomTcK37tS+iOlKmuz529JfMTBwAB8tfITkD5N0W+jEs/2KkyABgJm3Z/Dd09/BVmMLW40G9EYDDb2FYJ+Ezxc94c4CoEc6sZFhBINBAEA2m/W1Sb3K+vo69brBYNBOxDupSROmbYsdc/GkCgsAJjFhGNY52pWrlylB8Xjck+PdCbkjIyO078RbE3aC3WiS7EpRUidLnqwjI+rcAZDJzCRZXC4T9XGFvPb91xxXT6LRKKlUKqRXqdfrJBqN0v5iXCTq4wpZXC6Ty1cv0+dfotL8kXojSZYqi0T9WCViXKTPBUEg09PTZG1trSOxa2trZHp6mgiCQPsdP3GcrHyskiV1kUxmJr+M5BKmNSidykxiNC6C53ncyN3AB7/7oO8jo+yVaei6jocPy3j9B6/3v8RcZsN9muHefbb+3im+H5bfe/s2Ee4ylZm0NPlxhbwv/ZYEg8GeZywYDJLCrwpEfVwhS+oieee9d3atBYSQrvfuZ/3ib4fb7zuYTtuq1BtJvPq9V+kphFIs4c78na7H9mfFs4jFhulZ2/z8HcxkZ3bvJLpo0m40109j/a67eQ/Tbd969NgRTGUu4RvfDLpOI9zpRnjiVuc/nqx+8gl+eT2PhdLC3njhLgPdS4Ldk/m5EOzIyeGTOH3mNI69cAxfDQS8OVw7tPp0YwOPlh7h/t37e0bs563B+2GDeyL4qfQvDCHkGYZh/v2Uin3YYBDC/HcArOiX8zGX6zMAAAAASUVORK5CYII=",
+ "cc-by-nc": common + "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",
+ "cc-by-nc-sa": common + "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",
+ "cc-by-nc-nd": common + "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"
+ },
+ target;
+
return {
manifest: {
about:{
name: "Popcorn Attribution Plugin",
- version: "0.1",
- author: "@annasob",
- website: "annasob.wordpress.com"
+ version: "0.2",
+ author: "@rwaldron",
+ website: "github.com/rwldrn"
},
options:{
- start : {elem:'input', type:'text', label:'In'},
- end : {elem:'input', type:'text', label:'Out'},
- nameofwork : {elem:'input', type:'text', label:'Name of Work'},
- nameofworkurl : {elem:'input', type:'text', label:'Url of Work'},
- copyrightholder : {elem:'input', type:'text', label:'Copyright Holder'},
- copyrightholderurl : {elem:'input', type:'text', label:'Copyright Holder Url'},
- license : {elem:'input', type:'text', label:'License type'},
- licenseurl : {elem:'input', type:'text', label:'License URL'},
- target : 'attribution-container'
+ start: { elem:"input", type:"text", label:"In" },
+ end: { elem:"input", type:"text", label:"Out" },
+ nameofwork: { elem:"input", type:"text", label:"Name of Work" },
+ nameofworkurl: { elem:"input", type:"text", label:"Url of Work" },
+ copyrightholder: { elem:"input", type:"text", label:"Copyright Holder" },
+ copyrightholderurl: { elem:"input", type:"text", label:"Copyright Holder Url" },
+ license: { elem:"input", type:"text", label:"License type" },
+ licenseurl: { elem:"input", type:"text", label:"License URL" },
+ target: "attribution-container"
}
},
- _setup: function(options) {
- var attrib = "";
+ _setup: function( options ) {
+
+ var attrib = "",
+ license = options.license && licenses[ options.license.toLowerCase() ],
+ tar = "target=_blank";
+
// make a div to put the information into
- options._container = document.createElement( 'div' );
+ options._container = document.createElement( "div" );
options._container.style.display = "none";
-
- if (options.nameofworkurl) {
- attrib += "<a href='" + options.nameofworkurl + "' target='_blank'>";
+
+ // Cache declared target
+ target = document.getElementById( options.target );
+
+ if ( options.nameofworkurl ) {
+ attrib += "<a href='" + options.nameofworkurl + "' " + tar + ">";
}
- if (options.nameofwork) {
+ if ( options.nameofwork ) {
attrib += options.nameofwork;
}
- if (options.nameofworkurl) {
+ if ( options.nameofworkurl ) {
attrib += "</a>";
}
- if (options.copyrightholderurl) {
- attrib += "<a href='" + options.copyrightholderurl + "' target='_blank'>";
+ if ( options.copyrightholderurl ) {
+ attrib += "<a href='" + options.copyrightholderurl + "' " + tar + ">";
}
- if (options.copyrightholder) {
+ if ( options.copyrightholder ) {
attrib += ", " + options.copyrightholder;
}
- if (options.copyrightholderurl) {
+ if ( options.copyrightholderurl ) {
attrib += "</a>";
}
@@ -86,34 +98,37 @@
attrib = options.text;
}
- if (options.license) {
- if (licenses[options.license.toLowerCase()]) {
- if (options.licenseurl) {
- attrib = "<a href='" + options.licenseurl + "' target='_blank'><img src='"+ licenses[options.license.toLowerCase()] +"' border='0'/></a> " + attrib;
+ if ( options.license ) {
+ if ( license ) {
+ if ( options.licenseurl ) {
+ attrib = "<a href='" + options.licenseurl + "' " + tar + "><img src='"+ license +"' border='0'/></a> " + attrib;
} else {
- attrib = "<img src='"+ licenses[options.license.toLowerCase()] +"' />" + attrib;
+ attrib = "<img src='"+ license +"' />" + attrib;
}
} else {
- if (options.licenseurl) {
- attrib += ", license: <a href='" + options.licenseurl + "' target='_blank'>" + options.license + "</a> ";
+ attrib += ", license: ";
+
+ if ( options.licenseurl ) {
+ attrib += "<a href='" + options.licenseurl + "' " + tar + ">" + options.license + "</a> ";
} else {
- attrib += ", license: " + options.license;
+ attrib += options.license;
}
}
- } else if (options.licenseurl) {
- attrib += ", <a href='" + options.licenseurl + "' target='_blank'>license</a> ";
+ } else if ( options.licenseurl ) {
+ attrib += ", <a href='" + options.licenseurl + "' " + tar + ">license</a> ";
}
+
options._container.innerHTML = attrib;
- document.getElementById( options.target ) && document.getElementById( options.target ).appendChild( options._container );
+ target && target.appendChild( options._container );
},
/**
* @member attribution
* The start function will be executed when the currentTime
* of the video reaches the start time provided by the
* options variable
*/
- start: function(event, options){
+ start: function( event, options ) {
options._container.style.display = "inline";
},
/**
@@ -122,11 +137,15 @@
* of the video reaches the end time provided by the
* options variable
*/
- end: function(event, options){
+ end: function( event, options ) {
options._container.style.display = "none";
},
_teardown: function( options ) {
- document.getElementById( options.target ) && document.getElementById( options.target ).removeChild( options._container );
+
+ // Cache declared target
+ target = document.getElementById( options.target );
+
+ target && target.removeChild( options._container );
}
};
})());
View
0 plugins/attribution/popcorn.attribution.unit.html 100644 → 100755
File mode changed.
View
20 plugins/attribution/popcorn.attribution.unit.js 100644 → 100755
@@ -1,7 +1,7 @@
test("Popcorn attribution Plugin", function () {
var popped = Popcorn("#video"),
- expects = 8,
+ expects = 10,
count = 0,
setupId,
attributiondiv = document.getElementById('attribdiv');
@@ -25,16 +25,15 @@ test("Popcorn attribution Plugin", function () {
popped.attribution({
start: 0, // seconds
- end: 0.5, // seconds
+ end: 2, // seconds
nameofwork: "A Shared Culture",
copyrightholder:"Jesse Dylan",
- license: "CC-BY-N6",
licenseurl: "http://creativecommons.org/licenses/by-nc/2.0/",
target: 'attribdiv'
} )
.attribution({
- start: 0.5, // seconds
- end: 1, // seconds
+ start: 2, // seconds
+ end: 4, // seconds
nameofwork: "Internet",
nameofworkurl:"http://www.archive.org/details/CC1232_internet",
copyrightholder:"The Computer Chronicles",
@@ -53,12 +52,19 @@ test("Popcorn attribution Plugin", function () {
plus();
});
- popped.exec( 0.5, function() {
+ popped.exec( 2, function() {
+
+ ok( /target="_blank"/.test( attributiondiv.innerHTML ), "attributions create anchors that target=_blank" );
+ plus();
+
equals (attributiondiv.children[1].style.display , "inline", "second attribution is visible on the page" );
plus();
+
+ equals ( typeof popped.data.trackEvents.byStart[ 1 ]._license, "undefined", "undefined license is properly being handled" );
+ plus();
});
- popped.exec( 1, function() {
+ popped.exec( 4, function() {
equals(attributiondiv.children[1].style.display , "none", "second attribution is no longer visible on the page" );
plus();
equals(attributiondiv.children[0].style.display , "none", "first attribution is no longer visible on the page" );
View
0 plugins/code/popcorn.code.html 100644 → 100755
File mode changed.