Mercurial > public > bravenewsurf
diff bns_website/templates/videos/index.html @ 60:a0d3bc630ebd
For issue #8, create a videos application to randomize videos in the playlist.
This commit now adds a dependency to the Google Python GData library.
The admin enters a playlist URL in the admin. Then the admin uses an admin action to synchronize the playlist with YouTube. This reads the playlist title and retrieves the video list from YouTube. The view function reads all the playlist objects to get the complete list of videos, then shuffles them up. The template generates Javascript to create a YouTube player with the shuffled list.
A fixture is included for convenience and for the tests.
I also committed a test tool I wrote to prove out this idea in case it is useful for future enhancements or experimentation.
author | Brian Neal <bgneal@gmail.com> |
---|---|
date | Sat, 19 Nov 2011 14:19:00 -0600 |
parents | |
children | 1d2473f4bcaa |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/bns_website/templates/videos/index.html Sat Nov 19 14:19:00 2011 -0600 @@ -0,0 +1,41 @@ +{% extends 'base.html' %} +{% load core_tags %} +{% block title %}Watch{% endblock %} +{% block content %} +{% navbar 'videos' %} +<h1>Watch</h1> + +{% if videos %} +<p> +Please enjoy this {{ videos|length }} video playlist of the bands that performed on the +<em>Brave New Surf</em> compilation. You can use the button that looks like a widescreen TV +at the bottom of the player to scroll through all the videos. +</p> +<div id="player"></div> + +<script> +var tag = document.createElement('script'); +tag.src = "http://www.youtube.com/player_api"; +var firstScriptTag = document.getElementsByTagName('script')[0]; +firstScriptTag.parentNode.insertBefore(tag, firstScriptTag); + +var player; +function onYouTubePlayerAPIReady() { + player = new YT.Player('player', { + videoId: '{{ videos|first }}', + {% if playlist %} + playerVars: { playlist: [ + {% for video in videos|slice:"1:" %} + {% if not forloop.first %},{% endif %}'{{ video }}' + {% endfor %} ]}, + {% endif %} + width: '853', + height: '480' + }); +} +</script> + +{% else %} + <p>Videos of the bands are coming soon. Please check back later.</p> +{% endif %} +{% endblock %}