]> git.parisson.com Git - timeside.git/commitdiff
- server: components moved to server/
authorGuillaume Pellerin <yomguy@parisson.com>
Mon, 28 Apr 2014 23:00:30 +0000 (01:00 +0200)
committerGuillaume Pellerin <yomguy@parisson.com>
Mon, 28 Apr 2014 23:00:30 +0000 (01:00 +0200)
- server: sandbox moved to server/sandbox/
- player: static files moved to player/static/timeside/
- bugfixes, cleanup

136 files changed:
tests/sandbox/test_limsi_sad.py [new file with mode: 0644]
tests/server/__init__.py [deleted file]
tests/server/diag.sh [deleted file]
tests/server/diagram/timeside.dot [deleted file]
tests/server/diagram/timeside.pdf [deleted file]
tests/server/manage.py [deleted file]
tests/server/settings.py [deleted file]
tests/server/update_schema.sh [deleted file]
tests/server/urls.py [deleted file]
tests/server/wsgi.py [deleted file]
timeside/__init__.py
timeside/admin.py [deleted file]
timeside/encoder/metadata.py [new file with mode: 0644]
timeside/metadata.py [deleted file]
timeside/migrations/0001_initial.py [deleted file]
timeside/migrations/0002_auto__chg_field_parameters_processor.py [deleted file]
timeside/migrations/0003_auto__del_field_processor_type.py [deleted file]
timeside/migrations/0004_auto__del_field_result_processor__add_field_result_parameters.py [deleted file]
timeside/migrations/0005_auto__del_field_result_output_mime_type__del_field_result_output__add_.py [deleted file]
timeside/migrations/0006_auto__del_parameters__add_preset__del_field_result_parameters__add_fie.py [deleted file]
timeside/migrations/__init__.py [deleted file]
timeside/models.py [deleted file]
timeside/player/__init__.py [new file with mode: 0644]
timeside/player/static/timeside/README.rst [new file with mode: 0644]
timeside/player/static/timeside/js/libs/jquery-1.6.min.js [new file with mode: 0644]
timeside/player/static/timeside/js/libs/raphael-min.js [new file with mode: 0644]
timeside/player/static/timeside/js/libs/soundmanager2-jsmin.js [new file with mode: 0644]
timeside/player/static/timeside/js/libs/soundmanager2-nodebug-jsmin.js [new file with mode: 0644]
timeside/player/static/timeside/js/libs/soundmanager2-nodebug.js [new file with mode: 0644]
timeside/player/static/timeside/js/libs/soundmanager2.js [new file with mode: 0644]
timeside/player/static/timeside/js/markermap.js [new file with mode: 0644]
timeside/player/static/timeside/js/player.js [new file with mode: 0644]
timeside/player/static/timeside/js/ruler.js [new file with mode: 0644]
timeside/player/static/timeside/js/rulermarker.js [new file with mode: 0644]
timeside/player/static/timeside/js/timeside.js [new file with mode: 0644]
timeside/player/static/timeside/skins/classic/img/forward.png [new file with mode: 0644]
timeside/player/static/timeside/skins/classic/img/pause.png [new file with mode: 0644]
timeside/player/static/timeside/skins/classic/img/play.png [new file with mode: 0644]
timeside/player/static/timeside/skins/classic/img/player_controlbg.png [new file with mode: 0644]
timeside/player/static/timeside/skins/classic/img/rewind.png [new file with mode: 0644]
timeside/player/static/timeside/skins/classic/img/setmarker.png [new file with mode: 0644]
timeside/player/static/timeside/skins/classic/img/volumeoff.png [new file with mode: 0644]
timeside/player/static/timeside/skins/classic/img/volumeon.png [new file with mode: 0644]
timeside/player/static/timeside/skins/classic/img/wait.gif [new file with mode: 0644]
timeside/player/static/timeside/skins/classic/style.css [new file with mode: 0644]
timeside/player/static/timeside/skins/lab/img/controlbg-inverted.png [new file with mode: 0644]
timeside/player/static/timeside/skins/lab/img/controlbg.png [new file with mode: 0644]
timeside/player/static/timeside/skins/lab/img/empty.png [new file with mode: 0644]
timeside/player/static/timeside/skins/lab/img/forward.png [new file with mode: 0644]
timeside/player/static/timeside/skins/lab/img/pause.png [new file with mode: 0644]
timeside/player/static/timeside/skins/lab/img/play.png [new file with mode: 0644]
timeside/player/static/timeside/skins/lab/img/rewind.png [new file with mode: 0644]
timeside/player/static/timeside/skins/lab/img/setmarker.png [new file with mode: 0644]
timeside/player/static/timeside/skins/lab/img/volume.png [new file with mode: 0644]
timeside/player/static/timeside/skins/lab/img/volumeoff.png [new file with mode: 0644]
timeside/player/static/timeside/skins/lab/img/volumeon.png [new file with mode: 0644]
timeside/player/static/timeside/skins/lab/img/wait.gif [new file with mode: 0644]
timeside/player/static/timeside/skins/lab/img/wait2.gif [new file with mode: 0644]
timeside/player/static/timeside/skins/lab/img/wait3.gif [new file with mode: 0644]
timeside/player/static/timeside/skins/lab/style.css [new file with mode: 0644]
timeside/player/static/timeside/swf/soundmanager2.swf [new file with mode: 0644]
timeside/player/static/timeside/swf/soundmanager2_debug.swf [new file with mode: 0644]
timeside/player/static/timeside/swf/soundmanager2_flash9.swf [new file with mode: 0644]
timeside/player/static/timeside/swf/soundmanager2_flash9_debug.swf [new file with mode: 0644]
timeside/player/static/timeside/swf/soundmanager2_flash_xdomain.zip [new file with mode: 0644]
timeside/serializers.py [deleted file]
timeside/server/__init__.py [new file with mode: 0644]
timeside/server/admin.py [new file with mode: 0644]
timeside/server/migrations/0001_initial.py [new file with mode: 0644]
timeside/server/migrations/0002_auto__chg_field_parameters_processor.py [new file with mode: 0644]
timeside/server/migrations/0003_auto__del_field_processor_type.py [new file with mode: 0644]
timeside/server/migrations/0004_auto__del_field_result_processor__add_field_result_parameters.py [new file with mode: 0644]
timeside/server/migrations/0005_auto__del_field_result_output_mime_type__del_field_result_output__add_.py [new file with mode: 0644]
timeside/server/migrations/0006_auto__del_parameters__add_preset__del_field_result_parameters__add_fie.py [new file with mode: 0644]
timeside/server/migrations/__init__.py [new file with mode: 0644]
timeside/server/models.py [new file with mode: 0644]
timeside/server/sandbox/__init__.py [new file with mode: 0644]
timeside/server/sandbox/diag.sh [new file with mode: 0755]
timeside/server/sandbox/diagram/timeside.dot [new file with mode: 0644]
timeside/server/sandbox/diagram/timeside.pdf [new file with mode: 0644]
timeside/server/sandbox/manage.py [new file with mode: 0755]
timeside/server/sandbox/settings.py [new file with mode: 0644]
timeside/server/sandbox/update_schema.sh [new file with mode: 0755]
timeside/server/sandbox/urls.py [new file with mode: 0644]
timeside/server/sandbox/wsgi.py [new file with mode: 0644]
timeside/server/serializers.py [new file with mode: 0644]
timeside/server/templates/timeside/base.html [new file with mode: 0644]
timeside/server/templates/timeside/index.html [new file with mode: 0644]
timeside/server/urls.py [new file with mode: 0644]
timeside/server/views.py [new file with mode: 0644]
timeside/static/timeside/README.rst [deleted file]
timeside/static/timeside/js/libs/jquery-1.6.min.js [deleted file]
timeside/static/timeside/js/libs/raphael-min.js [deleted file]
timeside/static/timeside/js/libs/soundmanager2-jsmin.js [deleted file]
timeside/static/timeside/js/libs/soundmanager2-nodebug-jsmin.js [deleted file]
timeside/static/timeside/js/libs/soundmanager2-nodebug.js [deleted file]
timeside/static/timeside/js/libs/soundmanager2.js [deleted file]
timeside/static/timeside/js/markermap.js [deleted file]
timeside/static/timeside/js/player.js [deleted file]
timeside/static/timeside/js/ruler.js [deleted file]
timeside/static/timeside/js/rulermarker.js [deleted file]
timeside/static/timeside/js/timeside.js [deleted file]
timeside/static/timeside/skins/classic/img/forward.png [deleted file]
timeside/static/timeside/skins/classic/img/pause.png [deleted file]
timeside/static/timeside/skins/classic/img/play.png [deleted file]
timeside/static/timeside/skins/classic/img/player_controlbg.png [deleted file]
timeside/static/timeside/skins/classic/img/rewind.png [deleted file]
timeside/static/timeside/skins/classic/img/setmarker.png [deleted file]
timeside/static/timeside/skins/classic/img/volumeoff.png [deleted file]
timeside/static/timeside/skins/classic/img/volumeon.png [deleted file]
timeside/static/timeside/skins/classic/img/wait.gif [deleted file]
timeside/static/timeside/skins/classic/style.css [deleted file]
timeside/static/timeside/skins/lab/img/controlbg-inverted.png [deleted file]
timeside/static/timeside/skins/lab/img/controlbg.png [deleted file]
timeside/static/timeside/skins/lab/img/empty.png [deleted file]
timeside/static/timeside/skins/lab/img/forward.png [deleted file]
timeside/static/timeside/skins/lab/img/pause.png [deleted file]
timeside/static/timeside/skins/lab/img/play.png [deleted file]
timeside/static/timeside/skins/lab/img/rewind.png [deleted file]
timeside/static/timeside/skins/lab/img/setmarker.png [deleted file]
timeside/static/timeside/skins/lab/img/volume.png [deleted file]
timeside/static/timeside/skins/lab/img/volumeoff.png [deleted file]
timeside/static/timeside/skins/lab/img/volumeon.png [deleted file]
timeside/static/timeside/skins/lab/img/wait.gif [deleted file]
timeside/static/timeside/skins/lab/img/wait2.gif [deleted file]
timeside/static/timeside/skins/lab/img/wait3.gif [deleted file]
timeside/static/timeside/skins/lab/style.css [deleted file]
timeside/static/timeside/swf/soundmanager2.swf [deleted file]
timeside/static/timeside/swf/soundmanager2_debug.swf [deleted file]
timeside/static/timeside/swf/soundmanager2_flash9.swf [deleted file]
timeside/static/timeside/swf/soundmanager2_flash9_debug.swf [deleted file]
timeside/static/timeside/swf/soundmanager2_flash_xdomain.zip [deleted file]
timeside/templates/timeside/base.html [deleted file]
timeside/templates/timeside/index.html [deleted file]
timeside/urls.py [deleted file]
timeside/views.py [deleted file]

diff --git a/tests/sandbox/test_limsi_sad.py b/tests/sandbox/test_limsi_sad.py
new file mode 100644 (file)
index 0000000..2c54070
--- /dev/null
@@ -0,0 +1,8 @@
+# -*- coding: utf-8 -*-
+
+import timeside
+
+decoder  =  timeside.decoder.FileDecoder('/home/momo/music_local/test/sweep.wav')
+analyzer = timeside.analyzer.LimsiSad('etape')
+(decoder | analyzer).run()
+print analyzer.results()
diff --git a/tests/server/__init__.py b/tests/server/__init__.py
deleted file mode 100644 (file)
index e69de29..0000000
diff --git a/tests/server/diag.sh b/tests/server/diag.sh
deleted file mode 100755 (executable)
index a76eca4..0000000
+++ /dev/null
@@ -1,19 +0,0 @@
-#!/bin/sh
-
-app="timeside"
-dir="diagram"
-
-if [ ! -d $dir ]; then
-       mkdir $dir
-fi
-
-./manage.py graph_models  -a > $dir/$app-all.dot
-./manage.py graph_models $app > $dir/$app.dot
-
-sed -i '/#\ /d' $dir/$app-all.dot
-sed -i '/#\ /d' $dir/$app.dot
-
-dot $dir/$app-all.dot -Tpdf -o $dir/$app-all.pdf
-dot $dir/$app.dot -Tpdf -o $dir/$app.pdf
-
-rsync -a $dir/ doc.parisson.com:/var/www/files/doc/$app/diagram/
diff --git a/tests/server/diagram/timeside.dot b/tests/server/diagram/timeside.dot
deleted file mode 100644 (file)
index 2f04481..0000000
+++ /dev/null
@@ -1,541 +0,0 @@
-digraph model_graph {
-
-  fontname = "Helvetica"
-  fontsize = 8
-  splines  = true
-
-  node [
-    fontname = "Helvetica"
-    fontsize = 8
-    shape = "plaintext"
-  ]
-
-  edge [
-    fontname = "Helvetica"
-    fontsize = 8
-  ]
-
-
-
-  timeside_models_DocBaseResource [label=<
-    <TABLE BGCOLOR="palegoldenrod" BORDER="0" CELLBORDER="0" CELLSPACING="0">
-    <TR><TD COLSPAN="2" CELLPADDING="4" ALIGN="CENTER" BGCOLOR="olivedrab4">
-    <FONT FACE="Helvetica Bold" COLOR="white">
-    DocBaseResource<BR/>&lt;<FONT FACE="Helvetica Italic">BaseResource</FONT>&gt;
-    </FONT></TD></TR>
-  
-    <TR><TD ALIGN="LEFT" BORDER="0">
-    <FONT COLOR="#7B7B7B" FACE="Helvetica Italic">date_added</FONT>
-    </TD><TD ALIGN="LEFT">
-    <FONT COLOR="#7B7B7B" FACE="Helvetica Italic">DateTimeField</FONT>
-    </TD></TR>
-  
-    <TR><TD ALIGN="LEFT" BORDER="0">
-    <FONT COLOR="#7B7B7B" FACE="Helvetica Italic">date_modified</FONT>
-    </TD><TD ALIGN="LEFT">
-    <FONT COLOR="#7B7B7B" FACE="Helvetica Italic">DateTimeField</FONT>
-    </TD></TR>
-  
-    <TR><TD ALIGN="LEFT" BORDER="0">
-    <FONT COLOR="#7B7B7B" FACE="Helvetica ">description</FONT>
-    </TD><TD ALIGN="LEFT">
-    <FONT COLOR="#7B7B7B" FACE="Helvetica ">TextField</FONT>
-    </TD></TR>
-  
-    <TR><TD ALIGN="LEFT" BORDER="0">
-    <FONT COLOR="#7B7B7B" FACE="Helvetica ">title</FONT>
-    </TD><TD ALIGN="LEFT">
-    <FONT COLOR="#7B7B7B" FACE="Helvetica ">CharField</FONT>
-    </TD></TR>
-  
-    <TR><TD ALIGN="LEFT" BORDER="0">
-    <FONT COLOR="#7B7B7B" FACE="Helvetica Italic">uuid</FONT>
-    </TD><TD ALIGN="LEFT">
-    <FONT COLOR="#7B7B7B" FACE="Helvetica Italic">CharField</FONT>
-    </TD></TR>
-  
-    </TABLE>
-    >]
-
-  timeside_models_BaseResource [label=<
-    <TABLE BGCOLOR="palegoldenrod" BORDER="0" CELLBORDER="0" CELLSPACING="0">
-    <TR><TD COLSPAN="2" CELLPADDING="4" ALIGN="CENTER" BGCOLOR="olivedrab4">
-    <FONT FACE="Helvetica Bold" COLOR="white">
-    BaseResource
-    </FONT></TD></TR>
-  
-    <TR><TD ALIGN="LEFT" BORDER="0">
-    <FONT COLOR="#7B7B7B" FACE="Helvetica ">date_added</FONT>
-    </TD><TD ALIGN="LEFT">
-    <FONT COLOR="#7B7B7B" FACE="Helvetica ">DateTimeField</FONT>
-    </TD></TR>
-  
-    <TR><TD ALIGN="LEFT" BORDER="0">
-    <FONT COLOR="#7B7B7B" FACE="Helvetica ">date_modified</FONT>
-    </TD><TD ALIGN="LEFT">
-    <FONT COLOR="#7B7B7B" FACE="Helvetica ">DateTimeField</FONT>
-    </TD></TR>
-  
-    <TR><TD ALIGN="LEFT" BORDER="0">
-    <FONT COLOR="#7B7B7B" FACE="Helvetica ">uuid</FONT>
-    </TD><TD ALIGN="LEFT">
-    <FONT COLOR="#7B7B7B" FACE="Helvetica ">CharField</FONT>
-    </TD></TR>
-  
-    </TABLE>
-    >]
-
-  timeside_models_Selection [label=<
-    <TABLE BGCOLOR="palegoldenrod" BORDER="0" CELLBORDER="0" CELLSPACING="0">
-    <TR><TD COLSPAN="2" CELLPADDING="4" ALIGN="CENTER" BGCOLOR="olivedrab4">
-    <FONT FACE="Helvetica Bold" COLOR="white">
-    Selection<BR/>&lt;<FONT FACE="Helvetica Italic">DocBaseResource</FONT>&gt;
-    </FONT></TD></TR>
-  
-    <TR><TD ALIGN="LEFT" BORDER="0">
-    <FONT FACE="Helvetica Bold">id</FONT>
-    </TD><TD ALIGN="LEFT">
-    <FONT FACE="Helvetica Bold">AutoField</FONT>
-    </TD></TR>
-  
-    <TR><TD ALIGN="LEFT" BORDER="0">
-    <FONT COLOR="#7B7B7B" FACE="Helvetica Bold">author</FONT>
-    </TD><TD ALIGN="LEFT">
-    <FONT COLOR="#7B7B7B" FACE="Helvetica Bold">ForeignKey (id)</FONT>
-    </TD></TR>
-  
-    <TR><TD ALIGN="LEFT" BORDER="0">
-    <FONT COLOR="#7B7B7B" FACE="Helvetica Italic">date_added</FONT>
-    </TD><TD ALIGN="LEFT">
-    <FONT COLOR="#7B7B7B" FACE="Helvetica Italic">DateTimeField</FONT>
-    </TD></TR>
-  
-    <TR><TD ALIGN="LEFT" BORDER="0">
-    <FONT COLOR="#7B7B7B" FACE="Helvetica Italic">date_modified</FONT>
-    </TD><TD ALIGN="LEFT">
-    <FONT COLOR="#7B7B7B" FACE="Helvetica Italic">DateTimeField</FONT>
-    </TD></TR>
-  
-    <TR><TD ALIGN="LEFT" BORDER="0">
-    <FONT COLOR="#7B7B7B" FACE="Helvetica Italic">description</FONT>
-    </TD><TD ALIGN="LEFT">
-    <FONT COLOR="#7B7B7B" FACE="Helvetica Italic">TextField</FONT>
-    </TD></TR>
-  
-    <TR><TD ALIGN="LEFT" BORDER="0">
-    <FONT COLOR="#7B7B7B" FACE="Helvetica Italic">title</FONT>
-    </TD><TD ALIGN="LEFT">
-    <FONT COLOR="#7B7B7B" FACE="Helvetica Italic">CharField</FONT>
-    </TD></TR>
-  
-    <TR><TD ALIGN="LEFT" BORDER="0">
-    <FONT COLOR="#7B7B7B" FACE="Helvetica Italic">uuid</FONT>
-    </TD><TD ALIGN="LEFT">
-    <FONT COLOR="#7B7B7B" FACE="Helvetica Italic">CharField</FONT>
-    </TD></TR>
-  
-    </TABLE>
-    >]
-
-  timeside_models_Item [label=<
-    <TABLE BGCOLOR="palegoldenrod" BORDER="0" CELLBORDER="0" CELLSPACING="0">
-    <TR><TD COLSPAN="2" CELLPADDING="4" ALIGN="CENTER" BGCOLOR="olivedrab4">
-    <FONT FACE="Helvetica Bold" COLOR="white">
-    Item<BR/>&lt;<FONT FACE="Helvetica Italic">DocBaseResource</FONT>&gt;
-    </FONT></TD></TR>
-  
-    <TR><TD ALIGN="LEFT" BORDER="0">
-    <FONT FACE="Helvetica Bold">id</FONT>
-    </TD><TD ALIGN="LEFT">
-    <FONT FACE="Helvetica Bold">AutoField</FONT>
-    </TD></TR>
-  
-    <TR><TD ALIGN="LEFT" BORDER="0">
-    <FONT COLOR="#7B7B7B" FACE="Helvetica Bold">author</FONT>
-    </TD><TD ALIGN="LEFT">
-    <FONT COLOR="#7B7B7B" FACE="Helvetica Bold">ForeignKey (id)</FONT>
-    </TD></TR>
-  
-    <TR><TD ALIGN="LEFT" BORDER="0">
-    <FONT COLOR="#7B7B7B" FACE="Helvetica Italic">date_added</FONT>
-    </TD><TD ALIGN="LEFT">
-    <FONT COLOR="#7B7B7B" FACE="Helvetica Italic">DateTimeField</FONT>
-    </TD></TR>
-  
-    <TR><TD ALIGN="LEFT" BORDER="0">
-    <FONT COLOR="#7B7B7B" FACE="Helvetica Italic">date_modified</FONT>
-    </TD><TD ALIGN="LEFT">
-    <FONT COLOR="#7B7B7B" FACE="Helvetica Italic">DateTimeField</FONT>
-    </TD></TR>
-  
-    <TR><TD ALIGN="LEFT" BORDER="0">
-    <FONT COLOR="#7B7B7B" FACE="Helvetica Italic">description</FONT>
-    </TD><TD ALIGN="LEFT">
-    <FONT COLOR="#7B7B7B" FACE="Helvetica Italic">TextField</FONT>
-    </TD></TR>
-  
-    <TR><TD ALIGN="LEFT" BORDER="0">
-    <FONT COLOR="#7B7B7B" FACE="Helvetica ">file</FONT>
-    </TD><TD ALIGN="LEFT">
-    <FONT COLOR="#7B7B7B" FACE="Helvetica ">FileField</FONT>
-    </TD></TR>
-  
-    <TR><TD ALIGN="LEFT" BORDER="0">
-    <FONT COLOR="#7B7B7B" FACE="Helvetica ">hdf5</FONT>
-    </TD><TD ALIGN="LEFT">
-    <FONT COLOR="#7B7B7B" FACE="Helvetica ">FileField</FONT>
-    </TD></TR>
-  
-    <TR><TD ALIGN="LEFT" BORDER="0">
-    <FONT COLOR="#7B7B7B" FACE="Helvetica ">lock</FONT>
-    </TD><TD ALIGN="LEFT">
-    <FONT COLOR="#7B7B7B" FACE="Helvetica ">BooleanField</FONT>
-    </TD></TR>
-  
-    <TR><TD ALIGN="LEFT" BORDER="0">
-    <FONT COLOR="#7B7B7B" FACE="Helvetica ">mime_type</FONT>
-    </TD><TD ALIGN="LEFT">
-    <FONT COLOR="#7B7B7B" FACE="Helvetica ">CharField</FONT>
-    </TD></TR>
-  
-    <TR><TD ALIGN="LEFT" BORDER="0">
-    <FONT COLOR="#7B7B7B" FACE="Helvetica ">sha1</FONT>
-    </TD><TD ALIGN="LEFT">
-    <FONT COLOR="#7B7B7B" FACE="Helvetica ">CharField</FONT>
-    </TD></TR>
-  
-    <TR><TD ALIGN="LEFT" BORDER="0">
-    <FONT COLOR="#7B7B7B" FACE="Helvetica Italic">title</FONT>
-    </TD><TD ALIGN="LEFT">
-    <FONT COLOR="#7B7B7B" FACE="Helvetica Italic">CharField</FONT>
-    </TD></TR>
-  
-    <TR><TD ALIGN="LEFT" BORDER="0">
-    <FONT COLOR="#7B7B7B" FACE="Helvetica ">url</FONT>
-    </TD><TD ALIGN="LEFT">
-    <FONT COLOR="#7B7B7B" FACE="Helvetica ">URLField</FONT>
-    </TD></TR>
-  
-    <TR><TD ALIGN="LEFT" BORDER="0">
-    <FONT COLOR="#7B7B7B" FACE="Helvetica Italic">uuid</FONT>
-    </TD><TD ALIGN="LEFT">
-    <FONT COLOR="#7B7B7B" FACE="Helvetica Italic">CharField</FONT>
-    </TD></TR>
-  
-    </TABLE>
-    >]
-
-  timeside_models_Experience [label=<
-    <TABLE BGCOLOR="palegoldenrod" BORDER="0" CELLBORDER="0" CELLSPACING="0">
-    <TR><TD COLSPAN="2" CELLPADDING="4" ALIGN="CENTER" BGCOLOR="olivedrab4">
-    <FONT FACE="Helvetica Bold" COLOR="white">
-    Experience<BR/>&lt;<FONT FACE="Helvetica Italic">DocBaseResource</FONT>&gt;
-    </FONT></TD></TR>
-  
-    <TR><TD ALIGN="LEFT" BORDER="0">
-    <FONT FACE="Helvetica Bold">id</FONT>
-    </TD><TD ALIGN="LEFT">
-    <FONT FACE="Helvetica Bold">AutoField</FONT>
-    </TD></TR>
-  
-    <TR><TD ALIGN="LEFT" BORDER="0">
-    <FONT COLOR="#7B7B7B" FACE="Helvetica Bold">author</FONT>
-    </TD><TD ALIGN="LEFT">
-    <FONT COLOR="#7B7B7B" FACE="Helvetica Bold">ForeignKey (id)</FONT>
-    </TD></TR>
-  
-    <TR><TD ALIGN="LEFT" BORDER="0">
-    <FONT COLOR="#7B7B7B" FACE="Helvetica Italic">date_added</FONT>
-    </TD><TD ALIGN="LEFT">
-    <FONT COLOR="#7B7B7B" FACE="Helvetica Italic">DateTimeField</FONT>
-    </TD></TR>
-  
-    <TR><TD ALIGN="LEFT" BORDER="0">
-    <FONT COLOR="#7B7B7B" FACE="Helvetica Italic">date_modified</FONT>
-    </TD><TD ALIGN="LEFT">
-    <FONT COLOR="#7B7B7B" FACE="Helvetica Italic">DateTimeField</FONT>
-    </TD></TR>
-  
-    <TR><TD ALIGN="LEFT" BORDER="0">
-    <FONT COLOR="#7B7B7B" FACE="Helvetica Italic">description</FONT>
-    </TD><TD ALIGN="LEFT">
-    <FONT COLOR="#7B7B7B" FACE="Helvetica Italic">TextField</FONT>
-    </TD></TR>
-  
-    <TR><TD ALIGN="LEFT" BORDER="0">
-    <FONT COLOR="#7B7B7B" FACE="Helvetica ">is_public</FONT>
-    </TD><TD ALIGN="LEFT">
-    <FONT COLOR="#7B7B7B" FACE="Helvetica ">BooleanField</FONT>
-    </TD></TR>
-  
-    <TR><TD ALIGN="LEFT" BORDER="0">
-    <FONT COLOR="#7B7B7B" FACE="Helvetica Italic">title</FONT>
-    </TD><TD ALIGN="LEFT">
-    <FONT COLOR="#7B7B7B" FACE="Helvetica Italic">CharField</FONT>
-    </TD></TR>
-  
-    <TR><TD ALIGN="LEFT" BORDER="0">
-    <FONT COLOR="#7B7B7B" FACE="Helvetica Italic">uuid</FONT>
-    </TD><TD ALIGN="LEFT">
-    <FONT COLOR="#7B7B7B" FACE="Helvetica Italic">CharField</FONT>
-    </TD></TR>
-  
-    </TABLE>
-    >]
-
-  timeside_models_Processor [label=<
-    <TABLE BGCOLOR="palegoldenrod" BORDER="0" CELLBORDER="0" CELLSPACING="0">
-    <TR><TD COLSPAN="2" CELLPADDING="4" ALIGN="CENTER" BGCOLOR="olivedrab4">
-    <FONT FACE="Helvetica Bold" COLOR="white">
-    Processor
-    </FONT></TD></TR>
-  
-    <TR><TD ALIGN="LEFT" BORDER="0">
-    <FONT FACE="Helvetica Bold">id</FONT>
-    </TD><TD ALIGN="LEFT">
-    <FONT FACE="Helvetica Bold">AutoField</FONT>
-    </TD></TR>
-  
-    <TR><TD ALIGN="LEFT" BORDER="0">
-    <FONT FACE="Helvetica ">pid</FONT>
-    </TD><TD ALIGN="LEFT">
-    <FONT FACE="Helvetica ">CharField</FONT>
-    </TD></TR>
-  
-    <TR><TD ALIGN="LEFT" BORDER="0">
-    <FONT COLOR="#7B7B7B" FACE="Helvetica ">version</FONT>
-    </TD><TD ALIGN="LEFT">
-    <FONT COLOR="#7B7B7B" FACE="Helvetica ">CharField</FONT>
-    </TD></TR>
-  
-    </TABLE>
-    >]
-
-  timeside_models_Preset [label=<
-    <TABLE BGCOLOR="palegoldenrod" BORDER="0" CELLBORDER="0" CELLSPACING="0">
-    <TR><TD COLSPAN="2" CELLPADDING="4" ALIGN="CENTER" BGCOLOR="olivedrab4">
-    <FONT FACE="Helvetica Bold" COLOR="white">
-    Preset
-    </FONT></TD></TR>
-  
-    <TR><TD ALIGN="LEFT" BORDER="0">
-    <FONT FACE="Helvetica Bold">id</FONT>
-    </TD><TD ALIGN="LEFT">
-    <FONT FACE="Helvetica Bold">AutoField</FONT>
-    </TD></TR>
-  
-    <TR><TD ALIGN="LEFT" BORDER="0">
-    <FONT COLOR="#7B7B7B" FACE="Helvetica Bold">processor</FONT>
-    </TD><TD ALIGN="LEFT">
-    <FONT COLOR="#7B7B7B" FACE="Helvetica Bold">ForeignKey (id)</FONT>
-    </TD></TR>
-  
-    <TR><TD ALIGN="LEFT" BORDER="0">
-    <FONT COLOR="#7B7B7B" FACE="Helvetica ">is_public</FONT>
-    </TD><TD ALIGN="LEFT">
-    <FONT COLOR="#7B7B7B" FACE="Helvetica ">BooleanField</FONT>
-    </TD></TR>
-  
-    <TR><TD ALIGN="LEFT" BORDER="0">
-    <FONT COLOR="#7B7B7B" FACE="Helvetica ">parameters</FONT>
-    </TD><TD ALIGN="LEFT">
-    <FONT COLOR="#7B7B7B" FACE="Helvetica ">TextField</FONT>
-    </TD></TR>
-  
-    </TABLE>
-    >]
-
-  timeside_models_Result [label=<
-    <TABLE BGCOLOR="palegoldenrod" BORDER="0" CELLBORDER="0" CELLSPACING="0">
-    <TR><TD COLSPAN="2" CELLPADDING="4" ALIGN="CENTER" BGCOLOR="olivedrab4">
-    <FONT FACE="Helvetica Bold" COLOR="white">
-    Result<BR/>&lt;<FONT FACE="Helvetica Italic">BaseResource</FONT>&gt;
-    </FONT></TD></TR>
-  
-    <TR><TD ALIGN="LEFT" BORDER="0">
-    <FONT FACE="Helvetica Bold">id</FONT>
-    </TD><TD ALIGN="LEFT">
-    <FONT FACE="Helvetica Bold">AutoField</FONT>
-    </TD></TR>
-  
-    <TR><TD ALIGN="LEFT" BORDER="0">
-    <FONT COLOR="#7B7B7B" FACE="Helvetica Bold">item</FONT>
-    </TD><TD ALIGN="LEFT">
-    <FONT COLOR="#7B7B7B" FACE="Helvetica Bold">ForeignKey (id)</FONT>
-    </TD></TR>
-  
-    <TR><TD ALIGN="LEFT" BORDER="0">
-    <FONT COLOR="#7B7B7B" FACE="Helvetica Bold">preset</FONT>
-    </TD><TD ALIGN="LEFT">
-    <FONT COLOR="#7B7B7B" FACE="Helvetica Bold">ForeignKey (id)</FONT>
-    </TD></TR>
-  
-    <TR><TD ALIGN="LEFT" BORDER="0">
-    <FONT COLOR="#7B7B7B" FACE="Helvetica Italic">date_added</FONT>
-    </TD><TD ALIGN="LEFT">
-    <FONT COLOR="#7B7B7B" FACE="Helvetica Italic">DateTimeField</FONT>
-    </TD></TR>
-  
-    <TR><TD ALIGN="LEFT" BORDER="0">
-    <FONT COLOR="#7B7B7B" FACE="Helvetica Italic">date_modified</FONT>
-    </TD><TD ALIGN="LEFT">
-    <FONT COLOR="#7B7B7B" FACE="Helvetica Italic">DateTimeField</FONT>
-    </TD></TR>
-  
-    <TR><TD ALIGN="LEFT" BORDER="0">
-    <FONT COLOR="#7B7B7B" FACE="Helvetica ">file</FONT>
-    </TD><TD ALIGN="LEFT">
-    <FONT COLOR="#7B7B7B" FACE="Helvetica ">FileField</FONT>
-    </TD></TR>
-  
-    <TR><TD ALIGN="LEFT" BORDER="0">
-    <FONT COLOR="#7B7B7B" FACE="Helvetica ">hdf5</FONT>
-    </TD><TD ALIGN="LEFT">
-    <FONT COLOR="#7B7B7B" FACE="Helvetica ">FileField</FONT>
-    </TD></TR>
-  
-    <TR><TD ALIGN="LEFT" BORDER="0">
-    <FONT COLOR="#7B7B7B" FACE="Helvetica ">mime_type</FONT>
-    </TD><TD ALIGN="LEFT">
-    <FONT COLOR="#7B7B7B" FACE="Helvetica ">CharField</FONT>
-    </TD></TR>
-  
-    <TR><TD ALIGN="LEFT" BORDER="0">
-    <FONT FACE="Helvetica ">status</FONT>
-    </TD><TD ALIGN="LEFT">
-    <FONT FACE="Helvetica ">IntegerField</FONT>
-    </TD></TR>
-  
-    <TR><TD ALIGN="LEFT" BORDER="0">
-    <FONT COLOR="#7B7B7B" FACE="Helvetica Italic">uuid</FONT>
-    </TD><TD ALIGN="LEFT">
-    <FONT COLOR="#7B7B7B" FACE="Helvetica Italic">CharField</FONT>
-    </TD></TR>
-  
-    </TABLE>
-    >]
-
-  timeside_models_Task [label=<
-    <TABLE BGCOLOR="palegoldenrod" BORDER="0" CELLBORDER="0" CELLSPACING="0">
-    <TR><TD COLSPAN="2" CELLPADDING="4" ALIGN="CENTER" BGCOLOR="olivedrab4">
-    <FONT FACE="Helvetica Bold" COLOR="white">
-    Task
-    </FONT></TD></TR>
-  
-    <TR><TD ALIGN="LEFT" BORDER="0">
-    <FONT FACE="Helvetica Bold">id</FONT>
-    </TD><TD ALIGN="LEFT">
-    <FONT FACE="Helvetica Bold">AutoField</FONT>
-    </TD></TR>
-  
-    <TR><TD ALIGN="LEFT" BORDER="0">
-    <FONT COLOR="#7B7B7B" FACE="Helvetica Bold">author</FONT>
-    </TD><TD ALIGN="LEFT">
-    <FONT COLOR="#7B7B7B" FACE="Helvetica Bold">ForeignKey (id)</FONT>
-    </TD></TR>
-  
-    <TR><TD ALIGN="LEFT" BORDER="0">
-    <FONT COLOR="#7B7B7B" FACE="Helvetica Bold">experience</FONT>
-    </TD><TD ALIGN="LEFT">
-    <FONT COLOR="#7B7B7B" FACE="Helvetica Bold">ForeignKey (id)</FONT>
-    </TD></TR>
-  
-    <TR><TD ALIGN="LEFT" BORDER="0">
-    <FONT COLOR="#7B7B7B" FACE="Helvetica Bold">selection</FONT>
-    </TD><TD ALIGN="LEFT">
-    <FONT COLOR="#7B7B7B" FACE="Helvetica Bold">ForeignKey (id)</FONT>
-    </TD></TR>
-  
-    <TR><TD ALIGN="LEFT" BORDER="0">
-    <FONT FACE="Helvetica ">status</FONT>
-    </TD><TD ALIGN="LEFT">
-    <FONT FACE="Helvetica ">IntegerField</FONT>
-    </TD></TR>
-  
-    </TABLE>
-    >]
-
-
-
-
-
-  timeside_models_DocBaseResource -> timeside_models_BaseResource
-  [label="abstract\ninheritance"] [arrowhead=empty, arrowtail=none, dir=both];
-  django_contrib_auth_models_User [label=<
-  <TABLE BGCOLOR="palegoldenrod" BORDER="0" CELLBORDER="0" CELLSPACING="0">
-  <TR><TD COLSPAN="2" CELLPADDING="4" ALIGN="CENTER" BGCOLOR="olivedrab4">
-  <FONT FACE="Helvetica Bold" COLOR="white">User</FONT>
-  </TD></TR>
-  </TABLE>
-  >]
-  timeside_models_Selection -> django_contrib_auth_models_User
-  [label="author (selections)"] [arrowhead=none, arrowtail=dot, dir=both];
-
-  timeside_models_Selection -> timeside_models_Item
-  [label="items (selections)"] [arrowhead=dot arrowtail=dot, dir=both];
-
-  timeside_models_Selection -> timeside_models_Selection
-  [label="selections (other_selections)"] [arrowhead=dot arrowtail=dot, dir=both];
-
-  timeside_models_Selection -> timeside_models_DocBaseResource
-  [label="abstract\ninheritance"] [arrowhead=empty, arrowtail=none, dir=both];
-  django_contrib_auth_models_User [label=<
-  <TABLE BGCOLOR="palegoldenrod" BORDER="0" CELLBORDER="0" CELLSPACING="0">
-  <TR><TD COLSPAN="2" CELLPADDING="4" ALIGN="CENTER" BGCOLOR="olivedrab4">
-  <FONT FACE="Helvetica Bold" COLOR="white">User</FONT>
-  </TD></TR>
-  </TABLE>
-  >]
-  timeside_models_Item -> django_contrib_auth_models_User
-  [label="author (items)"] [arrowhead=none, arrowtail=dot, dir=both];
-
-  timeside_models_Item -> timeside_models_DocBaseResource
-  [label="abstract\ninheritance"] [arrowhead=empty, arrowtail=none, dir=both];
-  django_contrib_auth_models_User [label=<
-  <TABLE BGCOLOR="palegoldenrod" BORDER="0" CELLBORDER="0" CELLSPACING="0">
-  <TR><TD COLSPAN="2" CELLPADDING="4" ALIGN="CENTER" BGCOLOR="olivedrab4">
-  <FONT FACE="Helvetica Bold" COLOR="white">User</FONT>
-  </TD></TR>
-  </TABLE>
-  >]
-  timeside_models_Experience -> django_contrib_auth_models_User
-  [label="author (experiences)"] [arrowhead=none, arrowtail=dot, dir=both];
-
-  timeside_models_Experience -> timeside_models_Preset
-  [label="presets (experiences)"] [arrowhead=dot arrowtail=dot, dir=both];
-
-  timeside_models_Experience -> timeside_models_Experience
-  [label="experiences (other_experiences)"] [arrowhead=dot arrowtail=dot, dir=both];
-
-  timeside_models_Experience -> timeside_models_DocBaseResource
-  [label="abstract\ninheritance"] [arrowhead=empty, arrowtail=none, dir=both];
-
-  timeside_models_Preset -> timeside_models_Processor
-  [label="processor (preset)"] [arrowhead=none, arrowtail=dot, dir=both];
-
-  timeside_models_Result -> timeside_models_Item
-  [label="item (results)"] [arrowhead=none, arrowtail=dot, dir=both];
-
-  timeside_models_Result -> timeside_models_Preset
-  [label="preset (results)"] [arrowhead=none, arrowtail=dot, dir=both];
-
-  timeside_models_Result -> timeside_models_BaseResource
-  [label="abstract\ninheritance"] [arrowhead=empty, arrowtail=none, dir=both];
-
-  timeside_models_Task -> timeside_models_Experience
-  [label="experience (task)"] [arrowhead=none, arrowtail=dot, dir=both];
-
-  timeside_models_Task -> timeside_models_Selection
-  [label="selection (task)"] [arrowhead=none, arrowtail=dot, dir=both];
-  django_contrib_auth_models_User [label=<
-  <TABLE BGCOLOR="palegoldenrod" BORDER="0" CELLBORDER="0" CELLSPACING="0">
-  <TR><TD COLSPAN="2" CELLPADDING="4" ALIGN="CENTER" BGCOLOR="olivedrab4">
-  <FONT FACE="Helvetica Bold" COLOR="white">User</FONT>
-  </TD></TR>
-  </TABLE>
-  >]
-  timeside_models_Task -> django_contrib_auth_models_User
-  [label="author (tasks)"] [arrowhead=none, arrowtail=dot, dir=both];
-
-}
-
diff --git a/tests/server/diagram/timeside.pdf b/tests/server/diagram/timeside.pdf
deleted file mode 100644 (file)
index 9f72bae..0000000
Binary files a/tests/server/diagram/timeside.pdf and /dev/null differ
diff --git a/tests/server/manage.py b/tests/server/manage.py
deleted file mode 100755 (executable)
index f9726f9..0000000
+++ /dev/null
@@ -1,10 +0,0 @@
-#!/usr/bin/env python
-import os
-import sys
-
-if __name__ == "__main__":
-    os.environ.setdefault("DJANGO_SETTINGS_MODULE", "settings")
-
-    from django.core.management import execute_from_command_line
-
-    execute_from_command_line(sys.argv)
diff --git a/tests/server/settings.py b/tests/server/settings.py
deleted file mode 100644 (file)
index 057b403..0000000
+++ /dev/null
@@ -1,168 +0,0 @@
-# Django settings for server project.
-
-DEBUG = True
-TEMPLATE_DEBUG = DEBUG
-
-import os, sys
-sys.dont_write_bytecode = True
-
-ADMINS = (
-    # ('Your Name', 'your_email@example.com'),
-)
-
-MANAGERS = ADMINS
-
-DATABASES = {
-    'default': {
-        'ENGINE': 'django.db.backends.sqlite3', # Add 'postgresql_psycopg2', 'mysql', 'sqlite3' or 'oracle'.
-        'NAME': 'timeside.sql',                      # Or path to database file if using sqlite3.
-        'USER': '',                      # Not used with sqlite3.
-        'PASSWORD': '',                  # Not used with sqlite3.
-        'HOST': '',                      # Set to empty string for localhost. Not used with sqlite3.
-        'PORT': '',                      # Set to empty string for default. Not used with sqlite3.
-    }
-}
-
-# Hosts/domain names that are valid for this site; required if DEBUG is False
-# See https://docs.djangoproject.com/en/1.4/ref/settings/#allowed-hosts
-ALLOWED_HOSTS = []
-
-# Local time zone for this installation. Choices can be found here:
-# http://en.wikipedia.org/wiki/List_of_tz_zones_by_name
-# although not all choices may be available on all operating systems.
-# In a Windows environment this must be set to your system time zone.
-TIME_ZONE = 'America/Chicago'
-
-# Language code for this installation. All choices can be found here:
-# http://www.i18nguy.com/unicode/language-identifiers.html
-LANGUAGE_CODE = 'en-us'
-
-SITE_ID = 1
-
-# If you set this to False, Django will make some optimizations so as not
-# to load the internationalization machinery.
-USE_I18N = True
-
-# If you set this to False, Django will not format dates, numbers and
-# calendars according to the current locale.
-USE_L10N = True
-
-# If you set this to False, Django will not use timezone-aware datetimes.
-USE_TZ = True
-
-# Full filesystem path to the project.
-PROJECT_ROOT = os.path.dirname(os.path.abspath(__file__))
-
-# Absolute filesystem path to the directory that will hold user-uploaded files.
-# Example: "/home/media/media.lawrence.com/media/"
-MEDIA_ROOT = PROJECT_ROOT + '/media/'
-
-# URL that handles the media served from MEDIA_ROOT. Make sure to use a
-# trailing slash.
-# Examples: "http://media.lawrence.com/media/", "http://example.com/media/"
-MEDIA_URL = ''
-
-# Absolute path to the directory static files should be collected to.
-# Don't put anything in this directory yourself; store your static files
-# in apps' "static/" subdirectories and in STATICFILES_DIRS.
-# Example: "/home/media/media.lawrence.com/static/"
-STATIC_ROOT = ''
-
-# URL prefix for static files.
-# Example: "http://media.lawrence.com/static/"
-STATIC_URL = '/static/'
-
-# Additional locations of static files
-STATICFILES_DIRS = (
-    # Put strings here, like "/home/html/static" or "C:/www/django/static".
-    # Always use forward slashes, even on Windows.
-    # Don't forget to use absolute paths, not relative paths.
-)
-
-# List of finder classes that know how to find static files in
-# various locations.
-STATICFILES_FINDERS = (
-    'django.contrib.staticfiles.finders.FileSystemFinder',
-    'django.contrib.staticfiles.finders.AppDirectoriesFinder',
-#    'django.contrib.staticfiles.finders.DefaultStorageFinder',
-)
-
-# Make this unique, and don't share it with anybody.
-SECRET_KEY = '5%z&amp;a3r@t0=xr2eaio+400qf-32$b5zp897pr*wh5i^s4(-+3('
-
-# List of callables that know how to import templates from various sources.
-TEMPLATE_LOADERS = (
-    'django.template.loaders.filesystem.Loader',
-    'django.template.loaders.app_directories.Loader',
-#    'django.template.loaders.eggs.Loader',
-)
-
-MIDDLEWARE_CLASSES = (
-    'django.middleware.common.CommonMiddleware',
-    'django.contrib.sessions.middleware.SessionMiddleware',
-    'django.middleware.csrf.CsrfViewMiddleware',
-    'django.contrib.auth.middleware.AuthenticationMiddleware',
-    'django.contrib.messages.middleware.MessageMiddleware',
-    # Uncomment the next line for simple clickjacking protection:
-    # 'django.middleware.clickjacking.XFrameOptionsMiddleware',
-)
-
-ROOT_URLCONF = 'urls'
-
-# Python dotted path to the WSGI application used by Django's runserver.
-WSGI_APPLICATION = 'wsgi.application'
-
-TEMPLATE_DIRS = (
-    # Put strings here, like "/home/html/django_templates" or "C:/www/django/templates".
-    # Always use forward slashes, even on Windows.
-    # Don't forget to use absolute paths, not relative paths.
-)
-
-INSTALLED_APPS = (
-    'django.contrib.auth',
-    'django.contrib.contenttypes',
-    'django.contrib.sessions',
-    'django.contrib.sites',
-    'django.contrib.messages',
-    'django.contrib.staticfiles',
-    # Uncomment the next line to enable the admin:
-    'django.contrib.admin',
-    # Uncomment the next line to enable admin documentation:
-    # 'django.contrib.admindocs',
-    'django_extensions',
-    'south',
-    'timeside',
-    'rest_framework',
-)
-
-# A sample logging configuration. The only tangible logging
-# performed by this configuration is to send an email to
-# the site admins on every HTTP 500 error when DEBUG=False.
-# See http://docs.djangoproject.com/en/dev/topics/logging for
-# more details on how to customize your logging configuration.
-LOGGING = {
-    'version': 1,
-    'disable_existing_loggers': False,
-    'filters': {
-        'require_debug_false': {
-            '()': 'django.utils.log.RequireDebugFalse'
-        }
-    },
-    'handlers': {
-        'mail_admins': {
-            'level': 'ERROR',
-            'filters': ['require_debug_false'],
-            'class': 'django.utils.log.AdminEmailHandler'
-        }
-    },
-    'loggers': {
-        'django.request': {
-            'handlers': ['mail_admins'],
-            'level': 'ERROR',
-            'propagate': True,
-        },
-    }
-}
-
-REST_FRAMEWORK = {
-}
\ No newline at end of file
diff --git a/tests/server/update_schema.sh b/tests/server/update_schema.sh
deleted file mode 100755 (executable)
index 82d28e9..0000000
+++ /dev/null
@@ -1,5 +0,0 @@
-#!/bin/sh
-
-./manage.py schemamigration timeside --auto
-./manage.py migrate timeside
-
diff --git a/tests/server/urls.py b/tests/server/urls.py
deleted file mode 100644 (file)
index 98374ec..0000000
+++ /dev/null
@@ -1,20 +0,0 @@
-from django.conf.urls import patterns, include, url
-
-# Uncomment the next two lines to enable the admin:
-from django.contrib import admin
-admin.autodiscover()
-
-urlpatterns = patterns('',
-
-    url(r'^', include('timeside.urls')),
-
-    # Examples:
-    # url(r'^$', 'server.views.home', name='home'),
-    # url(r'^server/', include('server.foo.urls')),
-
-    # Uncomment the admin/doc line below to enable admin documentation:
-    # url(r'^admin/doc/', include('django.contrib.admindocs.urls')),
-
-    # Uncomment the next line to enable the admin:
-    url(r'^admin/', include(admin.site.urls)),
-)
diff --git a/tests/server/wsgi.py b/tests/server/wsgi.py
deleted file mode 100644 (file)
index c4ec771..0000000
+++ /dev/null
@@ -1,28 +0,0 @@
-"""
-WSGI config for server project.
-
-This module contains the WSGI application used by Django's development server
-and any production WSGI deployments. It should expose a module-level variable
-named ``application``. Django's ``runserver`` and ``runfcgi`` commands discover
-this application via the ``WSGI_APPLICATION`` setting.
-
-Usually you will have the standard Django WSGI application here, but it also
-might make sense to replace the whole Django WSGI application with a custom one
-that later delegates to the Django one. For example, you could introduce WSGI
-middleware here, or combine a Django application with an application of another
-framework.
-
-"""
-import os
-
-os.environ.setdefault("DJANGO_SETTINGS_MODULE", "server.settings")
-
-# This application object is used by any WSGI server configured to use this
-# file. This includes Django's development server, if the WSGI_APPLICATION
-# setting points here.
-from django.core.wsgi import get_wsgi_application
-application = get_wsgi_application()
-
-# Apply WSGI middleware here.
-# from helloworld.wsgi import HelloWorldApplication
-# application = HelloWorldApplication(application)
index 333a661f16bc70453ed4d66116ff32167396ef16..2bbc454e6a1b5e10386448b67e7a7774640b7800 100644 (file)
@@ -7,4 +7,5 @@ from . import analyzer
 from . import grapher
 from . import encoder
 
+
 __version__ = '0.5.5'
diff --git a/timeside/admin.py b/timeside/admin.py
deleted file mode 100644 (file)
index 9ad18c1..0000000
+++ /dev/null
@@ -1,12 +0,0 @@
-
-from django.contrib import admin
-from timeside.models import *
-
-admin.site.register(Selection)
-admin.site.register(Item)
-admin.site.register(Experience)
-admin.site.register(Processor)
-admin.site.register(Preset)
-admin.site.register(Result)
-admin.site.register(Task)
-
diff --git a/timeside/encoder/metadata.py b/timeside/encoder/metadata.py
new file mode 100644 (file)
index 0000000..86abf87
--- /dev/null
@@ -0,0 +1,25 @@
+# -*- coding: utf-8 -*-
+#
+# Copyright (C) 2007-2009 Parisson
+# Copyright (c) 2007 Olivier Guilyardi <olivier@samalyse.com>
+# Copyright (c) 2007-2009 Guillaume Pellerin <pellerin@parisson.com>
+#
+# This file is part of TimeSide.
+
+# TimeSide is free software: you can redistribute it and/or modify
+# it under the terms of the GNU General Public License as published by
+# the Free Software Foundation, either version 2 of the License, or
+# (at your option) any later version.
+
+# TimeSide is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+# GNU General Public License for more details.
+
+# You should have received a copy of the GNU General Public License
+# along with TimeSide.  If not, see <http://www.gnu.org/licenses/>.
+
+class Metadata(object):
+    pass
+        
+        
diff --git a/timeside/metadata.py b/timeside/metadata.py
deleted file mode 100644 (file)
index 86abf87..0000000
+++ /dev/null
@@ -1,25 +0,0 @@
-# -*- coding: utf-8 -*-
-#
-# Copyright (C) 2007-2009 Parisson
-# Copyright (c) 2007 Olivier Guilyardi <olivier@samalyse.com>
-# Copyright (c) 2007-2009 Guillaume Pellerin <pellerin@parisson.com>
-#
-# This file is part of TimeSide.
-
-# TimeSide is free software: you can redistribute it and/or modify
-# it under the terms of the GNU General Public License as published by
-# the Free Software Foundation, either version 2 of the License, or
-# (at your option) any later version.
-
-# TimeSide is distributed in the hope that it will be useful,
-# but WITHOUT ANY WARRANTY; without even the implied warranty of
-# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
-# GNU General Public License for more details.
-
-# You should have received a copy of the GNU General Public License
-# along with TimeSide.  If not, see <http://www.gnu.org/licenses/>.
-
-class Metadata(object):
-    pass
-        
-        
diff --git a/timeside/migrations/0001_initial.py b/timeside/migrations/0001_initial.py
deleted file mode 100644 (file)
index bba562c..0000000
+++ /dev/null
@@ -1,284 +0,0 @@
-# -*- coding: utf-8 -*-
-from south.utils import datetime_utils as datetime
-from south.db import db
-from south.v2 import SchemaMigration
-from django.db import models
-
-
-class Migration(SchemaMigration):
-
-    def forwards(self, orm):
-        # Adding model 'Selection'
-        db.create_table('timeside_selections', (
-            ('id', self.gf('django.db.models.fields.AutoField')(primary_key=True)),
-            ('date_added', self.gf('django.db.models.fields.DateTimeField')(auto_now_add=True, blank=True)),
-            ('date_modified', self.gf('django.db.models.fields.DateTimeField')(auto_now=True, null=True, blank=True)),
-            ('uuid', self.gf('django.db.models.fields.CharField')(unique=True, max_length=512, blank=True)),
-            ('title', self.gf('django.db.models.fields.CharField')(max_length=512, blank=True)),
-            ('description', self.gf('django.db.models.fields.TextField')(blank=True)),
-            ('author', self.gf('django.db.models.fields.related.ForeignKey')(blank=True, related_name='selections', null=True, on_delete=models.SET_NULL, to=orm['auth.User'])),
-        ))
-        db.send_create_signal('timeside', ['Selection'])
-
-        # Adding M2M table for field items on 'Selection'
-        m2m_table_name = db.shorten_name('timeside_selections_items')
-        db.create_table(m2m_table_name, (
-            ('id', models.AutoField(verbose_name='ID', primary_key=True, auto_created=True)),
-            ('selection', models.ForeignKey(orm['timeside.selection'], null=False)),
-            ('item', models.ForeignKey(orm['timeside.item'], null=False))
-        ))
-        db.create_unique(m2m_table_name, ['selection_id', 'item_id'])
-
-        # Adding M2M table for field selections on 'Selection'
-        m2m_table_name = db.shorten_name('timeside_selections_selections')
-        db.create_table(m2m_table_name, (
-            ('id', models.AutoField(verbose_name='ID', primary_key=True, auto_created=True)),
-            ('from_selection', models.ForeignKey(orm['timeside.selection'], null=False)),
-            ('to_selection', models.ForeignKey(orm['timeside.selection'], null=False))
-        ))
-        db.create_unique(m2m_table_name, ['from_selection_id', 'to_selection_id'])
-
-        # Adding model 'Item'
-        db.create_table('timeside_items', (
-            ('id', self.gf('django.db.models.fields.AutoField')(primary_key=True)),
-            ('date_added', self.gf('django.db.models.fields.DateTimeField')(auto_now_add=True, blank=True)),
-            ('date_modified', self.gf('django.db.models.fields.DateTimeField')(auto_now=True, null=True, blank=True)),
-            ('uuid', self.gf('django.db.models.fields.CharField')(unique=True, max_length=512, blank=True)),
-            ('title', self.gf('django.db.models.fields.CharField')(max_length=512, blank=True)),
-            ('description', self.gf('django.db.models.fields.TextField')(blank=True)),
-            ('file', self.gf('django.db.models.fields.files.FileField')(max_length=1024, blank=True)),
-            ('url', self.gf('django.db.models.fields.URLField')(max_length=1024, blank=True)),
-            ('sha1', self.gf('django.db.models.fields.CharField')(max_length=512, blank=True)),
-            ('mime_type', self.gf('django.db.models.fields.CharField')(max_length=256, blank=True)),
-            ('hdf5', self.gf('django.db.models.fields.files.FileField')(max_length=1024, blank=True)),
-            ('lock', self.gf('django.db.models.fields.BooleanField')(default=False)),
-            ('author', self.gf('django.db.models.fields.related.ForeignKey')(blank=True, related_name='items', null=True, on_delete=models.SET_NULL, to=orm['auth.User'])),
-        ))
-        db.send_create_signal('timeside', ['Item'])
-
-        # Adding model 'Experience'
-        db.create_table('timeside_experiences', (
-            ('id', self.gf('django.db.models.fields.AutoField')(primary_key=True)),
-            ('date_added', self.gf('django.db.models.fields.DateTimeField')(auto_now_add=True, blank=True)),
-            ('date_modified', self.gf('django.db.models.fields.DateTimeField')(auto_now=True, null=True, blank=True)),
-            ('uuid', self.gf('django.db.models.fields.CharField')(unique=True, max_length=512, blank=True)),
-            ('title', self.gf('django.db.models.fields.CharField')(max_length=512, blank=True)),
-            ('description', self.gf('django.db.models.fields.TextField')(blank=True)),
-            ('author', self.gf('django.db.models.fields.related.ForeignKey')(blank=True, related_name='experiences', null=True, on_delete=models.SET_NULL, to=orm['auth.User'])),
-            ('is_preset', self.gf('django.db.models.fields.BooleanField')(default=False)),
-        ))
-        db.send_create_signal('timeside', ['Experience'])
-
-        # Adding M2M table for field processors on 'Experience'
-        m2m_table_name = db.shorten_name('timeside_experiences_processors')
-        db.create_table(m2m_table_name, (
-            ('id', models.AutoField(verbose_name='ID', primary_key=True, auto_created=True)),
-            ('experience', models.ForeignKey(orm['timeside.experience'], null=False)),
-            ('processor', models.ForeignKey(orm['timeside.processor'], null=False))
-        ))
-        db.create_unique(m2m_table_name, ['experience_id', 'processor_id'])
-
-        # Adding M2M table for field experiences on 'Experience'
-        m2m_table_name = db.shorten_name('timeside_experiences_experiences')
-        db.create_table(m2m_table_name, (
-            ('id', models.AutoField(verbose_name='ID', primary_key=True, auto_created=True)),
-            ('from_experience', models.ForeignKey(orm['timeside.experience'], null=False)),
-            ('to_experience', models.ForeignKey(orm['timeside.experience'], null=False))
-        ))
-        db.create_unique(m2m_table_name, ['from_experience_id', 'to_experience_id'])
-
-        # Adding model 'Processor'
-        db.create_table('timeside_processors', (
-            ('id', self.gf('django.db.models.fields.AutoField')(primary_key=True)),
-            ('pid', self.gf('django.db.models.fields.CharField')(max_length=256)),
-            ('type', self.gf('django.db.models.fields.CharField')(default='none', max_length=64)),
-            ('version', self.gf('django.db.models.fields.CharField')(max_length=64, blank=True)),
-        ))
-        db.send_create_signal('timeside', ['Processor'])
-
-        # Adding model 'Result'
-        db.create_table('timeside_results', (
-            ('id', self.gf('django.db.models.fields.AutoField')(primary_key=True)),
-            ('date_added', self.gf('django.db.models.fields.DateTimeField')(auto_now_add=True, blank=True)),
-            ('date_modified', self.gf('django.db.models.fields.DateTimeField')(auto_now=True, null=True, blank=True)),
-            ('uuid', self.gf('django.db.models.fields.CharField')(unique=True, max_length=512, blank=True)),
-            ('item', self.gf('django.db.models.fields.related.ForeignKey')(blank=True, related_name='results', null=True, on_delete=models.SET_NULL, to=orm['timeside.Item'])),
-            ('processor', self.gf('django.db.models.fields.related.ForeignKey')(blank=True, related_name='results', null=True, on_delete=models.SET_NULL, to=orm['timeside.Processor'])),
-            ('hdf5', self.gf('django.db.models.fields.files.FileField')(max_length=1024, blank=True)),
-            ('output', self.gf('django.db.models.fields.files.FileField')(max_length=1024, blank=True)),
-            ('output_mime_type', self.gf('django.db.models.fields.CharField')(max_length=256, blank=True)),
-            ('status', self.gf('django.db.models.fields.IntegerField')(default=1)),
-        ))
-        db.send_create_signal('timeside', ['Result'])
-
-        # Adding model 'Parameters'
-        db.create_table('timeside_parameters', (
-            ('id', self.gf('django.db.models.fields.AutoField')(primary_key=True)),
-            ('processor', self.gf('django.db.models.fields.related.ForeignKey')(blank=True, related_name='parameters', null=True, to=orm['timeside.Experience'])),
-            ('parameters', self.gf('django.db.models.fields.TextField')(blank=True)),
-            ('is_preset', self.gf('django.db.models.fields.BooleanField')(default=False)),
-        ))
-        db.send_create_signal('timeside', ['Parameters'])
-
-        # Adding model 'Task'
-        db.create_table('timeside_tasks', (
-            ('id', self.gf('django.db.models.fields.AutoField')(primary_key=True)),
-            ('experience', self.gf('django.db.models.fields.related.ForeignKey')(blank=True, related_name='task', null=True, to=orm['timeside.Experience'])),
-            ('selection', self.gf('django.db.models.fields.related.ForeignKey')(blank=True, related_name='task', null=True, to=orm['timeside.Selection'])),
-            ('status', self.gf('django.db.models.fields.IntegerField')(default=1)),
-            ('author', self.gf('django.db.models.fields.related.ForeignKey')(blank=True, related_name='tasks', null=True, on_delete=models.SET_NULL, to=orm['auth.User'])),
-        ))
-        db.send_create_signal('timeside', ['Task'])
-
-
-    def backwards(self, orm):
-        # Deleting model 'Selection'
-        db.delete_table('timeside_selections')
-
-        # Removing M2M table for field items on 'Selection'
-        db.delete_table(db.shorten_name('timeside_selections_items'))
-
-        # Removing M2M table for field selections on 'Selection'
-        db.delete_table(db.shorten_name('timeside_selections_selections'))
-
-        # Deleting model 'Item'
-        db.delete_table('timeside_items')
-
-        # Deleting model 'Experience'
-        db.delete_table('timeside_experiences')
-
-        # Removing M2M table for field processors on 'Experience'
-        db.delete_table(db.shorten_name('timeside_experiences_processors'))
-
-        # Removing M2M table for field experiences on 'Experience'
-        db.delete_table(db.shorten_name('timeside_experiences_experiences'))
-
-        # Deleting model 'Processor'
-        db.delete_table('timeside_processors')
-
-        # Deleting model 'Result'
-        db.delete_table('timeside_results')
-
-        # Deleting model 'Parameters'
-        db.delete_table('timeside_parameters')
-
-        # Deleting model 'Task'
-        db.delete_table('timeside_tasks')
-
-
-    models = {
-        'auth.group': {
-            'Meta': {'object_name': 'Group'},
-            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
-            'name': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '80'}),
-            'permissions': ('django.db.models.fields.related.ManyToManyField', [], {'to': "orm['auth.Permission']", 'symmetrical': 'False', 'blank': 'True'})
-        },
-        'auth.permission': {
-            'Meta': {'ordering': "('content_type__app_label', 'content_type__model', 'codename')", 'unique_together': "(('content_type', 'codename'),)", 'object_name': 'Permission'},
-            'codename': ('django.db.models.fields.CharField', [], {'max_length': '100'}),
-            'content_type': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['contenttypes.ContentType']"}),
-            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
-            'name': ('django.db.models.fields.CharField', [], {'max_length': '50'})
-        },
-        'auth.user': {
-            'Meta': {'object_name': 'User'},
-            'date_joined': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime.now'}),
-            'email': ('django.db.models.fields.EmailField', [], {'max_length': '75', 'blank': 'True'}),
-            'first_name': ('django.db.models.fields.CharField', [], {'max_length': '30', 'blank': 'True'}),
-            'groups': ('django.db.models.fields.related.ManyToManyField', [], {'to': "orm['auth.Group']", 'symmetrical': 'False', 'blank': 'True'}),
-            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
-            'is_active': ('django.db.models.fields.BooleanField', [], {'default': 'True'}),
-            'is_staff': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
-            'is_superuser': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
-            'last_login': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime.now'}),
-            'last_name': ('django.db.models.fields.CharField', [], {'max_length': '30', 'blank': 'True'}),
-            'password': ('django.db.models.fields.CharField', [], {'max_length': '128'}),
-            'user_permissions': ('django.db.models.fields.related.ManyToManyField', [], {'to': "orm['auth.Permission']", 'symmetrical': 'False', 'blank': 'True'}),
-            'username': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '30'})
-        },
-        'contenttypes.contenttype': {
-            'Meta': {'ordering': "('name',)", 'unique_together': "(('app_label', 'model'),)", 'object_name': 'ContentType', 'db_table': "'django_content_type'"},
-            'app_label': ('django.db.models.fields.CharField', [], {'max_length': '100'}),
-            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
-            'model': ('django.db.models.fields.CharField', [], {'max_length': '100'}),
-            'name': ('django.db.models.fields.CharField', [], {'max_length': '100'})
-        },
-        'timeside.experience': {
-            'Meta': {'object_name': 'Experience', 'db_table': "'timeside_experiences'"},
-            'author': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'experiences'", 'null': 'True', 'on_delete': 'models.SET_NULL', 'to': "orm['auth.User']"}),
-            'date_added': ('django.db.models.fields.DateTimeField', [], {'auto_now_add': 'True', 'blank': 'True'}),
-            'date_modified': ('django.db.models.fields.DateTimeField', [], {'auto_now': 'True', 'null': 'True', 'blank': 'True'}),
-            'description': ('django.db.models.fields.TextField', [], {'blank': 'True'}),
-            'experiences': ('django.db.models.fields.related.ManyToManyField', [], {'blank': 'True', 'related_name': "'other_experiences'", 'null': 'True', 'symmetrical': 'False', 'to': "orm['timeside.Experience']"}),
-            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
-            'is_preset': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
-            'processors': ('django.db.models.fields.related.ManyToManyField', [], {'blank': 'True', 'related_name': "'experiences'", 'null': 'True', 'symmetrical': 'False', 'to': "orm['timeside.Processor']"}),
-            'title': ('django.db.models.fields.CharField', [], {'max_length': '512', 'blank': 'True'}),
-            'uuid': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '512', 'blank': 'True'})
-        },
-        'timeside.item': {
-            'Meta': {'ordering': "['title']", 'object_name': 'Item', 'db_table': "'timeside_items'"},
-            'author': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'items'", 'null': 'True', 'on_delete': 'models.SET_NULL', 'to': "orm['auth.User']"}),
-            'date_added': ('django.db.models.fields.DateTimeField', [], {'auto_now_add': 'True', 'blank': 'True'}),
-            'date_modified': ('django.db.models.fields.DateTimeField', [], {'auto_now': 'True', 'null': 'True', 'blank': 'True'}),
-            'description': ('django.db.models.fields.TextField', [], {'blank': 'True'}),
-            'file': ('django.db.models.fields.files.FileField', [], {'max_length': '1024', 'blank': 'True'}),
-            'hdf5': ('django.db.models.fields.files.FileField', [], {'max_length': '1024', 'blank': 'True'}),
-            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
-            'lock': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
-            'mime_type': ('django.db.models.fields.CharField', [], {'max_length': '256', 'blank': 'True'}),
-            'sha1': ('django.db.models.fields.CharField', [], {'max_length': '512', 'blank': 'True'}),
-            'title': ('django.db.models.fields.CharField', [], {'max_length': '512', 'blank': 'True'}),
-            'url': ('django.db.models.fields.URLField', [], {'max_length': '1024', 'blank': 'True'}),
-            'uuid': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '512', 'blank': 'True'})
-        },
-        'timeside.parameters': {
-            'Meta': {'object_name': 'Parameters'},
-            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
-            'is_preset': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
-            'parameters': ('django.db.models.fields.TextField', [], {'blank': 'True'}),
-            'processor': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'parameters'", 'null': 'True', 'to': "orm['timeside.Experience']"})
-        },
-        'timeside.processor': {
-            'Meta': {'object_name': 'Processor', 'db_table': "'timeside_processors'"},
-            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
-            'pid': ('django.db.models.fields.CharField', [], {'max_length': '256'}),
-            'type': ('django.db.models.fields.CharField', [], {'default': "'none'", 'max_length': '64'}),
-            'version': ('django.db.models.fields.CharField', [], {'max_length': '64', 'blank': 'True'})
-        },
-        'timeside.result': {
-            'Meta': {'object_name': 'Result', 'db_table': "'timeside_results'"},
-            'date_added': ('django.db.models.fields.DateTimeField', [], {'auto_now_add': 'True', 'blank': 'True'}),
-            'date_modified': ('django.db.models.fields.DateTimeField', [], {'auto_now': 'True', 'null': 'True', 'blank': 'True'}),
-            'hdf5': ('django.db.models.fields.files.FileField', [], {'max_length': '1024', 'blank': 'True'}),
-            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
-            'item': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'results'", 'null': 'True', 'on_delete': 'models.SET_NULL', 'to': "orm['timeside.Item']"}),
-            'output': ('django.db.models.fields.files.FileField', [], {'max_length': '1024', 'blank': 'True'}),
-            'output_mime_type': ('django.db.models.fields.CharField', [], {'max_length': '256', 'blank': 'True'}),
-            'processor': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'results'", 'null': 'True', 'on_delete': 'models.SET_NULL', 'to': "orm['timeside.Processor']"}),
-            'status': ('django.db.models.fields.IntegerField', [], {'default': '1'}),
-            'uuid': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '512', 'blank': 'True'})
-        },
-        'timeside.selection': {
-            'Meta': {'object_name': 'Selection', 'db_table': "'timeside_selections'"},
-            'author': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'selections'", 'null': 'True', 'on_delete': 'models.SET_NULL', 'to': "orm['auth.User']"}),
-            'date_added': ('django.db.models.fields.DateTimeField', [], {'auto_now_add': 'True', 'blank': 'True'}),
-            'date_modified': ('django.db.models.fields.DateTimeField', [], {'auto_now': 'True', 'null': 'True', 'blank': 'True'}),
-            'description': ('django.db.models.fields.TextField', [], {'blank': 'True'}),
-            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
-            'items': ('django.db.models.fields.related.ManyToManyField', [], {'blank': 'True', 'related_name': "'selections'", 'null': 'True', 'symmetrical': 'False', 'to': "orm['timeside.Item']"}),
-            'selections': ('django.db.models.fields.related.ManyToManyField', [], {'blank': 'True', 'related_name': "'other_selections'", 'null': 'True', 'symmetrical': 'False', 'to': "orm['timeside.Selection']"}),
-            'title': ('django.db.models.fields.CharField', [], {'max_length': '512', 'blank': 'True'}),
-            'uuid': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '512', 'blank': 'True'})
-        },
-        'timeside.task': {
-            'Meta': {'object_name': 'Task', 'db_table': "'timeside_tasks'"},
-            'author': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'tasks'", 'null': 'True', 'on_delete': 'models.SET_NULL', 'to': "orm['auth.User']"}),
-            'experience': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'task'", 'null': 'True', 'to': "orm['timeside.Experience']"}),
-            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
-            'selection': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'task'", 'null': 'True', 'to': "orm['timeside.Selection']"}),
-            'status': ('django.db.models.fields.IntegerField', [], {'default': '1'})
-        }
-    }
-
-    complete_apps = ['timeside']
\ No newline at end of file
diff --git a/timeside/migrations/0002_auto__chg_field_parameters_processor.py b/timeside/migrations/0002_auto__chg_field_parameters_processor.py
deleted file mode 100644 (file)
index aea7f91..0000000
+++ /dev/null
@@ -1,135 +0,0 @@
-# -*- coding: utf-8 -*-
-from south.utils import datetime_utils as datetime
-from south.db import db
-from south.v2 import SchemaMigration
-from django.db import models
-
-
-class Migration(SchemaMigration):
-
-    def forwards(self, orm):
-
-        # Changing field 'Parameters.processor'
-        db.alter_column('timeside_parameters', 'processor_id', self.gf('django.db.models.fields.related.ForeignKey')(null=True, to=orm['timeside.Processor']))
-
-    def backwards(self, orm):
-
-        # Changing field 'Parameters.processor'
-        db.alter_column('timeside_parameters', 'processor_id', self.gf('django.db.models.fields.related.ForeignKey')(null=True, to=orm['timeside.Experience']))
-
-    models = {
-        'auth.group': {
-            'Meta': {'object_name': 'Group'},
-            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
-            'name': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '80'}),
-            'permissions': ('django.db.models.fields.related.ManyToManyField', [], {'to': "orm['auth.Permission']", 'symmetrical': 'False', 'blank': 'True'})
-        },
-        'auth.permission': {
-            'Meta': {'ordering': "('content_type__app_label', 'content_type__model', 'codename')", 'unique_together': "(('content_type', 'codename'),)", 'object_name': 'Permission'},
-            'codename': ('django.db.models.fields.CharField', [], {'max_length': '100'}),
-            'content_type': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['contenttypes.ContentType']"}),
-            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
-            'name': ('django.db.models.fields.CharField', [], {'max_length': '50'})
-        },
-        'auth.user': {
-            'Meta': {'object_name': 'User'},
-            'date_joined': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime.now'}),
-            'email': ('django.db.models.fields.EmailField', [], {'max_length': '75', 'blank': 'True'}),
-            'first_name': ('django.db.models.fields.CharField', [], {'max_length': '30', 'blank': 'True'}),
-            'groups': ('django.db.models.fields.related.ManyToManyField', [], {'to': "orm['auth.Group']", 'symmetrical': 'False', 'blank': 'True'}),
-            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
-            'is_active': ('django.db.models.fields.BooleanField', [], {'default': 'True'}),
-            'is_staff': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
-            'is_superuser': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
-            'last_login': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime.now'}),
-            'last_name': ('django.db.models.fields.CharField', [], {'max_length': '30', 'blank': 'True'}),
-            'password': ('django.db.models.fields.CharField', [], {'max_length': '128'}),
-            'user_permissions': ('django.db.models.fields.related.ManyToManyField', [], {'to': "orm['auth.Permission']", 'symmetrical': 'False', 'blank': 'True'}),
-            'username': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '30'})
-        },
-        'contenttypes.contenttype': {
-            'Meta': {'ordering': "('name',)", 'unique_together': "(('app_label', 'model'),)", 'object_name': 'ContentType', 'db_table': "'django_content_type'"},
-            'app_label': ('django.db.models.fields.CharField', [], {'max_length': '100'}),
-            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
-            'model': ('django.db.models.fields.CharField', [], {'max_length': '100'}),
-            'name': ('django.db.models.fields.CharField', [], {'max_length': '100'})
-        },
-        'timeside.experience': {
-            'Meta': {'object_name': 'Experience', 'db_table': "'timeside_experiences'"},
-            'author': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'experiences'", 'null': 'True', 'on_delete': 'models.SET_NULL', 'to': "orm['auth.User']"}),
-            'date_added': ('django.db.models.fields.DateTimeField', [], {'auto_now_add': 'True', 'blank': 'True'}),
-            'date_modified': ('django.db.models.fields.DateTimeField', [], {'auto_now': 'True', 'null': 'True', 'blank': 'True'}),
-            'description': ('django.db.models.fields.TextField', [], {'blank': 'True'}),
-            'experiences': ('django.db.models.fields.related.ManyToManyField', [], {'blank': 'True', 'related_name': "'other_experiences'", 'null': 'True', 'symmetrical': 'False', 'to': "orm['timeside.Experience']"}),
-            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
-            'is_preset': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
-            'processors': ('django.db.models.fields.related.ManyToManyField', [], {'blank': 'True', 'related_name': "'experiences'", 'null': 'True', 'symmetrical': 'False', 'to': "orm['timeside.Processor']"}),
-            'title': ('django.db.models.fields.CharField', [], {'max_length': '512', 'blank': 'True'}),
-            'uuid': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '512', 'blank': 'True'})
-        },
-        'timeside.item': {
-            'Meta': {'ordering': "['title']", 'object_name': 'Item', 'db_table': "'timeside_items'"},
-            'author': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'items'", 'null': 'True', 'on_delete': 'models.SET_NULL', 'to': "orm['auth.User']"}),
-            'date_added': ('django.db.models.fields.DateTimeField', [], {'auto_now_add': 'True', 'blank': 'True'}),
-            'date_modified': ('django.db.models.fields.DateTimeField', [], {'auto_now': 'True', 'null': 'True', 'blank': 'True'}),
-            'description': ('django.db.models.fields.TextField', [], {'blank': 'True'}),
-            'file': ('django.db.models.fields.files.FileField', [], {'max_length': '1024', 'blank': 'True'}),
-            'hdf5': ('django.db.models.fields.files.FileField', [], {'max_length': '1024', 'blank': 'True'}),
-            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
-            'lock': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
-            'mime_type': ('django.db.models.fields.CharField', [], {'max_length': '256', 'blank': 'True'}),
-            'sha1': ('django.db.models.fields.CharField', [], {'max_length': '512', 'blank': 'True'}),
-            'title': ('django.db.models.fields.CharField', [], {'max_length': '512', 'blank': 'True'}),
-            'url': ('django.db.models.fields.URLField', [], {'max_length': '1024', 'blank': 'True'}),
-            'uuid': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '512', 'blank': 'True'})
-        },
-        'timeside.parameters': {
-            'Meta': {'object_name': 'Parameters'},
-            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
-            'is_preset': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
-            'parameters': ('django.db.models.fields.TextField', [], {'blank': 'True'}),
-            'processor': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'parameters'", 'null': 'True', 'to': "orm['timeside.Processor']"})
-        },
-        'timeside.processor': {
-            'Meta': {'object_name': 'Processor', 'db_table': "'timeside_processors'"},
-            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
-            'pid': ('django.db.models.fields.CharField', [], {'max_length': '256'}),
-            'type': ('django.db.models.fields.CharField', [], {'default': "'none'", 'max_length': '64'}),
-            'version': ('django.db.models.fields.CharField', [], {'max_length': '64', 'blank': 'True'})
-        },
-        'timeside.result': {
-            'Meta': {'object_name': 'Result', 'db_table': "'timeside_results'"},
-            'date_added': ('django.db.models.fields.DateTimeField', [], {'auto_now_add': 'True', 'blank': 'True'}),
-            'date_modified': ('django.db.models.fields.DateTimeField', [], {'auto_now': 'True', 'null': 'True', 'blank': 'True'}),
-            'hdf5': ('django.db.models.fields.files.FileField', [], {'max_length': '1024', 'blank': 'True'}),
-            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
-            'item': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'results'", 'null': 'True', 'on_delete': 'models.SET_NULL', 'to': "orm['timeside.Item']"}),
-            'output': ('django.db.models.fields.files.FileField', [], {'max_length': '1024', 'blank': 'True'}),
-            'output_mime_type': ('django.db.models.fields.CharField', [], {'max_length': '256', 'blank': 'True'}),
-            'processor': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'results'", 'null': 'True', 'on_delete': 'models.SET_NULL', 'to': "orm['timeside.Processor']"}),
-            'status': ('django.db.models.fields.IntegerField', [], {'default': '1'}),
-            'uuid': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '512', 'blank': 'True'})
-        },
-        'timeside.selection': {
-            'Meta': {'object_name': 'Selection', 'db_table': "'timeside_selections'"},
-            'author': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'selections'", 'null': 'True', 'on_delete': 'models.SET_NULL', 'to': "orm['auth.User']"}),
-            'date_added': ('django.db.models.fields.DateTimeField', [], {'auto_now_add': 'True', 'blank': 'True'}),
-            'date_modified': ('django.db.models.fields.DateTimeField', [], {'auto_now': 'True', 'null': 'True', 'blank': 'True'}),
-            'description': ('django.db.models.fields.TextField', [], {'blank': 'True'}),
-            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
-            'items': ('django.db.models.fields.related.ManyToManyField', [], {'blank': 'True', 'related_name': "'selections'", 'null': 'True', 'symmetrical': 'False', 'to': "orm['timeside.Item']"}),
-            'selections': ('django.db.models.fields.related.ManyToManyField', [], {'blank': 'True', 'related_name': "'other_selections'", 'null': 'True', 'symmetrical': 'False', 'to': "orm['timeside.Selection']"}),
-            'title': ('django.db.models.fields.CharField', [], {'max_length': '512', 'blank': 'True'}),
-            'uuid': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '512', 'blank': 'True'})
-        },
-        'timeside.task': {
-            'Meta': {'object_name': 'Task', 'db_table': "'timeside_tasks'"},
-            'author': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'tasks'", 'null': 'True', 'on_delete': 'models.SET_NULL', 'to': "orm['auth.User']"}),
-            'experience': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'task'", 'null': 'True', 'to': "orm['timeside.Experience']"}),
-            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
-            'selection': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'task'", 'null': 'True', 'to': "orm['timeside.Selection']"}),
-            'status': ('django.db.models.fields.IntegerField', [], {'default': '1'})
-        }
-    }
-
-    complete_apps = ['timeside']
\ No newline at end of file
diff --git a/timeside/migrations/0003_auto__del_field_processor_type.py b/timeside/migrations/0003_auto__del_field_processor_type.py
deleted file mode 100644 (file)
index 1c5c6a2..0000000
+++ /dev/null
@@ -1,136 +0,0 @@
-# -*- coding: utf-8 -*-
-from south.utils import datetime_utils as datetime
-from south.db import db
-from south.v2 import SchemaMigration
-from django.db import models
-
-
-class Migration(SchemaMigration):
-
-    def forwards(self, orm):
-        # Deleting field 'Processor.type'
-        db.delete_column('timeside_processors', 'type')
-
-
-    def backwards(self, orm):
-        # Adding field 'Processor.type'
-        db.add_column('timeside_processors', 'type',
-                      self.gf('django.db.models.fields.CharField')(default='none', max_length=64),
-                      keep_default=False)
-
-
-    models = {
-        'auth.group': {
-            'Meta': {'object_name': 'Group'},
-            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
-            'name': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '80'}),
-            'permissions': ('django.db.models.fields.related.ManyToManyField', [], {'to': "orm['auth.Permission']", 'symmetrical': 'False', 'blank': 'True'})
-        },
-        'auth.permission': {
-            'Meta': {'ordering': "('content_type__app_label', 'content_type__model', 'codename')", 'unique_together': "(('content_type', 'codename'),)", 'object_name': 'Permission'},
-            'codename': ('django.db.models.fields.CharField', [], {'max_length': '100'}),
-            'content_type': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['contenttypes.ContentType']"}),
-            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
-            'name': ('django.db.models.fields.CharField', [], {'max_length': '50'})
-        },
-        'auth.user': {
-            'Meta': {'object_name': 'User'},
-            'date_joined': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime.now'}),
-            'email': ('django.db.models.fields.EmailField', [], {'max_length': '75', 'blank': 'True'}),
-            'first_name': ('django.db.models.fields.CharField', [], {'max_length': '30', 'blank': 'True'}),
-            'groups': ('django.db.models.fields.related.ManyToManyField', [], {'to': "orm['auth.Group']", 'symmetrical': 'False', 'blank': 'True'}),
-            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
-            'is_active': ('django.db.models.fields.BooleanField', [], {'default': 'True'}),
-            'is_staff': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
-            'is_superuser': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
-            'last_login': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime.now'}),
-            'last_name': ('django.db.models.fields.CharField', [], {'max_length': '30', 'blank': 'True'}),
-            'password': ('django.db.models.fields.CharField', [], {'max_length': '128'}),
-            'user_permissions': ('django.db.models.fields.related.ManyToManyField', [], {'to': "orm['auth.Permission']", 'symmetrical': 'False', 'blank': 'True'}),
-            'username': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '30'})
-        },
-        'contenttypes.contenttype': {
-            'Meta': {'ordering': "('name',)", 'unique_together': "(('app_label', 'model'),)", 'object_name': 'ContentType', 'db_table': "'django_content_type'"},
-            'app_label': ('django.db.models.fields.CharField', [], {'max_length': '100'}),
-            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
-            'model': ('django.db.models.fields.CharField', [], {'max_length': '100'}),
-            'name': ('django.db.models.fields.CharField', [], {'max_length': '100'})
-        },
-        'timeside.experience': {
-            'Meta': {'object_name': 'Experience', 'db_table': "'timeside_experiences'"},
-            'author': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'experiences'", 'null': 'True', 'on_delete': 'models.SET_NULL', 'to': "orm['auth.User']"}),
-            'date_added': ('django.db.models.fields.DateTimeField', [], {'auto_now_add': 'True', 'blank': 'True'}),
-            'date_modified': ('django.db.models.fields.DateTimeField', [], {'auto_now': 'True', 'null': 'True', 'blank': 'True'}),
-            'description': ('django.db.models.fields.TextField', [], {'blank': 'True'}),
-            'experiences': ('django.db.models.fields.related.ManyToManyField', [], {'blank': 'True', 'related_name': "'other_experiences'", 'null': 'True', 'symmetrical': 'False', 'to': "orm['timeside.Experience']"}),
-            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
-            'is_preset': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
-            'processors': ('django.db.models.fields.related.ManyToManyField', [], {'blank': 'True', 'related_name': "'experiences'", 'null': 'True', 'symmetrical': 'False', 'to': "orm['timeside.Processor']"}),
-            'title': ('django.db.models.fields.CharField', [], {'max_length': '512', 'blank': 'True'}),
-            'uuid': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '512', 'blank': 'True'})
-        },
-        'timeside.item': {
-            'Meta': {'ordering': "['title']", 'object_name': 'Item', 'db_table': "'timeside_items'"},
-            'author': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'items'", 'null': 'True', 'on_delete': 'models.SET_NULL', 'to': "orm['auth.User']"}),
-            'date_added': ('django.db.models.fields.DateTimeField', [], {'auto_now_add': 'True', 'blank': 'True'}),
-            'date_modified': ('django.db.models.fields.DateTimeField', [], {'auto_now': 'True', 'null': 'True', 'blank': 'True'}),
-            'description': ('django.db.models.fields.TextField', [], {'blank': 'True'}),
-            'file': ('django.db.models.fields.files.FileField', [], {'max_length': '1024', 'blank': 'True'}),
-            'hdf5': ('django.db.models.fields.files.FileField', [], {'max_length': '1024', 'blank': 'True'}),
-            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
-            'lock': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
-            'mime_type': ('django.db.models.fields.CharField', [], {'max_length': '256', 'blank': 'True'}),
-            'sha1': ('django.db.models.fields.CharField', [], {'max_length': '512', 'blank': 'True'}),
-            'title': ('django.db.models.fields.CharField', [], {'max_length': '512', 'blank': 'True'}),
-            'url': ('django.db.models.fields.URLField', [], {'max_length': '1024', 'blank': 'True'}),
-            'uuid': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '512', 'blank': 'True'})
-        },
-        'timeside.parameters': {
-            'Meta': {'object_name': 'Parameters'},
-            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
-            'is_preset': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
-            'parameters': ('django.db.models.fields.TextField', [], {'blank': 'True'}),
-            'processor': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'parameters'", 'null': 'True', 'to': "orm['timeside.Processor']"})
-        },
-        'timeside.processor': {
-            'Meta': {'object_name': 'Processor', 'db_table': "'timeside_processors'"},
-            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
-            'pid': ('django.db.models.fields.CharField', [], {'max_length': '256'}),
-            'version': ('django.db.models.fields.CharField', [], {'max_length': '64', 'blank': 'True'})
-        },
-        'timeside.result': {
-            'Meta': {'object_name': 'Result', 'db_table': "'timeside_results'"},
-            'date_added': ('django.db.models.fields.DateTimeField', [], {'auto_now_add': 'True', 'blank': 'True'}),
-            'date_modified': ('django.db.models.fields.DateTimeField', [], {'auto_now': 'True', 'null': 'True', 'blank': 'True'}),
-            'hdf5': ('django.db.models.fields.files.FileField', [], {'max_length': '1024', 'blank': 'True'}),
-            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
-            'item': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'results'", 'null': 'True', 'on_delete': 'models.SET_NULL', 'to': "orm['timeside.Item']"}),
-            'output': ('django.db.models.fields.files.FileField', [], {'max_length': '1024', 'blank': 'True'}),
-            'output_mime_type': ('django.db.models.fields.CharField', [], {'max_length': '256', 'blank': 'True'}),
-            'processor': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'results'", 'null': 'True', 'on_delete': 'models.SET_NULL', 'to': "orm['timeside.Processor']"}),
-            'status': ('django.db.models.fields.IntegerField', [], {'default': '1'}),
-            'uuid': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '512', 'blank': 'True'})
-        },
-        'timeside.selection': {
-            'Meta': {'object_name': 'Selection', 'db_table': "'timeside_selections'"},
-            'author': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'selections'", 'null': 'True', 'on_delete': 'models.SET_NULL', 'to': "orm['auth.User']"}),
-            'date_added': ('django.db.models.fields.DateTimeField', [], {'auto_now_add': 'True', 'blank': 'True'}),
-            'date_modified': ('django.db.models.fields.DateTimeField', [], {'auto_now': 'True', 'null': 'True', 'blank': 'True'}),
-            'description': ('django.db.models.fields.TextField', [], {'blank': 'True'}),
-            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
-            'items': ('django.db.models.fields.related.ManyToManyField', [], {'blank': 'True', 'related_name': "'selections'", 'null': 'True', 'symmetrical': 'False', 'to': "orm['timeside.Item']"}),
-            'selections': ('django.db.models.fields.related.ManyToManyField', [], {'blank': 'True', 'related_name': "'other_selections'", 'null': 'True', 'symmetrical': 'False', 'to': "orm['timeside.Selection']"}),
-            'title': ('django.db.models.fields.CharField', [], {'max_length': '512', 'blank': 'True'}),
-            'uuid': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '512', 'blank': 'True'})
-        },
-        'timeside.task': {
-            'Meta': {'object_name': 'Task', 'db_table': "'timeside_tasks'"},
-            'author': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'tasks'", 'null': 'True', 'on_delete': 'models.SET_NULL', 'to': "orm['auth.User']"}),
-            'experience': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'task'", 'null': 'True', 'to': "orm['timeside.Experience']"}),
-            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
-            'selection': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'task'", 'null': 'True', 'to': "orm['timeside.Selection']"}),
-            'status': ('django.db.models.fields.IntegerField', [], {'default': '1'})
-        }
-    }
-
-    complete_apps = ['timeside']
\ No newline at end of file
diff --git a/timeside/migrations/0004_auto__del_field_result_processor__add_field_result_parameters.py b/timeside/migrations/0004_auto__del_field_result_processor__add_field_result_parameters.py
deleted file mode 100644 (file)
index 6b03bcf..0000000
+++ /dev/null
@@ -1,144 +0,0 @@
-# -*- coding: utf-8 -*-
-from south.utils import datetime_utils as datetime
-from south.db import db
-from south.v2 import SchemaMigration
-from django.db import models
-
-
-class Migration(SchemaMigration):
-
-    def forwards(self, orm):
-        # Deleting field 'Result.processor'
-        db.delete_column('timeside_results', 'processor_id')
-
-        # Adding field 'Result.parameters'
-        db.add_column('timeside_results', 'parameters',
-                      self.gf('django.db.models.fields.related.ForeignKey')(blank=True, related_name='results', null=True, on_delete=models.SET_NULL, to=orm['timeside.Parameters']),
-                      keep_default=False)
-
-
-    def backwards(self, orm):
-        # Adding field 'Result.processor'
-        db.add_column('timeside_results', 'processor',
-                      self.gf('django.db.models.fields.related.ForeignKey')(related_name='results', null=True, to=orm['timeside.Processor'], on_delete=models.SET_NULL, blank=True),
-                      keep_default=False)
-
-        # Deleting field 'Result.parameters'
-        db.delete_column('timeside_results', 'parameters_id')
-
-
-    models = {
-        'auth.group': {
-            'Meta': {'object_name': 'Group'},
-            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
-            'name': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '80'}),
-            'permissions': ('django.db.models.fields.related.ManyToManyField', [], {'to': "orm['auth.Permission']", 'symmetrical': 'False', 'blank': 'True'})
-        },
-        'auth.permission': {
-            'Meta': {'ordering': "('content_type__app_label', 'content_type__model', 'codename')", 'unique_together': "(('content_type', 'codename'),)", 'object_name': 'Permission'},
-            'codename': ('django.db.models.fields.CharField', [], {'max_length': '100'}),
-            'content_type': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['contenttypes.ContentType']"}),
-            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
-            'name': ('django.db.models.fields.CharField', [], {'max_length': '50'})
-        },
-        'auth.user': {
-            'Meta': {'object_name': 'User'},
-            'date_joined': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime.now'}),
-            'email': ('django.db.models.fields.EmailField', [], {'max_length': '75', 'blank': 'True'}),
-            'first_name': ('django.db.models.fields.CharField', [], {'max_length': '30', 'blank': 'True'}),
-            'groups': ('django.db.models.fields.related.ManyToManyField', [], {'to': "orm['auth.Group']", 'symmetrical': 'False', 'blank': 'True'}),
-            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
-            'is_active': ('django.db.models.fields.BooleanField', [], {'default': 'True'}),
-            'is_staff': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
-            'is_superuser': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
-            'last_login': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime.now'}),
-            'last_name': ('django.db.models.fields.CharField', [], {'max_length': '30', 'blank': 'True'}),
-            'password': ('django.db.models.fields.CharField', [], {'max_length': '128'}),
-            'user_permissions': ('django.db.models.fields.related.ManyToManyField', [], {'to': "orm['auth.Permission']", 'symmetrical': 'False', 'blank': 'True'}),
-            'username': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '30'})
-        },
-        'contenttypes.contenttype': {
-            'Meta': {'ordering': "('name',)", 'unique_together': "(('app_label', 'model'),)", 'object_name': 'ContentType', 'db_table': "'django_content_type'"},
-            'app_label': ('django.db.models.fields.CharField', [], {'max_length': '100'}),
-            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
-            'model': ('django.db.models.fields.CharField', [], {'max_length': '100'}),
-            'name': ('django.db.models.fields.CharField', [], {'max_length': '100'})
-        },
-        'timeside.experience': {
-            'Meta': {'object_name': 'Experience', 'db_table': "'timeside_experiences'"},
-            'author': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'experiences'", 'null': 'True', 'on_delete': 'models.SET_NULL', 'to': "orm['auth.User']"}),
-            'date_added': ('django.db.models.fields.DateTimeField', [], {'auto_now_add': 'True', 'blank': 'True'}),
-            'date_modified': ('django.db.models.fields.DateTimeField', [], {'auto_now': 'True', 'null': 'True', 'blank': 'True'}),
-            'description': ('django.db.models.fields.TextField', [], {'blank': 'True'}),
-            'experiences': ('django.db.models.fields.related.ManyToManyField', [], {'blank': 'True', 'related_name': "'other_experiences'", 'null': 'True', 'symmetrical': 'False', 'to': "orm['timeside.Experience']"}),
-            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
-            'is_preset': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
-            'processors': ('django.db.models.fields.related.ManyToManyField', [], {'blank': 'True', 'related_name': "'experiences'", 'null': 'True', 'symmetrical': 'False', 'to': "orm['timeside.Processor']"}),
-            'title': ('django.db.models.fields.CharField', [], {'max_length': '512', 'blank': 'True'}),
-            'uuid': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '512', 'blank': 'True'})
-        },
-        'timeside.item': {
-            'Meta': {'ordering': "['title']", 'object_name': 'Item', 'db_table': "'timeside_items'"},
-            'author': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'items'", 'null': 'True', 'on_delete': 'models.SET_NULL', 'to': "orm['auth.User']"}),
-            'date_added': ('django.db.models.fields.DateTimeField', [], {'auto_now_add': 'True', 'blank': 'True'}),
-            'date_modified': ('django.db.models.fields.DateTimeField', [], {'auto_now': 'True', 'null': 'True', 'blank': 'True'}),
-            'description': ('django.db.models.fields.TextField', [], {'blank': 'True'}),
-            'file': ('django.db.models.fields.files.FileField', [], {'max_length': '1024', 'blank': 'True'}),
-            'hdf5': ('django.db.models.fields.files.FileField', [], {'max_length': '1024', 'blank': 'True'}),
-            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
-            'lock': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
-            'mime_type': ('django.db.models.fields.CharField', [], {'max_length': '256', 'blank': 'True'}),
-            'sha1': ('django.db.models.fields.CharField', [], {'max_length': '512', 'blank': 'True'}),
-            'title': ('django.db.models.fields.CharField', [], {'max_length': '512', 'blank': 'True'}),
-            'url': ('django.db.models.fields.URLField', [], {'max_length': '1024', 'blank': 'True'}),
-            'uuid': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '512', 'blank': 'True'})
-        },
-        'timeside.parameters': {
-            'Meta': {'object_name': 'Parameters'},
-            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
-            'is_preset': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
-            'parameters': ('django.db.models.fields.TextField', [], {'blank': 'True'}),
-            'processor': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'parameters'", 'null': 'True', 'to': "orm['timeside.Processor']"})
-        },
-        'timeside.processor': {
-            'Meta': {'object_name': 'Processor', 'db_table': "'timeside_processors'"},
-            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
-            'pid': ('django.db.models.fields.CharField', [], {'max_length': '256'}),
-            'version': ('django.db.models.fields.CharField', [], {'max_length': '64', 'blank': 'True'})
-        },
-        'timeside.result': {
-            'Meta': {'object_name': 'Result', 'db_table': "'timeside_results'"},
-            'date_added': ('django.db.models.fields.DateTimeField', [], {'auto_now_add': 'True', 'blank': 'True'}),
-            'date_modified': ('django.db.models.fields.DateTimeField', [], {'auto_now': 'True', 'null': 'True', 'blank': 'True'}),
-            'hdf5': ('django.db.models.fields.files.FileField', [], {'max_length': '1024', 'blank': 'True'}),
-            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
-            'item': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'results'", 'null': 'True', 'on_delete': 'models.SET_NULL', 'to': "orm['timeside.Item']"}),
-            'output': ('django.db.models.fields.files.FileField', [], {'max_length': '1024', 'blank': 'True'}),
-            'output_mime_type': ('django.db.models.fields.CharField', [], {'max_length': '256', 'blank': 'True'}),
-            'parameters': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'results'", 'null': 'True', 'on_delete': 'models.SET_NULL', 'to': "orm['timeside.Parameters']"}),
-            'status': ('django.db.models.fields.IntegerField', [], {'default': '1'}),
-            'uuid': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '512', 'blank': 'True'})
-        },
-        'timeside.selection': {
-            'Meta': {'object_name': 'Selection', 'db_table': "'timeside_selections'"},
-            'author': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'selections'", 'null': 'True', 'on_delete': 'models.SET_NULL', 'to': "orm['auth.User']"}),
-            'date_added': ('django.db.models.fields.DateTimeField', [], {'auto_now_add': 'True', 'blank': 'True'}),
-            'date_modified': ('django.db.models.fields.DateTimeField', [], {'auto_now': 'True', 'null': 'True', 'blank': 'True'}),
-            'description': ('django.db.models.fields.TextField', [], {'blank': 'True'}),
-            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
-            'items': ('django.db.models.fields.related.ManyToManyField', [], {'blank': 'True', 'related_name': "'selections'", 'null': 'True', 'symmetrical': 'False', 'to': "orm['timeside.Item']"}),
-            'selections': ('django.db.models.fields.related.ManyToManyField', [], {'blank': 'True', 'related_name': "'other_selections'", 'null': 'True', 'symmetrical': 'False', 'to': "orm['timeside.Selection']"}),
-            'title': ('django.db.models.fields.CharField', [], {'max_length': '512', 'blank': 'True'}),
-            'uuid': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '512', 'blank': 'True'})
-        },
-        'timeside.task': {
-            'Meta': {'object_name': 'Task', 'db_table': "'timeside_tasks'"},
-            'author': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'tasks'", 'null': 'True', 'on_delete': 'models.SET_NULL', 'to': "orm['auth.User']"}),
-            'experience': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'task'", 'null': 'True', 'to': "orm['timeside.Experience']"}),
-            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
-            'selection': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'task'", 'null': 'True', 'to': "orm['timeside.Selection']"}),
-            'status': ('django.db.models.fields.IntegerField', [], {'default': '1'})
-        }
-    }
-
-    complete_apps = ['timeside']
\ No newline at end of file
diff --git a/timeside/migrations/0005_auto__del_field_result_output_mime_type__del_field_result_output__add_.py b/timeside/migrations/0005_auto__del_field_result_output_mime_type__del_field_result_output__add_.py
deleted file mode 100644 (file)
index 64dd868..0000000
+++ /dev/null
@@ -1,166 +0,0 @@
-# -*- coding: utf-8 -*-
-from south.utils import datetime_utils as datetime
-from south.db import db
-from south.v2 import SchemaMigration
-from django.db import models
-
-
-class Migration(SchemaMigration):
-
-    def forwards(self, orm):
-        # Deleting field 'Result.output_mime_type'
-        db.delete_column('timeside_results', 'output_mime_type')
-
-        # Deleting field 'Result.output'
-        db.delete_column('timeside_results', 'output')
-
-        # Adding field 'Result.file'
-        db.add_column('timeside_results', 'file',
-                      self.gf('django.db.models.fields.files.FileField')(max_length=1024, null=True, blank=True),
-                      keep_default=False)
-
-        # Adding field 'Result.mime_type'
-        db.add_column('timeside_results', 'mime_type',
-                      self.gf('django.db.models.fields.CharField')(default='', max_length=256, blank=True),
-                      keep_default=False)
-
-
-        # Changing field 'Result.hdf5'
-        db.alter_column('timeside_results', 'hdf5', self.gf('django.db.models.fields.files.FileField')(max_length=1024, null=True))
-
-    def backwards(self, orm):
-        # Adding field 'Result.output_mime_type'
-        db.add_column('timeside_results', 'output_mime_type',
-                      self.gf('django.db.models.fields.CharField')(default='', max_length=256, blank=True),
-                      keep_default=False)
-
-        # Adding field 'Result.output'
-        db.add_column('timeside_results', 'output',
-                      self.gf('django.db.models.fields.files.FileField')(default='foo.bar', max_length=1024, blank=True),
-                      keep_default=False)
-
-        # Deleting field 'Result.file'
-        db.delete_column('timeside_results', 'file')
-
-        # Deleting field 'Result.mime_type'
-        db.delete_column('timeside_results', 'mime_type')
-
-
-        # Changing field 'Result.hdf5'
-        db.alter_column('timeside_results', 'hdf5', self.gf('django.db.models.fields.files.FileField')(default='foo.bar', max_length=1024))
-
-    models = {
-        'auth.group': {
-            'Meta': {'object_name': 'Group'},
-            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
-            'name': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '80'}),
-            'permissions': ('django.db.models.fields.related.ManyToManyField', [], {'to': "orm['auth.Permission']", 'symmetrical': 'False', 'blank': 'True'})
-        },
-        'auth.permission': {
-            'Meta': {'ordering': "('content_type__app_label', 'content_type__model', 'codename')", 'unique_together': "(('content_type', 'codename'),)", 'object_name': 'Permission'},
-            'codename': ('django.db.models.fields.CharField', [], {'max_length': '100'}),
-            'content_type': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['contenttypes.ContentType']"}),
-            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
-            'name': ('django.db.models.fields.CharField', [], {'max_length': '50'})
-        },
-        'auth.user': {
-            'Meta': {'object_name': 'User'},
-            'date_joined': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime.now'}),
-            'email': ('django.db.models.fields.EmailField', [], {'max_length': '75', 'blank': 'True'}),
-            'first_name': ('django.db.models.fields.CharField', [], {'max_length': '30', 'blank': 'True'}),
-            'groups': ('django.db.models.fields.related.ManyToManyField', [], {'to': "orm['auth.Group']", 'symmetrical': 'False', 'blank': 'True'}),
-            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
-            'is_active': ('django.db.models.fields.BooleanField', [], {'default': 'True'}),
-            'is_staff': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
-            'is_superuser': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
-            'last_login': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime.now'}),
-            'last_name': ('django.db.models.fields.CharField', [], {'max_length': '30', 'blank': 'True'}),
-            'password': ('django.db.models.fields.CharField', [], {'max_length': '128'}),
-            'user_permissions': ('django.db.models.fields.related.ManyToManyField', [], {'to': "orm['auth.Permission']", 'symmetrical': 'False', 'blank': 'True'}),
-            'username': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '30'})
-        },
-        'contenttypes.contenttype': {
-            'Meta': {'ordering': "('name',)", 'unique_together': "(('app_label', 'model'),)", 'object_name': 'ContentType', 'db_table': "'django_content_type'"},
-            'app_label': ('django.db.models.fields.CharField', [], {'max_length': '100'}),
-            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
-            'model': ('django.db.models.fields.CharField', [], {'max_length': '100'}),
-            'name': ('django.db.models.fields.CharField', [], {'max_length': '100'})
-        },
-        'timeside.experience': {
-            'Meta': {'object_name': 'Experience', 'db_table': "'timeside_experiences'"},
-            'author': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'experiences'", 'null': 'True', 'on_delete': 'models.SET_NULL', 'to': "orm['auth.User']"}),
-            'date_added': ('django.db.models.fields.DateTimeField', [], {'auto_now_add': 'True', 'blank': 'True'}),
-            'date_modified': ('django.db.models.fields.DateTimeField', [], {'auto_now': 'True', 'null': 'True', 'blank': 'True'}),
-            'description': ('django.db.models.fields.TextField', [], {'blank': 'True'}),
-            'experiences': ('django.db.models.fields.related.ManyToManyField', [], {'blank': 'True', 'related_name': "'other_experiences'", 'null': 'True', 'symmetrical': 'False', 'to': "orm['timeside.Experience']"}),
-            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
-            'is_preset': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
-            'processors': ('django.db.models.fields.related.ManyToManyField', [], {'blank': 'True', 'related_name': "'experiences'", 'null': 'True', 'symmetrical': 'False', 'to': "orm['timeside.Processor']"}),
-            'title': ('django.db.models.fields.CharField', [], {'max_length': '512', 'blank': 'True'}),
-            'uuid': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '512', 'blank': 'True'})
-        },
-        'timeside.item': {
-            'Meta': {'ordering': "['title']", 'object_name': 'Item', 'db_table': "'timeside_items'"},
-            'author': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'items'", 'null': 'True', 'on_delete': 'models.SET_NULL', 'to': "orm['auth.User']"}),
-            'date_added': ('django.db.models.fields.DateTimeField', [], {'auto_now_add': 'True', 'blank': 'True'}),
-            'date_modified': ('django.db.models.fields.DateTimeField', [], {'auto_now': 'True', 'null': 'True', 'blank': 'True'}),
-            'description': ('django.db.models.fields.TextField', [], {'blank': 'True'}),
-            'file': ('django.db.models.fields.files.FileField', [], {'max_length': '1024', 'blank': 'True'}),
-            'hdf5': ('django.db.models.fields.files.FileField', [], {'max_length': '1024', 'blank': 'True'}),
-            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
-            'lock': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
-            'mime_type': ('django.db.models.fields.CharField', [], {'max_length': '256', 'blank': 'True'}),
-            'sha1': ('django.db.models.fields.CharField', [], {'max_length': '512', 'blank': 'True'}),
-            'title': ('django.db.models.fields.CharField', [], {'max_length': '512', 'blank': 'True'}),
-            'url': ('django.db.models.fields.URLField', [], {'max_length': '1024', 'blank': 'True'}),
-            'uuid': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '512', 'blank': 'True'})
-        },
-        'timeside.parameters': {
-            'Meta': {'object_name': 'Parameters'},
-            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
-            'is_preset': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
-            'parameters': ('django.db.models.fields.TextField', [], {'blank': 'True'}),
-            'processor': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'parameters'", 'null': 'True', 'to': "orm['timeside.Processor']"})
-        },
-        'timeside.processor': {
-            'Meta': {'object_name': 'Processor', 'db_table': "'timeside_processors'"},
-            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
-            'pid': ('django.db.models.fields.CharField', [], {'max_length': '256'}),
-            'version': ('django.db.models.fields.CharField', [], {'max_length': '64', 'blank': 'True'})
-        },
-        'timeside.result': {
-            'Meta': {'object_name': 'Result', 'db_table': "'timeside_results'"},
-            'date_added': ('django.db.models.fields.DateTimeField', [], {'auto_now_add': 'True', 'blank': 'True'}),
-            'date_modified': ('django.db.models.fields.DateTimeField', [], {'auto_now': 'True', 'null': 'True', 'blank': 'True'}),
-            'file': ('django.db.models.fields.files.FileField', [], {'max_length': '1024', 'null': 'True', 'blank': 'True'}),
-            'hdf5': ('django.db.models.fields.files.FileField', [], {'max_length': '1024', 'null': 'True', 'blank': 'True'}),
-            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
-            'item': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'results'", 'null': 'True', 'on_delete': 'models.SET_NULL', 'to': "orm['timeside.Item']"}),
-            'mime_type': ('django.db.models.fields.CharField', [], {'max_length': '256', 'blank': 'True'}),
-            'parameters': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'results'", 'null': 'True', 'on_delete': 'models.SET_NULL', 'to': "orm['timeside.Parameters']"}),
-            'status': ('django.db.models.fields.IntegerField', [], {'default': '1'}),
-            'uuid': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '512', 'blank': 'True'})
-        },
-        'timeside.selection': {
-            'Meta': {'object_name': 'Selection', 'db_table': "'timeside_selections'"},
-            'author': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'selections'", 'null': 'True', 'on_delete': 'models.SET_NULL', 'to': "orm['auth.User']"}),
-            'date_added': ('django.db.models.fields.DateTimeField', [], {'auto_now_add': 'True', 'blank': 'True'}),
-            'date_modified': ('django.db.models.fields.DateTimeField', [], {'auto_now': 'True', 'null': 'True', 'blank': 'True'}),
-            'description': ('django.db.models.fields.TextField', [], {'blank': 'True'}),
-            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
-            'items': ('django.db.models.fields.related.ManyToManyField', [], {'blank': 'True', 'related_name': "'selections'", 'null': 'True', 'symmetrical': 'False', 'to': "orm['timeside.Item']"}),
-            'selections': ('django.db.models.fields.related.ManyToManyField', [], {'blank': 'True', 'related_name': "'other_selections'", 'null': 'True', 'symmetrical': 'False', 'to': "orm['timeside.Selection']"}),
-            'title': ('django.db.models.fields.CharField', [], {'max_length': '512', 'blank': 'True'}),
-            'uuid': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '512', 'blank': 'True'})
-        },
-        'timeside.task': {
-            'Meta': {'object_name': 'Task', 'db_table': "'timeside_tasks'"},
-            'author': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'tasks'", 'null': 'True', 'on_delete': 'models.SET_NULL', 'to': "orm['auth.User']"}),
-            'experience': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'task'", 'null': 'True', 'to': "orm['timeside.Experience']"}),
-            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
-            'selection': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'task'", 'null': 'True', 'to': "orm['timeside.Selection']"}),
-            'status': ('django.db.models.fields.IntegerField', [], {'default': '1'})
-        }
-    }
-
-    complete_apps = ['timeside']
\ No newline at end of file
diff --git a/timeside/migrations/0006_auto__del_parameters__add_preset__del_field_result_parameters__add_fie.py b/timeside/migrations/0006_auto__del_parameters__add_preset__del_field_result_parameters__add_fie.py
deleted file mode 100644 (file)
index 5f9d3fe..0000000
+++ /dev/null
@@ -1,220 +0,0 @@
-# -*- coding: utf-8 -*-
-from south.utils import datetime_utils as datetime
-from south.db import db
-from south.v2 import SchemaMigration
-from django.db import models
-
-
-class Migration(SchemaMigration):
-
-    def forwards(self, orm):
-        # Deleting model 'Parameters'
-        db.delete_table('timeside_parameters')
-
-        # Adding model 'Preset'
-        db.create_table('timeside_presets', (
-            ('id', self.gf('django.db.models.fields.AutoField')(primary_key=True)),
-            ('processor', self.gf('django.db.models.fields.related.ForeignKey')(blank=True, related_name='preset', null=True, to=orm['timeside.Processor'])),
-            ('parameters', self.gf('django.db.models.fields.TextField')(blank=True)),
-            ('is_public', self.gf('django.db.models.fields.BooleanField')(default=False)),
-        ))
-        db.send_create_signal('timeside', ['Preset'])
-
-        # Deleting field 'Result.parameters'
-        db.delete_column('timeside_results', 'parameters_id')
-
-        # Adding field 'Result.preset'
-        db.add_column('timeside_results', 'preset',
-                      self.gf('django.db.models.fields.related.ForeignKey')(blank=True, related_name='results', null=True, on_delete=models.SET_NULL, to=orm['timeside.Preset']),
-                      keep_default=False)
-
-
-        # Changing field 'Result.hdf5'
-        db.alter_column('timeside_results', 'hdf5', self.gf('django.db.models.fields.files.FileField')(default=0, max_length=1024))
-
-        # Changing field 'Result.file'
-        db.alter_column('timeside_results', 'file', self.gf('django.db.models.fields.files.FileField')(default=0, max_length=1024))
-        # Deleting field 'Experience.is_preset'
-        db.delete_column('timeside_experiences', 'is_preset')
-
-        # Adding field 'Experience.is_public'
-        db.add_column('timeside_experiences', 'is_public',
-                      self.gf('django.db.models.fields.BooleanField')(default=False),
-                      keep_default=False)
-
-        # Removing M2M table for field processors on 'Experience'
-        db.delete_table(db.shorten_name('timeside_experiences_processors'))
-
-        # Adding M2M table for field presets on 'Experience'
-        m2m_table_name = db.shorten_name('timeside_experiences_presets')
-        db.create_table(m2m_table_name, (
-            ('id', models.AutoField(verbose_name='ID', primary_key=True, auto_created=True)),
-            ('experience', models.ForeignKey(orm['timeside.experience'], null=False)),
-            ('preset', models.ForeignKey(orm['timeside.preset'], null=False))
-        ))
-        db.create_unique(m2m_table_name, ['experience_id', 'preset_id'])
-
-
-    def backwards(self, orm):
-        # Adding model 'Parameters'
-        db.create_table('timeside_parameters', (
-            ('parameters', self.gf('django.db.models.fields.TextField')(blank=True)),
-            ('id', self.gf('django.db.models.fields.AutoField')(primary_key=True)),
-            ('is_preset', self.gf('django.db.models.fields.BooleanField')(default=False)),
-            ('processor', self.gf('django.db.models.fields.related.ForeignKey')(related_name='parameters', null=True, to=orm['timeside.Processor'], blank=True)),
-        ))
-        db.send_create_signal('timeside', ['Parameters'])
-
-        # Deleting model 'Preset'
-        db.delete_table('timeside_presets')
-
-        # Adding field 'Result.parameters'
-        db.add_column('timeside_results', 'parameters',
-                      self.gf('django.db.models.fields.related.ForeignKey')(related_name='results', null=True, to=orm['timeside.Parameters'], on_delete=models.SET_NULL, blank=True),
-                      keep_default=False)
-
-        # Deleting field 'Result.preset'
-        db.delete_column('timeside_results', 'preset_id')
-
-
-        # Changing field 'Result.hdf5'
-        db.alter_column('timeside_results', 'hdf5', self.gf('django.db.models.fields.files.FileField')(max_length=1024, null=True))
-
-        # Changing field 'Result.file'
-        db.alter_column('timeside_results', 'file', self.gf('django.db.models.fields.files.FileField')(max_length=1024, null=True))
-        # Adding field 'Experience.is_preset'
-        db.add_column('timeside_experiences', 'is_preset',
-                      self.gf('django.db.models.fields.BooleanField')(default=False),
-                      keep_default=False)
-
-        # Deleting field 'Experience.is_public'
-        db.delete_column('timeside_experiences', 'is_public')
-
-        # Adding M2M table for field processors on 'Experience'
-        m2m_table_name = db.shorten_name('timeside_experiences_processors')
-        db.create_table(m2m_table_name, (
-            ('id', models.AutoField(verbose_name='ID', primary_key=True, auto_created=True)),
-            ('experience', models.ForeignKey(orm['timeside.experience'], null=False)),
-            ('processor', models.ForeignKey(orm['timeside.processor'], null=False))
-        ))
-        db.create_unique(m2m_table_name, ['experience_id', 'processor_id'])
-
-        # Removing M2M table for field presets on 'Experience'
-        db.delete_table(db.shorten_name('timeside_experiences_presets'))
-
-
-    models = {
-        'auth.group': {
-            'Meta': {'object_name': 'Group'},
-            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
-            'name': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '80'}),
-            'permissions': ('django.db.models.fields.related.ManyToManyField', [], {'to': "orm['auth.Permission']", 'symmetrical': 'False', 'blank': 'True'})
-        },
-        'auth.permission': {
-            'Meta': {'ordering': "('content_type__app_label', 'content_type__model', 'codename')", 'unique_together': "(('content_type', 'codename'),)", 'object_name': 'Permission'},
-            'codename': ('django.db.models.fields.CharField', [], {'max_length': '100'}),
-            'content_type': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['contenttypes.ContentType']"}),
-            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
-            'name': ('django.db.models.fields.CharField', [], {'max_length': '50'})
-        },
-        'auth.user': {
-            'Meta': {'object_name': 'User'},
-            'date_joined': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime.now'}),
-            'email': ('django.db.models.fields.EmailField', [], {'max_length': '75', 'blank': 'True'}),
-            'first_name': ('django.db.models.fields.CharField', [], {'max_length': '30', 'blank': 'True'}),
-            'groups': ('django.db.models.fields.related.ManyToManyField', [], {'to': "orm['auth.Group']", 'symmetrical': 'False', 'blank': 'True'}),
-            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
-            'is_active': ('django.db.models.fields.BooleanField', [], {'default': 'True'}),
-            'is_staff': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
-            'is_superuser': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
-            'last_login': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime.now'}),
-            'last_name': ('django.db.models.fields.CharField', [], {'max_length': '30', 'blank': 'True'}),
-            'password': ('django.db.models.fields.CharField', [], {'max_length': '128'}),
-            'user_permissions': ('django.db.models.fields.related.ManyToManyField', [], {'to': "orm['auth.Permission']", 'symmetrical': 'False', 'blank': 'True'}),
-            'username': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '30'})
-        },
-        'contenttypes.contenttype': {
-            'Meta': {'ordering': "('name',)", 'unique_together': "(('app_label', 'model'),)", 'object_name': 'ContentType', 'db_table': "'django_content_type'"},
-            'app_label': ('django.db.models.fields.CharField', [], {'max_length': '100'}),
-            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
-            'model': ('django.db.models.fields.CharField', [], {'max_length': '100'}),
-            'name': ('django.db.models.fields.CharField', [], {'max_length': '100'})
-        },
-        'timeside.experience': {
-            'Meta': {'object_name': 'Experience', 'db_table': "'timeside_experiences'"},
-            'author': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'experiences'", 'null': 'True', 'on_delete': 'models.SET_NULL', 'to': "orm['auth.User']"}),
-            'date_added': ('django.db.models.fields.DateTimeField', [], {'auto_now_add': 'True', 'blank': 'True'}),
-            'date_modified': ('django.db.models.fields.DateTimeField', [], {'auto_now': 'True', 'null': 'True', 'blank': 'True'}),
-            'description': ('django.db.models.fields.TextField', [], {'blank': 'True'}),
-            'experiences': ('django.db.models.fields.related.ManyToManyField', [], {'blank': 'True', 'related_name': "'other_experiences'", 'null': 'True', 'symmetrical': 'False', 'to': "orm['timeside.Experience']"}),
-            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
-            'is_public': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
-            'presets': ('django.db.models.fields.related.ManyToManyField', [], {'blank': 'True', 'related_name': "'experiences'", 'null': 'True', 'symmetrical': 'False', 'to': "orm['timeside.Preset']"}),
-            'title': ('django.db.models.fields.CharField', [], {'max_length': '512', 'blank': 'True'}),
-            'uuid': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '512', 'blank': 'True'})
-        },
-        'timeside.item': {
-            'Meta': {'ordering': "['title']", 'object_name': 'Item', 'db_table': "'timeside_items'"},
-            'author': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'items'", 'null': 'True', 'on_delete': 'models.SET_NULL', 'to': "orm['auth.User']"}),
-            'date_added': ('django.db.models.fields.DateTimeField', [], {'auto_now_add': 'True', 'blank': 'True'}),
-            'date_modified': ('django.db.models.fields.DateTimeField', [], {'auto_now': 'True', 'null': 'True', 'blank': 'True'}),
-            'description': ('django.db.models.fields.TextField', [], {'blank': 'True'}),
-            'file': ('django.db.models.fields.files.FileField', [], {'max_length': '1024', 'blank': 'True'}),
-            'hdf5': ('django.db.models.fields.files.FileField', [], {'max_length': '1024', 'blank': 'True'}),
-            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
-            'lock': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
-            'mime_type': ('django.db.models.fields.CharField', [], {'max_length': '256', 'blank': 'True'}),
-            'sha1': ('django.db.models.fields.CharField', [], {'max_length': '512', 'blank': 'True'}),
-            'title': ('django.db.models.fields.CharField', [], {'max_length': '512', 'blank': 'True'}),
-            'url': ('django.db.models.fields.URLField', [], {'max_length': '1024', 'blank': 'True'}),
-            'uuid': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '512', 'blank': 'True'})
-        },
-        'timeside.preset': {
-            'Meta': {'object_name': 'Preset', 'db_table': "'timeside_presets'"},
-            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
-            'is_public': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
-            'parameters': ('django.db.models.fields.TextField', [], {'blank': 'True'}),
-            'processor': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'preset'", 'null': 'True', 'to': "orm['timeside.Processor']"})
-        },
-        'timeside.processor': {
-            'Meta': {'object_name': 'Processor', 'db_table': "'timeside_processors'"},
-            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
-            'pid': ('django.db.models.fields.CharField', [], {'max_length': '256'}),
-            'version': ('django.db.models.fields.CharField', [], {'max_length': '64', 'blank': 'True'})
-        },
-        'timeside.result': {
-            'Meta': {'object_name': 'Result', 'db_table': "'timeside_results'"},
-            'date_added': ('django.db.models.fields.DateTimeField', [], {'auto_now_add': 'True', 'blank': 'True'}),
-            'date_modified': ('django.db.models.fields.DateTimeField', [], {'auto_now': 'True', 'null': 'True', 'blank': 'True'}),
-            'file': ('django.db.models.fields.files.FileField', [], {'max_length': '1024', 'blank': 'True'}),
-            'hdf5': ('django.db.models.fields.files.FileField', [], {'max_length': '1024', 'blank': 'True'}),
-            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
-            'item': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'results'", 'null': 'True', 'on_delete': 'models.SET_NULL', 'to': "orm['timeside.Item']"}),
-            'mime_type': ('django.db.models.fields.CharField', [], {'max_length': '256', 'blank': 'True'}),
-            'preset': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'results'", 'null': 'True', 'on_delete': 'models.SET_NULL', 'to': "orm['timeside.Preset']"}),
-            'status': ('django.db.models.fields.IntegerField', [], {'default': '1'}),
-            'uuid': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '512', 'blank': 'True'})
-        },
-        'timeside.selection': {
-            'Meta': {'object_name': 'Selection', 'db_table': "'timeside_selections'"},
-            'author': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'selections'", 'null': 'True', 'on_delete': 'models.SET_NULL', 'to': "orm['auth.User']"}),
-            'date_added': ('django.db.models.fields.DateTimeField', [], {'auto_now_add': 'True', 'blank': 'True'}),
-            'date_modified': ('django.db.models.fields.DateTimeField', [], {'auto_now': 'True', 'null': 'True', 'blank': 'True'}),
-            'description': ('django.db.models.fields.TextField', [], {'blank': 'True'}),
-            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
-            'items': ('django.db.models.fields.related.ManyToManyField', [], {'blank': 'True', 'related_name': "'selections'", 'null': 'True', 'symmetrical': 'False', 'to': "orm['timeside.Item']"}),
-            'selections': ('django.db.models.fields.related.ManyToManyField', [], {'blank': 'True', 'related_name': "'other_selections'", 'null': 'True', 'symmetrical': 'False', 'to': "orm['timeside.Selection']"}),
-            'title': ('django.db.models.fields.CharField', [], {'max_length': '512', 'blank': 'True'}),
-            'uuid': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '512', 'blank': 'True'})
-        },
-        'timeside.task': {
-            'Meta': {'object_name': 'Task', 'db_table': "'timeside_tasks'"},
-            'author': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'tasks'", 'null': 'True', 'on_delete': 'models.SET_NULL', 'to': "orm['auth.User']"}),
-            'experience': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'task'", 'null': 'True', 'to': "orm['timeside.Experience']"}),
-            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
-            'selection': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'task'", 'null': 'True', 'to': "orm['timeside.Selection']"}),
-            'status': ('django.db.models.fields.IntegerField', [], {'default': '1'})
-        }
-    }
-
-    complete_apps = ['timeside']
\ No newline at end of file
diff --git a/timeside/migrations/__init__.py b/timeside/migrations/__init__.py
deleted file mode 100644 (file)
index e69de29..0000000
diff --git a/timeside/models.py b/timeside/models.py
deleted file mode 100644 (file)
index 67052b4..0000000
+++ /dev/null
@@ -1,263 +0,0 @@
-# -*- coding: utf-8 -*-
-
-import timeside, os, uuid, time, hashlib, mimetypes
-
-from timeside.analyzer.core import AnalyzerResultContainer, AnalyzerResult
-from timeside.decoder.utils import sha1sum_file
-
-from django.db import models
-from django.utils.translation import ugettext_lazy as _
-from django.contrib.auth.models import User
-from django.db.models.signals import post_save
-from django.conf import settings
-
-app = 'timeside'
-
-processors = timeside.core.processors(timeside.api.IProcessor)
-
-PROCESSOR_PIDS = [(processor.id(), processor.id())  for processor in processors]
-
-STATUS = ((0, _('failed')), (1, _('pending')), (2, _('running')),
-                         (3, _('done')), (4, _('ready')))
-
-def get_mime_type(path):
-    return mimetypes.guess_type(path)[0]
-
-def get_processor(pid):
-    for proc in processors:
-        if proc.id() == pid:
-            return proc()
-    raise ValueError('Processor %s does not exists' % pid) 
-
-def set_mimetype(sender, **kwargs):
-    instance = kwargs['instance']
-    if instance.file:
-        if not instance.mime_type:
-            instance.mime_type = get_mime_type(instance.file.path)
-
-def set_hash(sender, **kwargs):
-    instance = kwargs['instance']
-    if instance.file:
-        if not instance.sha1:
-            instance.sha1 = sha1sum_file(instance.file.path)
-
-class MetaCore:
-
-    app_label = app
-
-
-class BaseResource(models.Model):
-
-    date_added = models.DateTimeField(_('date added'), auto_now_add=True)
-    date_modified = models.DateTimeField(_('date modified'), auto_now=True, null=True)
-    uuid = models.CharField(_('uuid'), unique=True, blank=True, max_length=512, editable=False)
-
-    class Meta(MetaCore):
-        abstract = True
-    
-    def save(self, **kwargs):
-        if not self.uuid:
-            self.uuid = uuid.uuid4()
-        super(BaseResource, self).save(**kwargs)
-
-
-class DocBaseResource(BaseResource):
-
-    title = models.CharField(_('title'), blank=True, max_length=512)
-    description = models.TextField(_('description'), blank=True)
-
-    def __unicode__(self):
-        return self.title    
-    
-    class Meta(MetaCore):
-        abstract = True
-    
-
-class Selection(DocBaseResource):
-
-    items = models.ManyToManyField('Item', related_name="selections", verbose_name=_('items'), blank=True, null=True)
-    author = models.ForeignKey(User, related_name="selections", verbose_name=_('author'), blank=True, null=True, on_delete=models.SET_NULL)
-    selections = models.ManyToManyField('Selection', related_name="other_selections", verbose_name=_('other selections'), blank=True, null=True)
-
-    class Meta(MetaCore):
-        db_table = app + '_selections'
-        verbose_name = _('selection')
-
-
-class Item(DocBaseResource):
-
-    file = models.FileField(_('file'), upload_to='items/%Y/%m/%d', blank=True, max_length=1024)
-    url = models.URLField(_('URL'), blank=True, max_length=1024)
-    sha1 = models.CharField(_('sha1'), blank=True, max_length=512)
-    mime_type = models.CharField(_('mime type'), blank=True, max_length=256)
-    hdf5 = models.FileField(_('HDF5 result file'), upload_to='results/%Y/%m/%d', blank=True, max_length=1024)
-    lock = models.BooleanField(default=False)
-    author = models.ForeignKey(User, related_name="items", verbose_name=_('author'), blank=True, null=True, on_delete=models.SET_NULL)
-
-    class Meta(MetaCore):
-        db_table = app + '_items'
-        ordering = ['title']
-        verbose_name = _('item')
-
-    def results(self):
-        return [result for result in self.results.all()]
-
-    def lock_setter(self, lock):
-        self.lock = lock
-        self.save()
-
-
-class Experience(DocBaseResource):
-
-    presets = models.ManyToManyField('Preset', related_name="experiences", verbose_name=_('presets'), blank=True, null=True)
-    author = models.ForeignKey(User, related_name="experiences", verbose_name=_('author'), blank=True, null=True, on_delete=models.SET_NULL)
-    experiences = models.ManyToManyField('Experience', related_name="other_experiences", verbose_name=_('other experiences'), blank=True, null=True)
-    is_public = models.BooleanField(default=False)
-
-    class Meta(MetaCore):
-        db_table = app + '_experiences'
-        verbose_name = _('Experience')
-
-    
-
-class Processor(models.Model):
-    
-    pid = models.CharField(_('pid'), choices=PROCESSOR_PIDS, max_length=256)
-    version = models.CharField(_('version'), max_length=64, blank=True)
-
-    class Meta(MetaCore):
-        db_table = app + '_processors'
-        verbose_name = _('processor')
-
-    def __unicode__(self):
-        return '_'.join([self.pid, str(self.id)])
-    
-    def save(self, **kwargs):
-        if not self.version:
-            self.version = timeside.__version__
-        super(Processor, self).save(**kwargs)
-        
-
-class Preset(models.Model):
-
-    processor = models.ForeignKey('Processor', related_name="preset", verbose_name=_('processor'), blank=True, null=True)
-    parameters = models.TextField(_('Parameters'), blank=True)
-    is_public = models.BooleanField(default=False)
-
-    class Meta:
-        db_table = app + '_presets'
-        verbose_name = _('Preset')
-        verbose_name_plural = _('Presets')
-
-    def __unicode__(self):
-        return '_'.join([unicode(self.processor), str(self.id)])
-
-    
-class Result(BaseResource):
-
-    item = models.ForeignKey('Item', related_name="results", verbose_name=_('item'), blank=True, null=True, on_delete=models.SET_NULL)
-    preset = models.ForeignKey('Preset', related_name="results", verbose_name=_('preset'), blank=True, null=True, on_delete=models.SET_NULL)
-    hdf5 = models.FileField(_('HDF5 result file'), upload_to='results/%Y/%m/%d', blank=True, max_length=1024)
-    file = models.FileField(_('Output file'), upload_to='results/%Y/%m/%d', blank=True, max_length=1024)
-    mime_type = models.CharField(_('Output file MIME type'), blank=True, max_length=256)
-    status = models.IntegerField(_('status'), choices=STATUS, default=1)
-    
-    class Meta(MetaCore):
-        db_table = app + '_results'
-        verbose_name = _('Result')
-        verbose_name_plural = _('Results')
-
-    def status_setter(self, status):
-        self.status = status
-        self.save()
-
-    def __unicode__(self):
-        return '_'.join([self.item.title, unicode(self.parameters.processor)])
-
-
-class Task(models.Model):
-
-    experience = models.ForeignKey('Experience', related_name="task", verbose_name=_('experience'), blank=True, null=True)
-    selection = models.ForeignKey('Selection', related_name="task", verbose_name=_('selection'), blank=True, null=True)
-    status = models.IntegerField(_('status'), choices=STATUS, default=1)
-    author = models.ForeignKey(User, related_name="tasks", verbose_name=_('author'), blank=True, null=True, on_delete=models.SET_NULL)    
-
-    class Meta(MetaCore):
-        db_table = app + '_tasks'
-        verbose_name = _('Task')
-        verbose_name_plural = _('Tasks')
-
-    def __unicode__(self):
-        return '_'.join([unicode(self.experience), unicode(self.id)])
-
-    def status_setter(self, status):
-        self.status = status
-        self.save()
-
-    def run(self):
-        results_root = 'results'
-        if not os.path.exists(settings.MEDIA_ROOT + results_root):
-            os.makedirs(settings.MEDIA_ROOT + results_root)
-
-        self.status_setter(2)
-
-        for item in self.selection.items.all():
-            path = results_root + os.sep + item.uuid + os.sep
-            if not os.path.exists(settings.MEDIA_ROOT + os.sep + path):
-                os.makedirs(settings.MEDIA_ROOT + os.sep + path)
-            
-            # pipe = timeside.decoder.FileDecoder(item.file.path, sha1=item.sha1)
-            pipe = timeside.decoder.FileDecoder(item.file.path)
-            
-            proc_dict = {}
-
-            for preset in self.experience.presets.all():
-                proc = get_processor(preset.processor.pid)
-                proc_dict[preset.processor] = proc
-                #proc.set_parameters(preset.parameters)
-                pipe = pipe | proc
-
-            # while item.lock:
-            #     time.sleep(30)
-            
-            if not item.hdf5:
-                item.hdf5 =  path + item.uuid + '.hdf5'
-                item.save()
-
-            pipe.run()
-            item.lock_setter(True)
-            pipe.results.to_hdf5(item.hdf5.path)
-            item.lock_setter(False)
-            
-            for processor in proc_dict.keys():
-                proc = proc_dict[processor]
-
-                for processor_id in proc.results.keys():
-                    parameters = proc.results[processor_id].parameters
-                    preset, c = Preset.objects.get_or_create(processor=processor, parameters=unicode(parameters))
-                    result, c = Result.objects.get_or_create(preset=preset, item=item)
-                
-                    if proc.type == 'analyzer':
-                        result.hdf5 = path + item.uuid + '_' + str(proc.UUID) + '.hdf5'
-                        proc.results.to_hdf5(result.hdf5.path)
-                        
-                    if proc.type == 'grapher':
-                        result.file = path + item.uuid + '_' + str(proc.UUID) + '.png'
-                        proc.render(output=result.file)
-                    
-                    result.save()
-            
-            # except:
-            #     self.status_setter(0)
-            #     item.lock_setter(False)
-            #     break
-        
-        self.status_setter(3)
-        del proc
-        del pipe
-
-
-post_save.connect(set_mimetype, sender=Item)
-post_save.connect(set_hash, sender=Item)
-post_save.connect(set_mimetype, sender=Result)
-
diff --git a/timeside/player/__init__.py b/timeside/player/__init__.py
new file mode 100644 (file)
index 0000000..e69de29
diff --git a/timeside/player/static/timeside/README.rst b/timeside/player/static/timeside/README.rst
new file mode 100644 (file)
index 0000000..241b18b
--- /dev/null
@@ -0,0 +1,30 @@
+===================
+TimeSide UI 
+===================
+
+Please refer to http://code.google.com/p/timeside/wiki/UiGuide for an exhaustive guide.
+
+Provides
+=========
+
+* SoundManager 2 >= 2.97 : http://www.schillmania.com/projects/soundmanager2
+* jQuery => 1.6 : http://www.jquery.com
+* Raphael (ADDED AUTOMATICALLY, DO NOT ADD YOURSELF) => 1.52 http://raphaeljs.com/
+
+
+Licensing
+=========
+
+Copyright (c) 2009-2011 Parisson SARL
+
+Copyright (c) 2008-2009 Samalyse
+
+Copyright (c) 2011 Riccardo Zaccarelli
+
+Authors:
+
+ * Riccardo Zaccarelli <riccardo.zaccarelli gmail.com>
+ * Olivier Guilyardi <olivier samalyse com>
+
+TimeSide is released under the terms of the GNU General Public License
+version 2. Please see the LICENSE file for details.
diff --git a/timeside/player/static/timeside/js/libs/jquery-1.6.min.js b/timeside/player/static/timeside/js/libs/jquery-1.6.min.js
new file mode 100644 (file)
index 0000000..c72011d
--- /dev/null
@@ -0,0 +1,16 @@
+/*!
+ * jQuery JavaScript Library v1.6
+ * http://jquery.com/
+ *
+ * Copyright 2011, John Resig
+ * Dual licensed under the MIT or GPL Version 2 licenses.
+ * http://jquery.org/license
+ *
+ * Includes Sizzle.js
+ * http://sizzlejs.com/
+ * Copyright 2011, The Dojo Foundation
+ * Released under the MIT, BSD, and GPL Licenses.
+ *
+ * Date: Mon May 2 13:50:00 2011 -0400
+ */
+(function(a,b){function cw(a){return f.isWindow(a)?a:a.nodeType===9?a.defaultView||a.parentWindow:!1}function ct(a){if(!ch[a]){var b=f("<"+a+">").appendTo("body"),d=b.css("display");b.remove();if(d==="none"||d===""){ci||(ci=c.createElement("iframe"),ci.frameBorder=ci.width=ci.height=0),c.body.appendChild(ci);if(!cj||!ci.createElement)cj=(ci.contentWindow||ci.contentDocument).document,cj.write("<!doctype><html><body></body></html>");b=cj.createElement(a),cj.body.appendChild(b),d=f.css(b,"display"),c.body.removeChild(ci)}ch[a]=d}return ch[a]}function cs(a,b){var c={};f.each(cn.concat.apply([],cn.slice(0,b)),function(){c[this]=a});return c}function cr(){co=b}function cq(){setTimeout(cr,0);return co=f.now()}function cg(){try{return new a.ActiveXObject("Microsoft.XMLHTTP")}catch(b){}}function cf(){try{return new a.XMLHttpRequest}catch(b){}}function b_(a,c){a.dataFilter&&(c=a.dataFilter(c,a.dataType));var d=a.dataTypes,e={},g,h,i=d.length,j,k=d[0],l,m,n,o,p;for(g=1;g<i;g++){if(g===1)for(h in a.converters)typeof h=="string"&&(e[h.toLowerCase()]=a.converters[h]);l=k,k=d[g];if(k==="*")k=l;else if(l!=="*"&&l!==k){m=l+" "+k,n=e[m]||e["* "+k];if(!n){p=b;for(o in e){j=o.split(" ");if(j[0]===l||j[0]==="*"){p=e[j[1]+" "+k];if(p){o=e[o],o===!0?n=p:p===!0&&(n=o);break}}}}!n&&!p&&f.error("No conversion from "+m.replace(" "," to ")),n!==!0&&(c=n?n(c):p(o(c)))}}return c}function b$(a,c,d){var e=a.contents,f=a.dataTypes,g=a.responseFields,h,i,j,k;for(i in g)i in d&&(c[g[i]]=d[i]);while(f[0]==="*")f.shift(),h===b&&(h=a.mimeType||c.getResponseHeader("content-type"));if(h)for(i in e)if(e[i]&&e[i].test(h)){f.unshift(i);break}if(f[0]in d)j=f[0];else{for(i in d){if(!f[0]||a.converters[i+" "+f[0]]){j=i;break}k||(k=i)}j=j||k}if(j){j!==f[0]&&f.unshift(j);return d[j]}}function bZ(a,b,c,d){if(f.isArray(b))f.each(b,function(b,e){c||bD.test(a)?d(a,e):bZ(a+"["+(typeof e=="object"||f.isArray(e)?b:"")+"]",e,c,d)});else if(!c&&b!=null&&typeof b=="object")for(var e in b)bZ(a+"["+e+"]",b[e],c,d);else d(a,b)}function bY(a,c,d,e,f,g){f=f||c.dataTypes[0],g=g||{},g[f]=!0;var h=a[f],i=0,j=h?h.length:0,k=a===bS,l;for(;i<j&&(k||!l);i++)l=h[i](c,d,e),typeof l=="string"&&(!k||g[l]?l=b:(c.dataTypes.unshift(l),l=bY(a,c,d,e,l,g)));(k||!l)&&!g["*"]&&(l=bY(a,c,d,e,"*",g));return l}function bX(a){return function(b,c){typeof b!="string"&&(c=b,b="*");if(f.isFunction(c)){var d=b.toLowerCase().split(bO),e=0,g=d.length,h,i,j;for(;e<g;e++)h=d[e],j=/^\+/.test(h),j&&(h=h.substr(1)||"*"),i=a[h]=a[h]||[],i[j?"unshift":"push"](c)}}}function bB(a,b,c){var d=b==="width"?bv:bw,e=b==="width"?a.offsetWidth:a.offsetHeight;if(c==="border")return e;f.each(d,function(){c||(e-=parseFloat(f.css(a,"padding"+this))||0),c==="margin"?e+=parseFloat(f.css(a,"margin"+this))||0:e-=parseFloat(f.css(a,"border"+this+"Width"))||0});return e}function bl(a,b){b.src?f.ajax({url:b.src,async:!1,dataType:"script"}):f.globalEval(b.text||b.textContent||b.innerHTML||""),b.parentNode&&b.parentNode.removeChild(b)}function bk(a){f.nodeName(a,"input")?bj(a):a.getElementsByTagName&&f.grep(a.getElementsByTagName("input"),bj)}function bj(a){if(a.type==="checkbox"||a.type==="radio")a.defaultChecked=a.checked}function bi(a){return"getElementsByTagName"in a?a.getElementsByTagName("*"):"querySelectorAll"in a?a.querySelectorAll("*"):[]}function bh(a,b){var c;if(b.nodeType===1){b.clearAttributes&&b.clearAttributes(),b.mergeAttributes&&b.mergeAttributes(a),c=b.nodeName.toLowerCase();if(c==="object")b.outerHTML=a.outerHTML;else if(c!=="input"||a.type!=="checkbox"&&a.type!=="radio"){if(c==="option")b.selected=a.defaultSelected;else if(c==="input"||c==="textarea")b.defaultValue=a.defaultValue}else a.checked&&(b.defaultChecked=b.checked=a.checked),b.value!==a.value&&(b.value=a.value);b.removeAttribute(f.expando)}}function bg(a,b){if(b.nodeType===1&&!!f.hasData(a)){var c=f.expando,d=f.data(a),e=f.data(b,d);if(d=d[c]){var g=d.events;e=e[c]=f.extend({},d);if(g){delete e.handle,e.events={};for(var h in g)for(var i=0,j=g[h].length;i<j;i++)f.event.add(b,h+(g[h][i].namespace?".":"")+g[h][i].namespace,g[h][i],g[h][i].data)}}}}function bf(a,b){return f.nodeName(a,"table")?a.getElementsByTagName("tbody")[0]||a.appendChild(a.ownerDocument.createElement("tbody")):a}function W(a,b,c){b=b||0;if(f.isFunction(b))return f.grep(a,function(a,d){var e=!!b.call(a,d,a);return e===c});if(b.nodeType)return f.grep(a,function(a,d){return a===b===c});if(typeof b=="string"){var d=f.grep(a,function(a){return a.nodeType===1});if(R.test(b))return f.filter(b,d,!c);b=f.filter(b,d)}return f.grep(a,function(a,d){return f.inArray(a,b)>=0===c})}function V(a){return!a||!a.parentNode||a.parentNode.nodeType===11}function N(a,b){return(a&&a!=="*"?a+".":"")+b.replace(z,"`").replace(A,"&")}function M(a){var b,c,d,e,g,h,i,j,k,l,m,n,o,p=[],q=[],r=f._data(this,"events");if(!(a.liveFired===this||!r||!r.live||a.target.disabled||a.button&&a.type==="click")){a.namespace&&(n=new RegExp("(^|\\.)"+a.namespace.split(".").join("\\.(?:.*\\.)?")+"(\\.|$)")),a.liveFired=this;var s=r.live.slice(0);for(i=0;i<s.length;i++)g=s[i],g.origType.replace(x,"")===a.type?q.push(g.selector):s.splice(i--,1);e=f(a.target).closest(q,a.currentTarget);for(j=0,k=e.length;j<k;j++){m=e[j];for(i=0;i<s.length;i++){g=s[i];if(m.selector===g.selector&&(!n||n.test(g.namespace))&&!m.elem.disabled){h=m.elem,d=null;if(g.preType==="mouseenter"||g.preType==="mouseleave")a.type=g.preType,d=f(a.relatedTarget).closest(g.selector)[0],d&&f.contains(h,d)&&(d=h);(!d||d!==h)&&p.push({elem:h,handleObj:g,level:m.level})}}}for(j=0,k=p.length;j<k;j++){e=p[j];if(c&&e.level>c)break;a.currentTarget=e.elem,a.data=e.handleObj.data,a.handleObj=e.handleObj,o=e.handleObj.origHandler.apply(e.elem,arguments);if(o===!1||a.isPropagationStopped()){c=e.level,o===!1&&(b=!1);if(a.isImmediatePropagationStopped())break}}return b}}function K(a,c,d){var e=f.extend({},d[0]);e.type=a,e.originalEvent={},e.liveFired=b,f.event.handle.call(c,e),e.isDefaultPrevented()&&d[0].preventDefault()}function E(){return!0}function D(){return!1}function m(a,c,d){var e=c+"defer",g=c+"queue",h=c+"mark",i=f.data(a,e,b,!0);i&&(d==="queue"||!f.data(a,g,b,!0))&&(d==="mark"||!f.data(a,h,b,!0))&&setTimeout(function(){!f.data(a,g,b,!0)&&!f.data(a,h,b,!0)&&(f.removeData(a,e,!0),i.resolve())},0)}function l(a){for(var b in a)if(b!=="toJSON")return!1;return!0}function k(a,c,d){if(d===b&&a.nodeType===1){name="data-"+c.replace(j,"$1-$2").toLowerCase(),d=a.getAttribute(name);if(typeof d=="string"){try{d=d==="true"?!0:d==="false"?!1:d==="null"?null:f.isNaN(d)?i.test(d)?f.parseJSON(d):d:parseFloat(d)}catch(e){}f.data(a,c,d)}else d=b}return d}var c=a.document,d=a.navigator,e=a.location,f=function(){function H(){if(!e.isReady){try{c.documentElement.doScroll("left")}catch(a){setTimeout(H,1);return}e.ready()}}var e=function(a,b){return new e.fn.init(a,b,h)},f=a.jQuery,g=a.$,h,i=/^(?:[^<]*(<[\w\W]+>)[^>]*$|#([\w\-]*)$)/,j=/\S/,k=/^\s+/,l=/\s+$/,m=/\d/,n=/^<(\w+)\s*\/?>(?:<\/\1>)?$/,o=/^[\],:{}\s]*$/,p=/\\(?:["\\\/bfnrt]|u[0-9a-fA-F]{4})/g,q=/"[^"\\\n\r]*"|true|false|null|-?\d+(?:\.\d*)?(?:[eE][+\-]?\d+)?/g,r=/(?:^|:|,)(?:\s*\[)+/g,s=/(webkit)[ \/]([\w.]+)/,t=/(opera)(?:.*version)?[ \/]([\w.]+)/,u=/(msie) ([\w.]+)/,v=/(mozilla)(?:.*? rv:([\w.]+))?/,w=d.userAgent,x,y,z,A=Object.prototype.toString,B=Object.prototype.hasOwnProperty,C=Array.prototype.push,D=Array.prototype.slice,E=String.prototype.trim,F=Array.prototype.indexOf,G={};e.fn=e.prototype={constructor:e,init:function(a,d,f){var g,h,j,k;if(!a)return this;if(a.nodeType){this.context=this[0]=a,this.length=1;return this}if(a==="body"&&!d&&c.body){this.context=c,this[0]=c.body,this.selector=a,this.length=1;return this}if(typeof a=="string"){a.charAt(0)==="<"&&a.charAt(a.length-1)===">"&&a.length>=3?g=[null,a,null]:g=i.exec(a);if(g&&(g[1]||!d)){if(g[1]){d=d instanceof e?d[0]:d,k=d?d.ownerDocument||d:c,j=n.exec(a),j?e.isPlainObject(d)?(a=[c.createElement(j[1])],e.fn.attr.call(a,d,!0)):a=[k.createElement(j[1])]:(j=e.buildFragment([g[1]],[k]),a=(j.cacheable?e.clone(j.fragment):j.fragment).childNodes);return e.merge(this,a)}h=c.getElementById(g[2]);if(h&&h.parentNode){if(h.id!==g[2])return f.find(a);this.length=1,this[0]=h}this.context=c,this.selector=a;return this}return!d||d.jquery?(d||f).find(a):this.constructor(d).find(a)}if(e.isFunction(a))return f.ready(a);a.selector!==b&&(this.selector=a.selector,this.context=a.context);return e.makeArray(a,this)},selector:"",jquery:"1.6",length:0,size:function(){return this.length},toArray:function(){return D.call(this,0)},get:function(a){return a==null?this.toArray():a<0?this[this.length+a]:this[a]},pushStack:function(a,b,c){var d=this.constructor();e.isArray(a)?C.apply(d,a):e.merge(d,a),d.prevObject=this,d.context=this.context,b==="find"?d.selector=this.selector+(this.selector?" ":"")+c:b&&(d.selector=this.selector+"."+b+"("+c+")");return d},each:function(a,b){return e.each(this,a,b)},ready:function(a){e.bindReady(),y.done(a);return this},eq:function(a){return a===-1?this.slice(a):this.slice(a,+a+1)},first:function(){return this.eq(0)},last:function(){return this.eq(-1)},slice:function(){return this.pushStack(D.apply(this,arguments),"slice",D.call(arguments).join(","))},map:function(a){return this.pushStack(e.map(this,function(b,c){return a.call(b,c,b)}))},end:function(){return this.prevObject||this.constructor(null)},push:C,sort:[].sort,splice:[].splice},e.fn.init.prototype=e.fn,e.extend=e.fn.extend=function(){var a,c,d,f,g,h,i=arguments[0]||{},j=1,k=arguments.length,l=!1;typeof i=="boolean"&&(l=i,i=arguments[1]||{},j=2),typeof i!="object"&&!e.isFunction(i)&&(i={}),k===j&&(i=this,--j);for(;j<k;j++)if((a=arguments[j])!=null)for(c in a){d=i[c],f=a[c];if(i===f)continue;l&&f&&(e.isPlainObject(f)||(g=e.isArray(f)))?(g?(g=!1,h=d&&e.isArray(d)?d:[]):h=d&&e.isPlainObject(d)?d:{},i[c]=e.extend(l,h,f)):f!==b&&(i[c]=f)}return i},e.extend({noConflict:function(b){a.$===e&&(a.$=g),b&&a.jQuery===e&&(a.jQuery=f);return e},isReady:!1,readyWait:1,holdReady:function(a){a?e.readyWait++:e.ready(!0)},ready:function(a){if(a===!0&&!--e.readyWait||a!==!0&&!e.isReady){if(!c.body)return setTimeout(e.ready,1);e.isReady=!0;if(a!==!0&&--e.readyWait>0)return;y.resolveWith(c,[e]),e.fn.trigger&&e(c).trigger("ready").unbind("ready")}},bindReady:function(){if(!y){y=e._Deferred();if(c.readyState==="complete")return setTimeout(e.ready,1);if(c.addEventListener)c.addEventListener("DOMContentLoaded",z,!1),a.addEventListener("load",e.ready,!1);else if(c.attachEvent){c.attachEvent("onreadystatechange",z),a.attachEvent("onload",e.ready);var b=!1;try{b=a.frameElement==null}catch(d){}c.documentElement.doScroll&&b&&H()}}},isFunction:function(a){return e.type(a)==="function"},isArray:Array.isArray||function(a){return e.type(a)==="array"},isWindow:function(a){return a&&typeof a=="object"&&"setInterval"in a},isNaN:function(a){return a==null||!m.test(a)||isNaN(a)},type:function(a){return a==null?String(a):G[A.call(a)]||"object"},isPlainObject:function(a){if(!a||e.type(a)!=="object"||a.nodeType||e.isWindow(a))return!1;if(a.constructor&&!B.call(a,"constructor")&&!B.call(a.constructor.prototype,"isPrototypeOf"))return!1;var c;for(c in a);return c===b||B.call(a,c)},isEmptyObject:function(a){for(var b in a)return!1;return!0},error:function(a){throw a},parseJSON:function(b){if(typeof b!="string"||!b)return null;b=e.trim(b);if(a.JSON&&a.JSON.parse)return a.JSON.parse(b);if(o.test(b.replace(p,"@").replace(q,"]").replace(r,"")))return(new Function("return "+b))();e.error("Invalid JSON: "+b)},parseXML:function(b,c,d){a.DOMParser?(d=new DOMParser,c=d.parseFromString(b,"text/xml")):(c=new ActiveXObject("Microsoft.XMLDOM"),c.async="false",c.loadXML(b)),d=c.documentElement,(!d||!d.nodeName||d.nodeName==="parsererror")&&e.error("Invalid XML: "+b);return c},noop:function(){},globalEval:function(b){b&&j.test(b)&&(a.execScript||function(b){a.eval.call(a,b)})(b)},nodeName:function(a,b){return a.nodeName&&a.nodeName.toUpperCase()===b.toUpperCase()},each:function(a,c,d){var f,g=0,h=a.length,i=h===b||e.isFunction(a);if(d){if(i){for(f in a)if(c.apply(a[f],d)===!1)break}else for(;g<h;)if(c.apply(a[g++],d)===!1)break}else if(i){for(f in a)if(c.call(a[f],f,a[f])===!1)break}else for(;g<h;)if(c.call(a[g],g,a[g++])===!1)break;return a},trim:E?function(a){return a==null?"":E.call(a)}:function(a){return a==null?"":(a+"").replace(k,"").replace(l,"")},makeArray:function(a,b){var c=b||[];if(a!=null){var d=e.type(a);a.length==null||d==="string"||d==="function"||d==="regexp"||e.isWindow(a)?C.call(c,a):e.merge(c,a)}return c},inArray:function(a,b){if(F)return F.call(b,a);for(var c=0,d=b.length;c<d;c++)if(b[c]===a)return c;return-1},merge:function(a,c){var d=a.length,e=0;if(typeof c.length=="number")for(var f=c.length;e<f;e++)a[d++]=c[e];else while(c[e]!==b)a[d++]=c[e++];a.length=d;return a},grep:function(a,b,c){var d=[],e;c=!!c;for(var f=0,g=a.length;f<g;f++)e=!!b(a[f],f),c!==e&&d.push(a[f]);return d},map:function(a,c,d){var f,g,h=[],i=0,j=a.length,k=a instanceof e||j!==b&&typeof j=="number"&&(j>0&&a[0]&&a[j-1]||j===0||e.isArray(a));if(k)for(;i<j;i++)f=c(a[i],i,d),f!=null&&(h[h.length]=f);else for(g in a)f=c(a[g],g,d),f!=null&&(h[h.length]=f);return h.concat.apply([],h)},guid:1,proxy:function(a,c){if(typeof c=="string"){var d=a[c];c=a,a=d}if(!e.isFunction(a))return b;var f=D.call(arguments,2),g=function(){return a.apply(c,f.concat(D.call(arguments)))};g.guid=a.guid=a.guid||g.guid||e.guid++;return g},access:function(a,c,d,f,g,h){var i=a.length;if(typeof c=="object"){for(var j in c)e.access(a,j,c[j],f,g,d);return a}if(d!==b){f=!h&&f&&e.isFunction(d);for(var k=0;k<i;k++)g(a[k],c,f?d.call(a[k],k,g(a[k],c)):d,h);return a}return i?g(a[0],c):b},now:function(){return(new Date).getTime()},uaMatch:function(a){a=a.toLowerCase();var b=s.exec(a)||t.exec(a)||u.exec(a)||a.indexOf("compatible")<0&&v.exec(a)||[];return{browser:b[1]||"",version:b[2]||"0"}},sub:function(){function a(b,c){return new a.fn.init(b,c)}e.extend(!0,a,this),a.superclass=this,a.fn=a.prototype=this(),a.fn.constructor=a,a.sub=this.sub,a.fn.init=function(c,d){d&&d instanceof e&&!(d instanceof a)&&(d=a(d));return e.fn.init.call(this,c,d,b)},a.fn.init.prototype=a.fn;var b=a(c);return a},browser:{}}),e.each("Boolean Number String Function Array Date RegExp Object".split(" "),function(a,b){G["[object "+b+"]"]=b.toLowerCase()}),x=e.uaMatch(w),x.browser&&(e.browser[x.browser]=!0,e.browser.version=x.version),e.browser.webkit&&(e.browser.safari=!0),j.test(" ")&&(k=/^[\s\xA0]+/,l=/[\s\xA0]+$/),h=e(c),c.addEventListener?z=function(){c.removeEventListener("DOMContentLoaded",z,!1),e.ready()}:c.attachEvent&&(z=function(){c.readyState==="complete"&&(c.detachEvent("onreadystatechange",z),e.ready())});return e}(),g="done fail isResolved isRejected promise then always pipe".split(" "),h=[].slice;f.extend({_Deferred:function(){var a=[],b,c,d,e={done:function(){if(!d){var c=arguments,g,h,i,j,k;b&&(k=b,b=0);for(g=0,h=c.length;g<h;g++)i=c[g],j=f.type(i),j==="array"?e.done.apply(e,i):j==="function"&&a.push(i);k&&e.resolveWith(k[0],k[1])}return this},resolveWith:function(e,f){if(!d&&!b&&!c){f=f||[],c=1;try{while(a[0])a.shift().apply(e,f)}finally{b=[e,f],c=0}}return this},resolve:function(){e.resolveWith(this,arguments);return this},isResolved:function(){return!!c||!!b},cancel:function(){d=1,a=[];return this}};return e},Deferred:function(a){var b=f._Deferred(),c=f._Deferred(),d;f.extend(b,{then:function(a,c){b.done(a).fail(c);return this},always:function(){return b.done.apply(b,arguments).fail.apply(this,arguments)},fail:c.done,rejectWith:c.resolveWith,reject:c.resolve,isRejected:c.isResolved,pipe:function(a,c){return f.Deferred(function(d){f.each({done:[a,"resolve"],fail:[c,"reject"]},function(a,c){var e=c[0],g=c[1],h;f.isFunction(e)?b[a](function(){h=e.apply(this,arguments),f.isFunction(h.promise)?h.promise().then(d.resolve,d.reject):d[g](h)}):b[a](d[g])})}).promise()},promise:function(a){if(a==null){if(d)return d;d=a={}}var c=g.length;while(c--)a[g[c]]=b[g[c]];return a}}),b.done(c.cancel).fail(b.cancel),delete b.cancel,a&&a.call(b,b);return b},when:function(a){function i(a){return function(c){b[a]=arguments.length>1?h.call(arguments,0):c,--e||g.resolveWith(g,h.call(b,0))}}var b=arguments,c=0,d=b.length,e=d,g=d<=1&&a&&f.isFunction(a.promise)?a:f.Deferred();if(d>1){for(;c<d;c++)b[c]&&f.isFunction(b[c].promise)?b[c].promise().then(i(c),g.reject):--e;e||g.resolveWith(g,b)}else g!==a&&g.resolveWith(g,d?[a]:[]);return g.promise()}}),f.support=function(){var a=c.createElement("div"),b,d,e,f,g,h,i,j,k,l,m,n,o,p,q;a.setAttribute("className","t"),a.innerHTML="   <link/><table></table><a href='/a' style='top:1px;float:left;opacity:.55;'>a</a><input type='checkbox'/>",b=a.getElementsByTagName("*"),d=a.getElementsByTagName("a")[0];if(!b||!b.length||!d)return{};e=c.createElement("select"),f=e.appendChild(c.createElement("option")),g=a.getElementsByTagName("input")[0],i={leadingWhitespace:a.firstChild.nodeType===3,tbody:!a.getElementsByTagName("tbody").length,htmlSerialize:!!a.getElementsByTagName("link").length,style:/top/.test(d.getAttribute("style")),hrefNormalized:d.getAttribute("href")==="/a",opacity:/^0.55$/.test(d.style.opacity),cssFloat:!!d.style.cssFloat,checkOn:g.value==="on",optSelected:f.selected,getSetAttribute:a.className!=="t",submitBubbles:!0,changeBubbles:!0,focusinBubbles:!1,deleteExpando:!0,noCloneEvent:!0,inlineBlockNeedsLayout:!1,shrinkWrapBlocks:!1,reliableMarginRight:!0},g.checked=!0,i.noCloneChecked=g.cloneNode(!0).checked,e.disabled=!0,i.optDisabled=!f.disabled;try{delete a.test}catch(r){i.deleteExpando=!1}!a.addEventListener&&a.attachEvent&&a.fireEvent&&(a.attachEvent("onclick",function click(){i.noCloneEvent=!1,a.detachEvent("onclick",click)}),a.cloneNode(!0).fireEvent("onclick")),g=c.createElement("input"),g.value="t",g.setAttribute("type","radio"),i.radioValue=g.value==="t",g.setAttribute("checked","checked"),a.appendChild(g),j=c.createDocumentFragment(),j.appendChild(a.firstChild),i.checkClone=j.cloneNode(!0).cloneNode(!0).lastChild.checked,a.innerHTML="",a.style.width=a.style.paddingLeft="1px",k=c.createElement("body"),l={visibility:"hidden",width:0,height:0,border:0,margin:0,background:"none"};for(p in l)k.style[p]=l[p];k.appendChild(a),c.documentElement.appendChild(k),i.appendChecked=g.checked,i.boxModel=a.offsetWidth===2,"zoom"in a.style&&(a.style.display="inline",a.style.zoom=1,i.inlineBlockNeedsLayout=a.offsetWidth===2,a.style.display="",a.innerHTML="<div style='width:4px;'></div>",i.shrinkWrapBlocks=a.offsetWidth!==2),a.innerHTML="<table><tr><td style='padding:0;border:0;display:none'></td><td>t</td></tr></table>",m=a.getElementsByTagName("td"),q=m[0].offsetHeight===0,m[0].style.display="",m[1].style.display="none",i.reliableHiddenOffsets=q&&m[0].offsetHeight===0,a.innerHTML="",c.defaultView&&c.defaultView.getComputedStyle&&(h=c.createElement("div"),h.style.width="0",h.style.marginRight="0",a.appendChild(h),i.reliableMarginRight=(parseInt(c.defaultView.getComputedStyle(h,null).marginRight,10)||0)===0),k.innerHTML="",c.documentElement.removeChild(k);if(a.attachEvent)for(p in{submit:1,change:1,focusin:1})o="on"+p,q=o in a,q||(a.setAttribute(o,"return;"),q=typeof a[o]=="function"),i[p+"Bubbles"]=q;return i}(),f.boxModel=f.support.boxModel;var i=/^(?:\{.*\}|\[.*\])$/,j=/([a-z])([A-Z])/g;f.extend({cache:{},uuid:0,expando:"jQuery"+(f.fn.jquery+Math.random()).replace(/\D/g,""),noData:{embed:!0,object:"clsid:D27CDB6E-AE6D-11cf-96B8-444553540000",applet:!0},hasData:function(a){a=a.nodeType?f.cache[a[f.expando]]:a[f.expando];return!!a&&!l(a)},data:function(a,c,d,e){if(!!f.acceptData(a)){var g=f.expando,h=typeof c=="string",i,j=a.nodeType,k=j?f.cache:a,l=j?a[f.expando]:a[f.expando]&&f.expando;if((!l||e&&l&&!k[l][g])&&h&&d===b)return;l||(j?a[f.expando]=l=++f.uuid:l=f.expando),k[l]||(k[l]={},j||(k[l].toJSON=f.noop));if(typeof c=="object"||typeof c=="function")e?k[l][g]=f.extend(k[l][g],c):k[l]=f.extend(k[l],c);i=k[l],e&&(i[g]||(i[g]={}),i=i[g]),d!==b&&(i[c]=d);if(c==="events"&&!i[c])return i[g]&&i[g].events;return h?i[c]:i}},removeData:function(b,c,d){if(!!f.acceptData(b)){var e=f.expando,g=b.nodeType,h=g?f.cache:b,i=g?b[f.expando]:f.expando;if(!h[i])return;if(c){var j=d?h[i][e]:h[i];if(j){delete j[c];if(!l(j))return}}if(d){delete h[i][e];if(!l(h[i]))return}var k=h[i][e];f.support.deleteExpando||h!=a?delete h[i]:h[i]=null,k?(h[i]={},g||(h[i].toJSON=f.noop),h[i][e]=k):g&&(f.support.deleteExpando?delete b[f.expando]:b.removeAttribute?b.removeAttribute(f.expando):b[f.expando]=null)}},_data:function(a,b,c){return f.data(a,b,c,!0)},acceptData:function(a){if(a.nodeName){var b=f.noData[a.nodeName.toLowerCase()];if(b)return b!==!0&&a.getAttribute("classid")===b}return!0}}),f.fn.extend({data:function(a,c){var d=null;if(typeof a=="undefined"){if(this.length){d=f.data(this[0]);if(this[0].nodeType===1){var e=this[0].attributes,g;for(var h=0,i=e.length;h<i;h++)g=e[h].name,g.indexOf("data-")===0&&(g=f.camelCase(g.substring(5)),k(this[0],g,d[g]))}}return d}if(typeof a=="object")return this.each(function(){f.data(this,a)});var j=a.split(".");j[1]=j[1]?"."+j[1]:"";if(c===b){d=this.triggerHandler("getData"+j[1]+"!",[j[0]]),d===b&&this.length&&(d=f.data(this[0],a),d=k(this[0],a,d));return d===b&&j[1]?this.data(j[0]):d}return this.each(function(){var b=f(this),d=[j[0],c];b.triggerHandler("setData"+j[1]+"!",d),f.data(this,a,c),b.triggerHandler("changeData"+j[1]+"!",d)})},removeData:function(a){return this.each(function(){f.removeData(this,a)})}}),f.extend({_mark:function(a,c){a&&(c=(c||"fx")+"mark",f.data(a,c,(f.data(a,c,b,!0)||0)+1,!0))},_unmark:function(a,c,d){a!==!0&&(d=c,c=a,a=!1);if(c){d=d||"fx";var e=d+"mark",g=a?0:(f.data(c,e,b,!0)||1)-1;g?f.data(c,e,g,!0):(f.removeData(c,e,!0),m(c,d,"mark"))}},queue:function(a,c,d){if(a){c=(c||"fx")+"queue";var e=f.data(a,c,b,!0);d&&(!e||f.isArray(d)?e=f.data(a,c,f.makeArray(d),!0):e.push(d));return e||[]}},dequeue:function(a,b){b=b||"fx";var c=f.queue(a,b),d=c.shift(),e;d==="inprogress"&&(d=c.shift()),d&&(b==="fx"&&c.unshift("inprogress"),d.call(a,function(){f.dequeue(a,b)})),c.length||(f.removeData(a,b+"queue",!0),m(a,b,"queue"))}}),f.fn.extend({queue:function(a,c){typeof a!="string"&&(c=a,a="fx");if(c===b)return f.queue(this[0],a);return this.each(function(){var b=f.queue(this,a,c);a==="fx"&&b[0]!=="inprogress"&&f.dequeue(this,a)})},dequeue:function(a){return this.each(function(){f.dequeue(this,a)})},delay:function(a,b){a=f.fx?f.fx.speeds[a]||a:a,b=b||"fx";return this.queue(b,function(){var c=this;setTimeout(function(){f.dequeue(c,b)},a)})},clearQueue:function(a){return this.queue(a||"fx",[])},promise:function(a,c){function l(){--h||d.resolveWith(e,[e])}typeof a!="string"&&(c=a,a=b),a=a||"fx";var d=f.Deferred(),e=this,g=e.length,h=1,i=a+"defer",j=a+"queue",k=a+"mark";while(g--)if(tmp=f.data(e[g],i,b,!0)||(f.data(e[g],j,b,!0)||f.data(e[g],k,b,!0))&&f.data(e[g],i,f._Deferred(),!0))h++,tmp.done(l);l();return d.promise()}});var n=/[\n\t\r]/g,o=/\s+/,p=/\r/g,q=/^(?:button|input)$/i,r=/^(?:button|input|object|select|textarea)$/i,s=/^a(?:rea)?$/i,t=/^(?:data-|aria-)/,u=/\:/,v;f.fn.extend({attr:function(a,b){return f.access(this,a,b,!0,f.attr)},removeAttr:function(a){return this.each(function(){f.removeAttr(this,a)})},prop:function(a,b){return f.access(this,a,b,!0,f.prop)},removeProp:function(a){return this.each(function(){try{this[a]=b,delete this[a]}catch(c){}})},addClass:function(a){if(f.isFunction(a))return this.each(function(b){var c=f(this);c.addClass(a.call(this,b,c.attr("class")||""))});if(a&&typeof a=="string"){var b=(a||"").split(o);for(var c=0,d=this.length;c<d;c++){var e=this[c];if(e.nodeType===1)if(!e.className)e.className=a;else{var g=" "+e.className+" ",h=e.className;for(var i=0,j=b.length;i<j;i++)g.indexOf(" "+b[i]+" ")<0&&(h+=" "+b[i]);e.className=f.trim(h)}}}return this},removeClass:function(a){if(f.isFunction(a))return this.each(function(b){var c=f(this);c.removeClass(a.call(this,b,c.attr("class")))});if(a&&typeof a=="string"||a===b){var c=(a||"").split(o);for(var d=0,e=this.length;d<e;d++){var g=this[d];if(g.nodeType===1&&g.className)if(a){var h=(" "+g.className+" ").replace(n," ");for(var i=0,j=c.length;i<j;i++)h=h.replace(" "+c[i]+" "," ");g.className=f.trim(h)}else g.className=""}}return this},toggleClass:function(a,b){var c=typeof a,d=typeof b=="boolean";if(f.isFunction(a))return this.each(function(c){var d=f(this);d.toggleClass(a.call(this,c,d.attr("class"),b),b)});return this.each(function(){if(c==="string"){var e,g=0,h=f(this),i=b,j=a.split(o);while(e=j[g++])i=d?i:!h.hasClass(e),h[i?"addClass":"removeClass"](e)}else if(c==="undefined"||c==="boolean")this.className&&f._data(this,"__className__",this.className),this.className=this.className||a===!1?"":f._data(this,"__className__")||""})},hasClass:function(a){var b=" "+a+" ";for(var c=0,d=this.length;c<d;c++)if((" "+this[c].className+" ").replace(n," ").indexOf(b)>-1)return!0;return!1},val:function(a){var c,d,e=this[0];if(!arguments.length){if(e){c=f.valHooks[e.nodeName.toLowerCase()]||f.valHooks[e.type];if(c&&"get"in c&&(d=c.get(e,"value"))!==b)return d;return(e.value||"").replace(p,"")}return b}var g=f.isFunction(a);return this.each(function(d){var e=f(this),h;if(this.nodeType===1){g?h=a.call(this,d,e.val()):h=a,h==null?h="":typeof h=="number"?h+="":f.isArray(h)&&(h=f.map(h,function(a){return a==null?"":a+""})),c=f.valHooks[this.nodeName.toLowerCase()]||f.valHooks[this.type];if(!c||"set"in c&&c.set(this,h,"value")===b)this.value=h}})}}),f.extend({valHooks:{option:{get:function(a){var b=a.attributes.value;return!b||b.specified?a.value:a.text}},select:{get:function(a){var b=a.selectedIndex,c=[],d=a.options,e=a.type==="select-one";if(b<0)return null;for(var g=e?b:0,h=e?b+1:d.length;g<h;g++){var i=d[g];if(i.selected&&(f.support.optDisabled?!i.disabled:i.getAttribute("disabled")===null)&&(!i.parentNode.disabled||!f.nodeName(i.parentNode,"optgroup"))){value=f(i).val();if(e)return value;c.push(value)}}if(e&&!c.length&&d.length)return f(d[b]).val();return c},set:function(a,b){var c=f.makeArray(b);f(a).find("option").each(function(){this.selected=f.inArray(f(this).val(),c)>=0}),c.length||(a.selectedIndex=-1);return c}}},attrFn:{val:!0,css:!0,html:!0,text:!0,data:!0,width:!0,height:!0,offset:!0},attrFix:{tabindex:"tabIndex",readonly:"readOnly"},attr:function(a,c,d,e){var g=a.nodeType;if(!a||g===3||g===8||g===2)return b;if(e&&c in f.attrFn)return f(a)[c](d);var h,i,j=g!==1||!f.isXMLDoc(a);c=j&&f.attrFix[c]||c,i=f.attrHooks[c]||(v&&(f.nodeName(a,"form")||u.test(c))?v:b);if(d!==b){if(d===null||d===!1&&!t.test(c)){f.removeAttr(a,c);return b}if(i&&"set"in i&&j&&(h=i.set(a,d,c))!==b)return h;d===!0&&!t.test(c)&&(d=c),a.setAttribute(c,""+d);return d}if(i&&"get"in i&&j)return i.get(a,c);h=a.getAttribute(c);return h===null?b:h},removeAttr:function(a,b){a.nodeType===1&&(b=f.attrFix[b]||b,f.support.getSetAttribute?a.removeAttribute(b):(f.attr(a,b,""),a.removeAttributeNode(a.getAttributeNode(b))))},attrHooks:{type:{set:function(a,b){if(q.test(a.nodeName)&&a.parentNode)f.error("type property can't be changed");else if(!f.support.radioValue&&b==="radio"&&f.nodeName(a,"input")){var c=a.getAttribute("value");a.setAttribute("type",b),c&&(a.value=c);return b}}},tabIndex:{get:function(a){var c=a.getAttributeNode("tabIndex");return c&&c.specified?parseInt(c.value,10):r.test(a.nodeName)||s.test(a.nodeName)&&a.href?0:b}}},propFix:{},prop:function(a,c,d){var e=a.nodeType;if(!a||e===3||e===8||e===2)return b;var g,h,i=e!==1||!f.isXMLDoc(a);c=i&&f.propFix[c]||c,h=f.propHooks[c];return d!==b?h&&"set"in h&&(g=h.set(a,d,c))!==b?g:a[c]=d:h&&"get"in h&&(g=h.get(a,c))!==b?g:a[c]},propHooks:{}}),f.support.getSetAttribute||(f.attrFix=f.extend(f.attrFix,{"for":"htmlFor","class":"className",maxlength:"maxLength",cellspacing:"cellSpacing",cellpadding:"cellPadding",rowspan:"rowSpan",colspan:"colSpan",usemap:"useMap",frameborder:"frameBorder"}),v=f.attrHooks.name=f.attrHooks.value=f.valHooks.button={get:function(a,c){var d;if(c==="value"&&!f.nodeName(a,"button"))return a.getAttribute(c);d=a.getAttributeNode(c);return d&&d.specified?d.nodeValue:b},set:function(a,b,c){var d=a.getAttributeNode(c);if(d){d.nodeValue=b;return b}}},f.each(["width","height"],function(a,b){f.attrHooks[b]=f.extend(f.attrHooks[b],{set:function(a,c){if(c===""){a.setAttribute(b,"auto");return c}}})})),f.support.hrefNormalized||f.each(["href","src","width","height"],function(a,c){f.attrHooks[c]=f.extend(f.attrHooks[c],{get:function(a){var d=a.getAttribute(c,2);return d===null?b:d}})}),f.support.style||(f.attrHooks.style={get:function(a){return a.style.cssText.toLowerCase()||b},set:function(a,b){return a.style.cssText=""+b}}),f.support.optSelected||(f.propHooks.selected=f.extend(f.propHooks.selected,{get:function(a){var b=a.parentNode;b&&(b.selectedIndex,b.parentNode&&b.parentNode.selectedIndex)}})),f.support.checkOn||f.each(["radio","checkbox"],function(){f.valHooks[this]={get:function(a){return a.getAttribute("value")===null?"on":a.value}}}),f.each(["radio","checkbox"],function(){f.valHooks[this]=f.extend(f.valHooks[this],{set:function(a,b){if(f.isArray(b))return a.checked=f.inArray(f(a).val(),b)>=0}})});var w=Object.prototype.hasOwnProperty,x=/\.(.*)$/,y=/^(?:textarea|input|select)$/i,z=/\./g,A=/ /g,B=/[^\w\s.|`]/g,C=function(a){return a.replace(B,"\\$&")};f.event={add:function(a,c,d,e){if(a.nodeType!==3&&a.nodeType!==8){if(d===!1)d=D;else if(!d)return;var g,h;d.handler&&(g=d,d=g.handler),d.guid||(d.guid=f.guid++);var i=f._data(a);if(!i)return;var j=i.events,k=i.handle;j||(i.events=j={}),k||(i.handle=k=function(a){return typeof f!="undefined"&&(!a||f.event.triggered!==a.type)?f.event.handle.apply(k.elem,arguments):b}),k.elem=a,c=c.split(" ");var l,m=0,n;while(l=c[m++]){h=g?f.extend({},g):{handler:d,data:e},l.indexOf(".")>-1?(n=l.split("."),l=n.shift(),h.namespace=n.slice(0).sort().join(".")):(n=[],h.namespace=""),h.type=l,h.guid||(h.guid=d.guid);var o=j[l],p=f.event.special[l]||{};if(!o){o=j[l]=[];if(!p.setup||p.setup.call(a,e,n,k)===!1)a.addEventListener?a.addEventListener(l,k,!1):a.attachEvent&&a.attachEvent("on"+l,k)}p.add&&(p.add.call(a,h),h.handler.guid||(h.handler.guid=d.guid)),o.push(h),f.event.global[l]=!0}a=null}},global:{},remove:function(a,c,d,e){if(a.nodeType!==3&&a.nodeType!==8){d===!1&&(d=D);var g,h,i,j,k=0,l,m,n,o,p,q,r,s=f.hasData(a)&&f._data(a),t=s&&s.events;if(!s||!t)return;c&&c.type&&(d=c.handler,c=c.type);if(!c||typeof c=="string"&&c.charAt(0)==="."){c=c||"";for(h in t)f.event.remove(a,h+c);return}c=c.split(" ");while(h=c[k++]){r=h,q=null,l=h.indexOf(".")<0,m=[],l||(m=h.split("."),h=m.shift(),n=new RegExp("(^|\\.)"+f.map(m.slice(0).sort(),C).join("\\.(?:.*\\.)?")+"(\\.|$)")),p=t[h];if(!p)continue;if(!d){for(j=0;j<p.length;j++){q=p[j];if(l||n.test(q.namespace))f.event.remove(a,r,q.handler,j),p.splice(j--,1)}continue}o=f.event.special[h]||{};for(j=e||0;j<p.length;j++){q=p[j];if(d.guid===q.guid){if(l||n.test(q.namespace))e==null&&p.splice(j--,1),o.remove&&o.remove.call(a,q);if(e!=null)break}}if(p.length===0||e!=null&&p.length===1)(!o.teardown||o.teardown.call(a,m)===!1)&&f.removeEvent(a,h,s.handle),g=null,delete t[h]}if(f.isEmptyObject(t)){var u=s.handle;u&&(u.elem=null),delete s.events,delete s.handle,f.isEmptyObject(s)&&f.removeData(a,b,!0)}}},customEvent:{getData:!0,setData:!0,changeData:!0},trigger:function(c,d,e,g){var h=c.type||c,i=[],j;h.indexOf("!")>=0&&(h=h.slice(0,-1),j=!0),h.indexOf(".")>=0&&(i=h.split("."),h=i.shift(),i.sort());if(!!e&&!f.event.customEvent[h]||!!f.event.global[h]){c=typeof c=="object"?c[f.expando]?c:new f.Event(h,c):new f.Event(h),c.type=h,c.exclusive=j,c.namespace=i.join("."),c.namespace_re=new RegExp("(^|\\.)"+i.join("\\.(?:.*\\.)?")+"(\\.|$)");if(g||!e)c.preventDefault(),c.stopPropagation();if(!e){f.each(f.cache,function(){var a=f.expando,b=this[a];b&&b.events&&b.events[h]&&f.event.trigger(c,d,b.handle.elem)});return}if(e.nodeType===3||e.nodeType===8)return;c.result=b,c.target=e,d=d?f.makeArray(d):[],d.unshift(c);var k=e,l=h.indexOf(":")<0?"on"+h:"";do{var m=f._data(k,"handle");c.currentTarget=k,m&&m.apply(k,d),l&&f.acceptData(k)&&k[l]&&k[l].apply(k,d)===!1&&(c.result=!1,c.preventDefault()),k=k.parentNode||k.ownerDocument||k===c.target.ownerDocument&&a}while(k&&!c.isPropagationStopped());if(!c.isDefaultPrevented()){var n,o=f.event.special[h]||{};if((!o._default||o._default.call(e.ownerDocument,c)===!1)&&(h!=="click"||!f.nodeName(e,"a"))&&f.acceptData(e)){try{l&&e[h]&&(n=e[l],n&&(e[l]=null),f.event.triggered=h,e[h]())}catch(p){}n&&(e[l]=n),f.event.triggered=b}}return c.result}},handle:function(c){c=f.event.fix(c||a.event);var d=((f._data(this,"events")||{})[c.type]||[]).slice(0),e=!c.exclusive&&!c.namespace,g=Array.prototype.slice.call(arguments,0);g[0]=c,c.currentTarget=this;for(var h=0,i=d.length;h<i;h++){var j=d[h];if(e||c.namespace_re.test(j.namespace)){c.handler=j.handler,c.data=j.data,c.handleObj=j;var k=j.handler.apply(this,g);k!==b&&(c.result=k,k===!1&&(c.preventDefault(),c.stopPropagation()));if(c.isImmediatePropagationStopped())break}}return c.result},props:"altKey attrChange attrName bubbles button cancelable charCode clientX clientY ctrlKey currentTarget data detail eventPhase fromElement handler keyCode layerX layerY metaKey newValue offsetX offsetY pageX pageY prevValue relatedNode relatedTarget screenX screenY shiftKey srcElement target toElement view wheelDelta which".split(" "),fix:function(a){if(a[f.expando])return a;var d=a;a=f.Event(d);for(var e=this.props.length,g;e;)g=this.props[--e],a[g]=d[g];a.target||(a.target=a.srcElement||c),a.target.nodeType===3&&(a.target=a.target.parentNode),!a.relatedTarget&&a.fromElement&&(a.relatedTarget=a.fromElement===a.target?a.toElement:a.fromElement);if(a.pageX==null&&a.clientX!=null){var h=a.target.ownerDocument||c,i=h.documentElement,j=h.body;a.pageX=a.clientX+(i&&i.scrollLeft||j&&j.scrollLeft||0)-(i&&i.clientLeft||j&&j.clientLeft||0),a.pageY=a.clientY+(i&&i.scrollTop||j&&j.scrollTop||0)-(i&&i.clientTop||j&&j.clientTop||0)}a.which==null&&(a.charCode!=null||a.keyCode!=null)&&(a.which=a.charCode!=null?a.charCode:a.keyCode),!a.metaKey&&a.ctrlKey&&(a.metaKey=a.ctrlKey),!a.which&&a.button!==b&&(a.which=a.button&1?1:a.button&2?3:a.button&4?2:0);return a},guid:1e8,proxy:f.proxy,special:{ready:{setup:f.bindReady,teardown:f.noop},live:{add:function(a){f.event.add(this,N(a.origType,a.selector),f.extend({},a,{handler:M,guid:a.handler.guid}))},remove:function(a){f.event.remove(this,N(a.origType,a.selector),a)}},beforeunload:{setup:function(a,b,c){f.isWindow(this)&&(this.onbeforeunload=c)},teardown:function(a,b){this.onbeforeunload===b&&(this.onbeforeunload=null)}}}},f.removeEvent=c.removeEventListener?function(a,b,c){a.removeEventListener&&a.removeEventListener(b,c,!1)}:function(a,b,c){a.detachEvent&&a.detachEvent("on"+b,c)},f.Event=function(a,b){if(!this.preventDefault)return new f.Event(a,b);a&&a.type?(this.originalEvent=a,this.type=a.type,this.isDefaultPrevented=a.defaultPrevented||a.returnValue===!1||a.getPreventDefault&&a.getPreventDefault()?E:D):this.type=a,b&&f.extend(this,b),this.timeStamp=f.now(),this[f.expando]=!0},f.Event.prototype={preventDefault:function(){this.isDefaultPrevented=E;var a=this.originalEvent;!a||(a.preventDefault?a.preventDefault():a.returnValue=!1)},stopPropagation:function(){this.isPropagationStopped=E;var a=this.originalEvent;!a||(a.stopPropagation&&a.stopPropagation(),a.cancelBubble=!0)},stopImmediatePropagation:function(){this.isImmediatePropagationStopped=E,this.stopPropagation()},isDefaultPrevented:D,isPropagationStopped:D,isImmediatePropagationStopped:D};var F=function(a){var b=a.relatedTarget;try{if(b&&b!==c&&!b.parentNode)return;while(b&&b!==this)b=b.parentNode;b!==this&&(a.type=a.data,f.event.handle.apply(this,arguments))}catch(d){}},G=function(a){a.type=a.data,f.event.handle.apply(this,arguments)};f.each({mouseenter:"mouseover",mouseleave:"mouseout"},function(a,b){f.event.special[a]={setup:function(c){f.event.add(this,b,c&&c.selector?G:F,a)},teardown:function(a){f.event.remove(this,b,a&&a.selector?G:F)}}}),f.support.submitBubbles||(f.event.special.submit={setup:function(a,b){if(!f.nodeName(this,"form"))f.event.add(this,"click.specialSubmit",function(a){var b=a.target,c=b.type;(c==="submit"||c==="image")&&f(b).closest("form").length&&K("submit",this,arguments)}),f.event.add(this,"keypress.specialSubmit",function(a){var b=a.target,c=b.type;(c==="text"||c==="password")&&f(b).closest("form").length&&a.keyCode===13&&K("submit",this,arguments)});else return!1},teardown:function(a){f.event.remove(this,".specialSubmit")}});if(!f.support.changeBubbles){var H,I=function(a){var b=a.type,c=a.value;b==="radio"||b==="checkbox"?c=a.checked:b==="select-multiple"?c=a.selectedIndex>-1?f.map(a.options,function(a){return a.selected}).join("-"):"":f.nodeName(a,"select")&&(c=a.selectedIndex);return c},J=function J(a){var c=a.target,d,e;if(!!y.test(c.nodeName)&&!c.readOnly){d=f._data(c,"_change_data"),e=I(c),(a.type!=="focusout"||c.type!=="radio")&&f._data(c,"_change_data",e);if(d===b||e===d)return;if(d!=null||e)a.type="change",a.liveFired=b,f.event.trigger(a,arguments[1],c)}};f.event.special.change={filters:{focusout:J,beforedeactivate:J,click:function(a){var b=a.target,c=f.nodeName(b,"input")?b.type:"";(c==="radio"||c==="checkbox"||f.nodeName(b,"select"))&&J.call(this,a)},keydown:function(a){var b=a.target,c=f.nodeName(b,"input")?b.type:"";(a.keyCode===13&&!f.nodeName(b,"textarea")||a.keyCode===32&&(c==="checkbox"||c==="radio")||c==="select-multiple")&&J.call(this,a)},beforeactivate:function(a){var b=a.target;f._data(b,"_change_data",I(b))}},setup:function(a,b){if(this.type==="file")return!1;for(var c in H)f.event.add(this,c+".specialChange",H[c]);return y.test(this.nodeName)},teardown:function(a){f.event.remove(this,".specialChange");return y.test(this.nodeName)}},H=f.event.special.change.filters,H.focus=H.beforeactivate}f.support.focusinBubbles||f.each({focus:"focusin",blur:"focusout"},function(a,b){function e(a){var c=f.event.fix(a);c.type=b,c.originalEvent={},f.event.trigger(c,null,c.target),c.isDefaultPrevented()&&a.preventDefault()}var d=0;f.event.special[b]={setup:function(){d++===0&&c.addEventListener(a,e,!0)},teardown:function(){--d===0&&c.removeEventListener(a,e,!0)}}}),f.each(["bind","one"],function(a,c){f.fn[c]=function(a,d,e){var g;if(typeof a=="object"){for(var h in a)this[c](h,d,a[h],e);return this}if(arguments.length===2||d===!1)e=d,d=b;c==="one"?(g=function(a){f(this).unbind(a,g);return e.apply(this,arguments)},g.guid=e.guid||f.guid++):g=e;if(a==="unload"&&c!=="one")this.one(a,d,e);else for(var i=0,j=this.length;i<j;i++)f.event.add(this[i],a,g,d);return this}}),f.fn.extend({unbind:function(a,b){if(typeof a=="object"&&!a.preventDefault)for(var c in a)this.unbind(c,a[c]);else for(var d=0,e=this.length;d<e;d++)f.event.remove(this[d],a,b);return this},delegate:function(a,b,c,d){return this.live(b,c,d,a)},undelegate:function(a,b,c){return arguments.length===0?this.unbind("live"):this.die(b,null,c,a)},trigger:function(a,b){return this.each(function(){f.event.trigger(a,b,this)})},triggerHandler:function(a,b){if(this[0])return f.event.trigger(a,b,this[0],!0)},toggle:function(a){var b=arguments,c=a.guid||f.guid++,d=0,e=function(c){var e=(f.data(this,"lastToggle"+a.guid)||0)%d;f.data(this,"lastToggle"+a.guid,e+1),c.preventDefault();return b[e].apply(this,arguments)||!1};e.guid=c;while(d<b.length)b[d++].guid=c;return this.click(e)},hover:function(a,b){return this.mouseenter(a).mouseleave(b||a)}});var L={focus:"focusin",blur:"focusout",mouseenter:"mouseover",mouseleave:"mouseout"};f.each(["live","die"],function(a,c){f.fn[c]=function(a,d,e,g){var h,i=0,j,k,l,m=g||this.selector,n=g?this:f(this.context);if(typeof a=="object"&&!a.preventDefault){for(var o in a)n[c](o,d,a[o],m);return this}if(c==="die"&&!a&&g&&g.charAt(0)==="."){n.unbind(g);return this}if(d===!1||f.isFunction(d))e=d||D,d=b;a=(a||"").split(" ");while((h=a[i++])!=null){j=x.exec(h),k="",j&&(k=j[0],h=h.replace(x,""));if(h==="hover"){a.push("mouseenter"+k,"mouseleave"+k);continue}l=h,L[h]?(a.push(L[h]+k),h=h+k):h=(L[h]||h)+k;if(c==="live")for(var p=0,q=n.length;p<q;p++)f.event.add(n[p],"live."+N(h,m),{data:d,selector:m,handler:e,origType:h,origHandler:e,preType:l});else n.unbind("live."+N(h,m),e)}return this}}),f.each("blur focus focusin focusout load resize scroll unload click dblclick mousedown mouseup mousemove mouseover mouseout mouseenter mouseleave change select submit keydown keypress keyup error".split(" "),function(a,b){f.fn[b]=function(a,c){c==null&&(c=a,a=null);return arguments.length>0?this.bind(b,a,c):this.trigger(b)},f.attrFn&&(f.attrFn[b]=!0)}),function(){function u(a,b,c,d,e,f){for(var g=0,h=d.length;g<h;g++){var i=d[g];if(i){var j=!1;i=i[a];while(i){if(i.sizcache===c){j=d[i.sizset];break}if(i.nodeType===1){f||(i.sizcache=c,i.sizset=g);if(typeof b!="string"){if(i===b){j=!0;break}}else if(k.filter(b,[i]).length>0){j=i;break}}i=i[a]}d[g]=j}}}function t(a,b,c,d,e,f){for(var g=0,h=d.length;g<h;g++){var i=d[g];if(i){var j=!1;i=i[a];while(i){if(i.sizcache===c){j=d[i.sizset];break}i.nodeType===1&&!f&&(i.sizcache=c,i.sizset=g);if(i.nodeName.toLowerCase()===b){j=i;break}i=i[a]}d[g]=j}}}var a=/((?:\((?:\([^()]+\)|[^()]+)+\)|\[(?:\[[^\[\]]*\]|['"][^'"]*['"]|[^\[\]'"]+)+\]|\\.|[^ >+~,(\[\\]+)+|[>+~])(\s*,\s*)?((?:.|\r|\n)*)/g,d=0,e=Object.prototype.toString,g=!1,h=!0,i=/\\/g,j=/\W/;[0,0].sort(function(){h=!1;return 0});var k=function(b,d,f,g){f=f||[],d=d||c;var h=d;if(d.nodeType!==1&&d.nodeType!==9)return[];if(!b||typeof b!="string")return f;var i,j,n,o,q,r,s,t,u=!0,w=k.isXML(d),x=[],y=b;do{a.exec(""),i=a.exec(y);if(i){y=i[3],x.push(i[1]);if(i[2]){o=i[3];break}}}while(i);if(x.length>1&&m.exec(b))if(x.length===2&&l.relative[x[0]])j=v(x[0]+x[1],d);else{j=l.relative[x[0]]?[d]:k(x.shift(),d);while(x.length)b=x.shift(),l.relative[b]&&(b+=x.shift()),j=v(b,j)}else{!g&&x.length>1&&d.nodeType===9&&!w&&l.match.ID.test(x[0])&&!l.match.ID.test(x[x.length-1])&&(q=k.find(x.shift(),d,w),d=q.expr?k.filter(q.expr,q.set)[0]:q.set[0]);if(d){q=g?{expr:x.pop(),set:p(g)}:k.find(x.pop(),x.length===1&&(x[0]==="~"||x[0]==="+")&&d.parentNode?d.parentNode:d,w),j=q.expr?k.filter(q.expr,q.set):q.set,x.length>0?n=p(j):u=!1;while(x.length)r=x.pop(),s=r,l.relative[r]?s=x.pop():r="",s==null&&(s=d),l.relative[r](n,s,w)}else n=x=[]}n||(n=j),n||k.error(r||b);if(e.call(n)==="[object Array]")if(!u)f.push.apply(f,n);else if(d&&d.nodeType===1)for(t=0;n[t]!=null;t++)n[t]&&(n[t]===!0||n[t].nodeType===1&&k.contains(d,n[t]))&&f.push(j[t]);else for(t=0;n[t]!=null;t++)n[t]&&n[t].nodeType===1&&f.push(j[t]);else p(n,f);o&&(k(o,h,f,g),k.uniqueSort(f));return f};k.uniqueSort=function(a){if(r){g=h,a.sort(r);if(g)for(var b=1;b<a.length;b++)a[b]===a[b-1]&&a.splice(b--,1)}return a},k.matches=function(a,b){return k(a,null,null,b)},k.matchesSelector=function(a,b){return k(b,null,null,[a]).length>0},k.find=function(a,b,c){var d;if(!a)return[];for(var e=0,f=l.order.length;e<f;e++){var g,h=l.order[e];if(g=l.leftMatch[h].exec(a)){var j=g[1];g.splice(1,1);if(j.substr(j.length-1)!=="\\"){g[1]=(g[1]||"").replace(i,""),d=l.find[h](g,b,c);if(d!=null){a=a.replace(l.match[h],"");break}}}}d||(d=typeof b.getElementsByTagName!="undefined"?b.getElementsByTagName("*"):[]);return{set:d,expr:a}},k.filter=function(a,c,d,e){var f,g,h=a,i=[],j=c,m=c&&c[0]&&k.isXML(c[0]);while(a&&c.length){for(var n in l.filter)if((f=l.leftMatch[n].exec(a))!=null&&f[2]){var o,p,q=l.filter[n],r=f[1];g=!1,f.splice(1,1);if(r.substr(r.length-1)==="\\")continue;j===i&&(i=[]);if(l.preFilter[n]){f=l.preFilter[n](f,j,d,i,e,m);if(!f)g=o=!0;else if(f===!0)continue}if(f)for(var s=0;(p=j[s])!=null;s++)if(p){o=q(p,f,s,j);var t=e^!!o;d&&o!=null?t?g=!0:j[s]=!1:t&&(i.push(p),g=!0)}if(o!==b){d||(j=i),a=a.replace(l.match[n],"");if(!g)return[];break}}if(a===h)if(g==null)k.error(a);else break;h=a}return j},k.error=function(a){throw"Syntax error, unrecognized expression: "+a};var l=k.selectors={order:["ID","NAME","TAG"],match:{ID:/#((?:[\w\u00c0-\uFFFF\-]|\\.)+)/,CLASS:/\.((?:[\w\u00c0-\uFFFF\-]|\\.)+)/,NAME:/\[name=['"]*((?:[\w\u00c0-\uFFFF\-]|\\.)+)['"]*\]/,ATTR:/\[\s*((?:[\w\u00c0-\uFFFF\-]|\\.)+)\s*(?:(\S?=)\s*(?:(['"])(.*?)\3|(#?(?:[\w\u00c0-\uFFFF\-]|\\.)*)|)|)\s*\]/,TAG:/^((?:[\w\u00c0-\uFFFF\*\-]|\\.)+)/,CHILD:/:(only|nth|last|first)-child(?:\(\s*(even|odd|(?:[+\-]?\d+|(?:[+\-]?\d*)?n\s*(?:[+\-]\s*\d+)?))\s*\))?/,POS:/:(nth|eq|gt|lt|first|last|even|odd)(?:\((\d*)\))?(?=[^\-]|$)/,PSEUDO:/:((?:[\w\u00c0-\uFFFF\-]|\\.)+)(?:\((['"]?)((?:\([^\)]+\)|[^\(\)]*)+)\2\))?/},leftMatch:{},attrMap:{"class":"className","for":"htmlFor"},attrHandle:{href:function(a){return a.getAttribute("href")},type:function(a){return a.getAttribute("type")}},relative:{"+":function(a,b){var c=typeof b=="string",d=c&&!j.test(b),e=c&&!d;d&&(b=b.toLowerCase());for(var f=0,g=a.length,h;f<g;f++)if(h=a[f]){while((h=h.previousSibling)&&h.nodeType!==1);a[f]=e||h&&h.nodeName.toLowerCase()===b?h||!1:h===b}e&&k.filter(b,a,!0)},">":function(a,b){var c,d=typeof b=="string",e=0,f=a.length;if(d&&!j.test(b)){b=b.toLowerCase();for(;e<f;e++){c=a[e];if(c){var g=c.parentNode;a[e]=g.nodeName.toLowerCase()===b?g:!1}}}else{for(;e<f;e++)c=a[e],c&&(a[e]=d?c.parentNode:c.parentNode===b);d&&k.filter(b,a,!0)}},"":function(a,b,c){var e,f=d++,g=u;typeof b=="string"&&!j.test(b)&&(b=b.toLowerCase(),e=b,g=t),g("parentNode",b,f,a,e,c)},"~":function(a,b,c){var e,f=d++,g=u;typeof b=="string"&&!j.test(b)&&(b=b.toLowerCase(),e=b,g=t),g("previousSibling",b,f,a,e,c)}},find:{ID:function(a,b,c){if(typeof b.getElementById!="undefined"&&!c){var d=b.getElementById(a[1]);return d&&d.parentNode?[d]:[]}},NAME:function(a,b){if(typeof b.getElementsByName!="undefined"){var c=[],d=b.getElementsByName(a[1]);for(var e=0,f=d.length;e<f;e++)d[e].getAttribute("name")===a[1]&&c.push(d[e]);return c.length===0?null:c}},TAG:function(a,b){if(typeof b.getElementsByTagName!="undefined")return b.getElementsByTagName(a[1])}},preFilter:{CLASS:function(a,b,c,d,e,f){a=" "+a[1].replace(i,"")+" ";if(f)return a;for(var g=0,h;(h=b[g])!=null;g++)h&&(e^(h.className&&(" "+h.className+" ").replace(/[\t\n\r]/g," ").indexOf(a)>=0)?c||d.push(h):c&&(b[g]=!1));return!1},ID:function(a){return a[1].replace(i,"")},TAG:function(a,b){return a[1].replace(i,"").toLowerCase()},CHILD:function(a){if(a[1]==="nth"){a[2]||k.error(a[0]),a[2]=a[2].replace(/^\+|\s*/g,"");var b=/(-?)(\d*)(?:n([+\-]?\d*))?/.exec(a[2]==="even"&&"2n"||a[2]==="odd"&&"2n+1"||!/\D/.test(a[2])&&"0n+"+a[2]||a[2]);a[2]=b[1]+(b[2]||1)-0,a[3]=b[3]-0}else a[2]&&k.error(a[0]);a[0]=d++;return a},ATTR:function(a,b,c,d,e,f){var g=a[1]=a[1].replace(i,"");!f&&l.attrMap[g]&&(a[1]=l.attrMap[g]),a[4]=(a[4]||a[5]||"").replace(i,""),a[2]==="~="&&(a[4]=" "+a[4]+" ");return a},PSEUDO:function(b,c,d,e,f){if(b[1]==="not")if((a.exec(b[3])||"").length>1||/^\w/.test(b[3]))b[3]=k(b[3],null,null,c);else{var g=k.filter(b[3],c,d,!0^f);d||e.push.apply(e,g);return!1}else if(l.match.POS.test(b[0])||l.match.CHILD.test(b[0]))return!0;return b},POS:function(a){a.unshift(!0);return a}},filters:{enabled:function(a){return a.disabled===!1&&a.type!=="hidden"},disabled:function(a){return a.disabled===!0},checked:function(a){return a.checked===!0},selected:function(a){a.parentNode&&a.parentNode.selectedIndex;return a.selected===!0},parent:function(a){return!!a.firstChild},empty:function(a){return!a.firstChild},has:function(a,b,c){return!!k(c[3],a).length},header:function(a){return/h\d/i.test(a.nodeName)},text:function(a){var b=a.getAttribute("type"),c=a.type;return a.nodeName.toLowerCase()==="input"&&"text"===c&&(b===c||b===null)},radio:function(a){return a.nodeName.toLowerCase()==="input"&&"radio"===a.type},checkbox:function(a){return a.nodeName.toLowerCase()==="input"&&"checkbox"===a.type},file:function(a){return a.nodeName.toLowerCase()==="input"&&"file"===a.type},password:function(a){return a.nodeName.toLowerCase()==="input"&&"password"===a.type},submit:function(a){var b=a.nodeName.toLowerCase();return(b==="input"||b==="button")&&"submit"===a.type},image:function(a){return a.nodeName.toLowerCase()==="input"&&"image"===a.type},reset:function(a){return a.nodeName.toLowerCase()==="input"&&"reset"===a.type},button:function(a){var b=a.nodeName.toLowerCase();return b==="input"&&"button"===a.type||b==="button"},input:function(a){return/input|select|textarea|button/i.test(a.nodeName)},focus:function(a){return a===a.ownerDocument.activeElement}},setFilters:{first:function(a,b){return b===0},last:function(a,b,c,d){return b===d.length-1},even:function(a,b){return b%2===0},odd:function(a,b){return b%2===1},lt:function(a,b,c){return b<c[3]-0},gt:function(a,b,c){return b>c[3]-0},nth:function(a,b,c){return c[3]-0===b},eq:function(a,b,c){return c[3]-0===b}},filter:{PSEUDO:function(a,b,c,d){var e=b[1],f=l.filters[e];if(f)return f(a,c,b,d);if(e==="contains")return(a.textContent||a.innerText||k.getText([a])||"").indexOf(b[3])>=0;if(e==="not"){var g=b[3];for(var h=0,i=g.length;h<i;h++)if(g[h]===a)return!1;return!0}k.error(e)},CHILD:function(a,b){var c=b[1],d=a;switch(c){case"only":case"first":while(d=d.previousSibling)if(d.nodeType===1)return!1;if(c==="first")return!0;d=a;case"last":while(d=d.nextSibling)if(d.nodeType===1)return!1;return!0;case"nth":var e=b[2],f=b[3];if(e===1&&f===0)return!0;var g=b[0],h=a.parentNode;if(h&&(h.sizcache!==g||!a.nodeIndex)){var i=0;for(d=h.firstChild;d;d=d.nextSibling)d.nodeType===1&&(d.nodeIndex=++i);h.sizcache=g}var j=a.nodeIndex-f;return e===0?j===0:j%e===0&&j/e>=0}},ID:function(a,b){return a.nodeType===1&&a.getAttribute("id")===b},TAG:function(a,b){return b==="*"&&a.nodeType===1||a.nodeName.toLowerCase()===b},CLASS:function(a,b){return(" "+(a.className||a.getAttribute("class"))+" ").indexOf(b)>-1},ATTR:function(a,b){var c=b[1],d=l.attrHandle[c]?l.attrHandle[c](a):a[c]!=null?a[c]:a.getAttribute(c),e=d+"",f=b[2],g=b[4];return d==null?f==="!=":f==="="?e===g:f==="*="?e.indexOf(g)>=0:f==="~="?(" "+e+" ").indexOf(g)>=0:g?f==="!="?e!==g:f==="^="?e.indexOf(g)===0:f==="$="?e.substr(e.length-g.length)===g:f==="|="?e===g||e.substr(0,g.length+1)===g+"-":!1:e&&d!==!1},POS:function(a,b,c,d){var e=b[2],f=l.setFilters[e];if(f)return f(a,c,b,d)}}},m=l.match.POS,n=function(a,b){return"\\"+(b-0+1)};for(var o in l.match)l.match[o]=new RegExp(l.match[o].source+/(?![^\[]*\])(?![^\(]*\))/.source),l.leftMatch[o]=new RegExp(/(^(?:.|\r|\n)*?)/.source+l.match[o].source.replace(/\\(\d+)/g,n));var p=function(a,b){a=Array.prototype.slice.call(a,0);if(b){b.push.apply(b,a);return b}return a};try{Array.prototype.slice.call(c.documentElement.childNodes,0)[0].nodeType}catch(q){p=function(a,b){var c=0,d=b||[];if(e.call(a)==="[object Array]")Array.prototype.push.apply(d,a);else if(typeof a.length=="number")for(var f=a.length;c<f;c++)d.push(a[c]);else for(;a[c];c++)d.push(a[c]);return d}}var r,s;c.documentElement.compareDocumentPosition?r=function(a,b){if(a===b){g=!0;return 0}if(!a.compareDocumentPosition||!b.compareDocumentPosition)return a.compareDocumentPosition?-1:1;return a.compareDocumentPosition(b)&4?-1:1}:(r=function(a,b){var c,d,e=[],f=[],h=a.parentNode,i=b.parentNode,j=h;if(a===b){g=!0;return 0}if(h===i)return s(a,b);if(!h)return-1;if(!i)return 1;while(j)e.unshift(j),j=j.parentNode;j=i;while(j)f.unshift(j),j=j.parentNode;c=e.length,d=f.length;for(var k=0;k<c&&k<d;k++)if(e[k]!==f[k])return s(e[k],f[k]);return k===c?s(a,f[k],-1):s(e[k],b,1)},s=function(a,b,c){if(a===b)return c;var d=a.nextSibling;while(d){if(d===b)return-1;d=d.nextSibling}return 1}),k.getText=function(a){var b="",c;for(var d=0;a[d];d++)c=a[d],c.nodeType===3||c.nodeType===4?b+=c.nodeValue:c.nodeType!==8&&(b+=k.getText(c.childNodes));return b},function(){var a=c.createElement("div"),d="script"+(new Date).getTime(),e=c.documentElement;a.innerHTML="<a name='"+d+"'/>",e.insertBefore(a,e.firstChild),c.getElementById(d)&&(l.find.ID=function(a,c,d){if(typeof c.getElementById!="undefined"&&!d){var e=c.getElementById(a[1]);return e?e.id===a[1]||typeof e.getAttributeNode!="undefined"&&e.getAttributeNode("id").nodeValue===a[1]?[e]:b:[]}},l.filter.ID=function(a,b){var c=typeof a.getAttributeNode!="undefined"&&a.getAttributeNode("id");return a.nodeType===1&&c&&c.nodeValue===b}),e.removeChild(a),e=a=null}(),function(){var a=c.createElement("div");a.appendChild(c.createComment("")),a.getElementsByTagName("*").length>0&&(l.find.TAG=function(a,b){var c=b.getElementsByTagName(a[1]);if(a[1]==="*"){var d=[];for(var e=0;c[e];e++)c[e].nodeType===1&&d.push(c[e]);c=d}return c}),a.innerHTML="<a href='#'></a>",a.firstChild&&typeof a.firstChild.getAttribute!="undefined"&&a.firstChild.getAttribute("href")!=="#"&&(l.attrHandle.href=function(a){return a.getAttribute("href",2)}),a=null}(),c.querySelectorAll&&function(){var a=k,b=c.createElement("div"),d="__sizzle__";b.innerHTML="<p class='TEST'></p>";if(!b.querySelectorAll||b.querySelectorAll(".TEST").length!==0){k=function(b,e,f,g){e=e||c;if(!g&&!k.isXML(e)){var h=/^(\w+$)|^\.([\w\-]+$)|^#([\w\-]+$)/.exec(b);if(h&&(e.nodeType===1||e.nodeType===9)){if(h[1])return p(e.getElementsByTagName(b),f);if(h[2]&&l.find.CLASS&&e.getElementsByClassName)return p(e.getElementsByClassName(h[2]),f)}if(e.nodeType===9){if(b==="body"&&e.body)return p([e.body],f);if(h&&h[3]){var i=e.getElementById(h[3]);if(!i||!i.parentNode)return p([],f);if(i.id===h[3])return p([i],f)}try{return p(e.querySelectorAll(b),f)}catch(j){}}else if(e.nodeType===1&&e.nodeName.toLowerCase()!=="object"){var m=e,n=e.getAttribute("id"),o=n||d,q=e.parentNode,r=/^\s*[+~]/.test(b);n?o=o.replace(/'/g,"\\$&"):e.setAttribute("id",o),r&&q&&(e=e.parentNode);try{if(!r||q)return p(e.querySelectorAll("[id='"+o+"'] "+b),f)}catch(s){}finally{n||m.removeAttribute("id")}}}return a(b,e,f,g)};for(var e in a)k[e]=a[e];b=null}}(),function(){var a=c.documentElement,b=a.matchesSelector||a.mozMatchesSelector||a.webkitMatchesSelector||a.msMatchesSelector;if(b){var d=!b.call(c.createElement("div"),"div"),e=!1;try{b.call(c.documentElement,"[test!='']:sizzle")}catch(f){e=!0}k.matchesSelector=function(a,c){c=c.replace(/\=\s*([^'"\]]*)\s*\]/g,"='$1']");if(!k.isXML(a))try{if(e||!l.match.PSEUDO.test(c)&&!/!=/.test(c)){var f=b.call(a,c);if(f||!d||a.document&&a.document.nodeType!==11)return f}}catch(g){}return k(c,null,null,[a]).length>0}}}(),function(){var a=c.createElement("div");a.innerHTML="<div class='test e'></div><div class='test'></div>";if(!!a.getElementsByClassName&&a.getElementsByClassName("e").length!==0){a.lastChild.className="e";if(a.getElementsByClassName("e").length===1)return;l.order.splice(1,0,"CLASS"),l.find.CLASS=function(a,b,c){if(typeof b.getElementsByClassName!="undefined"&&!c)return b.getElementsByClassName(a[1])},a=null}}(),c.documentElement.contains?k.contains=function(a,b){return a!==b&&(a.contains?a.contains(b):!0)}:c.documentElement.compareDocumentPosition?k.contains=function(a,b){return!!(a.compareDocumentPosition(b)&16)}:k.contains=function(){return!1},k.isXML=function(a){var b=(a?a.ownerDocument||a:0).documentElement;return b?b.nodeName!=="HTML":!1};var v=function(a,b){var c,d=[],e="",f=b.nodeType?[b]:b;while(c=l.match.PSEUDO.exec(a))e+=c[0],a=a.replace(l.match.PSEUDO,"");a=l.relative[a]?a+"*":a;for(var g=0,h=f.length;g<h;g++)k(a,f[g],d);return k.filter(e,d)};f.find=k,f.expr=k.selectors,f.expr[":"]=f.expr.filters,f.unique=k.uniqueSort,f.text=k.getText,f.isXMLDoc=k.isXML,f.contains=k.contains}();var O=/Until$/,P=/^(?:parents|prevUntil|prevAll)/,Q=/,/,R=/^.[^:#\[\.,]*$/,S=Array.prototype.slice,T=f.expr.match.POS,U={children:!0,contents:!0,next:!0,prev:!0};f.fn.extend({find:function(a){var b=this,c,d;if(typeof a!="string")return f(a).filter(function(){for(c=0,d=b.length;c<d;c++)if(f.contains(b[c],this))return!0});var e=this.pushStack("","find",a),g,h,i;for(c=0,d=this.length;c<d;c++){g=e.length,f.find(a,this[c],e);if(c>0)for(h=g;h<e.length;h++)for(i=0;i<g;i++)if(e[i]===e[h]){e.splice(h--,1);break}}return e},has:function(a){var b=f(a);return this.filter(function(){for(var a=0,c=b.length;a<c;a++)if(f.contains(this,b[a]))return!0})},not:function(a){return this.pushStack(W(this,a,!1),"not",a)},filter:function(a){return this.pushStack(W(this,a,!0),"filter",a)},is:function(a){return!!a&&(typeof a=="string"?f.filter(a,this).length>0:this.filter(a).length>0)},closest:function(a,b){var c=[],d,e,g=this[0];if(f.isArray(a)){var h,i,j={},k=1;if(g&&a.length){for(d=0,e=a.length;d<e;d++)i=a[d],j[i]||(j[i]=T.test(i)?f(i,b||this.context):i);while(g&&g.ownerDocument&&g!==b){for(i in j)h=j[i],(h.jquery?h.index(g)>-1:f(g).is(h))&&c.push({selector:i,elem:g,level:k});g=g.parentNode,k++}}return c}var l=T.test(a)||typeof a!="string"?f(a,b||this.context):0;for(d=0,e=this.length;d<e;d++){g=this[d];while(g){if(l?l.index(g)>-1:f.find.matchesSelector(g,a)){c.push(g);break}g=g.parentNode;if(!g||!g.ownerDocument||g===b||g.nodeType===11)break}}c=c.length>1?f.unique(c):c;return this.pushStack(c,"closest",a)},index:function(a){if(!a||typeof a=="string")return f.inArray(this[0],a?f(a):this.parent().children());return f.inArray(a.jquery?a[0]:a,this)},add:function(a,b){var c=typeof a=="string"?f(a,b):f.makeArray(a&&a.nodeType?[a]:a),d=f.merge(this.get(),c);return this.pushStack(V(c[0])||V(d[0])?d:f.unique(d))},andSelf:function(){return this.add(this.prevObject)}}),f.each({parent:function(a){var b=a.parentNode;return b&&b.nodeType!==11?b:null},parents:function(a){return f.dir(a,"parentNode")},parentsUntil:function(a,b,c){return f.dir(a,"parentNode",c)},next:function(a){return f.nth(a,2,"nextSibling")},prev:function(a){return f.nth(a,2,"previousSibling")},nextAll:function(a){return f.dir(a,"nextSibling")},prevAll:function(a){return f.dir(a,"previousSibling")},nextUntil:function(a,b,c){return f.dir(a,"nextSibling",c)},prevUntil:function(a,b,c){return f.dir(a,"previousSibling",c)},siblings:function(a){return f.sibling(a.parentNode.firstChild,a)},children:function(a){return f.sibling(a.firstChild)},contents:function(a){return f.nodeName(a,"iframe")?a.contentDocument||a.contentWindow.document:f.makeArray(a.childNodes)}},function(a,b){f.fn[a]=function(c,d){var e=f.map(this,b,c),g=S.call(arguments);O.test(a)||(d=c),d&&typeof d=="string"&&(e=f.filter(d,e)),e=this.length>1&&!U[a]?f.unique(e):e,(this.length>1||Q.test(d))&&P.test(a)&&(e=e.reverse());return this.pushStack(e,a,g.join(","))}}),f.extend({filter:function(a,b,c){c&&(a=":not("+a+")");return b.length===1?f.find.matchesSelector(b[0],a)?[b[0]]:[]:f.find.matches(a,b)},dir:function(a,c,d){var e=[],g=a[c];while(g&&g.nodeType!==9&&(d===b||g.nodeType!==1||!f(g).is(d)))g.nodeType===1&&e.push(g),g=g[c];return e},nth:function(a,b,c,d){b=b||1;var e=0;for(;a;a=a[c])if(a.nodeType===1&&++e===b)break;return a},sibling:function(a,b){var c=[];for(;a;a=a.nextSibling)a.nodeType===1&&a!==b&&c.push(a);return c}});var X=/ jQuery\d+="(?:\d+|null)"/g,Y=/^\s+/,Z=/<(?!area|br|col|embed|hr|img|input|link|meta|param)(([\w:]+)[^>]*)\/>/ig,$=/<([\w:]+)/,_=/<tbody/i,ba=/<|&#?\w+;/,bb=/<(?:script|object|embed|option|style)/i,bc=/checked\s*(?:[^=]|=\s*.checked.)/i,bd=/\/(java|ecma)script/i,be={option:[1,"<select multiple='multiple'>","</select>"],legend:[1,"<fieldset>","</fieldset>"],thead:[1,"<table>","</table>"],tr:[2,"<table><tbody>","</tbody></table>"],td:[3,"<table><tbody><tr>","</tr></tbody></table>"],col:[2,"<table><tbody></tbody><colgroup>","</colgroup></table>"],area:[1,"<map>","</map>"],_default:[0,"",""]};be.optgroup=be.option,be.tbody=be.tfoot=be.colgroup=be.caption=be.thead,be.th=be.td,f.support.htmlSerialize||(be._default=[1,"div<div>","</div>"]),f.fn.extend({text:function(a){if(f.isFunction(a))return this.each(function(b){var c=f(this);c.text(a.call(this,b,c.text()))});if(typeof a!="object"&&a!==b)return this.empty().append((this[0]&&this[0].ownerDocument||c).createTextNode(a));return f.text(this)},wrapAll:function(a){if(f.isFunction(a))return this.each(function(b){f(this).wrapAll(a.call(this,b))});if(this[0]){var b=f(a,this[0].ownerDocument).eq(0).clone(!0);this[0].parentNode&&b.insertBefore(this[0]),b.map(function(){var a=this;while(a.firstChild&&a.firstChild.nodeType===1)a=a.firstChild;return a}).append(this)}return this},wrapInner:function(a){if(f.isFunction(a))return this.each(function(b){f(this).wrapInner(a.call(this,b))});return this.each(function(){var b=f(this),c=b.contents();c.length?c.wrapAll(a):b.append(a)})},wrap:function(a){return this.each(function(){f(this).wrapAll(a)})},unwrap:function(){return this.parent().each(function(){f.nodeName(this,"body")||f(this).replaceWith(this.childNodes)}).end()},append:function(){return this.domManip(arguments,!0,function(a){this.nodeType===1&&this.appendChild(a)})},prepend:function(){return this.domManip(arguments,!0,function(a){this.nodeType===1&&this.insertBefore(a,this.firstChild)})},before:function(){if(this[0]&&this[0].parentNode)return this.domManip(arguments,!1,function(a){this.parentNode.insertBefore(a,this)});if(arguments.length){var a=f(arguments[0]);a.push.apply(a,this.toArray());return this.pushStack(a,"before",arguments)}},after:function(){if(this[0]&&this[0].parentNode)return this.domManip(arguments,!1,function(a){this.parentNode.insertBefore(a,this.nextSibling)});if(arguments.length){var a=this.pushStack(this,"after",arguments);a.push.apply(a,f(arguments[0]).toArray());return a}},remove:function(a,b){for(var c=0,d;(d=this[c])!=null;c++)if(!a||f.filter(a,[d]).length)!b&&d.nodeType===1&&(f.cleanData(d.getElementsByTagName("*")),f.cleanData([d])),d.parentNode&&d.parentNode.removeChild(d);return this},empty:function(){for(var a=0,b;(b=this[a])!=null;a++){b.nodeType===1&&f.cleanData(b.getElementsByTagName("*"));while(b.firstChild)b.removeChild(b.firstChild)}return this},clone:function(a,b){a=a==null?!1:a,b=b==null?a:b;return this.map(function(){return f.clone(this,a,b)})},html:function(a){if(a===b)return this[0]&&this[0].nodeType===1?this[0].innerHTML.replace(X,""):null;if(typeof a=="string"&&!bb.test(a)&&(f.support.leadingWhitespace||!Y.test(a))&&!be[($.exec(a)||["",""])[1].toLowerCase()]){a=a.replace(Z,"<$1></$2>");try{for(var c=0,d=this.length;c<d;c++)this[c].nodeType===1&&(f.cleanData(this[c].getElementsByTagName("*")),this[c].innerHTML=a)}catch(e){this.empty().append(a)}}else f.isFunction(a)?this.each(function(b){var c=f(this);c.html(a.call(this,b,c.html()))}):this.empty().append(a);return this},replaceWith:function(a){if(this[0]&&this[0].parentNode){if(f.isFunction(a))return this.each(function(b){var c=f(this),d=c.html();c.replaceWith(a.call(this,b,d))});typeof a!="string"&&(a=f(a).detach());return this.each(function(){var b=this.nextSibling,c=this.parentNode;f(this).remove(),b?f(b).before(a):f(c).append(a)})}return this.length?this.pushStack(f(f.isFunction(a)?a():a),"replaceWith",a):this},detach:function(a){return this.remove(a,!0)},domManip:function(a,c,d){var e,g,h,i,j=a[0],k=[];if(!f.support.checkClone&&arguments.length===3&&typeof j=="string"&&bc.test(j))return this.each(function(){f(this).domManip(a,c,d,!0)});if(f.isFunction(j))return this.each(function(e){var g=f(this);a[0]=j.call(this,e,c?g.html():b),g.domManip(a,c,d)});if(this[0]){i=j&&j.parentNode,f.support.parentNode&&i&&i.nodeType===11&&i.childNodes.length===this.length?e={fragment:i}:e=f.buildFragment(a,this,k),h=e.fragment,h.childNodes.length===1?g=h=h.firstChild:g=h.firstChild;if(g){c=c&&f.nodeName(g,"tr");for(var l=0,m=this.length,n=m-1;l<m;l++)d.call(c?bf(this[l],g):this[l],e.cacheable||m>1&&l<n?f.clone(h,!0,!0):h)}k.length&&f.each(k,bl)}return this}}),f.buildFragment=function(a,b,d){var e,g,h,i=b&&b[0]?b[0].ownerDocument||b[0]:c;a.length===1&&typeof a[0]=="string"&&a[0].length<512&&i===c&&a[0].charAt(0)==="<"&&!bb.test(a[0])&&(f.support.checkClone||!bc.test(a[0]))&&(g=!0,h=f.fragments[a[0]],h&&h!==1&&(e=h)),e||(e=i.createDocumentFragment(),f.clean(a,i,e,d)),g&&(f.fragments[a[0]]=h?e:1);return{fragment:e,cacheable:g}},f.fragments={},f.each({appendTo:"append",prependTo:"prepend",insertBefore:"before",insertAfter:"after",replaceAll:"replaceWith"},function(a,b){f.fn[a]=function(c){var d=[],e=f(c),g=this.length===1&&this[0].parentNode;if(g&&g.nodeType===11&&g.childNodes.length===1&&e.length===1){e[b](this[0]);return this}for(var h=0,i=e.length;h<i;h++){var j=(h>0?this.clone(!0):this).get();f(e[h])[b](j),d=d.concat(j)}return this.pushStack(d,a,e.selector)}}),f.extend({clone:function(a,b,c){var d=a.cloneNode(!0),e,g,h;if((!f.support.noCloneEvent||!f.support.noCloneChecked)&&(a.nodeType===1||a.nodeType===11)&&!f.isXMLDoc(a)){bh(a,d),e=bi(a),g=bi(d);for(h=0;e[h];++h)bh(e[h],g[h])}if(b){bg(a,d);if(c){e=bi(a),g=bi(d);for(h=0;e[h];++h)bg(e[h],g[h])}}return d},clean:function(a,b,d,e){var g;b=b||c,typeof b.createElement=="undefined"&&(b=b.ownerDocument||b[0]&&b[0].ownerDocument||c);var h=[];for(var i=0,j;(j=a[i])!=null;i++){typeof j=="number"&&(j+="");if(!j)continue;if(typeof j=="string")if(!ba.test(j))j=b.createTextNode(j);else{j=j.replace(Z,"<$1></$2>");var k=($.exec(j)||["",""])[1].toLowerCase(),l=be[k]||be._default,m=l[0],n=b.createElement("div");n.innerHTML=l[1]+j+l[2];while(m--)n=n.lastChild;if(!f.support.tbody){var o=_.test(j),p=k==="table"&&!o?n.firstChild&&n.firstChild.childNodes:l[1]==="<table>"&&!o?n.childNodes:[];for(var q=p.length-1;q>=0;--q)f.nodeName(p[q],"tbody")&&!p[q].childNodes.length&&p[q].parentNode.removeChild(p[q])}!f.support.leadingWhitespace&&Y.test(j)&&n.insertBefore(b.createTextNode(Y.exec(j)[0]),n.firstChild),j=n.childNodes}var r;if(!f.support.appendChecked)if(j[0]&&typeof (r=j.length)=="number")for(i=0;i<r;i++)bk(j[i]);else bk(j);j.nodeType?h.push(j):h=f.merge(h,j)}if(d){g=function(a){return!a.type||bd.test(a.type)};for(i=0;h[i];i++)if(e&&f.nodeName(h[i],"script")&&(!h[i].type||h[i].type.toLowerCase()==="text/javascript"))e.push(h[i].parentNode?h[i].parentNode.removeChild(h[i]):h[i]);else{if(h[i].nodeType===1){var s=f.grep(h[i].getElementsByTagName("script"),g);h.splice.apply(h,[i+1,0].concat(s))}d.appendChild(h[i])}}return h},cleanData:function(a){var b,c,d=f.cache,e=f.expando,g=f.event.special,h=f.support.deleteExpando;for(var i=0,j;(j=a[i])!=null;i++){if(j.nodeName&&f.noData[j.nodeName.toLowerCase()])continue;c=j[f.expando];if(c){b=d[c]&&d[c][e];if(b&&b.events){for(var k in b.events)g[k]?f.event.remove(j,k):f.removeEvent(j,k,b.handle);b.handle&&(b.handle.elem=null)}h?delete j[f.expando]:j.removeAttribute&&j.removeAttribute(f.expando),delete d[c]}}}});var bm=/alpha\([^)]*\)/i,bn=/opacity=([^)]*)/,bo=/-([a-z])/ig,bp=/([A-Z]|^ms)/g,bq=/^-?\d+(?:px)?$/i,br=/^-?\d/,bs=/^[+\-]=/,bt=/[^+\-\.\de]+/g,bu={position:"absolute",visibility:"hidden",display:"block"},bv=["Left","Right"],bw=["Top","Bottom"],bx,by,bz,bA=function(a,b){return b.toUpperCase()};f.fn.css=function(a,c){if(arguments.length===2&&c===b)return this;return f.access(this,a,c,!0,function(a,c,d){return d!==b?f.style(a,c,d):f.css(a,c)})},f.extend({cssHooks:{opacity:{get:function(a,b){if(b){var c=bx(a,"opacity","opacity");return c===""?"1":c}return a.style.opacity}}},cssNumber:{zIndex:!0,fontWeight:!0,opacity:!0,zoom:!0,lineHeight:!0,widows:!0,orphans:!0},cssProps:{"float":f.support.cssFloat?"cssFloat":"styleFloat"},style:function(a,c,d,e){if(!!a&&a.nodeType!==3&&a.nodeType!==8&&!!a.style){var g,h,i=f.camelCase(c),j=a.style,k=f.cssHooks[i];c=f.cssProps[i]||i;if(d===b){if(k&&"get"in k&&(g=k.get(a,!1,e))!==b)return g;return j[c]}h=typeof d;if(h==="number"&&isNaN(d)||d==null)return;h==="string"&&bs.test(d)&&(d=+d.replace(bt,"")+parseFloat(f.css(a,c))),h==="number"&&!f.cssNumber[i]&&(d+="px");if(!k||!("set"in k)||(d=k.set(a,d))!==b)try{j[c]=d}catch(l){}}},css:function(a,c,d){var e,g;c=f.camelCase(c),g=f.cssHooks[c],c=f.cssProps[c]||c,c==="cssFloat"&&(c="float");if(g&&"get"in g&&(e=g.get(a,!0,d))!==b)return e;if(bx)return bx(a,c)},swap:function(a,b,c){var d={};for(var e in b)d[e]=a.style[e],a.style[e]=b[e];c.call(a);for(e in b)a.style[e]=d[e]},camelCase:function(a){return a.replace(bo,bA)}}),f.curCSS=f.css,f.each(["height","width"],function(a,b){f.cssHooks[b]={get:function(a,c,d){var e;if(c){a.offsetWidth!==0?e=bB(a,b,d):f.swap(a,bu,function(){e=bB(a,b,d)});if(e<=0){e=bx(a,b,b),e==="0px"&&bz&&(e=bz(a,b,b));if(e!=null)return e===""||e==="auto"?"0px":e}if(e<0||e==null){e=a.style[b];return e===""||e==="auto"?"0px":e}return typeof e=="string"?e:e+"px"}},set:function(a,b){if(!bq.test(b))return b;b=parseFloat(b);if(b>=0)return b+"px"}}}),f.support.opacity||(f.cssHooks.opacity={get:function(a,b){return bn.test((b&&a.currentStyle?a.currentStyle.filter:a.style.filter)||"")?parseFloat(RegExp.$1)/100+"":b?"1":""},set:function(a,b){var c=a.style,d=a.currentStyle;c.zoom=1;var e=f.isNaN(b)?"":"alpha(opacity="+b*100+")",g=d&&d.filter||c.filter||"";c.filter=bm.test(g)?g.replace(bm,e):g+" "+e}}),f(function(){f.support.reliableMarginRight||(f.cssHooks.marginRight={get:function(a,b){var c;f.swap(a,{display:"inline-block"},function(){b?c=bx(a,"margin-right","marginRight"):c=a.style.marginRight});return c}})}),c.defaultView&&c.defaultView.getComputedStyle&&(by=function(a,c){var d,e,g;c=c.replace(bp,"-$1").toLowerCase();if(!(e=a.ownerDocument.defaultView))return b;if(g=e.getComputedStyle(a,null))d=g.getPropertyValue(c),d===""&&!f.contains(a.ownerDocument.documentElement,a)&&(d=f.style(a,c));return d}),c.documentElement.currentStyle&&(bz=function(a,b){var c,d=a.currentStyle&&a.currentStyle[b],e=a.runtimeStyle&&a.runtimeStyle[b],f=a.style;!bq.test(d)&&br.test(d)&&(c=f.left,e&&(a.runtimeStyle.left=a.currentStyle.left),f.left=b==="fontSize"?"1em":d||0,d=f.pixelLeft+"px",f.left=c,e&&(a.runtimeStyle.left=e));return d===""?"auto":d}),bx=by||bz,f.expr&&f.expr.filters&&(f.expr.filters.hidden=function(a){var b=a.offsetWidth,c=a.offsetHeight;return b===0&&c===0||!f.support.reliableHiddenOffsets&&(a.style.display||f.css(a,"display"))==="none"},f.expr.filters.visible=function(a){return!f.expr.filters.hidden(a)});var bC=/%20/g,bD=/\[\]$/,bE=/\r?\n/g,bF=/#.*$/,bG=/^(.*?):[ \t]*([^\r\n]*)\r?$/mg,bH=/^(?:color|date|datetime|email|hidden|month|number|password|range|search|tel|text|time|url|week)$/i,bI=/^(?:about|app|app\-storage|.+\-extension|file|widget):$/,bJ=/^(?:GET|HEAD)$/,bK=/^\/\//,bL=/\?/,bM=/<script\b[^<]*(?:(?!<\/script>)<[^<]*)*<\/script>/gi,bN=/^(?:select|textarea)/i,bO=/\s+/,bP=/([?&])_=[^&]*/,bQ=/^([\w\+\.\-]+:)(?:\/\/([^\/?#:]*)(?::(\d+))?)?/,bR=f.fn.load,bS={},bT={},bU,bV;try{bU=e.href}catch(bW){bU=c.createElement("a"),bU.href="",bU=bU.href}bV=bQ.exec(bU.toLowerCase())||[],f.fn.extend({load:function(a,c,d){if(typeof a!="string"&&bR)return bR.apply(this,arguments);if(!this.length)return this;var e=a.indexOf(" ");if(e>=0){var g=a.slice(e,a.length);a=a.slice(0,e)}var h="GET";c&&(f.isFunction(c)?(d=c,c=b):typeof c=="object"&&(c=f.param(c,f.ajaxSettings.traditional),h="POST"));var i=this;f.ajax({url:a,type:h,dataType:"html",data:c,complete:function(a,b,c){c=a.responseText,a.isResolved()&&(a.done(function(a){c=a}),i.html(g?f("<div>").append(c.replace(bM,"")).find(g):c)),d&&i.each(d,[c,b,a])}});return this},serialize:function(){return f.param(this.serializeArray())},serializeArray:function(){return this.map(function(){return this.elements?f.makeArray(this.elements):this}).filter(function(){return this.name&&!this.disabled&&(this.checked||bN.test(this.nodeName)||bH.test(this.type))}).map(function(a,b){var c=f(this).val();return c==null?null:f.isArray(c)?f.map(c,function(a,c){return{name:b.name,value:a.replace(bE,"\r\n")}}):{name:b.name,value:c.replace(bE,"\r\n")}}).get()}}),f.each("ajaxStart ajaxStop ajaxComplete ajaxError ajaxSuccess ajaxSend".split(" "),function(a,b){f.fn[b]=function(a){return this.bind(b,a)}}),f.each(["get","post"],function(a,c){f[c]=function(a,d,e,g){f.isFunction(d)&&(g=g||e,e=d,d=b);return f.ajax({type:c,url:a,data:d,success:e,dataType:g})}}),f.extend({getScript:function(a,c){return f.get(a,b,c,"script")},getJSON:function(a,b,c){return f.get(a,b,c,"json")},ajaxSetup:function(a,b){b?f.extend(!0,a,f.ajaxSettings,b):(b=a,a=f.extend(!0,f.ajaxSettings,b));for(var c in{context:1,url:1})c in b?a[c]=b[c]:c in f.ajaxSettings&&(a[c]=f.ajaxSettings[c]);return a},ajaxSettings:{url:bU,isLocal:bI.test(bV[1]),global:!0,type:"GET",contentType:"application/x-www-form-urlencoded",processData:!0,async:!0,accepts:{xml:"application/xml, text/xml",html:"text/html",text:"text/plain",json:"application/json, text/javascript","*":"*/*"},contents:{xml:/xml/,html:/html/,json:/json/},responseFields:{xml:"responseXML",text:"responseText"},converters:{"* text":a.String,"text html":!0,"text json":f.parseJSON,"text xml":f.parseXML}},ajaxPrefilter:bX(bS),ajaxTransport:bX(bT),ajax:function(a,c){function w(a,c,l,m){if(s!==2){s=2,q&&clearTimeout(q),p=b,n=m||"",v.readyState=a?4:0;var o,r,u,w=l?b$(d,v,l):b,x,y;if(a>=200&&a<300||a===304){if(d.ifModified){if(x=v.getResponseHeader("Last-Modified"))f.lastModified[k]=x;if(y=v.getResponseHeader("Etag"))f.etag[k]=y}if(a===304)c="notmodified",o=!0;else try{r=b_(d,w),c="success",o=!0}catch(z){c="parsererror",u=z}}else{u=c;if(!c||a)c="error",a<0&&(a=0)}v.status=a,v.statusText=c,o?h.resolveWith(e,[r,c,v]):h.rejectWith(e,[v,c,u]),v.statusCode(j),j=b,t&&g.trigger("ajax"+(o?"Success":"Error"),[v,d,o?r:u]),i.resolveWith(e,[v,c]),t&&(g.trigger("ajaxComplete",[v,d]),--f.active||f.event.trigger("ajaxStop"))}}typeof a=="object"&&(c=a,a=b),c=c||{};var d=f.ajaxSetup({},c),e=d.context||d,g=e!==d&&(e.nodeType||e instanceof f)?f(e):f.event,h=f.Deferred(),i=f._Deferred(),j=d.statusCode||{},k,l={},m={},n,o,p,q,r,s=0,t,u,v={readyState:0,setRequestHeader:function(a,b){if(!s){var c=a.toLowerCase();a=m[c]=m[c]||a,l[a]=b}return this},getAllResponseHeaders:function(){return s===2?n:null},getResponseHeader:function(a){var c;if(s===2){if(!o){o={};while(c=bG.exec(n))o[c[1].toLowerCase()]=c[2]}c=o[a.toLowerCase()]}return c===b?null:c},overrideMimeType:function(a){s||(d.mimeType=a);return this},abort:function(a){a=a||"abort",p&&p.abort(a),w(0,a);return this}};h.promise(v),v.success=v.done,v.error=v.fail,v.complete=i.done,v.statusCode=function(a){if(a){var b;if(s<2)for(b in a)j[b]=[j[b],a[b]];else b=a[v.status],v.then(b,b)}return this},d.url=((a||d.url)+"").replace(bF,"").replace(bK,bV[1]+"//"),d.dataTypes=f.trim(d.dataType||"*").toLowerCase().split(bO),d.crossDomain==null&&(r=bQ.exec(d.url.toLowerCase()),d.crossDomain=!(!r||r[1]==bV[1]&&r[2]==bV[2]&&(r[3]||(r[1]==="http:"?80:443))==(bV[3]||(bV[1]==="http:"?80:443)))),d.data&&d.processData&&typeof d.data!="string"&&(d.data=f.param(d.data,d.traditional)),bY(bS,d,c,v);if(s===2)return!1;t=d.global,d.type=d.type.toUpperCase(),d.hasContent=!bJ.test(d.type),t&&f.active++===0&&f.event.trigger("ajaxStart");if(!d.hasContent){d.data&&(d.url+=(bL.test(d.url)?"&":"?")+d.data),k=d.url;if(d.cache===!1){var x=f.now(),y=d.url.replace(bP,"$1_="+x);d.url=y+(y===d.url?(bL.test(d.url)?"&":"?")+"_="+x:"")}}(d.data&&d.hasContent&&d.contentType!==!1||c.contentType)&&v.setRequestHeader("Content-Type",d.contentType),d.ifModified&&(k=k||d.url,f.lastModified[k]&&v.setRequestHeader("If-Modified-Since",f.lastModified[k]),f.etag[k]&&v.setRequestHeader("If-None-Match",f.etag[k])),v.setRequestHeader("Accept",d.dataTypes[0]&&d.accepts[d.dataTypes[0]]?d.accepts[d.dataTypes[0]]+(d.dataTypes[0]!=="*"?", */*; q=0.01":""):d.accepts["*"]);for(u in d.headers)v.setRequestHeader(u,d.headers[u]);if(d.beforeSend&&(d.beforeSend.call(e,v,d)===!1||s===2)){v.abort();return!1}for(u in{success:1,error:1,complete:1})v[u](d[u]);p=bY(bT,d,c,v);if(!p)w(-1,"No Transport");else{v.readyState=1,t&&g.trigger("ajaxSend",[v,d]),d.async&&d.timeout>0&&(q=setTimeout(function(){v.abort("timeout")},d.timeout));try{s=1,p.send(l,w)}catch(z){status<2?w(-1,z):f.error(z)}}return v},param:function(a,c){var d=[],e=function(a,b){b=f.isFunction(b)?b():b,d[d.length]=encodeURIComponent(a)+"="+encodeURIComponent(b)};c===b&&(c=f.ajaxSettings.traditional);if(f.isArray(a)||a.jquery&&!f.isPlainObject(a))f.each(a,function(){e(this.name,this.value)});else for(var g in a)bZ(g,a[g],c,e);return d.join("&").replace(bC,"+")}}),f.extend({active:0,lastModified:{},etag:{}});var ca=f.now(),cb=/(\=)\?(&|$)|\?\?/i;f.ajaxSetup({jsonp:"callback",jsonpCallback:function(){return f.expando+"_"+ca++}}),f.ajaxPrefilter("json jsonp",function(b,c,d){var e=b.contentType==="application/x-www-form-urlencoded"&&typeof b.data=="string";if(b.dataTypes[0]==="jsonp"||b.jsonp!==!1&&(cb.test(b.url)||e&&cb.test(b.data))){var g,h=b.jsonpCallback=f.isFunction(b.jsonpCallback)?b.jsonpCallback():b.jsonpCallback,i=a[h],j=b.url,k=b.data,l="$1"+h+"$2";b.jsonp!==!1&&(j=j.replace(cb,l),b.url===j&&(e&&(k=k.replace(cb,l)),b.data===k&&(j+=(/\?/.test(j)?"&":"?")+b.jsonp+"="+h))),b.url=j,b.data=k,a[h]=function(a){g=[a]},d.always(function(){a[h]=i,g&&f.isFunction(i)&&a[h](g[0])}),b.converters["script json"]=function(){g||f.error(h+" was not called");return g[0]},b.dataTypes[0]="json";return"script"}}),f.ajaxSetup({accepts:{script:"text/javascript, application/javascript, application/ecmascript, application/x-ecmascript"},contents:{script:/javascript|ecmascript/},converters:{"text script":function(a){f.globalEval(a);return a}}}),f.ajaxPrefilter("script",function(a){a.cache===b&&(a.cache=!1),a.crossDomain&&(a.type="GET",a.global=!1)}),f.ajaxTransport("script",function(a){if(a.crossDomain){var d,e=c.head||c.getElementsByTagName("head")[0]||c.documentElement;return{send:function(f,g){d=c.createElement("script"),d.async="async",a.scriptCharset&&(d.charset=a.scriptCharset),d.src=a.url,d.onload=d.onreadystatechange=function(a,c){if(c||!d.readyState||/loaded|complete/.test(d.readyState))d.onload=d.onreadystatechange=null,e&&d.parentNode&&e.removeChild(d),d=b,c||g(200,"success")},e.insertBefore(d,e.firstChild)},abort:function(){d&&d.onload(0,1)}}}});var cc=a.ActiveXObject?function(){for(var a in ce)ce[a](0,1)}:!1,cd=0,ce;f.ajaxSettings.xhr=a.ActiveXObject?function(){return!this.isLocal&&cf()||cg()}:cf,function(a){f.extend(f.support,{ajax:!!a,cors:!!a&&"withCredentials"in a})}(f.ajaxSettings.xhr()),f.support.ajax&&f.ajaxTransport(function(c){if(!c.crossDomain||f.support.cors){var d;return{send:function(e,g){var h=c.xhr(),i,j;c.username?h.open(c.type,c.url,c.async,c.username,c.password):h.open(c.type,c.url,c.async);if(c.xhrFields)for(j in c.xhrFields)h[j]=c.xhrFields[j];c.mimeType&&h.overrideMimeType&&h.overrideMimeType(c.mimeType),!c.crossDomain&&!e["X-Requested-With"]&&(e["X-Requested-With"]="XMLHttpRequest");try{for(j in e)h.setRequestHeader(j,e[j])}catch(k){}h.send(c.hasContent&&c.data||null),d=function(a,e){var j,k,l,m,n;try{if(d&&(e||h.readyState===4)){d=b,i&&(h.onreadystatechange=f.noop,cc&&delete ce[i]);if(e)h.readyState!==4&&h.abort();else{j=h.status,l=h.getAllResponseHeaders(),m={},n=h.responseXML,n&&n.documentElement&&(m.xml=n),m.text=h.responseText;try{k=h.statusText}catch(o){k=""}!j&&c.isLocal&&!c.crossDomain?j=m.text?200:404:j===1223&&(j=204)}}}catch(p){e||g(-1,p)}m&&g(j,k,m,l)},!c.async||h.readyState===4?d():(i=++cd,cc&&(ce||(ce={},f(a).unload(cc)),ce[i]=d),h.onreadystatechange=d)},abort:function(){d&&d(0,1)}}}});var ch={},ci,cj,ck=/^(?:toggle|show|hide)$/,cl=/^([+\-]=)?([\d+.\-]+)([a-z%]*)$/i,cm,cn=[["height","marginTop","marginBottom","paddingTop","paddingBottom"],["width","marginLeft","marginRight","paddingLeft","paddingRight"],["opacity"]],co,cp=a.webkitRequestAnimationFrame||a.mozRequestAnimationFrame||a.oRequestAnimationFrame;f.fn.extend({show:function(a,b,c){var d,e;if(a||a===0)return this.animate(cs("show",3),a,b,c);for(var g=0,h=this.length;g<h;g++)d=this[g],d.style&&(e=d.style.display,!f._data(d,"olddisplay")&&e==="none"&&(e=d.style.display=""),e===""&&f.css(d,"display")==="none"&&f._data(d,"olddisplay",ct(d.nodeName)));for(g=0;g<h;g++){d=this[g];if(d.style){e=d.style.display;if(e===""||e==="none")d.style.display=f._data(d,"olddisplay")||""}}return this},hide:function(a,b,c){if(a||a===0)return this.animate(cs("hide",3),a,b,c);for(var d=0,e=this.length;d<e;d++)if(this[d].style){var g=f.css(this[d],"display");g!=="none"&&!f._data(this[d],"olddisplay")&&f._data(this[d],"olddisplay",g)}for(d=0;d<e;d++)this[d].style&&(this[d].style.display="none");return this},_toggle:f.fn.toggle,toggle:function(a,b,c){var d=typeof a=="boolean";f.isFunction(a)&&f.isFunction(b)?this._toggle.apply(this,arguments):a==null||d?this.each(function(){var b=d?a:f(this).is(":hidden");f(this)[b?"show":"hide"]()}):this.animate(cs("toggle",3),a,b,c);return this},fadeTo:function(a,b,c,d){return this.filter(":hidden").css("opacity",0).show().end().animate({opacity:b},a,c,d)},animate:function(a,b,c,d){var e=f.speed(b,c,d);if(f.isEmptyObject(a))return this.each(e.complete,[!1]);return this[e.queue===!1?"each":"queue"](function(){e.queue===!1&&f._mark(this);var b=f.extend({},e),c=this.nodeType===1,d=c&&f(this).is(":hidden"),g,h,i,j,k,l,m,n,o;b.animatedProperties={};for(i in a){g=f.camelCase(i),i!==g&&(a[g]=a[i],delete a[i]),h=a[g];if(h==="hide"&&d||h==="show"&&!d)return b.complete.call(this);c&&(g==="height"||g==="width")&&(b.overflow=[this.style.overflow,this.style.overflowX,this.style.overflowY],f.css(this,"display")==="inline"&&f.css(this,"float")==="none"&&(f.support.inlineBlockNeedsLayout?(j=ct(this.nodeName),j==="inline"?this.style.display="inline-block":(this.style.display="inline",this.style.zoom=1)):this.style.display="inline-block")),b.animatedProperties[g]=f.isArray(h)?h[1]:b.specialEasing&&b.specialEasing[g]||b.easing||"swing"}b.overflow!=null&&(this.style.overflow="hidden");for(i in a)k=new f.fx(this,b,i),h=a[i],ck.test(h)?k[h==="toggle"?d?"show":"hide":h]():(l=cl.exec(h),m=k.cur(),l?(n=parseFloat(l[2]),o=l[3]||(f.cssNumber[g]?"":"px"),o!=="px"&&(f.style(this,i,(n||1)+o),m=(n||1)/k.cur()*m,f.style(this,i,m+o)),l[1]&&(n=(l[1]==="-="?-1:1)*n+m),k.custom(m,n,o)):k.custom(m,h,""));return!0})},stop:function(a,b){a&&this.queue([]),this.each(function(){var a=f.timers,c=a.length;b||f._unmark(!0,this);while(c--)a[c].elem===this&&(b&&a[c](!0),a.splice(c,1))}),b||this.dequeue();return this}}),f.each({slideDown:cs("show",1),slideUp:cs("hide",1),slideToggle:cs("toggle",1),fadeIn:{opacity:"show"},fadeOut:{opacity:"hide"},fadeToggle:{opacity:"toggle"}},function(a,b){f.fn[a]=function(a,c,d){return this.animate(b,a,c,d)}}),f.extend({speed:function(a,b,c){var d=a&&typeof a=="object"?f.extend({},a):{complete:c||!c&&b||f.isFunction(a)&&a,duration:a,easing:c&&b||b&&!f.isFunction(b)&&b};d.duration=f.fx.off?0:typeof d.duration=="number"?d.duration:d.duration in f.fx.speeds?f.fx.speeds[d.duration]:f.fx.speeds._default,d.old=d.complete,d.complete=function(a){d.queue!==!1?f.dequeue(this):a!==!1&&f._unmark(this),f.isFunction(d.old)&&d.old.call(this)};return d},easing:{linear:function(a,b,c,d){return c+d*a},swing:function(a,b,c,d){return(-Math.cos(a*Math.PI)/2+.5)*d+c}},timers:[],fx:function(a,b,c){this.options=b,this.elem=a,this.prop=c,b.orig=b.orig||{}}}),f.fx.prototype={update:function(){this.options.step&&this.options.step.call(this.elem,this.now,this),(f.fx.step[this.prop]||f.fx.step._default)(this)},cur:function(){if(this.elem[this.prop]!=null&&(!this.elem.style||this.elem.style[this.prop]==null))return this.elem[this.prop];var a,b=f.css(this.elem,this.prop);return isNaN(a=parseFloat(b))?!b||b==="auto"?0:b:a},custom:function(a,b,c){function h(a){return d.step(a)}var d=this,e=f.fx,g;this.startTime=co||cq(),this.start=a,this.end=b,this.unit=c||this.unit||(f.cssNumber[this.prop]?"":"px"),this.now=this.start,this.pos=this.state=0,h.elem=this.elem,h()&&f.timers.push(h)&&!cm&&(cp?(cm=1,g=function(){cm&&(cp(g),e.tick())},cp(g)):cm=setInterval(e.tick,e.interval))},show:function(){this.options.orig[this.prop]=f.style(this.elem,this.prop),this.options.show=!0,this.custom(this.prop==="width"||this.prop==="height"?1:0,this.cur()),f(this.elem).show()},hide:function(){this.options.orig[this.prop]=f.style(this.elem,this.prop),this.options.hide=!0,this.custom(this.cur(),0)},step:function(a){var b=co||cq(),c=!0,d=this.elem,e=this.options,g,h;if(a||b>=e.duration+this.startTime){this.now=this.end,this.pos=this.state=1,this.update(),e.animatedProperties[this.prop]=!0;for(g in e.animatedProperties)e.animatedProperties[g]!==!0&&(c=!1);if(c){e.overflow!=null&&!f.support.shrinkWrapBlocks&&f.each(["","X","Y"],function(a,b){d.style["overflow"+b]=e.overflow[a]}),e.hide&&f(d).hide();if(e.hide||e.show)for(var i in e.animatedProperties)f.style(d,i,e.orig[i]);e.complete.call(d)}return!1}e.duration==Infinity?this.now=b:(h=b-this.startTime,this.state=h/e.duration,this.pos=f.easing[e.animatedProperties[this.prop]](this.state,h,0,1,e.duration),this.now=this.start+(this.end-this.start)*this.pos),this.update();return!0}},f.extend(f.fx,{tick:function(){var a=f.timers,b=a.length;while(b--)a[b]()||a.splice(b,1);a.length||f.fx.stop()},interval:13,stop:function(){clearInterval(cm),cm=null},speeds:{slow:600,fast:200,_default:400},step:{opacity:function(a){f.style(a.elem,"opacity",a.now)},_default:function(a){a.elem.style&&a.elem.style[a.prop]!=null?a.elem.style[a.prop]=(a.prop==="width"||a.prop==="height"?Math.max(0,a.now):a.now)+a.unit:a.elem[a.prop]=a.now}}}),f.expr&&f.expr.filters&&(f.expr.filters.animated=function(a){return f.grep(f.timers,function(b){return a===b.elem}).length});var cu=/^t(?:able|d|h)$/i,cv=/^(?:body|html)$/i;"getBoundingClientRect"in c.documentElement?f.fn.offset=function(a){var b=this[0],c;if(a)return this.each(function(b){f.offset.setOffset(this,a,b)});if(!b||!b.ownerDocument)return null;if(b===b.ownerDocument.body)return f.offset.bodyOffset(b);try{c=b.getBoundingClientRect()}catch(d){}var e=b.ownerDocument,g=e.documentElement;if(!c||!f.contains(g,b))return c?{top:c.top,left:c.left}:{top:0,left:0};var h=e.body,i=cw(e),j=g.clientTop||h.clientTop||0,k=g.clientLeft||h.clientLeft||0,l=i.pageYOffset||f.support.boxModel&&g.scrollTop||h.scrollTop,m=i.pageXOffset||f.support.boxModel&&g.scrollLeft||h.scrollLeft,n=c.top+l-j,o=c.left+m-k;return{top:n,left:o}}:f.fn.offset=function(a){var b=this[0];if(a)return this.each(function(b){f.offset.setOffset(this,a,b)});if(!b||!b.ownerDocument)return null;if(b===b.ownerDocument.body)return f.offset.bodyOffset(b);f.offset.initialize();var c,d=b.offsetParent,e=b,g=b.ownerDocument,h=g.documentElement,i=g.body,j=g.defaultView,k=j?j.getComputedStyle(b,null):b.currentStyle,l=b.offsetTop,m=b.offsetLeft;while((b=b.parentNode)&&b!==i&&b!==h){if(f.offset.supportsFixedPosition&&k.position==="fixed")break;c=j?j.getComputedStyle(b,null):b.currentStyle,l-=b.scrollTop,m-=b.scrollLeft,b===d&&(l+=b.offsetTop,m+=b.offsetLeft,f.offset.doesNotAddBorder&&(!f.offset.doesAddBorderForTableAndCells||!cu.test(b.nodeName))&&(l+=parseFloat(c.borderTopWidth)||0,m+=parseFloat(c.borderLeftWidth)||0),e=d,d=b.offsetParent),f.offset.subtractsBorderForOverflowNotVisible&&c.overflow!=="visible"&&(l+=parseFloat(c.borderTopWidth)||0,m+=parseFloat(c.borderLeftWidth)||0),k=c}if(k.position==="relative"||k.position==="static")l+=i.offsetTop,m+=i.offsetLeft;f.offset.supportsFixedPosition&&k.position==="fixed"&&(l+=Math.max(h.scrollTop,i.scrollTop),m+=Math.max(h.scrollLeft,i.scrollLeft));return{top:l,left:m}},f.offset={initialize:function(){var a=c.body,b=c.createElement("div"),d,e,g,h,i=parseFloat(f.css(a,"marginTop"))||0,j="<div style='position:absolute;top:0;left:0;margin:0;border:5px solid #000;padding:0;width:1px;height:1px;'><div></div></div><table style='position:absolute;top:0;left:0;margin:0;border:5px solid #000;padding:0;width:1px;height:1px;' cellpadding='0' cellspacing='0'><tr><td></td></tr></table>";f.extend(b.style,{position:"absolute",top:0,left:0,margin:0,border:0,width:"1px",height:"1px",visibility:"hidden"}),b.innerHTML=j,a.insertBefore(b,a.firstChild),d=b.firstChild,e=d.firstChild,h=d.nextSibling.firstChild.firstChild,this.doesNotAddBorder=e.offsetTop!==5,this.doesAddBorderForTableAndCells=h.offsetTop===5,e.style.position="fixed",e.style.top="20px",this.supportsFixedPosition=e.offsetTop===20||e.offsetTop===15,e.style.position=e.style.top="",d.style.overflow="hidden",d.style.position="relative",this.subtractsBorderForOverflowNotVisible=e.offsetTop===-5,this.doesNotIncludeMarginInBodyOffset=a.offsetTop!==i,a.removeChild(b),f.offset.initialize=f.noop},bodyOffset:function(a){var b=a.offsetTop,c=a.offsetLeft;f.offset.initialize(),f.offset.doesNotIncludeMarginInBodyOffset&&(b+=parseFloat(f.css(a,"marginTop"))||0,c+=parseFloat(f.css(a,"marginLeft"))||0);return{top:b,left:c}},setOffset:function(a,b,c){var d=f.css(a,"position");d==="static"&&(a.style.position="relative");var e=f(a),g=e.offset(),h=f.css(a,"top"),i=f.css(a,"left"),j=(d==="absolute"||d==="fixed")&&f.inArray("auto",[h,i])>-1,k={},l={},m,n;j?(l=e.position(),m=l.top,n=l.left):(m=parseFloat(h)||0,n=parseFloat(i)||0),f.isFunction(b)&&(b=b.call(a,c,g)),b.top!=null&&(k.top=b.top-g.top+m),b.left!=null&&(k.left=b.left-g.left+n),"using"in b?b.using.call(a,k):e.css(k)}},f.fn.extend({position:function(){if(!this[0])return null;var a=this[0],b=this.offsetParent(),c=this.offset(),d=cv.test(b[0].nodeName)?{top:0,left:0}:b.offset();c.top-=parseFloat(f.css(a,"marginTop"))||0,c.left-=parseFloat(f.css(a,"marginLeft"))||0,d.top+=parseFloat(f.css(b[0],"borderTopWidth"))||0,d.left+=parseFloat(f.css(b[0],"borderLeftWidth"))||0;return{top:c.top-d.top,left:c.left-d.left}},offsetParent:function(){return this.map(function(){var a=this.offsetParent||c.body;while(a&&!cv.test(a.nodeName)&&f.css(a,"position")==="static")a=a.offsetParent;return a})}}),f.each(["Left","Top"],function(a,c){var d="scroll"+c;f.fn[d]=function(c){var e,g;if(c===b){e=this[0];if(!e)return null;g=cw(e);return g?"pageXOffset"in g?g[a?"pageYOffset":"pageXOffset"]:f.support.boxModel&&g.document.documentElement[d]||g.document.body[d]:e[d]}return this.each(function(){g=cw(this),g?g.scrollTo(a?f(g).scrollLeft():c,a?c:f(g).scrollTop()):this[d]=c})}}),f.each(["Height","Width"],function(a,c){var d=c.toLowerCase();f.fn["inner"+c]=function(){return this[0]?parseFloat(f.css(this[0],d,"padding")):null},f.fn["outer"+c]=function(a){return this[0]?parseFloat(f.css(this[0],d,a?"margin":"border")):null},f.fn[d]=function(a){var e=this[0];if(!e)return a==null?null:this;if(f.isFunction(a))return this.each(function(b){var c=f(this);c[d](a.call(this,b,c[d]()))});if(f.isWindow(e)){var g=e.document.documentElement["client"+c];return e.document.compatMode==="CSS1Compat"&&g||e.document.body["client"+c]||g}if(e.nodeType===9)return Math.max(e.documentElement["client"+c],e.body["scroll"+c],e.documentElement["scroll"+c],e.body["offset"+c],e.documentElement["offset"+c]);if(a===b){var h=f.css(e,d),i=parseFloat(h);return f.isNaN(i)?h:i}return this.css(d,typeof a=="string"?a:a+"px")}}),a.jQuery=a.$=f})(window);
\ No newline at end of file
diff --git a/timeside/player/static/timeside/js/libs/raphael-min.js b/timeside/player/static/timeside/js/libs/raphael-min.js
new file mode 100644 (file)
index 0000000..e5e7126
--- /dev/null
@@ -0,0 +1,7 @@
+/*
+ * Raphael 1.5.2 - JavaScript Vector Library
+ *
+ * Copyright (c) 2010 Dmitry Baranovskiy (http://raphaeljs.com)
+ * Licensed under the MIT (http://raphaeljs.com/license.html) license.
+ */
+(function(){function a(){if(a.is(arguments[0],G)){var b=arguments[0],d=bV[m](a,b.splice(0,3+a.is(b[0],E))),e=d.set();for(var g=0,h=b[w];g<h;g++){var i=b[g]||{};c[f](i.type)&&e[L](d[i.type]().attr(i))}return e}return bV[m](a,arguments)}a.version="1.5.2";var b=/[, ]+/,c={circle:1,rect:1,path:1,ellipse:1,text:1,image:1},d=/\{(\d+)\}/g,e="prototype",f="hasOwnProperty",g=document,h=window,i={was:Object[e][f].call(h,"Raphael"),is:h.Raphael},j=function(){this.customAttributes={}},k,l="appendChild",m="apply",n="concat",o="createTouch"in g,p="",q=" ",r=String,s="split",t="click dblclick mousedown mousemove mouseout mouseover mouseup touchstart touchmove touchend orientationchange touchcancel gesturestart gesturechange gestureend"[s](q),u={mousedown:"touchstart",mousemove:"touchmove",mouseup:"touchend"},v="join",w="length",x=r[e].toLowerCase,y=Math,z=y.max,A=y.min,B=y.abs,C=y.pow,D=y.PI,E="number",F="string",G="array",H="toString",I="fill",J=Object[e][H],K={},L="push",M=/^url\(['"]?([^\)]+?)['"]?\)$/i,N=/^\s*((#[a-f\d]{6})|(#[a-f\d]{3})|rgba?\(\s*([\d\.]+%?\s*,\s*[\d\.]+%?\s*,\s*[\d\.]+(?:%?\s*,\s*[\d\.]+)?)%?\s*\)|hsba?\(\s*([\d\.]+(?:deg|\xb0|%)?\s*,\s*[\d\.]+%?\s*,\s*[\d\.]+(?:%?\s*,\s*[\d\.]+)?)%?\s*\)|hsla?\(\s*([\d\.]+(?:deg|\xb0|%)?\s*,\s*[\d\.]+%?\s*,\s*[\d\.]+(?:%?\s*,\s*[\d\.]+)?)%?\s*\))\s*$/i,O={"NaN":1,Infinity:1,"-Infinity":1},P=/^(?:cubic-)?bezier\(([^,]+),([^,]+),([^,]+),([^\)]+)\)/,Q=y.round,R="setAttribute",S=parseFloat,T=parseInt,U=" progid:DXImageTransform.Microsoft",V=r[e].toUpperCase,W={blur:0,"clip-rect":"0 0 1e9 1e9",cursor:"default",cx:0,cy:0,fill:"#fff","fill-opacity":1,font:"10px \"Arial\"","font-family":"\"Arial\"","font-size":"10","font-style":"normal","font-weight":400,gradient:0,height:0,href:"http://raphaeljs.com/",opacity:1,path:"M0,0",r:0,rotation:0,rx:0,ry:0,scale:"1 1",src:"",stroke:"#000","stroke-dasharray":"","stroke-linecap":"butt","stroke-linejoin":"butt","stroke-miterlimit":0,"stroke-opacity":1,"stroke-width":1,target:"_blank","text-anchor":"middle",title:"Raphael",translation:"0 0",width:0,x:0,y:0},X={along:"along",blur:E,"clip-rect":"csv",cx:E,cy:E,fill:"colour","fill-opacity":E,"font-size":E,height:E,opacity:E,path:"path",r:E,rotation:"csv",rx:E,ry:E,scale:"csv",stroke:"colour","stroke-opacity":E,"stroke-width":E,translation:"csv",width:E,x:E,y:E},Y="replace",Z=/^(from|to|\d+%?)$/,$=/\s*,\s*/,_={hs:1,rg:1},ba=/,?([achlmqrstvxz]),?/gi,bb=/([achlmqstvz])[\s,]*((-?\d*\.?\d*(?:e[-+]?\d+)?\s*,?\s*)+)/ig,bc=/(-?\d*\.?\d*(?:e[-+]?\d+)?)\s*,?\s*/ig,bd=/^r(?:\(([^,]+?)\s*,\s*([^\)]+?)\))?/,be=function(a,b){return a.key-b.key};a.type=h.SVGAngle||g.implementation.hasFeature("http://www.w3.org/TR/SVG11/feature#BasicStructure","1.1")?"SVG":"VML";if(a.type=="VML"){var bf=g.createElement("div"),bg;bf.innerHTML="<v:shape adj=\"1\"/>";bg=bf.firstChild;bg.style.behavior="url(#default#VML)";if(!(bg&&typeof bg.adj=="object"))return a.type=null;bf=null}a.svg=!(a.vml=a.type=="VML");j[e]=a[e];k=j[e];a._id=0;a._oid=0;a.fn={};a.is=function(a,b){b=x.call(b);if(b=="finite")return!O[f](+a);return b=="null"&&a===null||b==typeof a||b=="object"&&a===Object(a)||b=="array"&&Array.isArray&&Array.isArray(a)||J.call(a).slice(8,-1).toLowerCase()==b};a.angle=function(b,c,d,e,f,g){{if(f==null){var h=b-d,i=c-e;if(!h&&!i)return 0;return((h<0)*180+y.atan(-i/-h)*180/D+360)%360}return a.angle(b,c,f,g)-a.angle(d,e,f,g)}};a.rad=function(a){return a%360*D/180};a.deg=function(a){return a*180/D%360};a.snapTo=function(b,c,d){d=a.is(d,"finite")?d:10;if(a.is(b,G)){var e=b.length;while(e--)if(B(b[e]-c)<=d)return b[e]}else{b=+b;var f=c%b;if(f<d)return c-f;if(f>b-d)return c-f+b}return c};function bh(){var a=[],b=0;for(;b<32;b++)a[b]=(~(~(y.random()*16)))[H](16);a[12]=4;a[16]=(a[16]&3|8)[H](16);return"r-"+a[v]("")}a.setWindow=function(a){h=a;g=h.document};var bi=function(b){if(a.vml){var c=/^\s+|\s+$/g,d;try{var e=new ActiveXObject("htmlfile");e.write("<body>");e.close();d=e.body}catch(a){d=createPopup().document.body}var f=d.createTextRange();bi=bm(function(a){try{d.style.color=r(a)[Y](c,p);var b=f.queryCommandValue("ForeColor");b=(b&255)<<16|b&65280|(b&16711680)>>>16;return"#"+("000000"+b[H](16)).slice(-6)}catch(a){return"none"}})}else{var h=g.createElement("i");h.title="Raphaël Colour Picker";h.style.display="none";g.body[l](h);bi=bm(function(a){h.style.color=a;return g.defaultView.getComputedStyle(h,p).getPropertyValue("color")})}return bi(b)},bj=function(){return"hsb("+[this.h,this.s,this.b]+")"},bk=function(){return"hsl("+[this.h,this.s,this.l]+")"},bl=function(){return this.hex};a.hsb2rgb=function(b,c,d,e){if(a.is(b,"object")&&"h"in b&&"s"in b&&"b"in b){d=b.b;c=b.s;b=b.h;e=b.o}return a.hsl2rgb(b,c,d/2,e)};a.hsl2rgb=function(b,c,d,e){if(a.is(b,"object")&&"h"in b&&"s"in b&&"l"in b){d=b.l;c=b.s;b=b.h}if(b>1||c>1||d>1){b/=360;c/=100;d/=100}var f={},g=["r","g","b"],h,i,j,k,l,m;if(c){d<0.5?h=d*(1+c):h=d+c-d*c;i=2*d-h;for(var n=0;n<3;n++){j=b+1/3*-(n-1);j<0&&j++;j>1&&j--;j*6<1?f[g[n]]=i+(h-i)*6*j:j*2<1?f[g[n]]=h:j*3<2?f[g[n]]=i+(h-i)*(2/3-j)*6:f[g[n]]=i}}else f={r:d,g:d,b:d};f.r*=255;f.g*=255;f.b*=255;f.hex="#"+(16777216|f.b|f.g<<8|f.r<<16).toString(16).slice(1);a.is(e,"finite")&&(f.opacity=e);f.toString=bl;return f};a.rgb2hsb=function(b,c,d){if(c==null&&a.is(b,"object")&&"r"in b&&"g"in b&&"b"in b){d=b.b;c=b.g;b=b.r}if(c==null&&a.is(b,F)){var e=a.getRGB(b);b=e.r;c=e.g;d=e.b}if(b>1||c>1||d>1){b/=255;c/=255;d/=255}var f=z(b,c,d),g=A(b,c,d),h,i,j=f;{if(g==f)return{h:0,s:0,b:f,toString:bj};var k=f-g;i=k/f;b==f?h=(c-d)/k:c==f?h=2+(d-b)/k:h=4+(b-c)/k;h/=6;h<0&&h++;h>1&&h--}return{h:h,s:i,b:j,toString:bj}};a.rgb2hsl=function(b,c,d){if(c==null&&a.is(b,"object")&&"r"in b&&"g"in b&&"b"in b){d=b.b;c=b.g;b=b.r}if(c==null&&a.is(b,F)){var e=a.getRGB(b);b=e.r;c=e.g;d=e.b}if(b>1||c>1||d>1){b/=255;c/=255;d/=255}var f=z(b,c,d),g=A(b,c,d),h,i,j=(f+g)/2,k;if(g==f)k={h:0,s:0,l:j};else{var l=f-g;i=j<0.5?l/(f+g):l/(2-f-g);b==f?h=(c-d)/l:c==f?h=2+(d-b)/l:h=4+(b-c)/l;h/=6;h<0&&h++;h>1&&h--;k={h:h,s:i,l:j}}k.toString=bk;return k};a._path2string=function(){return this.join(",")[Y](ba,"$1")};function bm(a,b,c){function d(){var g=Array[e].slice.call(arguments,0),h=g[v]("►"),i=d.cache=d.cache||{},j=d.count=d.count||[];if(i[f](h))return c?c(i[h]):i[h];j[w]>=1000&&delete i[j.shift()];j[L](h);i[h]=a[m](b,g);return c?c(i[h]):i[h]}return d}a.getRGB=bm(function(b){if(!b||!(!((b=r(b)).indexOf("-")+1)))return{r:-1,g:-1,b:-1,hex:"none",error:1};if(b=="none")return{r:-1,g:-1,b:-1,hex:"none"};!(_[f](b.toLowerCase().substring(0,2))||b.charAt()=="#")&&(b=bi(b));var c,d,e,g,h,i,j,k=b.match(N);if(k){if(k[2]){g=T(k[2].substring(5),16);e=T(k[2].substring(3,5),16);d=T(k[2].substring(1,3),16)}if(k[3]){g=T((i=k[3].charAt(3))+i,16);e=T((i=k[3].charAt(2))+i,16);d=T((i=k[3].charAt(1))+i,16)}if(k[4]){j=k[4][s]($);d=S(j[0]);j[0].slice(-1)=="%"&&(d*=2.55);e=S(j[1]);j[1].slice(-1)=="%"&&(e*=2.55);g=S(j[2]);j[2].slice(-1)=="%"&&(g*=2.55);k[1].toLowerCase().slice(0,4)=="rgba"&&(h=S(j[3]));j[3]&&j[3].slice(-1)=="%"&&(h/=100)}if(k[5]){j=k[5][s]($);d=S(j[0]);j[0].slice(-1)=="%"&&(d*=2.55);e=S(j[1]);j[1].slice(-1)=="%"&&(e*=2.55);g=S(j[2]);j[2].slice(-1)=="%"&&(g*=2.55);(j[0].slice(-3)=="deg"||j[0].slice(-1)=="°")&&(d/=360);k[1].toLowerCase().slice(0,4)=="hsba"&&(h=S(j[3]));j[3]&&j[3].slice(-1)=="%"&&(h/=100);return a.hsb2rgb(d,e,g,h)}if(k[6]){j=k[6][s]($);d=S(j[0]);j[0].slice(-1)=="%"&&(d*=2.55);e=S(j[1]);j[1].slice(-1)=="%"&&(e*=2.55);g=S(j[2]);j[2].slice(-1)=="%"&&(g*=2.55);(j[0].slice(-3)=="deg"||j[0].slice(-1)=="°")&&(d/=360);k[1].toLowerCase().slice(0,4)=="hsla"&&(h=S(j[3]));j[3]&&j[3].slice(-1)=="%"&&(h/=100);return a.hsl2rgb(d,e,g,h)}k={r:d,g:e,b:g};k.hex="#"+(16777216|g|e<<8|d<<16).toString(16).slice(1);a.is(h,"finite")&&(k.opacity=h);return k}return{r:-1,g:-1,b:-1,hex:"none",error:1}},a);a.getColor=function(a){var b=this.getColor.start=this.getColor.start||{h:0,s:1,b:a||0.75},c=this.hsb2rgb(b.h,b.s,b.b);b.h+=0.075;if(b.h>1){b.h=0;b.s-=0.2;b.s<=0&&(this.getColor.start={h:0,s:1,b:b.b})}return c.hex};a.getColor.reset=function(){delete this.start};a.parsePathString=bm(function(b){if(!b)return null;var c={a:7,c:6,h:1,l:2,m:2,q:4,s:4,t:2,v:1,z:0},d=[];a.is(b,G)&&a.is(b[0],G)&&(d=bo(b));d[w]||r(b)[Y](bb,function(a,b,e){var f=[],g=x.call(b);e[Y](bc,function(a,b){b&&f[L](+b)});if(g=="m"&&f[w]>2){d[L]([b][n](f.splice(0,2)));g="l";b=b=="m"?"l":"L"}while(f[w]>=c[g]){d[L]([b][n](f.splice(0,c[g])));if(!c[g])break}});d[H]=a._path2string;return d});a.findDotsAtSegment=function(a,b,c,d,e,f,g,h,i){var j=1-i,k=C(j,3)*a+C(j,2)*3*i*c+j*3*i*i*e+C(i,3)*g,l=C(j,3)*b+C(j,2)*3*i*d+j*3*i*i*f+C(i,3)*h,m=a+2*i*(c-a)+i*i*(e-2*c+a),n=b+2*i*(d-b)+i*i*(f-2*d+b),o=c+2*i*(e-c)+i*i*(g-2*e+c),p=d+2*i*(f-d)+i*i*(h-2*f+d),q=(1-i)*a+i*c,r=(1-i)*b+i*d,s=(1-i)*e+i*g,t=(1-i)*f+i*h,u=90-y.atan((m-o)/(n-p))*180/D;(m>o||n<p)&&(u+=180);return{x:k,y:l,m:{x:m,y:n},n:{x:o,y:p},start:{x:q,y:r},end:{x:s,y:t},alpha:u}};var bn=bm(function(a){if(!a)return{x:0,y:0,width:0,height:0};a=bw(a);var b=0,c=0,d=[],e=[],f;for(var g=0,h=a[w];g<h;g++){f=a[g];if(f[0]=="M"){b=f[1];c=f[2];d[L](b);e[L](c)}else{var i=bv(b,c,f[1],f[2],f[3],f[4],f[5],f[6]);d=d[n](i.min.x,i.max.x);e=e[n](i.min.y,i.max.y);b=f[5];c=f[6]}}var j=A[m](0,d),k=A[m](0,e);return{x:j,y:k,width:z[m](0,d)-j,height:z[m](0,e)-k}}),bo=function(b){var c=[];if(!a.is(b,G)||!a.is(b&&b[0],G))b=a.parsePathString(b);for(var d=0,e=b[w];d<e;d++){c[d]=[];for(var f=0,g=b[d][w];f<g;f++)c[d][f]=b[d][f]}c[H]=a._path2string;return c},bp=bm(function(b){if(!a.is(b,G)||!a.is(b&&b[0],G))b=a.parsePathString(b);var c=[],d=0,e=0,f=0,g=0,h=0;if(b[0][0]=="M"){d=b[0][1];e=b[0][2];f=d;g=e;h++;c[L](["M",d,e])}for(var i=h,j=b[w];i<j;i++){var k=c[i]=[],l=b[i];if(l[0]!=x.call(l[0])){k[0]=x.call(l[0]);switch(k[0]){case"a":k[1]=l[1];k[2]=l[2];k[3]=l[3];k[4]=l[4];k[5]=l[5];k[6]=+(l[6]-d).toFixed(3);k[7]=+(l[7]-e).toFixed(3);break;case"v":k[1]=+(l[1]-e).toFixed(3);break;case"m":f=l[1];g=l[2];default:for(var m=1,n=l[w];m<n;m++)k[m]=+(l[m]-(m%2?d:e)).toFixed(3)}}else{k=c[i]=[];if(l[0]=="m"){f=l[1]+d;g=l[2]+e}for(var o=0,p=l[w];o<p;o++)c[i][o]=l[o]}var q=c[i][w];switch(c[i][0]){case"z":d=f;e=g;break;case"h":d+=+c[i][q-1];break;case"v":e+=+c[i][q-1];break;default:d+=+c[i][q-2];e+=+c[i][q-1]}}c[H]=a._path2string;return c},0,bo),bq=bm(function(b){if(!a.is(b,G)||!a.is(b&&b[0],G))b=a.parsePathString(b);var c=[],d=0,e=0,f=0,g=0,h=0;if(b[0][0]=="M"){d=+b[0][1];e=+b[0][2];f=d;g=e;h++;c[0]=["M",d,e]}for(var i=h,j=b[w];i<j;i++){var k=c[i]=[],l=b[i];if(l[0]!=V.call(l[0])){k[0]=V.call(l[0]);switch(k[0]){case"A":k[1]=l[1];k[2]=l[2];k[3]=l[3];k[4]=l[4];k[5]=l[5];k[6]=+(l[6]+d);k[7]=+(l[7]+e);break;case"V":k[1]=+l[1]+e;break;case"H":k[1]=+l[1]+d;break;case"M":f=+l[1]+d;g=+l[2]+e;default:for(var m=1,n=l[w];m<n;m++)k[m]=+l[m]+(m%2?d:e)}}else for(var o=0,p=l[w];o<p;o++)c[i][o]=l[o];switch(k[0]){case"Z":d=f;e=g;break;case"H":d=k[1];break;case"V":e=k[1];break;case"M":f=c[i][c[i][w]-2];g=c[i][c[i][w]-1];default:d=c[i][c[i][w]-2];e=c[i][c[i][w]-1]}}c[H]=a._path2string;return c},null,bo),br=function(a,b,c,d){return[a,b,c,d,c,d]},bs=function(a,b,c,d,e,f){var g=1/3,h=2/3;return[g*a+h*c,g*b+h*d,g*e+h*c,g*f+h*d,e,f]},bt=function(a,b,c,d,e,f,g,h,i,j){var k=D*120/180,l=D/180*(+e||0),m=[],o,p=bm(function(a,b,c){var d=a*y.cos(c)-b*y.sin(c),e=a*y.sin(c)+b*y.cos(c);return{x:d,y:e}});if(j){G=j[0];H=j[1];E=j[2];F=j[3]}else{o=p(a,b,-l);a=o.x;b=o.y;o=p(h,i,-l);h=o.x;i=o.y;var q=y.cos(D/180*e),r=y.sin(D/180*e),t=(a-h)/2,u=(b-i)/2,x=t*t/(c*c)+u*u/(d*d);if(x>1){x=y.sqrt(x);c=x*c;d=x*d}var z=c*c,A=d*d,C=(f==g?-1:1)*y.sqrt(B((z*A-z*u*u-A*t*t)/(z*u*u+A*t*t))),E=C*c*u/d+(a+h)/2,F=C*-d*t/c+(b+i)/2,G=y.asin(((b-F)/d).toFixed(9)),H=y.asin(((i-F)/d).toFixed(9));G=a<E?D-G:G;H=h<E?D-H:H;G<0&&(G=D*2+G);H<0&&(H=D*2+H);g&&G>H&&(G=G-D*2);!g&&H>G&&(H=H-D*2)}var I=H-G;if(B(I)>k){var J=H,K=h,L=i;H=G+k*(g&&H>G?1:-1);h=E+c*y.cos(H);i=F+d*y.sin(H);m=bt(h,i,c,d,e,0,g,K,L,[H,J,E,F])}I=H-G;var M=y.cos(G),N=y.sin(G),O=y.cos(H),P=y.sin(H),Q=y.tan(I/4),R=4/3*c*Q,S=4/3*d*Q,T=[a,b],U=[a+R*N,b-S*M],V=[h+R*P,i-S*O],W=[h,i];U[0]=2*T[0]-U[0];U[1]=2*T[1]-U[1];{if(j)return[U,V,W][n](m);m=[U,V,W][n](m)[v]()[s](",");var X=[];for(var Y=0,Z=m[w];Y<Z;Y++)X[Y]=Y%2?p(m[Y-1],m[Y],l).y:p(m[Y],m[Y+1],l).x;return X}},bu=function(a,b,c,d,e,f,g,h,i){var j=1-i;return{x:C(j,3)*a+C(j,2)*3*i*c+j*3*i*i*e+C(i,3)*g,y:C(j,3)*b+C(j,2)*3*i*d+j*3*i*i*f+C(i,3)*h}},bv=bm(function(a,b,c,d,e,f,g,h){var i=e-2*c+a-(g-2*e+c),j=2*(c-a)-2*(e-c),k=a-c,l=(-j+y.sqrt(j*j-4*i*k))/2/i,n=(-j-y.sqrt(j*j-4*i*k))/2/i,o=[b,h],p=[a,g],q;B(l)>"1e12"&&(l=0.5);B(n)>"1e12"&&(n=0.5);if(l>0&&l<1){q=bu(a,b,c,d,e,f,g,h,l);p[L](q.x);o[L](q.y)}if(n>0&&n<1){q=bu(a,b,c,d,e,f,g,h,n);p[L](q.x);o[L](q.y)}i=f-2*d+b-(h-2*f+d);j=2*(d-b)-2*(f-d);k=b-d;l=(-j+y.sqrt(j*j-4*i*k))/2/i;n=(-j-y.sqrt(j*j-4*i*k))/2/i;B(l)>"1e12"&&(l=0.5);B(n)>"1e12"&&(n=0.5);if(l>0&&l<1){q=bu(a,b,c,d,e,f,g,h,l);p[L](q.x);o[L](q.y)}if(n>0&&n<1){q=bu(a,b,c,d,e,f,g,h,n);p[L](q.x);o[L](q.y)}return{min:{x:A[m](0,p),y:A[m](0,o)},max:{x:z[m](0,p),y:z[m](0,o)}}}),bw=bm(function(a,b){var c=bq(a),d=b&&bq(b),e={x:0,y:0,bx:0,by:0,X:0,Y:0,qx:null,qy:null},f={x:0,y:0,bx:0,by:0,X:0,Y:0,qx:null,qy:null},g=function(a,b){var c,d;if(!a)return["C",b.x,b.y,b.x,b.y,b.x,b.y];!(a[0]in{T:1,Q:1})&&(b.qx=b.qy=null);switch(a[0]){case"M":b.X=a[1];b.Y=a[2];break;case"A":a=["C"][n](bt[m](0,[b.x,b.y][n](a.slice(1))));break;case"S":c=b.x+(b.x-(b.bx||b.x));d=b.y+(b.y-(b.by||b.y));a=["C",c,d][n](a.slice(1));break;case"T":b.qx=b.x+(b.x-(b.qx||b.x));b.qy=b.y+(b.y-(b.qy||b.y));a=["C"][n](bs(b.x,b.y,b.qx,b.qy,a[1],a[2]));break;case"Q":b.qx=a[1];b.qy=a[2];a=["C"][n](bs(b.x,b.y,a[1],a[2],a[3],a[4]));break;case"L":a=["C"][n](br(b.x,b.y,a[1],a[2]));break;case"H":a=["C"][n](br(b.x,b.y,a[1],b.y));break;case"V":a=["C"][n](br(b.x,b.y,b.x,a[1]));break;case"Z":a=["C"][n](br(b.x,b.y,b.X,b.Y));break}return a},h=function(a,b){if(a[b][w]>7){a[b].shift();var e=a[b];while(e[w])a.splice(b++,0,["C"][n](e.splice(0,6)));a.splice(b,1);k=z(c[w],d&&d[w]||0)}},i=function(a,b,e,f,g){if(a&&b&&a[g][0]=="M"&&b[g][0]!="M"){b.splice(g,0,["M",f.x,f.y]);e.bx=0;e.by=0;e.x=a[g][1];e.y=a[g][2];k=z(c[w],d&&d[w]||0)}};for(var j=0,k=z(c[w],d&&d[w]||0);j<k;j++){c[j]=g(c[j],e);h(c,j);d&&(d[j]=g(d[j],f));d&&h(d,j);i(c,d,e,f,j);i(d,c,f,e,j);var l=c[j],o=d&&d[j],p=l[w],q=d&&o[w];e.x=l[p-2];e.y=l[p-1];e.bx=S(l[p-4])||e.x;e.by=S(l[p-3])||e.y;f.bx=d&&(S(o[q-4])||f.x);f.by=d&&(S(o[q-3])||f.y);f.x=d&&o[q-2];f.y=d&&o[q-1]}return d?[c,d]:c},null,bo),bx=bm(function(b){var c=[];for(var d=0,e=b[w];d<e;d++){var f={},g=b[d].match(/^([^:]*):?([\d\.]*)/);f.color=a.getRGB(g[1]);if(f.color.error)return null;f.color=f.color.hex;g[2]&&(f.offset=g[2]+"%");c[L](f)}for(d=1,e=c[w]-1;d<e;d++){if(!c[d].offset){var h=S(c[d-1].offset||0),i=0;for(var j=d+1;j<e;j++){if(c[j].offset){i=c[j].offset;break}}if(!i){i=100;j=e}i=S(i);var k=(i-h)/(j-d+1);for(;d<j;d++){h+=k;c[d].offset=h+"%"}}}return c}),by=function(b,c,d,e){var f;if(a.is(b,F)||a.is(b,"object")){f=a.is(b,F)?g.getElementById(b):b;if(f.tagName)return c==null?{container:f,width:f.style.pixelWidth||f.offsetWidth,height:f.style.pixelHeight||f.offsetHeight}:{container:f,width:c,height:d}}else return{container:1,x:b,y:c,width:d,height:e}},bz=function(a,b){var c=this;for(var d in b){if(b[f](d)&&!(d in a))switch(typeof b[d]){case"function":(function(b){a[d]=a===c?b:function(){return b[m](c,arguments)}})(b[d]);break;case"object":a[d]=a[d]||{};bz.call(this,a[d],b[d]);break;default:a[d]=b[d];break}}},bA=function(a,b){a==b.top&&(b.top=a.prev);a==b.bottom&&(b.bottom=a.next);a.next&&(a.next.prev=a.prev);a.prev&&(a.prev.next=a.next)},bB=function(a,b){if(b.top===a)return;bA(a,b);a.next=null;a.prev=b.top;b.top.next=a;b.top=a},bC=function(a,b){if(b.bottom===a)return;bA(a,b);a.next=b.bottom;a.prev=null;b.bottom.prev=a;b.bottom=a},bD=function(a,b,c){bA(a,c);b==c.top&&(c.top=a);b.next&&(b.next.prev=a);a.next=b.next;a.prev=b;b.next=a},bE=function(a,b,c){bA(a,c);b==c.bottom&&(c.bottom=a);b.prev&&(b.prev.next=a);a.prev=b.prev;b.prev=a;a.next=b},bF=function(a){return function(){throw new Error("Raphaël: you are calling to method “"+a+"” of removed object")}};a.pathToRelative=bp;if(a.svg){k.svgns="http://www.w3.org/2000/svg";k.xlink="http://www.w3.org/1999/xlink";Q=function(a){return+a+(~(~a)===a)*0.5};var bG=function(a,b){if(b)for(var c in b)b[f](c)&&a[R](c,r(b[c]));else{a=g.createElementNS(k.svgns,a);a.style.webkitTapHighlightColor="rgba(0,0,0,0)";return a}};a[H]=function(){return"Your browser supports SVG.\nYou are running Raphaël "+this.version};var bH=function(a,b){var c=bG("path");b.canvas&&b.canvas[l](c);var d=new bN(c,b);d.type="path";bK(d,{fill:"none",stroke:"#000",path:a});return d},bI=function(a,b,c){var d="linear",e=0.5,f=0.5,h=a.style;b=r(b)[Y](bd,function(a,b,c){d="radial";if(b&&c){e=S(b);f=S(c);var g=(f>0.5)*2-1;C(e-0.5,2)+C(f-0.5,2)>0.25&&(f=y.sqrt(0.25-C(e-0.5,2))*g+0.5)&&f!=0.5&&(f=f.toFixed(5)-0.00001*g)}return p});b=b[s](/\s*\-\s*/);if(d=="linear"){var i=b.shift();i=-S(i);if(isNaN(i))return null;var j=[0,0,y.cos(i*D/180),y.sin(i*D/180)],k=1/(z(B(j[2]),B(j[3]))||1);j[2]*=k;j[3]*=k;if(j[2]<0){j[0]=-j[2];j[2]=0}if(j[3]<0){j[1]=-j[3];j[3]=0}}var m=bx(b);if(!m)return null;var n=a.getAttribute(I);n=n.match(/^url\(#(.*)\)$/);n&&c.defs.removeChild(g.getElementById(n[1]));var o=bG(d+"Gradient");o.id=bh();bG(o,d=="radial"?{fx:e,fy:f}:{x1:j[0],y1:j[1],x2:j[2],y2:j[3]});c.defs[l](o);for(var q=0,t=m[w];q<t;q++){var u=bG("stop");bG(u,{offset:m[q].offset?m[q].offset:q?"100%":"0%","stop-color":m[q].color||"#fff"});o[l](u)}bG(a,{fill:"url(#"+o.id+")",opacity:1,"fill-opacity":1});h.fill=p;h.opacity=1;h.fillOpacity=1;return 1},bJ=function(b){var c=b.getBBox();bG(b.pattern,{patternTransform:a.format("translate({0},{1})",c.x,c.y)})},bK=function(c,d){var e={"":[0],none:[0],"-":[3,1],".":[1,1],"-.":[3,1,1,1],"-..":[3,1,1,1,1,1],". ":[1,3],"- ":[4,3],"--":[8,3],"- .":[4,3,1,3],"--.":[8,3,1,3],"--..":[8,3,1,3,1,3]},h=c.node,i=c.attrs,j=c.rotate(),k=function(a,b){b=e[x.call(b)];if(b){var c=a.attrs["stroke-width"]||"1",f=({round:c,square:c,butt:0})[a.attrs["stroke-linecap"]||d["stroke-linecap"]]||0,g=[],i=b[w];while(i--)g[i]=b[i]*c+(i%2?1:-1)*f;bG(h,{"stroke-dasharray":g[v](",")})}};d[f]("rotation")&&(j=d.rotation);var m=r(j)[s](b);if(m.length-1){m[1]=+m[1];m[2]=+m[2]}else m=null;S(j)&&c.rotate(0,true);for(var n in d){if(d[f](n)){if(!W[f](n))continue;var o=d[n];i[n]=o;switch(n){case"blur":c.blur(o);break;case"rotation":c.rotate(o,true);break;case"href":case"title":case"target":var t=h.parentNode;if(x.call(t.tagName)!="a"){var u=bG("a");t.insertBefore(u,h);u[l](h);t=u}n=="target"&&o=="blank"?t.setAttributeNS(c.paper.xlink,"show","new"):t.setAttributeNS(c.paper.xlink,n,o);break;case"cursor":h.style.cursor=o;break;case"clip-rect":var y=r(o)[s](b);if(y[w]==4){c.clip&&c.clip.parentNode.parentNode.removeChild(c.clip.parentNode);var z=bG("clipPath"),A=bG("rect");z.id=bh();bG(A,{x:y[0],y:y[1],width:y[2],height:y[3]});z[l](A);c.paper.defs[l](z);bG(h,{"clip-path":"url(#"+z.id+")"});c.clip=A}if(!o){var B=g.getElementById(h.getAttribute("clip-path")[Y](/(^url\(#|\)$)/g,p));B&&B.parentNode.removeChild(B);bG(h,{"clip-path":p});delete c.clip}break;case"path":c.type=="path"&&bG(h,{d:o?i.path=bq(o):"M0,0"});break;case"width":h[R](n,o);if(i.fx){n="x";o=i.x}else break;case"x":i.fx&&(o=-i.x-(i.width||0));case"rx":if(n=="rx"&&c.type=="rect")break;case"cx":m&&(n=="x"||n=="cx")&&(m[1]+=o-i[n]);h[R](n,o);c.pattern&&bJ(c);break;case"height":h[R](n,o);if(i.fy){n="y";o=i.y}else break;case"y":i.fy&&(o=-i.y-(i.height||0));case"ry":if(n=="ry"&&c.type=="rect")break;case"cy":m&&(n=="y"||n=="cy")&&(m[2]+=o-i[n]);h[R](n,o);c.pattern&&bJ(c);break;case"r":c.type=="rect"?bG(h,{rx:o,ry:o}):h[R](n,o);break;case"src":c.type=="image"&&h.setAttributeNS(c.paper.xlink,"href",o);break;case"stroke-width":h.style.strokeWidth=o;h[R](n,o);i["stroke-dasharray"]&&k(c,i["stroke-dasharray"]);break;case"stroke-dasharray":k(c,o);break;case"translation":var C=r(o)[s](b);C[0]=+C[0]||0;C[1]=+C[1]||0;if(m){m[1]+=C[0];m[2]+=C[1]}cz.call(c,C[0],C[1]);break;case"scale":C=r(o)[s](b);c.scale(+C[0]||1,+C[1]||+C[0]||1,isNaN(S(C[2]))?null:+C[2],isNaN(S(C[3]))?null:+C[3]);break;case I:var D=r(o).match(M);if(D){z=bG("pattern");var E=bG("image");z.id=bh();bG(z,{x:0,y:0,patternUnits:"userSpaceOnUse",height:1,width:1});bG(E,{x:0,y:0});E.setAttributeNS(c.paper.xlink,"href",D[1]);z[l](E);var F=g.createElement("img");F.style.cssText="position:absolute;left:-9999em;top-9999em";F.onload=function(){bG(z,{width:this.offsetWidth,height:this.offsetHeight});bG(E,{width:this.offsetWidth,height:this.offsetHeight});g.body.removeChild(this);c.paper.safari()};g.body[l](F);F.src=D[1];c.paper.defs[l](z);h.style.fill="url(#"+z.id+")";bG(h,{fill:"url(#"+z.id+")"});c.pattern=z;c.pattern&&bJ(c);break}var G=a.getRGB(o);if(G.error)if((({circle:1,ellipse:1})[f](c.type)||r(o).charAt()!="r")&&bI(h,o,c.paper)){i.gradient=o;i.fill="none";break}else{delete d.gradient;delete i.gradient;!a.is(i.opacity,"undefined")&&a.is(d.opacity,"undefined")&&bG(h,{opacity:i.opacity});!a.is(i["fill-opacity"],"undefined")&&a.is(d["fill-opacity"],"undefined")&&bG(h,{"fill-opacity":i["fill-opacity"]})}G[f]("opacity")&&bG(h,{"fill-opacity":G.opacity>1?G.opacity/100:G.opacity});case"stroke":G=a.getRGB(o);h[R](n,G.hex);n=="stroke"&&G[f]("opacity")&&bG(h,{"stroke-opacity":G.opacity>1?G.opacity/100:G.opacity});break;case"gradient":(({circle:1,ellipse:1})[f](c.type)||r(o).charAt()!="r")&&bI(h,o,c.paper);break;case"opacity":i.gradient&&!i[f]("stroke-opacity")&&bG(h,{"stroke-opacity":o>1?o/100:o});case"fill-opacity":if(i.gradient){var H=g.getElementById(h.getAttribute(I)[Y](/^url\(#|\)$/g,p));if(H){var J=H.getElementsByTagName("stop");J[J[w]-1][R]("stop-opacity",o)}break}default:n=="font-size"&&(o=T(o,10)+"px");var K=n[Y](/(\-.)/g,function(a){return V.call(a.substring(1))});h.style[K]=o;h[R](n,o);break}}}bM(c,d);m?c.rotate(m.join(q)):S(j)&&c.rotate(j,true)},bL=1.2,bM=function(b,c){if(b.type!="text"||!(c[f]("text")||c[f]("font")||c[f]("font-size")||c[f]("x")||c[f]("y")))return;var d=b.attrs,e=b.node,h=e.firstChild?T(g.defaultView.getComputedStyle(e.firstChild,p).getPropertyValue("font-size"),10):10;if(c[f]("text")){d.text=c.text;while(e.firstChild)e.removeChild(e.firstChild);var i=r(c.text)[s]("\n");for(var j=0,k=i[w];j<k;j++)if(i[j]){var m=bG("tspan");j&&bG(m,{dy:h*bL,x:d.x});m[l](g.createTextNode(i[j]));e[l](m)}}else{i=e.getElementsByTagName("tspan");for(j=0,k=i[w];j<k;j++)j&&bG(i[j],{dy:h*bL,x:d.x})}bG(e,{y:d.y});var n=b.getBBox(),o=d.y-(n.y+n.height/2);o&&a.is(o,"finite")&&bG(e,{y:d.y+o})},bN=function(b,c){var d=0,e=0;this[0]=b;this.id=a._oid++;this.node=b;b.raphael=this;this.paper=c;this.attrs=this.attrs||{};this.transformations=[];this._={tx:0,ty:0,rt:{deg:0,cx:0,cy:0},sx:1,sy:1};!c.bottom&&(c.bottom=this);this.prev=c.top;c.top&&(c.top.next=this);c.top=this;this.next=null},bO=bN[e];bN[e].rotate=function(c,d,e){if(this.removed)return this;if(c==null){if(this._.rt.cx)return[this._.rt.deg,this._.rt.cx,this._.rt.cy][v](q);return this._.rt.deg}var f=this.getBBox();c=r(c)[s](b);if(c[w]-1){d=S(c[1]);e=S(c[2])}c=S(c[0]);d!=null&&d!==false?this._.rt.deg=c:this._.rt.deg+=c;e==null&&(d=null);this._.rt.cx=d;this._.rt.cy=e;d=d==null?f.x+f.width/2:d;e=e==null?f.y+f.height/2:e;if(this._.rt.deg){this.transformations[0]=a.format("rotate({0} {1} {2})",this._.rt.deg,d,e);this.clip&&bG(this.clip,{transform:a.format("rotate({0} {1} {2})",-this._.rt.deg,d,e)})}else{this.transformations[0]=p;this.clip&&bG(this.clip,{transform:p})}bG(this.node,{transform:this.transformations[v](q)});return this};bN[e].hide=function(){!this.removed&&(this.node.style.display="none");return this};bN[e].show=function(){!this.removed&&(this.node.style.display="");return this};bN[e].remove=function(){if(this.removed)return;bA(this,this.paper);this.node.parentNode.removeChild(this.node);for(var a in this)delete this[a];this.removed=true};bN[e].getBBox=function(){if(this.removed)return this;if(this.type=="path")return bn(this.attrs.path);if(this.node.style.display=="none"){this.show();var a=true}var b={};try{b=this.node.getBBox()}catch(a){}finally{b=b||{}}if(this.type=="text"){b={x:b.x,y:Infinity,width:0,height:0};for(var c=0,d=this.node.getNumberOfChars();c<d;c++){var e=this.node.getExtentOfChar(c);e.y<b.y&&(b.y=e.y);e.y+e.height-b.y>b.height&&(b.height=e.y+e.height-b.y);e.x+e.width-b.x>b.width&&(b.width=e.x+e.width-b.x)}}a&&this.hide();return b};bN[e].attr=function(b,c){if(this.removed)return this;if(b==null){var d={};for(var e in this.attrs)this.attrs[f](e)&&(d[e]=this.attrs[e]);this._.rt.deg&&(d.rotation=this.rotate());(this._.sx!=1||this._.sy!=1)&&(d.scale=this.scale());d.gradient&&d.fill=="none"&&(d.fill=d.gradient)&&delete d.gradient;return d}if(c==null&&a.is(b,F)){if(b=="translation")return cz.call(this);if(b=="rotation")return this.rotate();if(b=="scale")return this.scale();if(b==I&&this.attrs.fill=="none"&&this.attrs.gradient)return this.attrs.gradient;return this.attrs[b]}if(c==null&&a.is(b,G)){var g={};for(var h=0,i=b.length;h<i;h++)g[b[h]]=this.attr(b[h]);return g}if(c!=null){var j={};j[b]=c}else b!=null&&a.is(b,"object")&&(j=b);for(var k in this.paper.customAttributes)if(this.paper.customAttributes[f](k)&&j[f](k)&&a.is(this.paper.customAttributes[k],"function")){var l=this.paper.customAttributes[k].apply(this,[][n](j[k]));this.attrs[k]=j[k];for(var m in l)l[f](m)&&(j[m]=l[m])}bK(this,j);return this};bN[e].toFront=function(){if(this.removed)return this;this.node.parentNode[l](this.node);var a=this.paper;a.top!=this&&bB(this,a);return this};bN[e].toBack=function(){if(this.removed)return this;if(this.node.parentNode.firstChild!=this.node){this.node.parentNode.insertBefore(this.node,this.node.parentNode.firstChild);bC(this,this.paper);var a=this.paper}return this};bN[e].insertAfter=function(a){if(this.removed)return this;var b=a.node||a[a.length-1].node;b.nextSibling?b.parentNode.insertBefore(this.node,b.nextSibling):b.parentNode[l](this.node);bD(this,a,this.paper);return this};bN[e].insertBefore=function(a){if(this.removed)return this;var b=a.node||a[0].node;b.parentNode.insertBefore(this.node,b);bE(this,a,this.paper);return this};bN[e].blur=function(a){var b=this;if(+a!==0){var c=bG("filter"),d=bG("feGaussianBlur");b.attrs.blur=a;c.id=bh();bG(d,{stdDeviation:+a||1.5});c.appendChild(d);b.paper.defs.appendChild(c);b._blur=c;bG(b.node,{filter:"url(#"+c.id+")"})}else{if(b._blur){b._blur.parentNode.removeChild(b._blur);delete b._blur;delete b.attrs.blur}b.node.removeAttribute("filter")}};var bP=function(a,b,c,d){var e=bG("circle");a.canvas&&a.canvas[l](e);var f=new bN(e,a);f.attrs={cx:b,cy:c,r:d,fill:"none",stroke:"#000"};f.type="circle";bG(e,f.attrs);return f},bQ=function(a,b,c,d,e,f){var g=bG("rect");a.canvas&&a.canvas[l](g);var h=new bN(g,a);h.attrs={x:b,y:c,width:d,height:e,r:f||0,rx:f||0,ry:f||0,fill:"none",stroke:"#000"};h.type="rect";bG(g,h.attrs);return h},bR=function(a,b,c,d,e){var f=bG("ellipse");a.canvas&&a.canvas[l](f);var g=new bN(f,a);g.attrs={cx:b,cy:c,rx:d,ry:e,fill:"none",stroke:"#000"};g.type="ellipse";bG(f,g.attrs);return g},bS=function(a,b,c,d,e,f){var g=bG("image");bG(g,{x:c,y:d,width:e,height:f,preserveAspectRatio:"none"});g.setAttributeNS(a.xlink,"href",b);a.canvas&&a.canvas[l](g);var h=new bN(g,a);h.attrs={x:c,y:d,width:e,height:f,src:b};h.type="image";return h},bT=function(a,b,c,d){var e=bG("text");bG(e,{x:b,y:c,"text-anchor":"middle"});a.canvas&&a.canvas[l](e);var f=new bN(e,a);f.attrs={x:b,y:c,"text-anchor":"middle",text:d,font:W.font,stroke:"none",fill:"#000"};f.type="text";bK(f,f.attrs);return f},bU=function(a,b){this.width=a||this.width;this.height=b||this.height;this.canvas[R]("width",this.width);this.canvas[R]("height",this.height);return this},bV=function(){var b=by[m](0,arguments),c=b&&b.container,d=b.x,e=b.y,f=b.width,h=b.height;if(!c)throw new Error("SVG container not found.");var i=bG("svg");d=d||0;e=e||0;f=f||512;h=h||342;bG(i,{xmlns:"http://www.w3.org/2000/svg",version:1.1,width:f,height:h});if(c==1){i.style.cssText="position:absolute;left:"+d+"px;top:"+e+"px";g.body[l](i)}else c.firstChild?c.insertBefore(i,c.firstChild):c[l](i);c=new j;c.width=f;c.height=h;c.canvas=i;bz.call(c,c,a.fn);c.clear();return c};k.clear=function(){var a=this.canvas;while(a.firstChild)a.removeChild(a.firstChild);this.bottom=this.top=null;(this.desc=bG("desc"))[l](g.createTextNode("Created with Raphaël"));a[l](this.desc);a[l](this.defs=bG("defs"))};k.remove=function(){this.canvas.parentNode&&this.canvas.parentNode.removeChild(this.canvas);for(var a in this)this[a]=bF(a)}}if(a.vml){var bW={M:"m",L:"l",C:"c",Z:"x",m:"t",l:"r",c:"v",z:"x"},bX=/([clmz]),?([^clmz]*)/gi,bY=/ progid:\S+Blur\([^\)]+\)/g,bZ=/-?[^,\s-]+/g,b$=1000+q+1000,b_=10,ca={path:1,rect:1},cb=function(a){var b=/[ahqstv]/ig,c=bq;r(a).match(b)&&(c=bw);b=/[clmz]/g;if(c==bq&&!r(a).match(b)){var d=r(a)[Y](bX,function(a,b,c){var d=[],e=x.call(b)=="m",f=bW[b];c[Y](bZ,function(a){if(e&&d[w]==2){f+=d+bW[b=="m"?"l":"L"];d=[]}d[L](Q(a*b_))});return f+d});return d}var e=c(a),f,g;d=[];for(var h=0,i=e[w];h<i;h++){f=e[h];g=x.call(e[h][0]);g=="z"&&(g="x");for(var j=1,k=f[w];j<k;j++)g+=Q(f[j]*b_)+(j!=k-1?",":p);d[L](g)}return d[v](q)};a[H]=function(){return"Your browser doesn’t support SVG. Falling down to VML.\nYou are running Raphaël "+this.version};bH=function(a,b){var c=cd("group");c.style.cssText="position:absolute;left:0;top:0;width:"+b.width+"px;height:"+b.height+"px";c.coordsize=b.coordsize;c.coordorigin=b.coordorigin;var d=cd("shape"),e=d.style;e.width=b.width+"px";e.height=b.height+"px";d.coordsize=b$;d.coordorigin=b.coordorigin;c[l](d);var f=new bN(d,c,b),g={fill:"none",stroke:"#000"};a&&(g.path=a);f.type="path";f.path=[];f.Path=p;bK(f,g);b.canvas[l](c);return f};bK=function(c,d){c.attrs=c.attrs||{};var e=c.node,h=c.attrs,i=e.style,j,k=(d.x!=h.x||d.y!=h.y||d.width!=h.width||d.height!=h.height||d.r!=h.r)&&c.type=="rect",m=c;for(var n in d)d[f](n)&&(h[n]=d[n]);if(k){h.path=cc(h.x,h.y,h.width,h.height,h.r);c.X=h.x;c.Y=h.y;c.W=h.width;c.H=h.height}d.href&&(e.href=d.href);d.title&&(e.title=d.title);d.target&&(e.target=d.target);d.cursor&&(i.cursor=d.cursor);"blur"in d&&c.blur(d.blur);if(d.path&&c.type=="path"||k)e.path=cb(h.path);d.rotation!=null&&c.rotate(d.rotation,true);if(d.translation){j=r(d.translation)[s](b);cz.call(c,j[0],j[1]);if(c._.rt.cx!=null){c._.rt.cx+=+j[0];c._.rt.cy+=+j[1];c.setBox(c.attrs,j[0],j[1])}}if(d.scale){j=r(d.scale)[s](b);c.scale(+j[0]||1,+j[1]||+j[0]||1,+j[2]||null,+j[3]||null)}if("clip-rect"in d){var o=r(d["clip-rect"])[s](b);if(o[w]==4){o[2]=+o[2]+ +o[0];o[3]=+o[3]+ +o[1];var q=e.clipRect||g.createElement("div"),t=q.style,u=e.parentNode;t.clip=a.format("rect({1}px {2}px {3}px {0}px)",o);if(!e.clipRect){t.position="absolute";t.top=0;t.left=0;t.width=c.paper.width+"px";t.height=c.paper.height+"px";u.parentNode.insertBefore(q,u);q[l](u);e.clipRect=q}}d["clip-rect"]||e.clipRect&&(e.clipRect.style.clip=p)}c.type=="image"&&d.src&&(e.src=d.src);if(c.type=="image"&&d.opacity){e.filterOpacity=U+".Alpha(opacity="+d.opacity*100+")";i.filter=(e.filterMatrix||p)+(e.filterOpacity||p)}d.font&&(i.font=d.font);d["font-family"]&&(i.fontFamily="\""+d["font-family"][s](",")[0][Y](/^['"]+|['"]+$/g,p)+"\"");d["font-size"]&&(i.fontSize=d["font-size"]);d["font-weight"]&&(i.fontWeight=d["font-weight"]);d["font-style"]&&(i.fontStyle=d["font-style"]);if(d.opacity!=null||d["stroke-width"]!=null||d.fill!=null||d.stroke!=null||d["stroke-width"]!=null||d["stroke-opacity"]!=null||d["fill-opacity"]!=null||d["stroke-dasharray"]!=null||d["stroke-miterlimit"]!=null||d["stroke-linejoin"]!=null||d["stroke-linecap"]!=null){e=c.shape||e;var v=e.getElementsByTagName(I)&&e.getElementsByTagName(I)[0],x=false;!v&&(x=v=cd(I));if("fill-opacity"in d||"opacity"in d){var y=((+h["fill-opacity"]+1||2)-1)*((+h.opacity+1||2)-1)*((+a.getRGB(d.fill).o+1||2)-1);y=A(z(y,0),1);v.opacity=y}d.fill&&(v.on=true);if(v.on==null||d.fill=="none")v.on=false;if(v.on&&d.fill){var B=d.fill.match(M);if(B){v.src=B[1];v.type="tile"}else{v.color=a.getRGB(d.fill).hex;v.src=p;v.type="solid";if(a.getRGB(d.fill).error&&(m.type in{circle:1,ellipse:1}||r(d.fill).charAt()!="r")&&bI(m,d.fill)){h.fill="none";h.gradient=d.fill}}}x&&e[l](v);var C=e.getElementsByTagName("stroke")&&e.getElementsByTagName("stroke")[0],D=false;!C&&(D=C=cd("stroke"));if(d.stroke&&d.stroke!="none"||d["stroke-width"]||d["stroke-opacity"]!=null||d["stroke-dasharray"]||d["stroke-miterlimit"]||d["stroke-linejoin"]||d["stroke-linecap"])C.on=true;(d.stroke=="none"||C.on==null||d.stroke==0||d["stroke-width"]==0)&&(C.on=false);var E=a.getRGB(d.stroke);C.on&&d.stroke&&(C.color=E.hex);y=((+h["stroke-opacity"]+1||2)-1)*((+h.opacity+1||2)-1)*((+E.o+1||2)-1);var F=(S(d["stroke-width"])||1)*0.75;y=A(z(y,0),1);d["stroke-width"]==null&&(F=h["stroke-width"]);d["stroke-width"]&&(C.weight=F);F&&F<1&&(y*=F)&&(C.weight=1);C.opacity=y;d["stroke-linejoin"]&&(C.joinstyle=d["stroke-linejoin"]||"miter");C.miterlimit=d["stroke-miterlimit"]||8;d["stroke-linecap"]&&(C.endcap=d["stroke-linecap"]=="butt"?"flat":d["stroke-linecap"]=="square"?"square":"round");if(d["stroke-dasharray"]){var G={"-":"shortdash",".":"shortdot","-.":"shortdashdot","-..":"shortdashdotdot",". ":"dot","- ":"dash","--":"longdash","- .":"dashdot","--.":"longdashdot","--..":"longdashdotdot"};C.dashstyle=G[f](d["stroke-dasharray"])?G[d["stroke-dasharray"]]:p}D&&e[l](C)}if(m.type=="text"){i=m.paper.span.style;h.font&&(i.font=h.font);h["font-family"]&&(i.fontFamily=h["font-family"]);h["font-size"]&&(i.fontSize=h["font-size"]);h["font-weight"]&&(i.fontWeight=h["font-weight"]);h["font-style"]&&(i.fontStyle=h["font-style"]);m.node.string&&(m.paper.span.innerHTML=r(m.node.string)[Y](/</g,"&#60;")[Y](/&/g,"&#38;")[Y](/\n/g,"<br>"));m.W=h.w=m.paper.span.offsetWidth;m.H=h.h=m.paper.span.offsetHeight;m.X=h.x;m.Y=h.y+Q(m.H/2);switch(h["text-anchor"]){case"start":m.node.style["v-text-align"]="left";m.bbx=Q(m.W/2);break;case"end":m.node.style["v-text-align"]="right";m.bbx=-Q(m.W/2);break;default:m.node.style["v-text-align"]="center";break}}};bI=function(a,b){a.attrs=a.attrs||{};var c=a.attrs,d,e="linear",f=".5 .5";a.attrs.gradient=b;b=r(b)[Y](bd,function(a,b,c){e="radial";if(b&&c){b=S(b);c=S(c);C(b-0.5,2)+C(c-0.5,2)>0.25&&(c=y.sqrt(0.25-C(b-0.5,2))*((c>0.5)*2-1)+0.5);f=b+q+c}return p});b=b[s](/\s*\-\s*/);if(e=="linear"){var g=b.shift();g=-S(g);if(isNaN(g))return null}var h=bx(b);if(!h)return null;a=a.shape||a.node;d=a.getElementsByTagName(I)[0]||cd(I);!d.parentNode&&a.appendChild(d);if(h[w]){d.on=true;d.method="none";d.color=h[0].color;d.color2=h[h[w]-1].color;var i=[];for(var j=0,k=h[w];j<k;j++)h[j].offset&&i[L](h[j].offset+q+h[j].color);d.colors&&(d.colors.value=i[w]?i[v]():"0% "+d.color);if(e=="radial"){d.type="gradientradial";d.focus="100%";d.focussize=f;d.focusposition=f}else{d.type="gradient";d.angle=(270-g)%360}}return 1};bN=function(b,c,d){var e=0,f=0,g=0,h=1;this[0]=b;this.id=a._oid++;this.node=b;b.raphael=this;this.X=0;this.Y=0;this.attrs={};this.Group=c;this.paper=d;this._={tx:0,ty:0,rt:{deg:0},sx:1,sy:1};!d.bottom&&(d.bottom=this);this.prev=d.top;d.top&&(d.top.next=this);d.top=this;this.next=null};bO=bN[e];bO.rotate=function(a,c,d){if(this.removed)return this;if(a==null){if(this._.rt.cx)return[this._.rt.deg,this._.rt.cx,this._.rt.cy][v](q);return this._.rt.deg}a=r(a)[s](b);if(a[w]-1){c=S(a[1]);d=S(a[2])}a=S(a[0]);c!=null?this._.rt.deg=a:this._.rt.deg+=a;d==null&&(c=null);this._.rt.cx=c;this._.rt.cy=d;this.setBox(this.attrs,c,d);this.Group.style.rotation=this._.rt.deg;return this};bO.setBox=function(a,b,c){if(this.removed)return this;var d=this.Group.style,e=this.shape&&this.shape.style||this.node.style;a=a||{};for(var g in a)a[f](g)&&(this.attrs[g]=a[g]);b=b||this._.rt.cx;c=c||this._.rt.cy;var h=this.attrs,i,j,k,l;switch(this.type){case"circle":i=h.cx-h.r;j=h.cy-h.r;k=l=h.r*2;break;case"ellipse":i=h.cx-h.rx;j=h.cy-h.ry;k=h.rx*2;l=h.ry*2;break;case"image":i=+h.x;j=+h.y;k=h.width||0;l=h.height||0;break;case"text":this.textpath.v=["m",Q(h.x),", ",Q(h.y-2),"l",Q(h.x)+1,", ",Q(h.y-2)][v](p);i=h.x-Q(this.W/2);j=h.y-this.H/2;k=this.W;l=this.H;break;case"rect":case"path":if(this.attrs.path){var m=bn(this.attrs.path);i=m.x;j=m.y;k=m.width;l=m.height}else{i=0;j=0;k=this.paper.width;l=this.paper.height}break;default:i=0;j=0;k=this.paper.width;l=this.paper.height;break}b=b==null?i+k/2:b;c=c==null?j+l/2:c;var n=b-this.paper.width/2,o=c-this.paper.height/2,q;d.left!=(q=n+"px")&&(d.left=q);d.top!=(q=o+"px")&&(d.top=q);this.X=ca[f](this.type)?-n:i;this.Y=ca[f](this.type)?-o:j;this.W=k;this.H=l;if(ca[f](this.type)){e.left!=(q=-n*b_+"px")&&(e.left=q);e.top!=(q=-o*b_+"px")&&(e.top=q)}else if(this.type=="text"){e.left!=(q=-n+"px")&&(e.left=q);e.top!=(q=-o+"px")&&(e.top=q)}else{d.width!=(q=this.paper.width+"px")&&(d.width=q);d.height!=(q=this.paper.height+"px")&&(d.height=q);e.left!=(q=i-n+"px")&&(e.left=q);e.top!=(q=j-o+"px")&&(e.top=q);e.width!=(q=k+"px")&&(e.width=q);e.height!=(q=l+"px")&&(e.height=q)}};bO.hide=function(){!this.removed&&(this.Group.style.display="none");return this};bO.show=function(){!this.removed&&(this.Group.style.display="block");return this};bO.getBBox=function(){if(this.removed)return this;if(ca[f](this.type))return bn(this.attrs.path);return{x:this.X+(this.bbx||0),y:this.Y,width:this.W,height:this.H}};bO.remove=function(){if(this.removed)return;bA(this,this.paper);this.node.parentNode.removeChild(this.node);this.Group.parentNode.removeChild(this.Group);this.shape&&this.shape.parentNode.removeChild(this.shape);for(var a in this)delete this[a];this.removed=true};bO.attr=function(b,c){if(this.removed)return this;if(b==null){var d={};for(var e in this.attrs)this.attrs[f](e)&&(d[e]=this.attrs[e]);this._.rt.deg&&(d.rotation=this.rotate());(this._.sx!=1||this._.sy!=1)&&(d.scale=this.scale());d.gradient&&d.fill=="none"&&(d.fill=d.gradient)&&delete d.gradient;return d}if(c==null&&a.is(b,"string")){if(b=="translation")return cz.call(this);if(b=="rotation")return this.rotate();if(b=="scale")return this.scale();if(b==I&&this.attrs.fill=="none"&&this.attrs.gradient)return this.attrs.gradient;return this.attrs[b]}if(this.attrs&&c==null&&a.is(b,G)){var g,h={};for(e=0,g=b[w];e<g;e++)h[b[e]]=this.attr(b[e]);return h}var i;if(c!=null){i={};i[b]=c}c==null&&a.is(b,"object")&&(i=b);if(i){for(var j in this.paper.customAttributes)if(this.paper.customAttributes[f](j)&&i[f](j)&&a.is(this.paper.customAttributes[j],"function")){var k=this.paper.customAttributes[j].apply(this,[][n](i[j]));this.attrs[j]=i[j];for(var l in k)k[f](l)&&(i[l]=k[l])}i.text&&this.type=="text"&&(this.node.string=i.text);bK(this,i);i.gradient&&(({circle:1,ellipse:1})[f](this.type)||r(i.gradient).charAt()!="r")&&bI(this,i.gradient);(!ca[f](this.type)||this._.rt.deg)&&this.setBox(this.attrs)}return this};bO.toFront=function(){!this.removed&&this.Group.parentNode[l](this.Group);this.paper.top!=this&&bB(this,this.paper);return this};bO.toBack=function(){if(this.removed)return this;if(this.Group.parentNode.firstChild!=this.Group){this.Group.parentNode.insertBefore(this.Group,this.Group.parentNode.firstChild);bC(this,this.paper)}return this};bO.insertAfter=function(a){if(this.removed)return this;a.constructor==cC&&(a=a[a.length-1]);a.Group.nextSibling?a.Group.parentNode.insertBefore(this.Group,a.Group.nextSibling):a.Group.parentNode[l](this.Group);bD(this,a,this.paper);return this};bO.insertBefore=function(a){if(this.removed)return this;a.constructor==cC&&(a=a[0]);a.Group.parentNode.insertBefore(this.Group,a.Group);bE(this,a,this.paper);return this};bO.blur=function(b){var c=this.node.runtimeStyle,d=c.filter;d=d.replace(bY,p);if(+b!==0){this.attrs.blur=b;c.filter=d+q+U+".Blur(pixelradius="+(+b||1.5)+")";c.margin=a.format("-{0}px 0 0 -{0}px",Q(+b||1.5))}else{c.filter=d;c.margin=0;delete this.attrs.blur}};bP=function(a,b,c,d){var e=cd("group"),f=cd("oval"),g=f.style;e.style.cssText="position:absolute;left:0;top:0;width:"+a.width+"px;height:"+a.height+"px";e.coordsize=b$;e.coordorigin=a.coordorigin;e[l](f);var h=new bN(f,e,a);h.type="circle";bK(h,{stroke:"#000",fill:"none"});h.attrs.cx=b;h.attrs.cy=c;h.attrs.r=d;h.setBox({x:b-d,y:c-d,width:d*2,height:d*2});a.canvas[l](e);return h};function cc(b,c,d,e,f){return f?a.format("M{0},{1}l{2},0a{3},{3},0,0,1,{3},{3}l0,{5}a{3},{3},0,0,1,{4},{3}l{6},0a{3},{3},0,0,1,{4},{4}l0,{7}a{3},{3},0,0,1,{3},{4}z",b+f,c,d-f*2,f,-f,e-f*2,f*2-d,f*2-e):a.format("M{0},{1}l{2},0,0,{3},{4},0z",b,c,d,e,-d)}bQ=function(a,b,c,d,e,f){var g=cc(b,c,d,e,f),h=a.path(g),i=h.attrs;h.X=i.x=b;h.Y=i.y=c;h.W=i.width=d;h.H=i.height=e;i.r=f;i.path=g;h.type="rect";return h};bR=function(a,b,c,d,e){var f=cd("group"),g=cd("oval"),h=g.style;f.style.cssText="position:absolute;left:0;top:0;width:"+a.width+"px;height:"+a.height+"px";f.coordsize=b$;f.coordorigin=a.coordorigin;f[l](g);var i=new bN(g,f,a);i.type="ellipse";bK(i,{stroke:"#000"});i.attrs.cx=b;i.attrs.cy=c;i.attrs.rx=d;i.attrs.ry=e;i.setBox({x:b-d,y:c-e,width:d*2,height:e*2});a.canvas[l](f);return i};bS=function(a,b,c,d,e,f){var g=cd("group"),h=cd("image");g.style.cssText="position:absolute;left:0;top:0;width:"+a.width+"px;height:"+a.height+"px";g.coordsize=b$;g.coordorigin=a.coordorigin;h.src=b;g[l](h);var i=new bN(h,g,a);i.type="image";i.attrs.src=b;i.attrs.x=c;i.attrs.y=d;i.attrs.w=e;i.attrs.h=f;i.setBox({x:c,y:d,width:e,height:f});a.canvas[l](g);return i};bT=function(b,c,d,e){var f=cd("group"),g=cd("shape"),h=g.style,i=cd("path"),j=i.style,k=cd("textpath");f.style.cssText="position:absolute;left:0;top:0;width:"+b.width+"px;height:"+b.height+"px";f.coordsize=b$;f.coordorigin=b.coordorigin;i.v=a.format("m{0},{1}l{2},{1}",Q(c*10),Q(d*10),Q(c*10)+1);i.textpathok=true;h.width=b.width;h.height=b.height;k.string=r(e);k.on=true;g[l](k);g[l](i);f[l](g);var m=new bN(k,f,b);m.shape=g;m.textpath=i;m.type="text";m.attrs.text=e;m.attrs.x=c;m.attrs.y=d;m.attrs.w=1;m.attrs.h=1;bK(m,{font:W.font,stroke:"none",fill:"#000"});m.setBox();b.canvas[l](f);return m};bU=function(a,b){var c=this.canvas.style;a==+a&&(a+="px");b==+b&&(b+="px");c.width=a;c.height=b;c.clip="rect(0 "+a+" "+b+" 0)";return this};var cd;g.createStyleSheet().addRule(".rvml","behavior:url(#default#VML)");try{!g.namespaces.rvml&&g.namespaces.add("rvml","urn:schemas-microsoft-com:vml");cd=function(a){return g.createElement("<rvml:"+a+" class=\"rvml\">")}}catch(a){cd=function(a){return g.createElement("<"+a+" xmlns=\"urn:schemas-microsoft.com:vml\" class=\"rvml\">")}}bV=function(){var b=by[m](0,arguments),c=b.container,d=b.height,e,f=b.width,h=b.x,i=b.y;if(!c)throw new Error("VML container not found.");var k=new j,n=k.canvas=g.createElement("div"),o=n.style;h=h||0;i=i||0;f=f||512;d=d||342;f==+f&&(f+="px");d==+d&&(d+="px");k.width=1000;k.height=1000;k.coordsize=b_*1000+q+b_*1000;k.coordorigin="0 0";k.span=g.createElement("span");k.span.style.cssText="position:absolute;left:-9999em;top:-9999em;padding:0;margin:0;line-height:1;display:inline;";n[l](k.span);o.cssText=a.format("top:0;left:0;width:{0};height:{1};display:inline-block;position:relative;clip:rect(0 {0} {1} 0);overflow:hidden",f,d);if(c==1){g.body[l](n);o.left=h+"px";o.top=i+"px";o.position="absolute"}else c.firstChild?c.insertBefore(n,c.firstChild):c[l](n);bz.call(k,k,a.fn);return k};k.clear=function(){this.canvas.innerHTML=p;this.span=g.createElement("span");this.span.style.cssText="position:absolute;left:-9999em;top:-9999em;padding:0;margin:0;line-height:1;display:inline;";this.canvas[l](this.span);this.bottom=this.top=null};k.remove=function(){this.canvas.parentNode.removeChild(this.canvas);for(var a in this)this[a]=bF(a);return true}}var ce=navigator.userAgent.match(/Version\\x2f(.*?)\s/);navigator.vendor=="Apple Computer, Inc."&&(ce&&ce[1]<4||navigator.platform.slice(0,2)=="iP")?k.safari=function(){var a=this.rect(-99,-99,this.width+99,this.height+99).attr({stroke:"none"});h.setTimeout(function(){a.remove()})}:k.safari=function(){};var cf=function(){this.returnValue=false},cg=function(){return this.originalEvent.preventDefault()},ch=function(){this.cancelBubble=true},ci=function(){return this.originalEvent.stopPropagation()},cj=(function(){{if(g.addEventListener)return function(a,b,c,d){var e=o&&u[b]?u[b]:b,g=function(e){if(o&&u[f](b))for(var g=0,h=e.targetTouches&&e.targetTouches.length;g<h;g++){if(e.targetTouches[g].target==a){var i=e;e=e.targetTouches[g];e.originalEvent=i;e.preventDefault=cg;e.stopPropagation=ci;break}}return c.call(d,e)};a.addEventListener(e,g,false);return function(){a.removeEventListener(e,g,false);return true}};if(g.attachEvent)return function(a,b,c,d){var e=function(a){a=a||h.event;a.preventDefault=a.preventDefault||cf;a.stopPropagation=a.stopPropagation||ch;return c.call(d,a)};a.attachEvent("on"+b,e);var f=function(){a.detachEvent("on"+b,e);return true};return f}}})(),ck=[],cl=function(a){var b=a.clientX,c=a.clientY,d=g.documentElement.scrollTop||g.body.scrollTop,e=g.documentElement.scrollLeft||g.body.scrollLeft,f,h=ck.length;while(h--){f=ck[h];if(o){var i=a.touches.length,j;while(i--){j=a.touches[i];if(j.identifier==f.el._drag.id){b=j.clientX;c=j.clientY;(a.originalEvent?a.originalEvent:a).preventDefault();break}}}else a.preventDefault();b+=e;c+=d;f.move&&f.move.call(f.move_scope||f.el,b-f.el._drag.x,c-f.el._drag.y,b,c,a)}},cm=function(b){a.unmousemove(cl).unmouseup(cm);var c=ck.length,d;while(c--){d=ck[c];d.el._drag={};d.end&&d.end.call(d.end_scope||d.start_scope||d.move_scope||d.el,b)}ck=[]};for(var cn=t[w];cn--;)(function(b){a[b]=bN[e][b]=function(c,d){if(a.is(c,"function")){this.events=this.events||[];this.events.push({name:b,f:c,unbind:cj(this.shape||this.node||g,b,c,d||this)})}return this};a["un"+b]=bN[e]["un"+b]=function(a){var c=this.events,d=c[w];while(d--)if(c[d].name==b&&c[d].f==a){c[d].unbind();c.splice(d,1);!c.length&&delete this.events;return this}return this}})(t[cn]);bO.hover=function(a,b,c,d){return this.mouseover(a,c).mouseout(b,d||c)};bO.unhover=function(a,b){return this.unmouseover(a).unmouseout(b)};bO.drag=function(b,c,d,e,f,h){this._drag={};this.mousedown(function(i){(i.originalEvent||i).preventDefault();var j=g.documentElement.scrollTop||g.body.scrollTop,k=g.documentElement.scrollLeft||g.body.scrollLeft;this._drag.x=i.clientX+k;this._drag.y=i.clientY+j;this._drag.id=i.identifier;c&&c.call(f||e||this,i.clientX+k,i.clientY+j,i);!ck.length&&a.mousemove(cl).mouseup(cm);ck.push({el:this,move:b,end:d,move_scope:e,start_scope:f,end_scope:h})});return this};bO.undrag=function(b,c,d){var e=ck.length;while(e--)ck[e].el==this&&(ck[e].move==b&&ck[e].end==d)&&ck.splice(e++,1);!ck.length&&a.unmousemove(cl).unmouseup(cm)};k.circle=function(a,b,c){return bP(this,a||0,b||0,c||0)};k.rect=function(a,b,c,d,e){return bQ(this,a||0,b||0,c||0,d||0,e||0)};k.ellipse=function(a,b,c,d){return bR(this,a||0,b||0,c||0,d||0)};k.path=function(b){b&&!a.is(b,F)&&!a.is(b[0],G)&&(b+=p);return bH(a.format[m](a,arguments),this)};k.image=function(a,b,c,d,e){return bS(this,a||"about:blank",b||0,c||0,d||0,e||0)};k.text=function(a,b,c){return bT(this,a||0,b||0,r(c))};k.set=function(a){arguments[w]>1&&(a=Array[e].splice.call(arguments,0,arguments[w]));return new cC(a)};k.setSize=bU;k.top=k.bottom=null;k.raphael=a;function co(){return this.x+q+this.y}bO.resetScale=function(){if(this.removed)return this;this._.sx=1;this._.sy=1;this.attrs.scale="1 1"};bO.scale=function(a,b,c,d){if(this.removed)return this;if(a==null&&b==null)return{x:this._.sx,y:this._.sy,toString:co};b=b||a;!(+b)&&(b=a);var e,f,g,h,i=this.attrs;if(a!=0){var j=this.getBBox(),k=j.x+j.width/2,l=j.y+j.height/2,m=B(a/this._.sx),o=B(b/this._.sy);c=+c||c==0?c:k;d=+d||d==0?d:l;var r=this._.sx>0,s=this._.sy>0,t=~(~(a/B(a))),u=~(~(b/B(b))),x=m*t,y=o*u,z=this.node.style,A=c+B(k-c)*x*(k>c==r?1:-1),C=d+B(l-d)*y*(l>d==s?1:-1),D=a*t>b*u?o:m;switch(this.type){case"rect":case"image":var E=i.width*m,F=i.height*o;this.attr({height:F,r:i.r*D,width:E,x:A-E/2,y:C-F/2});break;case"circle":case"ellipse":this.attr({rx:i.rx*m,ry:i.ry*o,r:i.r*D,cx:A,cy:C});break;case"text":this.attr({x:A,y:C});break;case"path":var G=bp(i.path),H=true,I=r?x:m,J=s?y:o;for(var K=0,L=G[w];K<L;K++){var M=G[K],N=V.call(M[0]);{if(N=="M"&&H)continue;H=false}if(N=="A"){M[G[K][w]-2]*=I;M[G[K][w]-1]*=J;M[1]*=m;M[2]*=o;M[5]=+(t+u?!(!(+M[5])):!(+M[5]))}else if(N=="H")for(var O=1,P=M[w];O<P;O++)M[O]*=I;else if(N=="V")for(O=1,P=M[w];O<P;O++)M[O]*=J;else for(O=1,P=M[w];O<P;O++)M[O]*=O%2?I:J}var Q=bn(G);e=A-Q.x-Q.width/2;f=C-Q.y-Q.height/2;G[0][1]+=e;G[0][2]+=f;this.attr({path:G});break}if(this.type in{text:1,image:1}&&(t!=1||u!=1))if(this.transformations){this.transformations[2]="scale("[n](t,",",u,")");this.node[R]("transform",this.transformations[v](q));e=t==-1?-i.x-(E||0):i.x;f=u==-1?-i.y-(F||0):i.y;this.attr({x:e,y:f});i.fx=t-1;i.fy=u-1}else{this.node.filterMatrix=U+".Matrix(M11="[n](t,", M12=0, M21=0, M22=",u,", Dx=0, Dy=0, sizingmethod='auto expand', filtertype='bilinear')");z.filter=(this.node.filterMatrix||p)+(this.node.filterOpacity||p)}else if(this.transformations){this.transformations[2]=p;this.node[R]("transform",this.transformations[v](q));i.fx=0;i.fy=0}else{this.node.filterMatrix=p;z.filter=(this.node.filterMatrix||p)+(this.node.filterOpacity||p)}i.scale=[a,b,c,d][v](q);this._.sx=a;this._.sy=b}return this};bO.clone=function(){if(this.removed)return null;var a=this.attr();delete a.scale;delete a.translation;return this.paper[this.type]().attr(a)};var cp={},cq=function(b,c,d,e,f,g,h,i,j){var k=0,l=100,m=[b,c,d,e,f,g,h,i].join(),n=cp[m],o,p;!n&&(cp[m]=n={data:[]});n.timer&&clearTimeout(n.timer);n.timer=setTimeout(function(){delete cp[m]},2000);if(j!=null){var q=cq(b,c,d,e,f,g,h,i);l=~(~q)*10}for(var r=0;r<l+1;r++){if(n.data[j]>r)p=n.data[r*l];else{p=a.findDotsAtSegment(b,c,d,e,f,g,h,i,r/l);n.data[r]=p}r&&(k+=C(C(o.x-p.x,2)+C(o.y-p.y,2),0.5));if(j!=null&&k>=j)return p;o=p}if(j==null)return k},cr=function(b,c){return function(d,e,f){d=bw(d);var g,h,i,j,k="",l={},m,n=0;for(var o=0,p=d.length;o<p;o++){i=d[o];if(i[0]=="M"){g=+i[1];h=+i[2]}else{j=cq(g,h,i[1],i[2],i[3],i[4],i[5],i[6]);if(n+j>e){if(c&&!l.start){m=cq(g,h,i[1],i[2],i[3],i[4],i[5],i[6],e-n);k+=["C",m.start.x,m.start.y,m.m.x,m.m.y,m.x,m.y];if(f)return k;l.start=k;k=["M",m.x,m.y+"C",m.n.x,m.n.y,m.end.x,m.end.y,i[5],i[6]][v]();n+=j;g=+i[5];h=+i[6];continue}if(!b&&!c){m=cq(g,h,i[1],i[2],i[3],i[4],i[5],i[6],e-n);return{x:m.x,y:m.y,alpha:m.alpha}}}n+=j;g=+i[5];h=+i[6]}k+=i}l.end=k;m=b?n:c?l:a.findDotsAtSegment(g,h,i[1],i[2],i[3],i[4],i[5],i[6],1);m.alpha&&(m={x:m.x,y:m.y,alpha:m.alpha});return m}},cs=cr(1),ct=cr(),cu=cr(0,1);bO.getTotalLength=function(){if(this.type!="path")return;if(this.node.getTotalLength)return this.node.getTotalLength();return cs(this.attrs.path)};bO.getPointAtLength=function(a){if(this.type!="path")return;return ct(this.attrs.path,a)};bO.getSubpath=function(a,b){if(this.type!="path")return;if(B(this.getTotalLength()-b)<"1e-6")return cu(this.attrs.path,a).end;var c=cu(this.attrs.path,b,1);return a?cu(c,a).end:c};a.easing_formulas={linear:function(a){return a},"<":function(a){return C(a,3)},">":function(a){return C(a-1,3)+1},"<>":function(a){a=a*2;if(a<1)return C(a,3)/2;a-=2;return(C(a,3)+2)/2},backIn:function(a){var b=1.70158;return a*a*((b+1)*a-b)},backOut:function(a){a=a-1;var b=1.70158;return a*a*((b+1)*a+b)+1},elastic:function(a){if(a==0||a==1)return a;var b=0.3,c=b/4;return C(2,-10*a)*y.sin((a-c)*(2*D)/b)+1},bounce:function(a){var b=7.5625,c=2.75,d;if(a<1/c)d=b*a*a;else if(a<2/c){a-=1.5/c;d=b*a*a+0.75}else if(a<2.5/c){a-=2.25/c;d=b*a*a+0.9375}else{a-=2.625/c;d=b*a*a+0.984375}return d}};var cv=[],cw=function(){var b=+(new Date);for(var c=0;c<cv[w];c++){var d=cv[c];if(d.stop||d.el.removed)continue;var e=b-d.start,g=d.ms,h=d.easing,i=d.from,j=d.diff,k=d.to,l=d.t,m=d.el,n={},o;if(e<g){var r=h(e/g);for(var s in i)if(i[f](s)){switch(X[s]){case"along":o=r*g*j[s];k.back&&(o=k.len-o);var t=ct(k[s],o);m.translate(j.sx-j.x||0,j.sy-j.y||0);j.x=t.x;j.y=t.y;m.translate(t.x-j.sx,t.y-j.sy);k.rot&&m.rotate(j.r+t.alpha,t.x,t.y);break;case E:o=+i[s]+r*g*j[s];break;case"colour":o="rgb("+[cy(Q(i[s].r+r*g*j[s].r)),cy(Q(i[s].g+r*g*j[s].g)),cy(Q(i[s].b+r*g*j[s].b))][v](",")+")";break;case"path":o=[];for(var u=0,x=i[s][w];u<x;u++){o[u]=[i[s][u][0]];for(var y=1,z=i[s][u][w];y<z;y++)o[u][y]=+i[s][u][y]+r*g*j[s][u][y];o[u]=o[u][v](q)}o=o[v](q);break;case"csv":switch(s){case"translation":var A=r*g*j[s][0]-l.x,B=r*g*j[s][1]-l.y;l.x+=A;l.y+=B;o=A+q+B;break;case"rotation":o=+i[s][0]+r*g*j[s][0];i[s][1]&&(o+=","+i[s][1]+","+i[s][2]);break;case"scale":o=[+i[s][0]+r*g*j[s][0],+i[s][1]+r*g*j[s][1],2 in k[s]?k[s][2]:p,3 in k[s]?k[s][3]:p][v](q);break;case"clip-rect":o=[];u=4;while(u--)o[u]=+i[s][u]+r*g*j[s][u];break}break;default:var C=[].concat(i[s]);o=[];u=m.paper.customAttributes[s].length;while(u--)o[u]=+C[u]+r*g*j[s][u];break}n[s]=o}m.attr(n);m._run&&m._run.call(m)}else{if(k.along){t=ct(k.along,k.len*!k.back);m.translate(j.sx-(j.x||0)+t.x-j.sx,j.sy-(j.y||0)+t.y-j.sy);k.rot&&m.rotate(j.r+t.alpha,t.x,t.y)}(l.x||l.y)&&m.translate(-l.x,-l.y);k.scale&&(k.scale+=p);m.attr(k);cv.splice(c--,1)}}a.svg&&m&&m.paper&&m.paper.safari();cv[w]&&setTimeout(cw)},cx=function(b,c,d,e,f){var g=d-e;c.timeouts.push(setTimeout(function(){a.is(f,"function")&&f.call(c);c.animate(b,g,b.easing)},e))},cy=function(a){return z(A(a,255),0)},cz=function(a,b){if(a==null)return{x:this._.tx,y:this._.ty,toString:co};this._.tx+=+a;this._.ty+=+b;switch(this.type){case"circle":case"ellipse":this.attr({cx:+a+this.attrs.cx,cy:+b+this.attrs.cy});break;case"rect":case"image":case"text":this.attr({x:+a+this.attrs.x,y:+b+this.attrs.y});break;case"path":var c=bp(this.attrs.path);c[0][1]+=+a;c[0][2]+=+b;this.attr({path:c});break}return this};bO.animateWith=function(a,b,c,d,e){for(var f=0,g=cv.length;f<g;f++)cv[f].el.id==a.id&&(b.start=cv[f].start);return this.animate(b,c,d,e)};bO.animateAlong=cA();bO.animateAlongBack=cA(1);function cA(b){return function(c,d,e,f){var g={back:b};a.is(e,"function")?f=e:g.rot=e;c&&c.constructor==bN&&(c=c.attrs.path);c&&(g.along=c);return this.animate(g,d,f)}}function cB(a,b,c,d,e,f){var g=3*b,h=3*(d-b)-g,i=1-g-h,j=3*c,k=3*(e-c)-j,l=1-j-k;function m(a){return((i*a+h)*a+g)*a}function n(a,b){var c=o(a,b);return((l*c+k)*c+j)*c}function o(a,b){var c,d,e,f,j,k;for(e=a,k=0;k<8;k++){f=m(e)-a;if(B(f)<b)return e;j=(3*i*e+2*h)*e+g;if(B(j)<0.000001)break;e=e-f/j}c=0;d=1;e=a;if(e<c)return c;if(e>d)return d;while(c<d){f=m(e);if(B(f-a)<b)return e;a>f?c=e:d=e;e=(d-c)/2+c}return e}return n(a,1/(200*f))}bO.onAnimation=function(a){this._run=a||0;return this};bO.animate=function(c,d,e,g){var h=this;h.timeouts=h.timeouts||[];if(a.is(e,"function")||!e)g=e||null;if(h.removed){g&&g.call(h);return h}var i={},j={},k=false,l={};for(var m in c)if(c[f](m)){if(X[f](m)||h.paper.customAttributes[f](m)){k=true;i[m]=h.attr(m);i[m]==null&&(i[m]=W[m]);j[m]=c[m];switch(X[m]){case"along":var n=cs(c[m]),o=ct(c[m],n*!(!c.back)),p=h.getBBox();l[m]=n/d;l.tx=p.x;l.ty=p.y;l.sx=o.x;l.sy=o.y;j.rot=c.rot;j.back=c.back;j.len=n;c.rot&&(l.r=S(h.rotate())||0);break;case E:l[m]=(j[m]-i[m])/d;break;case"colour":i[m]=a.getRGB(i[m]);var q=a.getRGB(j[m]);l[m]={r:(q.r-i[m].r)/d,g:(q.g-i[m].g)/d,b:(q.b-i[m].b)/d};break;case"path":var t=bw(i[m],j[m]);i[m]=t[0];var u=t[1];l[m]=[];for(var v=0,x=i[m][w];v<x;v++){l[m][v]=[0];for(var y=1,z=i[m][v][w];y<z;y++)l[m][v][y]=(u[v][y]-i[m][v][y])/d}break;case"csv":var A=r(c[m])[s](b),B=r(i[m])[s](b);switch(m){case"translation":i[m]=[0,0];l[m]=[A[0]/d,A[1]/d];break;case"rotation":i[m]=B[1]==A[1]&&B[2]==A[2]?B:[0,A[1],A[2]];l[m]=[(A[0]-i[m][0])/d,0,0];break;case"scale":c[m]=A;i[m]=r(i[m])[s](b);l[m]=[(A[0]-i[m][0])/d,(A[1]-i[m][1])/d,0,0];break;case"clip-rect":i[m]=r(i[m])[s](b);l[m]=[];v=4;while(v--)l[m][v]=(A[v]-i[m][v])/d;break}j[m]=A;break;default:A=[].concat(c[m]);B=[].concat(i[m]);l[m]=[];v=h.paper.customAttributes[m][w];while(v--)l[m][v]=((A[v]||0)-(B[v]||0))/d;break}}}if(k){var G=a.easing_formulas[e];if(!G){G=r(e).match(P);if(G&&G[w]==5){var H=G;G=function(a){return cB(a,+H[1],+H[2],+H[3],+H[4],d)}}else G=function(a){return a}}cv.push({start:c.start||+(new Date),ms:d,easing:G,from:i,diff:l,to:j,el:h,t:{x:0,y:0}});a.is(g,"function")&&(h._ac=setTimeout(function(){g.call(h)},d));cv[w]==1&&setTimeout(cw)}else{var C=[],D;for(var F in c)if(c[f](F)&&Z.test(F)){m={value:c[F]};F=="from"&&(F=0);F=="to"&&(F=100);m.key=T(F,10);C.push(m)}C.sort(be);C[0].key&&C.unshift({key:0,value:h.attrs});for(v=0,x=C[w];v<x;v++)cx(C[v].value,h,d/100*C[v].key,d/100*(C[v-1]&&C[v-1].key||0),C[v-1]&&C[v-1].value.callback);D=C[C[w]-1].value.callback;D&&h.timeouts.push(setTimeout(function(){D.call(h)},d))}return this};bO.stop=function(){for(var a=0;a<cv.length;a++)cv[a].el.id==this.id&&cv.splice(a--,1);for(a=0,ii=this.timeouts&&this.timeouts.length;a<ii;a++)clearTimeout(this.timeouts[a]);this.timeouts=[];clearTimeout(this._ac);delete this._ac;return this};bO.translate=function(a,b){return this.attr({translation:a+" "+b})};bO[H]=function(){return"Raphaël’s object"};a.ae=cv;var cC=function(a){this.items=[];this[w]=0;this.type="set";if(a)for(var b=0,c=a[w];b<c;b++){if(a[b]&&(a[b].constructor==bN||a[b].constructor==cC)){this[this.items[w]]=this.items[this.items[w]]=a[b];this[w]++}}};cC[e][L]=function(){var a,b;for(var c=0,d=arguments[w];c<d;c++){a=arguments[c];if(a&&(a.constructor==bN||a.constructor==cC)){b=this.items[w];this[b]=this.items[b]=a;this[w]++}}return this};cC[e].pop=function(){delete this[this[w]--];return this.items.pop()};for(var cD in bO)bO[f](cD)&&(cC[e][cD]=(function(a){return function(){for(var b=0,c=this.items[w];b<c;b++)this.items[b][a][m](this.items[b],arguments);return this}})(cD));cC[e].attr=function(b,c){if(b&&a.is(b,G)&&a.is(b[0],"object"))for(var d=0,e=b[w];d<e;d++)this.items[d].attr(b[d]);else for(var f=0,g=this.items[w];f<g;f++)this.items[f].attr(b,c);return this};cC[e].animate=function(b,c,d,e){(a.is(d,"function")||!d)&&(e=d||null);var f=this.items[w],g=f,h,i=this,j;e&&(j=function(){!(--f)&&e.call(i)});d=a.is(d,F)?d:j;h=this.items[--g].animate(b,c,d,j);while(g--)this.items[g]&&!this.items[g].removed&&this.items[g].animateWith(h,b,c,d,j);return this};cC[e].insertAfter=function(a){var b=this.items[w];while(b--)this.items[b].insertAfter(a);return this};cC[e].getBBox=function(){var a=[],b=[],c=[],d=[];for(var e=this.items[w];e--;){var f=this.items[e].getBBox();a[L](f.x);b[L](f.y);c[L](f.x+f.width);d[L](f.y+f.height)}a=A[m](0,a);b=A[m](0,b);return{x:a,y:b,width:z[m](0,c)-a,height:z[m](0,d)-b}};cC[e].clone=function(a){a=new cC;for(var b=0,c=this.items[w];b<c;b++)a[L](this.items[b].clone());return a};a.registerFont=function(a){if(!a.face)return a;this.fonts=this.fonts||{};var b={w:a.w,face:{},glyphs:{}},c=a.face["font-family"];for(var d in a.face)a.face[f](d)&&(b.face[d]=a.face[d]);this.fonts[c]?this.fonts[c][L](b):this.fonts[c]=[b];if(!a.svg){b.face["units-per-em"]=T(a.face["units-per-em"],10);for(var e in a.glyphs)if(a.glyphs[f](e)){var g=a.glyphs[e];b.glyphs[e]={w:g.w,k:{},d:g.d&&"M"+g.d[Y](/[mlcxtrv]/g,function(a){return({l:"L",c:"C",x:"z",t:"m",r:"l",v:"c"})[a]||"M"})+"z"};if(g.k)for(var h in g.k)g[f](h)&&(b.glyphs[e].k[h]=g.k[h])}}return a};k.getFont=function(b,c,d,e){e=e||"normal";d=d||"normal";c=+c||({normal:400,bold:700,lighter:300,bolder:800})[c]||400;if(!a.fonts)return;var g=a.fonts[b];if(!g){var h=new RegExp("(^|\\s)"+b[Y](/[^\w\d\s+!~.:_-]/g,p)+"(\\s|$)","i");for(var i in a.fonts)if(a.fonts[f](i)){if(h.test(i)){g=a.fonts[i];break}}}var j;if(g)for(var k=0,l=g[w];k<l;k++){j=g[k];if(j.face["font-weight"]==c&&(j.face["font-style"]==d||!j.face["font-style"])&&j.face["font-stretch"]==e)break}return j};k.print=function(c,d,e,f,g,h,i){h=h||"middle";i=z(A(i||0,1),-1);var j=this.set(),k=r(e)[s](p),l=0,m=p,n;a.is(f,e)&&(f=this.getFont(f));if(f){n=(g||16)/f.face["units-per-em"];var o=f.face.bbox.split(b),q=+o[0],t=+o[1]+(h=="baseline"?o[3]-o[1]+ +f.face.descent:(o[3]-o[1])/2);for(var u=0,v=k[w];u<v;u++){var x=u&&f.glyphs[k[u-1]]||{},y=f.glyphs[k[u]];l+=u?(x.w||f.w)+(x.k&&x.k[k[u]]||0)+f.w*i:0;y&&y.d&&j[L](this.path(y.d).attr({fill:"#000",stroke:"none",translation:[l,0]}))}j.scale(n,n,q,t).translate(c-q,d-t)}return j};a.format=function(b,c){var e=a.is(c,G)?[0][n](c):arguments;b&&a.is(b,F)&&e[w]-1&&(b=b[Y](d,function(a,b){return e[++b]==null?p:e[b]}));return b||p};a.ninja=function(){i.was?h.Raphael=i.is:delete Raphael;return a};a.el=bO;a.st=cC[e];i.was?h.Raphael=a:Raphael=a})()
\ No newline at end of file
diff --git a/timeside/player/static/timeside/js/libs/soundmanager2-jsmin.js b/timeside/player/static/timeside/js/libs/soundmanager2-jsmin.js
new file mode 100644 (file)
index 0000000..2f52e5f
--- /dev/null
@@ -0,0 +1,110 @@
+/** @license
+
+
+ SoundManager 2: JavaScript Sound for the Web
+ ----------------------------------------------
+ http://schillmania.com/projects/soundmanager2/
+
+ Copyright (c) 2007, Scott Schiller. All rights reserved.
+ Code provided under the BSD License:
+ http://schillmania.com/projects/soundmanager2/license.txt
+
+ V2.97a.20120916
+*/
+(function(Z){function $($,oa){function aa(a){return c.preferFlash&&z&&!c.ignoreFlash&&"undefined"!==typeof c.flash[a]&&c.flash[a]}function q(a){return function(d){var e=this._t;!e||!e._a?(e&&e.id?c._wD(s+"ignoring "+d.type+": "+e.id):c._wD(s+"ignoring "+d.type),d=null):d=a.call(this,d);return d}}this.setupOptions={url:$||null,flashVersion:8,debugMode:!0,debugFlash:!1,useConsole:!0,consoleOnly:!0,waitForWindowLoad:!1,bgColor:"#ffffff",useHighPerformance:!1,flashPollingInterval:null,html5PollingInterval:null,
+flashLoadTimeout:1E3,wmode:null,allowScriptAccess:"always",useFlashBlock:!1,useHTML5Audio:!0,html5Test:/^(probably|maybe)$/i,preferFlash:!0,noSWFCache:!1};this.defaultOptions={autoLoad:!1,autoPlay:!1,from:null,loops:1,onid3:null,onload:null,whileloading:null,onplay:null,onpause:null,onresume:null,whileplaying:null,onposition:null,onstop:null,onfailure:null,onfinish:null,multiShot:!0,multiShotEvents:!1,position:null,pan:0,stream:!0,to:null,type:null,usePolicyFile:!1,volume:100};this.flash9Options=
+{isMovieStar:null,usePeakData:!1,useWaveformData:!1,useEQData:!1,onbufferchange:null,ondataerror:null};this.movieStarOptions={bufferTime:3,serverURL:null,onconnect:null,duration:null};this.audioFormats={mp3:{type:['audio/mpeg; codecs="mp3"',"audio/mpeg","audio/mp3","audio/MPA","audio/mpa-robust"],required:!0},mp4:{related:["aac","m4a","m4b"],type:['audio/mp4; codecs="mp4a.40.2"',"audio/aac","audio/x-m4a","audio/MP4A-LATM","audio/mpeg4-generic"],required:!1},ogg:{type:["audio/ogg; codecs=vorbis"],
+required:!1},wav:{type:['audio/wav; codecs="1"',"audio/wav","audio/wave","audio/x-wav"],required:!1}};this.movieID="sm2-container";this.id=oa||"sm2movie";this.debugID="soundmanager-debug";this.debugURLParam=/([#?&])debug=1/i;this.versionNumber="V2.97a.20120916";this.altURL=this.movieURL=this.version=null;this.enabled=this.swfLoaded=!1;this.oMC=null;this.sounds={};this.soundIDs=[];this.didFlashBlock=this.muted=!1;this.filePattern=null;this.filePatterns={flash8:/\.mp3(\?.*)?$/i,flash9:/\.mp3(\?.*)?$/i};
+this.features={buffering:!1,peakData:!1,waveformData:!1,eqData:!1,movieStar:!1};this.sandbox={type:null,types:{remote:"remote (domain-based) rules",localWithFile:"local with file access (no internet access)",localWithNetwork:"local with network (internet access only, no local access)",localTrusted:"local, trusted (local+internet access)"},description:null,noRemote:null,noLocal:null};var pa;try{pa="undefined"!==typeof Audio&&"undefined"!==typeof(qa&&10>opera.version()?new Audio(null):new Audio).canPlayType}catch(ib){pa=
+!1}this.hasHTML5=pa;this.html5={usingFlash:null};this.flash={};this.ignoreFlash=this.html5Only=!1;var Ka,c=this,h=null,s="HTML5::",A,v=navigator.userAgent,k=Z,Q=k.location.href.toString(),i=document,ra,La,sa,j,D=[],ta=!0,x,R=!1,S=!1,m=!1,o=!1,ba=!1,n,eb=0,T,w,ua,H,va,I,J,K,Ma,wa,ca,da,ea,L,xa,U,fa,ga,M,Na,ya,fb=["log","info","warn","error"],Oa,ha,Pa,V=null,za=null,p,Aa,N,Qa,ia,ja,O,t,W=!1,Ba=!1,Ra,Sa,Ta,ka=0,X=null,la,B=null,Ua,ma,Y,E,Ca,Da,Va,u,Wa=Array.prototype.slice,G=!1,z,Ea,Xa,C,Ya,Fa=v.match(/(ipad|iphone|ipod)/i),
+F=v.match(/msie/i),gb=v.match(/webkit/i),Ga=v.match(/safari/i)&&!v.match(/chrome/i),qa=v.match(/opera/i),Ha=v.match(/(mobile|pre\/|xoom)/i)||Fa,Ia=!Q.match(/usehtml5audio/i)&&!Q.match(/sm2\-ignorebadua/i)&&Ga&&!v.match(/silk/i)&&v.match(/OS X 10_6_([3-7])/i),Za="undefined"!==typeof console&&"undefined"!==typeof console.log,Ja="undefined"!==typeof i.hasFocus?i.hasFocus():null,na=Ga&&("undefined"===typeof i.hasFocus||!i.hasFocus()),$a=!na,ab=/(mp3|mp4|mpa|m4a|m4b)/i,P=i.location?i.location.protocol.match(/http/i):
+null,bb=!P?"http://":"",cb=/^\s*audio\/(?:x-)?(?:mpeg4|aac|flv|mov|mp4||m4v|m4a|m4b|mp4v|3gp|3g2)\s*(?:$|;)/i,db="mpeg4,aac,flv,mov,mp4,m4v,f4v,m4a,m4b,mp4v,3gp,3g2".split(","),hb=RegExp("\\.("+db.join("|")+")(\\?.*)?$","i");this.mimePattern=/^\s*audio\/(?:x-)?(?:mp(?:eg|3))\s*(?:$|;)/i;this.useAltURL=!P;this._global_a=null;if(Ha&&(c.useHTML5Audio=!0,c.preferFlash=!1,Fa))G=c.ignoreFlash=!0;this.setup=function(a){var d=!c.url;"undefined"!==typeof a&&m&&B&&c.ok()&&("undefined"!==typeof a.flashVersion||
+"undefined"!==typeof a.url)&&O(p("setupLate"));ua(a);d&&U&&"undefined"!==typeof a.url&&c.beginDelayedInit();!U&&"undefined"!==typeof a.url&&"complete"===i.readyState&&setTimeout(L,1);return c};this.supported=this.ok=function(){return B?m&&!o:c.useHTML5Audio&&c.hasHTML5};this.getMovie=function(c){return A(c)||i[c]||k[c]};this.createSound=function(a,d){function e(){g=ia(g);c.sounds[f.id]=new Ka(f);c.soundIDs.push(f.id);return c.sounds[f.id]}var b,g=null,f=b=null;b="soundManager.createSound(): "+p(!m?
+"notReady":"notOK");if(!m||!c.ok())return O(b),!1;"undefined"!==typeof d&&(a={id:a,url:d});g=w(a);g.url=la(g.url);f=g;f.id.toString().charAt(0).match(/^[0-9]$/)&&c._wD("soundManager.createSound(): "+p("badID",f.id),2);c._wD("soundManager.createSound(): "+f.id+" ("+f.url+")",1);if(t(f.id,!0))return c._wD("soundManager.createSound(): "+f.id+" exists",1),c.sounds[f.id];if(ma(f))b=e(),c._wD("Creating sound "+f.id+", using HTML5"),b._setup_html5(f);else{if(8<j){if(null===f.isMovieStar)f.isMovieStar=!(!f.serverURL&&
+!(f.type&&f.type.match(cb)||f.url.match(hb)));f.isMovieStar&&(c._wD("soundManager.createSound(): using MovieStar handling"),1<f.loops&&n("noNSLoop"))}f=ja(f,"soundManager.createSound(): ");b=e();if(8===j)h._createSound(f.id,f.loops||1,f.usePolicyFile);else if(h._createSound(f.id,f.url,f.usePeakData,f.useWaveformData,f.useEQData,f.isMovieStar,f.isMovieStar?f.bufferTime:!1,f.loops||1,f.serverURL,f.duration||null,f.autoPlay,!0,f.autoLoad,f.usePolicyFile),!f.serverURL)b.connected=!0,f.onconnect&&f.onconnect.apply(b);
+!f.serverURL&&(f.autoLoad||f.autoPlay)&&b.load(f)}!f.serverURL&&f.autoPlay&&b.play();return b};this.destroySound=function(a,d){if(!t(a))return!1;var e=c.sounds[a],b;e._iO={};e.stop();e.unload();for(b=0;b<c.soundIDs.length;b++)if(c.soundIDs[b]===a){c.soundIDs.splice(b,1);break}d||e.destruct(!0);delete c.sounds[a];return!0};this.load=function(a,d){return!t(a)?!1:c.sounds[a].load(d)};this.unload=function(a){return!t(a)?!1:c.sounds[a].unload()};this.onposition=this.onPosition=function(a,d,e,b){return!t(a)?
+!1:c.sounds[a].onposition(d,e,b)};this.clearOnPosition=function(a,d,e){return!t(a)?!1:c.sounds[a].clearOnPosition(d,e)};this.start=this.play=function(a,d){var e=!1;if(!m||!c.ok())return O("soundManager.play(): "+p(!m?"notReady":"notOK")),e;if(!t(a)){d instanceof Object||(d={url:d});if(d&&d.url)c._wD('soundManager.play(): attempting to create "'+a+'"',1),d.id=a,e=c.createSound(d).play();return e}return c.sounds[a].play(d)};this.setPosition=function(a,d){return!t(a)?!1:c.sounds[a].setPosition(d)};this.stop=
+function(a){if(!t(a))return!1;c._wD("soundManager.stop("+a+")",1);return c.sounds[a].stop()};this.stopAll=function(){var a;c._wD("soundManager.stopAll()",1);for(a in c.sounds)c.sounds.hasOwnProperty(a)&&c.sounds[a].stop()};this.pause=function(a){return!t(a)?!1:c.sounds[a].pause()};this.pauseAll=function(){var a;for(a=c.soundIDs.length-1;0<=a;a--)c.sounds[c.soundIDs[a]].pause()};this.resume=function(a){return!t(a)?!1:c.sounds[a].resume()};this.resumeAll=function(){var a;for(a=c.soundIDs.length-1;0<=
+a;a--)c.sounds[c.soundIDs[a]].resume()};this.togglePause=function(a){return!t(a)?!1:c.sounds[a].togglePause()};this.setPan=function(a,d){return!t(a)?!1:c.sounds[a].setPan(d)};this.setVolume=function(a,d){return!t(a)?!1:c.sounds[a].setVolume(d)};this.mute=function(a){var d=0;"string"!==typeof a&&(a=null);if(a){if(!t(a))return!1;c._wD('soundManager.mute(): Muting "'+a+'"');return c.sounds[a].mute()}c._wD("soundManager.mute(): Muting all sounds");for(d=c.soundIDs.length-1;0<=d;d--)c.sounds[c.soundIDs[d]].mute();
+return c.muted=!0};this.muteAll=function(){c.mute()};this.unmute=function(a){"string"!==typeof a&&(a=null);if(a){if(!t(a))return!1;c._wD('soundManager.unmute(): Unmuting "'+a+'"');return c.sounds[a].unmute()}c._wD("soundManager.unmute(): Unmuting all sounds");for(a=c.soundIDs.length-1;0<=a;a--)c.sounds[c.soundIDs[a]].unmute();c.muted=!1;return!0};this.unmuteAll=function(){c.unmute()};this.toggleMute=function(a){return!t(a)?!1:c.sounds[a].toggleMute()};this.getMemoryUse=function(){var c=0;h&&8!==j&&
+(c=parseInt(h._getMemoryUse(),10));return c};this.disable=function(a){var d;"undefined"===typeof a&&(a=!1);if(o)return!1;o=!0;n("shutdown",1);for(d=c.soundIDs.length-1;0<=d;d--)Oa(c.sounds[c.soundIDs[d]]);T(a);u.remove(k,"load",J);return!0};this.canPlayMIME=function(a){var d;c.hasHTML5&&(d=Y({type:a}));!d&&B&&(d=a&&c.ok()?!!(8<j&&a.match(cb)||a.match(c.mimePattern)):null);return d};this.canPlayURL=function(a){var d;c.hasHTML5&&(d=Y({url:a}));!d&&B&&(d=a&&c.ok()?!!a.match(c.filePattern):null);return d};
+this.canPlayLink=function(a){return"undefined"!==typeof a.type&&a.type&&c.canPlayMIME(a.type)?!0:c.canPlayURL(a.href)};this.getSoundById=function(a,d){if(!a)throw Error("soundManager.getSoundById(): sID is null/undefined");var e=c.sounds[a];!e&&!d&&c._wD('"'+a+'" is an invalid sound ID.',2);return e};this.onready=function(a,d){var e=!1;if("function"===typeof a)m&&c._wD(p("queue","onready")),d||(d=k),va("onready",a,d),I();else throw p("needFunction","onready");return!0};this.ontimeout=function(a,d){var e=
+!1;if("function"===typeof a)m&&c._wD(p("queue","ontimeout")),d||(d=k),va("ontimeout",a,d),I({type:"ontimeout"});else throw p("needFunction","ontimeout");return!0};this._wD=this._writeDebug=function(a,d,e){var b,g;if(!c.debugMode)return!1;"undefined"!==typeof e&&e&&(a=a+" | "+(new Date).getTime());if(Za&&c.useConsole){e=fb[d];if("undefined"!==typeof console[e])console[e](a);else console.log(a);if(c.consoleOnly)return!0}try{b=A("soundmanager-debug");if(!b)return!1;g=i.createElement("div");if(0===++eb%
+2)g.className="sm2-alt";d="undefined"===typeof d?0:parseInt(d,10);g.appendChild(i.createTextNode(a));if(d){if(2<=d)g.style.fontWeight="bold";if(3===d)g.style.color="#ff3333"}b.insertBefore(g,b.firstChild)}catch(f){}return!0};this._debug=function(){var a,d;n("currentObj",1);for(a=0,d=c.soundIDs.length;a<d;a++)c.sounds[c.soundIDs[a]]._debug()};this.reboot=function(){c._wD("soundManager.reboot()");c.soundIDs.length&&c._wD("Destroying "+c.soundIDs.length+" SMSound objects...");var a,d;for(a=c.soundIDs.length-
+1;0<=a;a--)c.sounds[c.soundIDs[a]].destruct();if(h)try{if(F)za=h.innerHTML;V=h.parentNode.removeChild(h);c._wD("Flash movie removed.")}catch(e){n("badRemove",2)}za=V=B=null;c.enabled=U=m=W=Ba=R=S=o=c.swfLoaded=!1;c.soundIDs=[];c.sounds={};h=null;for(a in D)if(D.hasOwnProperty(a))for(d=D[a].length-1;0<=d;d--)D[a][d].fired=!1;c._wD("soundManager: Rebooting...");k.setTimeout(c.beginDelayedInit,20)};this.getMoviePercent=function(){return h&&"undefined"!==typeof h.PercentLoaded?h.PercentLoaded():null};
+this.beginDelayedInit=function(){ba=!0;L();setTimeout(function(){if(Ba)return!1;ga();ea();return Ba=!0},20);K()};this.destruct=function(){c._wD("soundManager.destruct()");c.disable(!0)};Ka=function(a){var d,e,b=this,g,f,r,l,i,k,m=!1,y=[],q=0,u,v,o=null;d=null;e=null;this.sID=this.id=a.id;this.url=a.url;this._iO=this.instanceOptions=this.options=w(a);this.pan=this.options.pan;this.volume=this.options.volume;this.isHTML5=!1;this._a=null;this.id3={};this._debug=function(){if(c.debugMode){var a=null,
+d=[],e,f;for(a in b.options)null!==b.options[a]&&("function"===typeof b.options[a]?(e=b.options[a].toString(),e=e.replace(/\s\s+/g," "),f=e.indexOf("{"),d.push(" "+a+": {"+e.substr(f+1,Math.min(Math.max(e.indexOf("\n")-1,64),64)).replace(/\n/g,"")+"... }")):d.push(" "+a+": "+b.options[a]));c._wD("SMSound() merged options: {\n"+d.join(", \n")+"\n}")}};this._debug();this.load=function(a){var d=null;if("undefined"!==typeof a)b._iO=w(a,b.options),b.instanceOptions=b._iO;else if(a=b.options,b._iO=a,b.instanceOptions=
+b._iO,o&&o!==b.url)n("manURL"),b._iO.url=b.url,b.url=null;if(!b._iO.url)b._iO.url=b.url;b._iO.url=la(b._iO.url);c._wD("SMSound.load(): "+b._iO.url,1);if(b._iO.url===b.url&&0!==b.readyState&&2!==b.readyState)return n("onURL",1),3===b.readyState&&b._iO.onload&&b._iO.onload.apply(b,[!!b.duration]),b;a=b._iO;o=b.url&&b.url.toString?b.url.toString():null;b.loaded=!1;b.readyState=1;b.playState=0;b.id3={};if(ma(a))if(d=b._setup_html5(a),d._called_load)c._wD(s+"ignoring request to load again: "+b.id);else{c._wD(s+
+"load: "+b.id);b._html5_canplay=!1;if(b._a.src!==a.url)c._wD(n("manURL")+": "+a.url),b._a.src=a.url,b.setPosition(0);b._a.autobuffer="auto";b._a.preload="auto";d._called_load=!0;a.autoPlay&&b.play()}else try{b.isHTML5=!1,b._iO=ja(ia(a)),a=b._iO,8===j?h._load(b.id,a.url,a.stream,a.autoPlay,a.whileloading?1:0,a.loops||1,a.usePolicyFile):h._load(b.id,a.url,!!a.stream,!!a.autoPlay,a.loops||1,!!a.autoLoad,a.usePolicyFile)}catch(e){n("smError",2),x("onload",!1),M({type:"SMSOUND_LOAD_JS_EXCEPTION",fatal:!0})}b.url=
+a.url;return b};this.unload=function(){if(0!==b.readyState){c._wD('SMSound.unload(): "'+b.id+'"');if(b.isHTML5){if(l(),b._a)b._a.pause(),Ca(b._a,"about:blank"),b.url="about:blank"}else 8===j?h._unload(b.id,"about:blank"):h._unload(b.id);g()}return b};this.destruct=function(a){c._wD('SMSound.destruct(): "'+b.id+'"');if(b.isHTML5){if(l(),b._a)b._a.pause(),Ca(b._a),G||r(),b._a._t=null,b._a=null}else b._iO.onfailure=null,h._destroySound(b.id);a||c.destroySound(b.id,!0)};this.start=this.play=function(a,
+d){var e,f;f=!0;f=null;d="undefined"===typeof d?!0:d;a||(a={});if(b.url)b._iO.url=b.url;b._iO=w(b._iO,b.options);b._iO=w(a,b._iO);b._iO.url=la(b._iO.url);b.instanceOptions=b._iO;if(b._iO.serverURL&&!b.connected)return b.getAutoPlay()||(c._wD("SMSound.play():  Netstream not connected yet - setting autoPlay"),b.setAutoPlay(!0)),b;ma(b._iO)&&(b._setup_html5(b._iO),i());if(1===b.playState&&!b.paused)(e=b._iO.multiShot)?c._wD('SMSound.play(): "'+b.id+'" already playing (multi-shot)',1):(c._wD('SMSound.play(): "'+
+b.id+'" already playing (one-shot)',1),f=b);if(null!==f)return f;a.url&&a.url!==b.url&&b.load(b._iO);if(b.loaded)c._wD('SMSound.play(): "'+b.id+'"');else if(0===b.readyState){c._wD('SMSound.play(): Attempting to load "'+b.id+'"',1);if(!b.isHTML5)b._iO.autoPlay=!0;b.load(b._iO)}else 2===b.readyState?(c._wD('SMSound.play(): Could not load "'+b.id+'" - exiting',2),f=b):c._wD('SMSound.play(): "'+b.id+'" is loading - attempting to play..',1);if(null!==f)return f;if(!b.isHTML5&&9===j&&0<b.position&&b.position===
+b.duration)c._wD('SMSound.play(): "'+b.id+'": Sound at end, resetting to position:0'),a.position=0;if(b.paused&&0<=b.position&&(!b._iO.serverURL||0<b.position))c._wD('SMSound.play(): "'+b.id+'" is resuming from paused state',1),b.resume();else{b._iO=w(a,b._iO);if(null!==b._iO.from&&null!==b._iO.to&&0===b.instanceCount&&0===b.playState&&!b._iO.serverURL){e=function(){b._iO=w(a,b._iO);b.play(b._iO)};if(b.isHTML5&&!b._html5_canplay)c._wD('SMSound.play(): Beginning load of "'+b.id+'" for from/to case'),
+b.load({_oncanplay:e}),f=!1;else if(!b.isHTML5&&!b.loaded&&(!b.readyState||2!==b.readyState))c._wD('SMSound.play(): Preloading "'+b.id+'" for from/to case'),b.load({onload:e}),f=!1;if(null!==f)return f;b._iO=v()}c._wD('SMSound.play(): "'+b.id+'" is starting to play');(!b.instanceCount||b._iO.multiShotEvents||!b.isHTML5&&8<j&&!b.getAutoPlay())&&b.instanceCount++;b._iO.onposition&&0===b.playState&&k(b);b.playState=1;b.paused=!1;b.position="undefined"!==typeof b._iO.position&&!isNaN(b._iO.position)?
+b._iO.position:0;if(!b.isHTML5)b._iO=ja(ia(b._iO));b._iO.onplay&&d&&(b._iO.onplay.apply(b),m=!0);b.setVolume(b._iO.volume,!0);b.setPan(b._iO.pan,!0);b.isHTML5?(i(),f=b._setup_html5(),b.setPosition(b._iO.position),f.play()):(f=h._start(b.id,b._iO.loops||1,9===j?b._iO.position:b._iO.position/1E3,b._iO.multiShot),9===j&&!f&&(c._wD("SMSound.play(): "+b.id+": No sound hardware, or 32-sound ceiling hit"),b._iO.onplayerror&&b._iO.onplayerror.apply(b)))}return b};this.stop=function(a){var c=b._iO;if(1===
+b.playState){b._onbufferchange(0);b._resetOnPosition(0);b.paused=!1;if(!b.isHTML5)b.playState=0;u();c.to&&b.clearOnPosition(c.to);if(b.isHTML5){if(b._a)a=b.position,b.setPosition(0),b.position=a,b._a.pause(),b.playState=0,b._onTimer(),l()}else h._stop(b.id,a),c.serverURL&&b.unload();b.instanceCount=0;b._iO={};c.onstop&&c.onstop.apply(b)}return b};this.setAutoPlay=function(a){c._wD("sound "+b.id+" turned autoplay "+(a?"on":"off"));b._iO.autoPlay=a;b.isHTML5||(h._setAutoPlay(b.id,a),a&&!b.instanceCount&&
+1===b.readyState&&(b.instanceCount++,c._wD("sound "+b.id+" incremented instance count to "+b.instanceCount)))};this.getAutoPlay=function(){return b._iO.autoPlay};this.setPosition=function(a){"undefined"===typeof a&&(a=0);var d=b.isHTML5?Math.max(a,0):Math.min(b.duration||b._iO.duration,Math.max(a,0));b.position=d;a=b.position/1E3;b._resetOnPosition(b.position);b._iO.position=d;if(b.isHTML5){if(b._a)if(b._html5_canplay){if(b._a.currentTime!==a){c._wD("setPosition("+a+"): setting position");try{b._a.currentTime=
+a,(0===b.playState||b.paused)&&b._a.pause()}catch(e){c._wD("setPosition("+a+"): setting position failed: "+e.message,2)}}}else c._wD("setPosition("+a+"): delaying, sound not ready")}else a=9===j?b.position:a,b.readyState&&2!==b.readyState&&h._setPosition(b.id,a,b.paused||!b.playState,b._iO.multiShot);b.isHTML5&&b.paused&&b._onTimer(!0);return b};this.pause=function(a){if(b.paused||0===b.playState&&1!==b.readyState)return b;c._wD("SMSound.pause()");b.paused=!0;b.isHTML5?(b._setup_html5().pause(),l()):
+(a||"undefined"===typeof a)&&h._pause(b.id,b._iO.multiShot);b._iO.onpause&&b._iO.onpause.apply(b);return b};this.resume=function(){var a=b._iO;if(!b.paused)return b;c._wD("SMSound.resume()");b.paused=!1;b.playState=1;b.isHTML5?(b._setup_html5().play(),i()):(a.isMovieStar&&!a.serverURL&&b.setPosition(b.position),h._pause(b.id,a.multiShot));!m&&a.onplay?(a.onplay.apply(b),m=!0):a.onresume&&a.onresume.apply(b);return b};this.togglePause=function(){c._wD("SMSound.togglePause()");if(0===b.playState)return b.play({position:9===
+j&&!b.isHTML5?b.position:b.position/1E3}),b;b.paused?b.resume():b.pause();return b};this.setPan=function(a,c){"undefined"===typeof a&&(a=0);"undefined"===typeof c&&(c=!1);b.isHTML5||h._setPan(b.id,a);b._iO.pan=a;if(!c)b.pan=a,b.options.pan=a;return b};this.setVolume=function(a,d){"undefined"===typeof a&&(a=100);"undefined"===typeof d&&(d=!1);if(b.isHTML5){if(b._a)b._a.volume=Math.max(0,Math.min(1,a/100))}else h._setVolume(b.id,c.muted&&!b.muted||b.muted?0:a);b._iO.volume=a;if(!d)b.volume=a,b.options.volume=
+a;return b};this.mute=function(){b.muted=!0;if(b.isHTML5){if(b._a)b._a.muted=!0}else h._setVolume(b.id,0);return b};this.unmute=function(){b.muted=!1;var a="undefined"!==typeof b._iO.volume;if(b.isHTML5){if(b._a)b._a.muted=!1}else h._setVolume(b.id,a?b._iO.volume:b.options.volume);return b};this.toggleMute=function(){return b.muted?b.unmute():b.mute()};this.onposition=this.onPosition=function(a,c,d){y.push({position:parseInt(a,10),method:c,scope:"undefined"!==typeof d?d:b,fired:!1});return b};this.clearOnPosition=
+function(b,a){var c,b=parseInt(b,10);if(isNaN(b))return!1;for(c=0;c<y.length;c++)if(b===y[c].position&&(!a||a===y[c].method))y[c].fired&&q--,y.splice(c,1)};this._processOnPosition=function(){var a,c;a=y.length;if(!a||!b.playState||q>=a)return!1;for(a-=1;0<=a;a--)if(c=y[a],!c.fired&&b.position>=c.position)c.fired=!0,q++,c.method.apply(c.scope,[c.position]);return!0};this._resetOnPosition=function(b){var a,c;a=y.length;if(!a)return!1;for(a-=1;0<=a;a--)if(c=y[a],c.fired&&b<=c.position)c.fired=!1,q--;
+return!0};v=function(){var a=b._iO,d=a.from,e=a.to,f,g;g=function(){c._wD(b.id+': "to" time of '+e+" reached.");b.clearOnPosition(e,g);b.stop()};f=function(){c._wD(b.id+': playing "from" '+d);if(null!==e&&!isNaN(e))b.onPosition(e,g)};if(null!==d&&!isNaN(d))a.position=d,a.multiShot=!1,f();return a};k=function(){var a,c=b._iO.onposition;if(c)for(a in c)if(c.hasOwnProperty(a))b.onPosition(parseInt(a,10),c[a])};u=function(){var a,c=b._iO.onposition;if(c)for(a in c)c.hasOwnProperty(a)&&b.clearOnPosition(parseInt(a,
+10))};i=function(){b.isHTML5&&Ra(b)};l=function(){b.isHTML5&&Sa(b)};g=function(a){a||(y=[],q=0);m=!1;b._hasTimer=null;b._a=null;b._html5_canplay=!1;b.bytesLoaded=null;b.bytesTotal=null;b.duration=b._iO&&b._iO.duration?b._iO.duration:null;b.durationEstimate=null;b.buffered=[];b.eqData=[];b.eqData.left=[];b.eqData.right=[];b.failures=0;b.isBuffering=!1;b.instanceOptions={};b.instanceCount=0;b.loaded=!1;b.metadata={};b.readyState=0;b.muted=!1;b.paused=!1;b.peakData={left:0,right:0};b.waveformData={left:[],
+right:[]};b.playState=0;b.position=null;b.id3={}};g();this._onTimer=function(a){var c,f=!1,g={};if(b._hasTimer||a){if(b._a&&(a||(0<b.playState||1===b.readyState)&&!b.paused)){c=b._get_html5_duration();if(c!==d)d=c,b.duration=c,f=!0;b.durationEstimate=b.duration;c=1E3*b._a.currentTime||0;c!==e&&(e=c,f=!0);(f||a)&&b._whileplaying(c,g,g,g,g)}return f}};this._get_html5_duration=function(){var a=b._iO;return(a=b._a&&b._a.duration?1E3*b._a.duration:a&&a.duration?a.duration:null)&&!isNaN(a)&&Infinity!==
+a?a:null};this._apply_loop=function(b,a){!b.loop&&1<a&&c._wD("Note: Native HTML5 looping is infinite.");b.loop=1<a?"loop":""};this._setup_html5=function(a){var a=w(b._iO,a),d=decodeURI,e=G?c._global_a:b._a,l=d(a.url),r=e&&e._t?e._t.instanceOptions:null,i;if(e){if(e._t){if(!G&&l===d(o))i=e;else if(G&&r.url===a.url&&(!o||o===r.url))i=e;if(i)return b._apply_loop(e,a.loops),i}c._wD("setting URL on existing object: "+l+(o?", old URL: "+o:""));G&&e._t&&e._t.playState&&a.url!==r.url&&e._t.stop();g(r&&r.url?
+a.url===r.url:o?o===a.url:!1);e.src=a.url;o=b.url=a.url;e._called_load=!1}else if(n("h5a"),b._a=a.autoLoad||a.autoPlay?new Audio(a.url):qa&&10>opera.version()?new Audio(null):new Audio,e=b._a,e._called_load=!1,G)c._global_a=e;b.isHTML5=!0;b._a=e;e._t=b;f();b._apply_loop(e,a.loops);a.autoLoad||a.autoPlay?b.load():(e.autobuffer=!1,e.preload="auto");return e};f=function(){if(b._a._added_events)return!1;var a;b._a._added_events=!0;for(a in C)C.hasOwnProperty(a)&&b._a&&b._a.addEventListener(a,C[a],!1);
+return!0};r=function(){var a;c._wD(s+"removing event listeners: "+b.id);b._a._added_events=!1;for(a in C)C.hasOwnProperty(a)&&b._a&&b._a.removeEventListener(a,C[a],!1)};this._onload=function(a){a=!!a||!b.isHTML5&&8===j&&b.duration;c._wD('SMSound._onload(): "'+b.id+'"'+(a?" loaded.":" failed to load? - "+b.url),a?1:2);!a&&!b.isHTML5&&(!0===c.sandbox.noRemote&&c._wD("SMSound._onload(): "+p("noNet"),1),!0===c.sandbox.noLocal&&c._wD("SMSound._onload(): "+p("noLocal"),1));b.loaded=a;b.readyState=a?3:2;
+b._onbufferchange(0);b._iO.onload&&b._iO.onload.apply(b,[a]);return!0};this._onbufferchange=function(a){if(0===b.playState||a&&b.isBuffering||!a&&!b.isBuffering)return!1;b.isBuffering=1===a;b._iO.onbufferchange&&(c._wD("SMSound._onbufferchange(): "+a),b._iO.onbufferchange.apply(b));return!0};this._onsuspend=function(){b._iO.onsuspend&&(c._wD("SMSound._onsuspend()"),b._iO.onsuspend.apply(b));return!0};this._onfailure=function(a,d,e){b.failures++;c._wD('SMSound._onfailure(): "'+b.id+'" count '+b.failures);
+if(b._iO.onfailure&&1===b.failures)b._iO.onfailure(b,a,d,e);else c._wD("SMSound._onfailure(): ignoring")};this._onfinish=function(){var a=b._iO.onfinish;b._onbufferchange(0);b._resetOnPosition(0);if(b.instanceCount){b.instanceCount--;if(!b.instanceCount&&(u(),b.playState=0,b.paused=!1,b.instanceCount=0,b.instanceOptions={},b._iO={},l(),b.isHTML5))b.position=0;if((!b.instanceCount||b._iO.multiShotEvents)&&a)c._wD('SMSound._onfinish(): "'+b.id+'"'),a.apply(b)}};this._whileloading=function(a,c,d,e){var f=
+b._iO;b.bytesLoaded=a;b.bytesTotal=c;b.duration=Math.floor(d);b.bufferLength=e;b.durationEstimate=!b.isHTML5&&!f.isMovieStar?f.duration?b.duration>f.duration?b.duration:f.duration:parseInt(b.bytesTotal/b.bytesLoaded*b.duration,10):b.duration;if(!b.isHTML5)b.buffered=[{start:0,end:b.duration}];(3!==b.readyState||b.isHTML5)&&f.whileloading&&f.whileloading.apply(b)};this._whileplaying=function(a,c,d,e,f){var g=b._iO;if(isNaN(a)||null===a)return!1;b.position=Math.max(0,a);b._processOnPosition();if(!b.isHTML5&&
+8<j){if(g.usePeakData&&"undefined"!==typeof c&&c)b.peakData={left:c.leftPeak,right:c.rightPeak};if(g.useWaveformData&&"undefined"!==typeof d&&d)b.waveformData={left:d.split(","),right:e.split(",")};if(g.useEQData&&"undefined"!==typeof f&&f&&f.leftEQ&&(a=f.leftEQ.split(","),b.eqData=a,b.eqData.left=a,"undefined"!==typeof f.rightEQ&&f.rightEQ))b.eqData.right=f.rightEQ.split(",")}1===b.playState&&(!b.isHTML5&&8===j&&!b.position&&b.isBuffering&&b._onbufferchange(0),g.whileplaying&&g.whileplaying.apply(b));
+return!0};this._oncaptiondata=function(a){c._wD('SMSound._oncaptiondata(): "'+this.id+'" caption data received.');b.captiondata=a;b._iO.oncaptiondata&&b._iO.oncaptiondata.apply(b,[a])};this._onmetadata=function(a,d){c._wD('SMSound._onmetadata(): "'+this.id+'" metadata received.');var e={},f,g;for(f=0,g=a.length;f<g;f++)e[a[f]]=d[f];b.metadata=e;b._iO.onmetadata&&b._iO.onmetadata.apply(b)};this._onid3=function(a,d){c._wD('SMSound._onid3(): "'+this.id+'" ID3 data received.');var e=[],f,g;for(f=0,g=
+a.length;f<g;f++)e[a[f]]=d[f];b.id3=w(b.id3,e);b._iO.onid3&&b._iO.onid3.apply(b)};this._onconnect=function(a){a=1===a;c._wD('SMSound._onconnect(): "'+b.id+'"'+(a?" connected.":" failed to connect? - "+b.url),a?1:2);if(b.connected=a)b.failures=0,t(b.id)&&(b.getAutoPlay()?b.play(void 0,b.getAutoPlay()):b._iO.autoLoad&&b.load()),b._iO.onconnect&&b._iO.onconnect.apply(b,[a])};this._ondataerror=function(a){0<b.playState&&(c._wD("SMSound._ondataerror(): "+a),b._iO.ondataerror&&b._iO.ondataerror.apply(b))}};
+fa=function(){return i.body||i._docElement||i.getElementsByTagName("div")[0]};A=function(a){return i.getElementById(a)};w=function(a,d){var e=a||{},b,g;b="undefined"===typeof d?c.defaultOptions:d;for(g in b)b.hasOwnProperty(g)&&"undefined"===typeof e[g]&&(e[g]="object"!==typeof b[g]||null===b[g]?b[g]:w(e[g],b[g]));return e};H={onready:1,ontimeout:1,defaultOptions:1,flash9Options:1,movieStarOptions:1};ua=function(a,d){var e,b=!0,g="undefined"!==typeof d,f=c.setupOptions;if("undefined"===typeof a){b=
+[];for(e in f)f.hasOwnProperty(e)&&b.push(e);for(e in H)H.hasOwnProperty(e)&&("object"===typeof c[e]?b.push(e+": {...}"):c[e]instanceof Function?b.push(e+": function() {...}"):b.push(e));c._wD(p("setup",b.join(", ")));return!1}for(e in a)if(a.hasOwnProperty(e))if("object"!==typeof a[e]||null===a[e]||a[e]instanceof Array)g&&"undefined"!==typeof H[d]?c[d][e]=a[e]:"undefined"!==typeof f[e]?(c.setupOptions[e]=a[e],c[e]=a[e]):"undefined"===typeof H[e]?(O(p("undefined"===typeof c[e]?"setupUndef":"setupError",
+e),2),b=!1):c[e]instanceof Function?c[e].apply(c,a[e]instanceof Array?a[e]:[a[e]]):c[e]=a[e];else if("undefined"===typeof H[e])O(p("undefined"===typeof c[e]?"setupUndef":"setupError",e),2),b=!1;else return ua(a[e],e);return b};u=function(){function a(a){var a=Wa.call(a),b=a.length;e?(a[1]="on"+a[1],3<b&&a.pop()):3===b&&a.push(!1);return a}function c(a,d){var r=a.shift(),l=[b[d]];if(e)r[l](a[0],a[1]);else r[l].apply(r,a)}var e=k.attachEvent,b={add:e?"attachEvent":"addEventListener",remove:e?"detachEvent":
+"removeEventListener"};return{add:function(){c(a(arguments),"add")},remove:function(){c(a(arguments),"remove")}}}();C={abort:q(function(){c._wD(s+"abort: "+this._t.id)}),canplay:q(function(){var a=this._t,d;if(a._html5_canplay)return!0;a._html5_canplay=!0;c._wD(s+"canplay: "+a.id+", "+a.url);a._onbufferchange(0);d="undefined"!==typeof a._iO.position&&!isNaN(a._iO.position)?a._iO.position/1E3:null;if(a.position&&this.currentTime!==d){c._wD(s+"canplay: setting position to "+d);try{this.currentTime=
+d}catch(e){c._wD(s+"setting position of "+d+" failed: "+e.message,2)}}a._iO._oncanplay&&a._iO._oncanplay()}),canplaythrough:q(function(){var a=this._t;a.loaded||(a._onbufferchange(0),a._whileloading(a.bytesLoaded,a.bytesTotal,a._get_html5_duration()),a._onload(!0))}),ended:q(function(){var a=this._t;c._wD(s+"ended: "+a.id);a._onfinish()}),error:q(function(){c._wD(s+"error: "+this.error.code);this._t._onload(!1)}),loadeddata:q(function(){var a=this._t;c._wD(s+"loadeddata: "+this._t.id);if(!a._loaded&&
+!Ga)a.duration=a._get_html5_duration()}),loadedmetadata:q(function(){c._wD(s+"loadedmetadata: "+this._t.id)}),loadstart:q(function(){c._wD(s+"loadstart: "+this._t.id);this._t._onbufferchange(1)}),play:q(function(){c._wD(s+"play: "+this._t.id+", "+this._t.url);this._t._onbufferchange(0)}),playing:q(function(){c._wD(s+"playing: "+this._t.id);this._t._onbufferchange(0)}),progress:q(function(a){var d=this._t,e,b,g;e=0;var f="progress"===a.type,r=a.target.buffered,l=a.loaded||0,i=a.total||1;d.buffered=
+[];if(r&&r.length){for(e=0,b=r.length;e<b;e++)d.buffered.push({start:1E3*r.start(e),end:1E3*r.end(e)});e=1E3*(r.end(0)-r.start(0));l=e/(1E3*a.target.duration);if(f&&1<r.length){g=[];b=r.length;for(e=0;e<b;e++)g.push(1E3*a.target.buffered.start(e)+"-"+1E3*a.target.buffered.end(e));c._wD(s+"progress: timeRanges: "+g.join(", "))}f&&!isNaN(l)&&c._wD(s+"progress: "+d.id+": "+Math.floor(100*l)+"% loaded")}isNaN(l)||(d._onbufferchange(0),d._whileloading(l,i,d._get_html5_duration()),l&&i&&l===i&&C.canplaythrough.call(this,
+a))}),ratechange:q(function(){c._wD(s+"ratechange: "+this._t.id)}),suspend:q(function(a){var d=this._t;c._wD(s+"suspend: "+d.id);C.progress.call(this,a);d._onsuspend()}),stalled:q(function(){c._wD(s+"stalled: "+this._t.id)}),timeupdate:q(function(){this._t._onTimer()}),waiting:q(function(){var a=this._t;c._wD(s+"waiting: "+a.id);a._onbufferchange(1)})};ma=function(a){return a.serverURL||a.type&&aa(a.type)?!1:a.type?Y({type:a.type}):Y({url:a.url})||c.html5Only};Ca=function(a,c){if(a)a.src=c};Y=function(a){if(!c.useHTML5Audio||
+!c.hasHTML5)return!1;var d=a.url||null,a=a.type||null,e=c.audioFormats,b;if(a&&"undefined"!==typeof c.html5[a])return c.html5[a]&&!aa(a);if(!E){E=[];for(b in e)e.hasOwnProperty(b)&&(E.push(b),e[b].related&&(E=E.concat(e[b].related)));E=RegExp("\\.("+E.join("|")+")(\\?.*)?$","i")}b=d?d.toLowerCase().match(E):null;!b||!b.length?a&&(d=a.indexOf(";"),b=(-1!==d?a.substr(0,d):a).substr(6)):b=b[1];b&&"undefined"!==typeof c.html5[b]?d=c.html5[b]&&!aa(b):(a="audio/"+b,d=c.html5.canPlayType({type:a}),d=(c.html5[b]=
+d)&&c.html5[a]&&!aa(a));return d};Va=function(){function a(a){var b,e,f=b=!1;if(!d||"function"!==typeof d.canPlayType)return b;if(a instanceof Array){for(b=0,e=a.length;b<e;b++)if(c.html5[a[b]]||d.canPlayType(a[b]).match(c.html5Test))f=!0,c.html5[a[b]]=!0,c.flash[a[b]]=!!a[b].match(ab);b=f}else a=d&&"function"===typeof d.canPlayType?d.canPlayType(a):!1,b=!(!a||!a.match(c.html5Test));return b}if(!c.useHTML5Audio||!c.hasHTML5)return!1;var d="undefined"!==typeof Audio?qa&&10>opera.version()?new Audio(null):
+new Audio:null,e,b,g={},f;f=c.audioFormats;for(e in f)if(f.hasOwnProperty(e)&&(b="audio/"+e,g[e]=a(f[e].type),g[b]=g[e],e.match(ab)?(c.flash[e]=!0,c.flash[b]=!0):(c.flash[e]=!1,c.flash[b]=!1),f[e]&&f[e].related))for(b=f[e].related.length-1;0<=b;b--)g["audio/"+f[e].related[b]]=g[e],c.html5[f[e].related[b]]=g[e],c.flash[f[e].related[b]]=g[e];g.canPlayType=d?a:null;c.html5=w(c.html5,g);return!0};da={notReady:"Not loaded yet - wait for soundManager.onready()",notOK:"Audio support is not available.",domError:"soundManager::createMovie(): appendChild/innerHTML call failed. DOM not ready or other error.",
+spcWmode:"soundManager::createMovie(): Removing wmode, preventing known SWF loading issue(s)",swf404:"soundManager: Verify that %s is a valid path.",tryDebug:"Try soundManager.debugFlash = true for more security details (output goes to SWF.)",checkSWF:"See SWF output for more debug info.",localFail:"soundManager: Non-HTTP page ("+i.location.protocol+" URL?) Review Flash player security settings for this special case:\nhttp://www.macromedia.com/support/documentation/en/flashplayer/help/settings_manager04.html\nMay need to add/allow path, eg. c:/sm2/ or /users/me/sm2/",
+waitFocus:"soundManager: Special case: Waiting for SWF to load with window focus...",waitImpatient:"soundManager: Getting impatient, still waiting for Flash%s...",waitForever:"soundManager: Waiting indefinitely for Flash (will recover if unblocked)...",waitSWF:"soundManager: Retrying, waiting for 100% SWF load...",needFunction:"soundManager: Function object expected for %s",badID:'Warning: Sound ID "%s" should be a string, starting with a non-numeric character',currentObj:"--- soundManager._debug(): Current sound objects ---",
+waitEI:"soundManager::initMovie(): Waiting for ExternalInterface call from Flash...",waitOnload:"soundManager: Waiting for window.onload()",docLoaded:"soundManager: Document already loaded",onload:"soundManager::initComplete(): calling soundManager.onload()",onloadOK:"soundManager.onload() complete",init:"soundManager::init()",didInit:"soundManager::init(): Already called?",flashJS:"soundManager: Attempting JS to Flash call...",secNote:"Flash security note: Network/internet URLs will not load due to security restrictions. Access can be configured via Flash Player Global Security Settings Page: http://www.macromedia.com/support/documentation/en/flashplayer/help/settings_manager04.html",
+badRemove:"Warning: Failed to remove flash movie.",shutdown:"soundManager.disable(): Shutting down",queue:"soundManager: Queueing %s handler",smFail:"soundManager: Failed to initialise.",smError:"SMSound.load(): Exception: JS-Flash communication failed, or JS error.",fbTimeout:"No flash response, applying .swf_timedout CSS...",fbLoaded:"Flash loaded",fbHandler:"soundManager::flashBlockHandler()",manURL:"SMSound.load(): Using manually-assigned URL",onURL:"soundManager.load(): current URL already assigned.",
+badFV:'soundManager.flashVersion must be 8 or 9. "%s" is invalid. Reverting to %s.',as2loop:"Note: Setting stream:false so looping can work (flash 8 limitation)",noNSLoop:"Note: Looping not implemented for MovieStar formats",needfl9:"Note: Switching to flash 9, required for MP4 formats.",mfTimeout:"Setting flashLoadTimeout = 0 (infinite) for off-screen, mobile flash case",needFlash:"soundManager: Fatal error: Flash is needed to play some required formats, but is not available.",gotFocus:"soundManager: Got window focus.",
+mfOn:"mobileFlash::enabling on-screen flash repositioning",policy:"Enabling usePolicyFile for data access",setup:"soundManager.setup(): allowed parameters: %s",setupError:'soundManager.setup(): "%s" cannot be assigned with this method.',setupUndef:'soundManager.setup(): Could not find option "%s"',setupLate:"soundManager.setup(): url + flashVersion changes will not take effect until reboot().",h5a:"creating HTML5 Audio() object",noURL:"soundManager: Flash URL required. Call soundManager.setup({url:...}) to get started."};
+p=function(){var a=Wa.call(arguments),c=a.shift(),c=da&&da[c]?da[c]:"",e,b;if(c&&a&&a.length)for(e=0,b=a.length;e<b;e++)c=c.replace("%s",a[e]);return c};ia=function(a){if(8===j&&1<a.loops&&a.stream)n("as2loop"),a.stream=!1;return a};ja=function(a,d){if(a&&!a.usePolicyFile&&(a.onid3||a.usePeakData||a.useWaveformData||a.useEQData))c._wD((d||"")+p("policy")),a.usePolicyFile=!0;return a};O=function(a){"undefined"!==typeof console&&"undefined"!==typeof console.warn?console.warn(a):c._wD(a)};ra=function(){return!1};
+Oa=function(a){for(var c in a)a.hasOwnProperty(c)&&"function"===typeof a[c]&&(a[c]=ra)};ha=function(a){"undefined"===typeof a&&(a=!1);if(o||a)n("smFail",2),c.disable(a)};Pa=function(a){var d=null;if(a)if(a.match(/\.swf(\?.*)?$/i)){if(d=a.substr(a.toLowerCase().lastIndexOf(".swf?")+4))return a}else a.lastIndexOf("/")!==a.length-1&&(a+="/");a=(a&&-1!==a.lastIndexOf("/")?a.substr(0,a.lastIndexOf("/")+1):"./")+c.movieURL;c.noSWFCache&&(a+="?ts="+(new Date).getTime());return a};wa=function(){j=parseInt(c.flashVersion,
+10);if(8!==j&&9!==j)c._wD(p("badFV",j,8)),c.flashVersion=j=8;var a=c.debugMode||c.debugFlash?"_debug.swf":".swf";if(c.useHTML5Audio&&!c.html5Only&&c.audioFormats.mp4.required&&9>j)c._wD(p("needfl9")),c.flashVersion=j=9;c.version=c.versionNumber+(c.html5Only?" (HTML5-only mode)":9===j?" (AS3/Flash 9)":" (AS2/Flash 8)");8<j?(c.defaultOptions=w(c.defaultOptions,c.flash9Options),c.features.buffering=!0,c.defaultOptions=w(c.defaultOptions,c.movieStarOptions),c.filePatterns.flash9=RegExp("\\.(mp3|"+db.join("|")+
+")(\\?.*)?$","i"),c.features.movieStar=!0):c.features.movieStar=!1;c.filePattern=c.filePatterns[8!==j?"flash9":"flash8"];c.movieURL=(8===j?"soundmanager2.swf":"soundmanager2_flash9.swf").replace(".swf",a);c.features.peakData=c.features.waveformData=c.features.eqData=8<j};Na=function(a,c){if(!h)return!1;h._setPolling(a,c)};ya=function(){if(c.debugURLParam.test(Q))c.debugMode=!0;if(A(c.debugID))return!1;var a,d,e,b;if(c.debugMode&&!A(c.debugID)&&(!Za||!c.useConsole||!c.consoleOnly)){a=i.createElement("div");
+a.id=c.debugID+"-toggle";d={position:"fixed",bottom:"0px",right:"0px",width:"1.2em",height:"1.2em",lineHeight:"1.2em",margin:"2px",textAlign:"center",border:"1px solid #999",cursor:"pointer",background:"#fff",color:"#333",zIndex:10001};a.appendChild(i.createTextNode("-"));a.onclick=Qa;a.title="Toggle SM2 debug console";if(v.match(/msie 6/i))a.style.position="absolute",a.style.cursor="hand";for(b in d)d.hasOwnProperty(b)&&(a.style[b]=d[b]);d=i.createElement("div");d.id=c.debugID;d.style.display=c.debugMode?
+"block":"none";if(c.debugMode&&!A(a.id)){try{e=fa(),e.appendChild(a)}catch(g){throw Error(p("domError")+" \n"+g.toString());}e.appendChild(d)}}};t=this.getSoundById;n=function(a,d){return!a?"":c._wD(p(a),d)};if(Q.indexOf("sm2-debug=alert")+1&&c.debugMode)c._wD=function(a){Z.alert(a)};Qa=function(){var a=A(c.debugID),d=A(c.debugID+"-toggle");if(!a)return!1;ta?(d.innerHTML="+",a.style.display="none"):(d.innerHTML="-",a.style.display="block");ta=!ta};x=function(a,c,e){if("undefined"!==typeof sm2Debugger)try{sm2Debugger.handleEvent(a,
+c,e)}catch(b){}return!0};N=function(){var a=[];c.debugMode&&a.push("sm2_debug");c.debugFlash&&a.push("flash_debug");c.useHighPerformance&&a.push("high_performance");return a.join(" ")};Aa=function(){var a=p("fbHandler"),d=c.getMoviePercent(),e={type:"FLASHBLOCK"};if(c.html5Only)return!1;if(c.ok()){if(c.didFlashBlock&&c._wD(a+": Unblocked"),c.oMC)c.oMC.className=[N(),"movieContainer","swf_loaded"+(c.didFlashBlock?" swf_unblocked":"")].join(" ")}else{if(B)c.oMC.className=N()+" movieContainer "+(null===
+d?"swf_timedout":"swf_error"),c._wD(a+": "+p("fbTimeout")+(d?" ("+p("fbLoaded")+")":""));c.didFlashBlock=!0;I({type:"ontimeout",ignoreInit:!0,error:e});M(e)}};va=function(a,c,e){"undefined"===typeof D[a]&&(D[a]=[]);D[a].push({method:c,scope:e||null,fired:!1})};I=function(a){a||(a={type:c.ok()?"onready":"ontimeout"});if(!m&&a&&!a.ignoreInit||"ontimeout"===a.type&&(c.ok()||o&&!a.ignoreInit))return!1;var d={success:a&&a.ignoreInit?c.ok():!o},e=a&&a.type?D[a.type]||[]:[],b=[],g,f=[d],i=B&&c.useFlashBlock&&
+!c.ok();if(a.error)f[0].error=a.error;for(d=0,g=e.length;d<g;d++)!0!==e[d].fired&&b.push(e[d]);if(b.length){c._wD("soundManager: Firing "+b.length+" "+a.type+"() item"+(1===b.length?"":"s"));for(d=0,g=b.length;d<g;d++)if(b[d].scope?b[d].method.apply(b[d].scope,f):b[d].method.apply(this,f),!i)b[d].fired=!0}return!0};J=function(){k.setTimeout(function(){c.useFlashBlock&&Aa();I();"function"===typeof c.onload&&(n("onload",1),c.onload.apply(k),n("onloadOK",1));c.waitForWindowLoad&&u.add(k,"load",J)},1)};
+Ea=function(){if("undefined"!==typeof z)return z;var a=!1,c=navigator,e=c.plugins,b,g=k.ActiveXObject;if(e&&e.length)(c=c.mimeTypes)&&c["application/x-shockwave-flash"]&&c["application/x-shockwave-flash"].enabledPlugin&&c["application/x-shockwave-flash"].enabledPlugin.description&&(a=!0);else if("undefined"!==typeof g){try{b=new g("ShockwaveFlash.ShockwaveFlash")}catch(f){}a=!!b}return z=a};Ua=function(){var a,d,e=c.audioFormats;if(Fa&&v.match(/os (1|2|3_0|3_1)/i)){if(c.hasHTML5=!1,c.html5Only=!0,
+c.oMC)c.oMC.style.display="none"}else if(c.useHTML5Audio){if(!c.html5||!c.html5.canPlayType)c._wD("SoundManager: No HTML5 Audio() support detected."),c.hasHTML5=!1;Ia&&c._wD("soundManager::Note: Buggy HTML5 Audio in Safari on this OS X release, see https://bugs.webkit.org/show_bug.cgi?id=32159 - "+(!z?" would use flash fallback for MP3/MP4, but none detected.":"will use flash fallback for MP3/MP4, if available"),1)}if(c.useHTML5Audio&&c.hasHTML5)for(d in e)if(e.hasOwnProperty(d)&&(e[d].required&&
+!c.html5.canPlayType(e[d].type)||c.preferFlash&&(c.flash[d]||c.flash[e[d].type])))a=!0;c.ignoreFlash&&(a=!1);c.html5Only=c.hasHTML5&&c.useHTML5Audio&&!a;return!c.html5Only};la=function(a){var d,e,b=0;if(a instanceof Array){for(d=0,e=a.length;d<e;d++)if(a[d]instanceof Object){if(c.canPlayMIME(a[d].type)){b=d;break}}else if(c.canPlayURL(a[d])){b=d;break}if(a[b].url)a[b]=a[b].url;a=a[b]}return a};Ra=function(a){if(!a._hasTimer)a._hasTimer=!0,!Ha&&c.html5PollingInterval&&(null===X&&0===ka&&(X=k.setInterval(Ta,
+c.html5PollingInterval)),ka++)};Sa=function(a){if(a._hasTimer)a._hasTimer=!1,!Ha&&c.html5PollingInterval&&ka--};Ta=function(){var a;if(null!==X&&!ka)return k.clearInterval(X),X=null,!1;for(a=c.soundIDs.length-1;0<=a;a--)c.sounds[c.soundIDs[a]].isHTML5&&c.sounds[c.soundIDs[a]]._hasTimer&&c.sounds[c.soundIDs[a]]._onTimer()};M=function(a){a="undefined"!==typeof a?a:{};"function"===typeof c.onerror&&c.onerror.apply(k,[{type:"undefined"!==typeof a.type?a.type:null}]);"undefined"!==typeof a.fatal&&a.fatal&&
+c.disable()};Xa=function(){if(!Ia||!Ea())return!1;var a=c.audioFormats,d,e;for(e in a)if(a.hasOwnProperty(e)&&("mp3"===e||"mp4"===e))if(c._wD("soundManager: Using flash fallback for "+e+" format"),c.html5[e]=!1,a[e]&&a[e].related)for(d=a[e].related.length-1;0<=d;d--)c.html5[a[e].related[d]]=!1};this._setSandboxType=function(a){var d=c.sandbox;d.type=a;d.description=d.types["undefined"!==typeof d.types[a]?a:"unknown"];c._wD("Flash security sandbox type: "+d.type);if("localWithFile"===d.type)d.noRemote=
+!0,d.noLocal=!1,n("secNote",2);else if("localWithNetwork"===d.type)d.noRemote=!1,d.noLocal=!0;else if("localTrusted"===d.type)d.noRemote=!1,d.noLocal=!1};this._externalInterfaceOK=function(a,d){if(c.swfLoaded)return!1;var e,b=(new Date).getTime();c._wD("soundManager::externalInterfaceOK()"+(a?" (~"+(b-a)+" ms)":""));x("swf",!0);x("flashtojs",!0);c.swfLoaded=!0;na=!1;Ia&&Xa();if(!d||d.replace(/\+dev/i,"")!==c.versionNumber.replace(/\+dev/i,""))return e='soundManager: Fatal: JavaScript file build "'+
+c.versionNumber+'" does not match Flash SWF build "'+d+'" at '+c.url+". Ensure both are up-to-date.",setTimeout(function(){throw Error(e);},0),!1;setTimeout(sa,F?100:1)};ga=function(a,d){function e(){c._wD("-- SoundManager 2 "+c.version+(!c.html5Only&&c.useHTML5Audio?c.hasHTML5?" + HTML5 audio":", no HTML5 audio support":"")+(!c.html5Only?(c.useHighPerformance?", high performance mode, ":", ")+((c.flashPollingInterval?"custom ("+c.flashPollingInterval+"ms)":"normal")+" polling")+(c.wmode?", wmode: "+
+c.wmode:"")+(c.debugFlash?", flash debug mode":"")+(c.useFlashBlock?", flashBlock mode":""):"")+" --",1)}function b(a,b){return'<param name="'+a+'" value="'+b+'" />'}if(R&&S)return!1;if(c.html5Only)return wa(),e(),c.oMC=A(c.movieID),sa(),S=R=!0,!1;var g=d||c.url,f=c.altURL||g,h=fa(),l=N(),k=null,k=i.getElementsByTagName("html")[0],j,o,m,k=k&&k.dir&&k.dir.match(/rtl/i),a="undefined"===typeof a?c.id:a;wa();c.url=Pa(P?g:f);d=c.url;c.wmode=!c.wmode&&c.useHighPerformance?"transparent":c.wmode;if(null!==
+c.wmode&&(v.match(/msie 8/i)||!F&&!c.useHighPerformance)&&navigator.platform.match(/win32|win64/i))n("spcWmode"),c.wmode=null;h={name:a,id:a,src:d,quality:"high",allowScriptAccess:c.allowScriptAccess,bgcolor:c.bgColor,pluginspage:bb+"www.macromedia.com/go/getflashplayer",title:"JS/Flash audio component (SoundManager 2)",type:"application/x-shockwave-flash",wmode:c.wmode,hasPriority:"true"};if(c.debugFlash)h.FlashVars="debug=1";c.wmode||delete h.wmode;if(F)g=i.createElement("div"),o=['<object id="'+
+a+'" data="'+d+'" type="'+h.type+'" title="'+h.title+'" classid="clsid:D27CDB6E-AE6D-11cf-96B8-444553540000" codebase="'+bb+'download.macromedia.com/pub/shockwave/cabs/flash/swflash.cab#version=6,0,40,0">',b("movie",d),b("AllowScriptAccess",c.allowScriptAccess),b("quality",h.quality),c.wmode?b("wmode",c.wmode):"",b("bgcolor",c.bgColor),b("hasPriority","true"),c.debugFlash?b("FlashVars",h.FlashVars):"","</object>"].join("");else for(j in g=i.createElement("embed"),h)h.hasOwnProperty(j)&&g.setAttribute(j,
+h[j]);ya();l=N();if(h=fa())if(c.oMC=A(c.movieID)||i.createElement("div"),c.oMC.id){m=c.oMC.className;c.oMC.className=(m?m+" ":"movieContainer")+(l?" "+l:"");c.oMC.appendChild(g);if(F)j=c.oMC.appendChild(i.createElement("div")),j.className="sm2-object-box",j.innerHTML=o;S=!0}else{c.oMC.id=c.movieID;c.oMC.className="movieContainer "+l;j=l=null;if(!c.useFlashBlock)if(c.useHighPerformance)l={position:"fixed",width:"8px",height:"8px",bottom:"0px",left:"0px",overflow:"hidden"};else if(l={position:"absolute",
+width:"6px",height:"6px",top:"-9999px",left:"-9999px"},k)l.left=Math.abs(parseInt(l.left,10))+"px";if(gb)c.oMC.style.zIndex=1E4;if(!c.debugFlash)for(m in l)l.hasOwnProperty(m)&&(c.oMC.style[m]=l[m]);try{F||c.oMC.appendChild(g);h.appendChild(c.oMC);if(F)j=c.oMC.appendChild(i.createElement("div")),j.className="sm2-object-box",j.innerHTML=o;S=!0}catch(q){throw Error(p("domError")+" \n"+q.toString());}}R=!0;e();c._wD("soundManager::createMovie(): Trying to load "+d+(!P&&c.altURL?" (alternate URL)":""),
+1);return!0};ea=function(){if(c.html5Only)return ga(),!1;if(h)return!1;if(!c.url)return n("noURL"),!1;h=c.getMovie(c.id);if(!h)V?(F?c.oMC.innerHTML=za:c.oMC.appendChild(V),V=null,R=!0):ga(c.id,c.url),h=c.getMovie(c.id);h&&n("waitEI");"function"===typeof c.oninitmovie&&setTimeout(c.oninitmovie,1);return!0};K=function(){setTimeout(Ma,1E3)};Ma=function(){var a,d=!1;if(!c.url||W)return!1;W=!0;u.remove(k,"load",K);if(na&&!Ja)return n("waitFocus"),!1;m||(a=c.getMoviePercent(),c._wD(p("waitImpatient",0<
+a?" (SWF "+a+"% loaded)":"")),0<a&&100>a&&(d=!0));setTimeout(function(){a=c.getMoviePercent();if(d)return W=!1,c._wD(p("waitSWF")),k.setTimeout(K,1),!1;m||(c._wD("soundManager: No Flash response within expected time.\nLikely causes: "+(0===a?"Loading "+c.movieURL+" may have failed (and/or Flash "+j+"+ not present?), ":"")+"Flash blocked or JS-Flash security error."+(c.debugFlash?" "+p("checkSWF"):""),2),!P&&a&&(n("localFail",2),c.debugFlash||n("tryDebug",2)),0===a&&c._wD(p("swf404",c.url)),x("flashtojs",
+!1,": Timed out"+P?" (Check flash security or flash blockers)":" (No plugin/missing SWF?)"));!m&&$a&&(null===a?c.useFlashBlock||0===c.flashLoadTimeout?(c.useFlashBlock&&Aa(),n("waitForever")):ha(!0):0===c.flashLoadTimeout?n("waitForever"):ha(!0))},c.flashLoadTimeout)};ca=function(){if(Ja||!na)return u.remove(k,"focus",ca),!0;Ja=$a=!0;n("gotFocus");W=!1;K();u.remove(k,"focus",ca);return!0};Ya=function(){var a,d=[];if(c.useHTML5Audio&&c.hasHTML5){for(a in c.audioFormats)c.audioFormats.hasOwnProperty(a)&&
+d.push(a+": "+c.html5[a]+(!c.html5[a]&&z&&c.flash[a]?" (using flash)":c.preferFlash&&c.flash[a]&&z?" (preferring flash)":!c.html5[a]?" ("+(c.audioFormats[a].required?"required, ":"")+"and no flash support)":""));c._wD("-- SoundManager 2: HTML5 support tests ("+c.html5Test+"): "+d.join(", ")+" --",1)}};T=function(a){if(m)return!1;if(c.html5Only)return c._wD("-- SoundManager 2: loaded --"),m=!0,J(),x("onload",!0),!0;var d=!0,e;if(!c.useFlashBlock||!c.flashLoadTimeout||c.getMoviePercent())m=!0,o&&(e=
+{type:!z&&B?"NO_FLASH":"INIT_TIMEOUT"});c._wD("-- SoundManager 2 "+(o?"failed to load":"loaded")+" ("+(o?"Flash security/load error":"OK")+") --",1);if(o||a){if(c.useFlashBlock&&c.oMC)c.oMC.className=N()+" "+(null===c.getMoviePercent()?"swf_timedout":"swf_error");I({type:"ontimeout",error:e,ignoreInit:!0});x("onload",!1);M(e);d=!1}else x("onload",!0);o||(c.waitForWindowLoad&&!ba?(n("waitOnload"),u.add(k,"load",J)):(c.waitForWindowLoad&&ba&&n("docLoaded"),J()));return d};La=function(){var a,d=c.setupOptions;
+for(a in d)d.hasOwnProperty(a)&&("undefined"===typeof c[a]?c[a]=d[a]:c[a]!==d[a]&&(c.setupOptions[a]=c[a]))};sa=function(){n("init");if(m)return n("didInit"),!1;if(c.html5Only){if(!m)u.remove(k,"load",c.beginDelayedInit),c.enabled=!0,T();return!0}ea();try{n("flashJS"),h._externalInterfaceTest(!1),Na(!0,c.flashPollingInterval||(c.useHighPerformance?10:50)),c.debugMode||h._disableDebug(),c.enabled=!0,x("jstoflash",!0),c.html5Only||u.add(k,"unload",ra)}catch(a){return c._wD("js/flash exception: "+a.toString()),
+x("jstoflash",!1),M({type:"JS_TO_FLASH_EXCEPTION",fatal:!0}),ha(!0),T(),!1}T();u.remove(k,"load",c.beginDelayedInit);return!0};L=function(){if(U)return!1;U=!0;La();ya();var a=null,a=null,d="undefined"!==typeof console&&"function"===typeof console.log,e=Q.toLowerCase();-1!==e.indexOf("sm2-usehtml5audio=")&&(a="1"===e.charAt(e.indexOf("sm2-usehtml5audio=")+18),d&&console.log((a?"Enabling ":"Disabling ")+"useHTML5Audio via URL parameter"),c.setup({useHTML5Audio:a}));-1!==e.indexOf("sm2-preferflash=")&&
+(a="1"===e.charAt(e.indexOf("sm2-preferflash=")+16),d&&console.log((a?"Enabling ":"Disabling ")+"preferFlash via URL parameter"),c.setup({preferFlash:a}));!z&&c.hasHTML5&&(c._wD("SoundManager: No Flash detected"+(!c.useHTML5Audio?", enabling HTML5.":". Trying HTML5-only mode.")),c.setup({useHTML5Audio:!0,preferFlash:!1}));Va();c.html5.usingFlash=Ua();B=c.html5.usingFlash;Ya();!z&&B&&(n("needFlash"),c.setup({flashLoadTimeout:1}));i.removeEventListener&&i.removeEventListener("DOMContentLoaded",L,!1);
+ea();return!0};Da=function(){"complete"===i.readyState&&(L(),i.detachEvent("onreadystatechange",Da));return!0};xa=function(){ba=!0;u.remove(k,"load",xa)};Ea();u.add(k,"focus",ca);u.add(k,"load",K);u.add(k,"load",xa);i.addEventListener?i.addEventListener("DOMContentLoaded",L,!1):i.attachEvent?i.attachEvent("onreadystatechange",Da):(x("onload",!1),M({type:"NO_DOM2_EVENTS",fatal:!0}))}var oa=null;if("undefined"===typeof SM2_DEFER||!SM2_DEFER)oa=new $;Z.SoundManager=$;Z.soundManager=oa})(window);
\ No newline at end of file
diff --git a/timeside/player/static/timeside/js/libs/soundmanager2-nodebug-jsmin.js b/timeside/player/static/timeside/js/libs/soundmanager2-nodebug-jsmin.js
new file mode 100644 (file)
index 0000000..ca2fc0e
--- /dev/null
@@ -0,0 +1,80 @@
+/** @license\r
+ *\r
+ * SoundManager 2: JavaScript Sound for the Web\r
+ * ----------------------------------------------\r
+ * http://schillmania.com/projects/soundmanager2/\r
+ *\r
+ * Copyright (c) 2007, Scott Schiller. All rights reserved.\r
+ * Code provided under the BSD License:\r
+ * http://schillmania.com/projects/soundmanager2/license.txt\r
+ *\r
+ * V2.97a.20120916\r
+ */\r
+(function(fa){function R(R,ea){function S(a){return c.preferFlash&&y&&!c.ignoreFlash&&"undefined"!==typeof c.flash[a]&&c.flash[a]}function l(a){return function(c){var d=this._t;return!d||!d._a?null:a.call(this,c)}}this.setupOptions={url:R||null,flashVersion:8,debugMode:!0,debugFlash:!1,useConsole:!0,consoleOnly:!0,waitForWindowLoad:!1,bgColor:"#ffffff",useHighPerformance:!1,flashPollingInterval:null,html5PollingInterval:null,flashLoadTimeout:1E3,wmode:null,allowScriptAccess:"always",useFlashBlock:!1,
+useHTML5Audio:!0,html5Test:/^(probably|maybe)$/i,preferFlash:!0,noSWFCache:!1};this.defaultOptions={autoLoad:!1,autoPlay:!1,from:null,loops:1,onid3:null,onload:null,whileloading:null,onplay:null,onpause:null,onresume:null,whileplaying:null,onposition:null,onstop:null,onfailure:null,onfinish:null,multiShot:!0,multiShotEvents:!1,position:null,pan:0,stream:!0,to:null,type:null,usePolicyFile:!1,volume:100};this.flash9Options={isMovieStar:null,usePeakData:!1,useWaveformData:!1,useEQData:!1,onbufferchange:null,
+ondataerror:null};this.movieStarOptions={bufferTime:3,serverURL:null,onconnect:null,duration:null};this.audioFormats={mp3:{type:['audio/mpeg; codecs="mp3"',"audio/mpeg","audio/mp3","audio/MPA","audio/mpa-robust"],required:!0},mp4:{related:["aac","m4a","m4b"],type:['audio/mp4; codecs="mp4a.40.2"',"audio/aac","audio/x-m4a","audio/MP4A-LATM","audio/mpeg4-generic"],required:!1},ogg:{type:["audio/ogg; codecs=vorbis"],required:!1},wav:{type:['audio/wav; codecs="1"',"audio/wav","audio/wave","audio/x-wav"],
+required:!1}};this.movieID="sm2-container";this.id=ea||"sm2movie";this.debugID="soundmanager-debug";this.debugURLParam=/([#?&])debug=1/i;this.versionNumber="V2.97a.20120916";this.altURL=this.movieURL=this.version=null;this.enabled=this.swfLoaded=!1;this.oMC=null;this.sounds={};this.soundIDs=[];this.didFlashBlock=this.muted=!1;this.filePattern=null;this.filePatterns={flash8:/\.mp3(\?.*)?$/i,flash9:/\.mp3(\?.*)?$/i};this.features={buffering:!1,peakData:!1,waveformData:!1,eqData:!1,movieStar:!1};this.sandbox=
+{};var ga;try{ga="undefined"!==typeof Audio&&"undefined"!==typeof(ha&&10>opera.version()?new Audio(null):new Audio).canPlayType}catch(Za){ga=!1}this.hasHTML5=ga;this.html5={usingFlash:null};this.flash={};this.ignoreFlash=this.html5Only=!1;var Da,c=this,i=null,T,q=navigator.userAgent,h=fa,ia=h.location.href.toString(),m=document,ja,Ea,ka,j,v=[],J=!1,K=!1,k=!1,s=!1,la=!1,L,r,ma,U,na,B,C,D,Fa,oa,V,W,E,pa,M,qa,X,F,Ga,ra,Ha,Y,Ia,N=null,sa=null,t,ta,G,Z,$,H,p,O=!1,ua=!1,Ja,Ka,La,aa=0,P=null,ba,n=null,Ma,
+ca,Q,w,va,wa,Na,o,Wa=Array.prototype.slice,z=!1,y,xa,Oa,u,Pa,ya=q.match(/(ipad|iphone|ipod)/i),x=q.match(/msie/i),Xa=q.match(/webkit/i),za=q.match(/safari/i)&&!q.match(/chrome/i),ha=q.match(/opera/i),Aa=q.match(/(mobile|pre\/|xoom)/i)||ya,Qa=!ia.match(/usehtml5audio/i)&&!ia.match(/sm2\-ignorebadua/i)&&za&&!q.match(/silk/i)&&q.match(/OS X 10_6_([3-7])/i),Ba="undefined"!==typeof m.hasFocus?m.hasFocus():null,da=za&&("undefined"===typeof m.hasFocus||!m.hasFocus()),Ra=!da,Sa=/(mp3|mp4|mpa|m4a|m4b)/i,Ca=
+m.location?m.location.protocol.match(/http/i):null,Ta=!Ca?"http://":"",Ua=/^\s*audio\/(?:x-)?(?:mpeg4|aac|flv|mov|mp4||m4v|m4a|m4b|mp4v|3gp|3g2)\s*(?:$|;)/i,Va="mpeg4,aac,flv,mov,mp4,m4v,f4v,m4a,m4b,mp4v,3gp,3g2".split(","),Ya=RegExp("\\.("+Va.join("|")+")(\\?.*)?$","i");this.mimePattern=/^\s*audio\/(?:x-)?(?:mp(?:eg|3))\s*(?:$|;)/i;this.useAltURL=!Ca;this._global_a=null;if(Aa&&(c.useHTML5Audio=!0,c.preferFlash=!1,ya))z=c.ignoreFlash=!0;this.setup=function(a){var e=!c.url;"undefined"!==typeof a&&
+k&&n&&c.ok()&&("undefined"!==typeof a.flashVersion||"undefined"!==typeof a.url)&&H(t("setupLate"));ma(a);e&&M&&"undefined"!==typeof a.url&&c.beginDelayedInit();!M&&"undefined"!==typeof a.url&&"complete"===m.readyState&&setTimeout(E,1);return c};this.supported=this.ok=function(){return n?k&&!s:c.useHTML5Audio&&c.hasHTML5};this.getMovie=function(a){return T(a)||m[a]||h[a]};this.createSound=function(a,e){function d(){b=Z(b);c.sounds[f.id]=new Da(f);c.soundIDs.push(f.id);return c.sounds[f.id]}var b=null,
+g=null,f=null;if(!k||!c.ok())return H(void 0),!1;"undefined"!==typeof e&&(a={id:a,url:e});b=r(a);b.url=ba(b.url);f=b;if(p(f.id,!0))return c.sounds[f.id];if(ca(f))g=d(),g._setup_html5(f);else{if(8<j&&null===f.isMovieStar)f.isMovieStar=!(!f.serverURL&&!(f.type&&f.type.match(Ua)||f.url.match(Ya)));f=$(f,void 0);g=d();if(8===j)i._createSound(f.id,f.loops||1,f.usePolicyFile);else if(i._createSound(f.id,f.url,f.usePeakData,f.useWaveformData,f.useEQData,f.isMovieStar,f.isMovieStar?f.bufferTime:!1,f.loops||
+1,f.serverURL,f.duration||null,f.autoPlay,!0,f.autoLoad,f.usePolicyFile),!f.serverURL)g.connected=!0,f.onconnect&&f.onconnect.apply(g);!f.serverURL&&(f.autoLoad||f.autoPlay)&&g.load(f)}!f.serverURL&&f.autoPlay&&g.play();return g};this.destroySound=function(a,e){if(!p(a))return!1;var d=c.sounds[a],b;d._iO={};d.stop();d.unload();for(b=0;b<c.soundIDs.length;b++)if(c.soundIDs[b]===a){c.soundIDs.splice(b,1);break}e||d.destruct(!0);delete c.sounds[a];return!0};this.load=function(a,e){return!p(a)?!1:c.sounds[a].load(e)};
+this.unload=function(a){return!p(a)?!1:c.sounds[a].unload()};this.onposition=this.onPosition=function(a,e,d,b){return!p(a)?!1:c.sounds[a].onposition(e,d,b)};this.clearOnPosition=function(a,e,d){return!p(a)?!1:c.sounds[a].clearOnPosition(e,d)};this.start=this.play=function(a,e){var d=!1;if(!k||!c.ok())return H("soundManager.play(): "+t(!k?"notReady":"notOK")),d;if(!p(a)){e instanceof Object||(e={url:e});if(e&&e.url)e.id=a,d=c.createSound(e).play();return d}return c.sounds[a].play(e)};this.setPosition=
+function(a,e){return!p(a)?!1:c.sounds[a].setPosition(e)};this.stop=function(a){return!p(a)?!1:c.sounds[a].stop()};this.stopAll=function(){for(var a in c.sounds)c.sounds.hasOwnProperty(a)&&c.sounds[a].stop()};this.pause=function(a){return!p(a)?!1:c.sounds[a].pause()};this.pauseAll=function(){var a;for(a=c.soundIDs.length-1;0<=a;a--)c.sounds[c.soundIDs[a]].pause()};this.resume=function(a){return!p(a)?!1:c.sounds[a].resume()};this.resumeAll=function(){var a;for(a=c.soundIDs.length-1;0<=a;a--)c.sounds[c.soundIDs[a]].resume()};
+this.togglePause=function(a){return!p(a)?!1:c.sounds[a].togglePause()};this.setPan=function(a,e){return!p(a)?!1:c.sounds[a].setPan(e)};this.setVolume=function(a,e){return!p(a)?!1:c.sounds[a].setVolume(e)};this.mute=function(a){var e=0;"string"!==typeof a&&(a=null);if(a)return!p(a)?!1:c.sounds[a].mute();for(e=c.soundIDs.length-1;0<=e;e--)c.sounds[c.soundIDs[e]].mute();return c.muted=!0};this.muteAll=function(){c.mute()};this.unmute=function(a){"string"!==typeof a&&(a=null);if(a)return!p(a)?!1:c.sounds[a].unmute();
+for(a=c.soundIDs.length-1;0<=a;a--)c.sounds[c.soundIDs[a]].unmute();c.muted=!1;return!0};this.unmuteAll=function(){c.unmute()};this.toggleMute=function(a){return!p(a)?!1:c.sounds[a].toggleMute()};this.getMemoryUse=function(){var a=0;i&&8!==j&&(a=parseInt(i._getMemoryUse(),10));return a};this.disable=function(a){var e;"undefined"===typeof a&&(a=!1);if(s)return!1;s=!0;for(e=c.soundIDs.length-1;0<=e;e--)Ha(c.sounds[c.soundIDs[e]]);L(a);o.remove(h,"load",C);return!0};this.canPlayMIME=function(a){var e;
+c.hasHTML5&&(e=Q({type:a}));!e&&n&&(e=a&&c.ok()?!!(8<j&&a.match(Ua)||a.match(c.mimePattern)):null);return e};this.canPlayURL=function(a){var e;c.hasHTML5&&(e=Q({url:a}));!e&&n&&(e=a&&c.ok()?!!a.match(c.filePattern):null);return e};this.canPlayLink=function(a){return"undefined"!==typeof a.type&&a.type&&c.canPlayMIME(a.type)?!0:c.canPlayURL(a.href)};this.getSoundById=function(a){if(!a)throw Error("soundManager.getSoundById(): sID is null/undefined");return c.sounds[a]};this.onready=function(a,c){var d=
+!1;if("function"===typeof a)c||(c=h),na("onready",a,c),B();else throw t("needFunction","onready");return!0};this.ontimeout=function(a,c){var d=!1;if("function"===typeof a)c||(c=h),na("ontimeout",a,c),B({type:"ontimeout"});else throw t("needFunction","ontimeout");return!0};this._wD=this._writeDebug=function(){return!0};this._debug=function(){};this.reboot=function(){var a,e;for(a=c.soundIDs.length-1;0<=a;a--)c.sounds[c.soundIDs[a]].destruct();if(i)try{if(x)sa=i.innerHTML;N=i.parentNode.removeChild(i)}catch(d){}sa=
+N=n=null;c.enabled=M=k=O=ua=J=K=s=c.swfLoaded=!1;c.soundIDs=[];c.sounds={};i=null;for(a in v)if(v.hasOwnProperty(a))for(e=v[a].length-1;0<=e;e--)v[a][e].fired=!1;h.setTimeout(c.beginDelayedInit,20)};this.getMoviePercent=function(){return i&&"undefined"!==typeof i.PercentLoaded?i.PercentLoaded():null};this.beginDelayedInit=function(){la=!0;E();setTimeout(function(){if(ua)return!1;X();W();return ua=!0},20);D()};this.destruct=function(){c.disable(!0)};Da=function(a){var e,d,b=this,g,f,A,I,h,m,l=!1,k=
+[],o=0,q,s,n=null;e=null;d=null;this.sID=this.id=a.id;this.url=a.url;this._iO=this.instanceOptions=this.options=r(a);this.pan=this.options.pan;this.volume=this.options.volume;this.isHTML5=!1;this._a=null;this.id3={};this._debug=function(){};this.load=function(a){var c=null;if("undefined"!==typeof a)b._iO=r(a,b.options),b.instanceOptions=b._iO;else if(a=b.options,b._iO=a,b.instanceOptions=b._iO,n&&n!==b.url)b._iO.url=b.url,b.url=null;if(!b._iO.url)b._iO.url=b.url;b._iO.url=ba(b._iO.url);if(b._iO.url===
+b.url&&0!==b.readyState&&2!==b.readyState)return 3===b.readyState&&b._iO.onload&&b._iO.onload.apply(b,[!!b.duration]),b;a=b._iO;n=b.url&&b.url.toString?b.url.toString():null;b.loaded=!1;b.readyState=1;b.playState=0;b.id3={};if(ca(a)){if(c=b._setup_html5(a),!c._called_load){b._html5_canplay=!1;if(b._a.src!==a.url)b._a.src=a.url,b.setPosition(0);b._a.autobuffer="auto";b._a.preload="auto";c._called_load=!0;a.autoPlay&&b.play()}}else try{b.isHTML5=!1,b._iO=$(Z(a)),a=b._iO,8===j?i._load(b.id,a.url,a.stream,
+a.autoPlay,a.whileloading?1:0,a.loops||1,a.usePolicyFile):i._load(b.id,a.url,!!a.stream,!!a.autoPlay,a.loops||1,!!a.autoLoad,a.usePolicyFile)}catch(e){F({type:"SMSOUND_LOAD_JS_EXCEPTION",fatal:!0})}b.url=a.url;return b};this.unload=function(){if(0!==b.readyState){if(b.isHTML5){if(I(),b._a)b._a.pause(),va(b._a,"about:blank"),b.url="about:blank"}else 8===j?i._unload(b.id,"about:blank"):i._unload(b.id);g()}return b};this.destruct=function(a){if(b.isHTML5){if(I(),b._a)b._a.pause(),va(b._a),z||A(),b._a._t=
+null,b._a=null}else b._iO.onfailure=null,i._destroySound(b.id);a||c.destroySound(b.id,!0)};this.start=this.play=function(a,c){var e,d;d=!0;d=null;c="undefined"===typeof c?!0:c;a||(a={});if(b.url)b._iO.url=b.url;b._iO=r(b._iO,b.options);b._iO=r(a,b._iO);b._iO.url=ba(b._iO.url);b.instanceOptions=b._iO;if(b._iO.serverURL&&!b.connected)return b.getAutoPlay()||b.setAutoPlay(!0),b;ca(b._iO)&&(b._setup_html5(b._iO),h());if(1===b.playState&&!b.paused)(e=b._iO.multiShot)||(d=b);if(null!==d)return d;a.url&&
+a.url!==b.url&&b.load(b._iO);if(!b.loaded)if(0===b.readyState){if(!b.isHTML5)b._iO.autoPlay=!0;b.load(b._iO)}else 2===b.readyState&&(d=b);if(null!==d)return d;if(!b.isHTML5&&9===j&&0<b.position&&b.position===b.duration)a.position=0;if(b.paused&&0<=b.position&&(!b._iO.serverURL||0<b.position))b.resume();else{b._iO=r(a,b._iO);if(null!==b._iO.from&&null!==b._iO.to&&0===b.instanceCount&&0===b.playState&&!b._iO.serverURL){e=function(){b._iO=r(a,b._iO);b.play(b._iO)};if(b.isHTML5&&!b._html5_canplay)b.load({_oncanplay:e}),
+d=!1;else if(!b.isHTML5&&!b.loaded&&(!b.readyState||2!==b.readyState))b.load({onload:e}),d=!1;if(null!==d)return d;b._iO=s()}(!b.instanceCount||b._iO.multiShotEvents||!b.isHTML5&&8<j&&!b.getAutoPlay())&&b.instanceCount++;b._iO.onposition&&0===b.playState&&m(b);b.playState=1;b.paused=!1;b.position="undefined"!==typeof b._iO.position&&!isNaN(b._iO.position)?b._iO.position:0;if(!b.isHTML5)b._iO=$(Z(b._iO));b._iO.onplay&&c&&(b._iO.onplay.apply(b),l=!0);b.setVolume(b._iO.volume,!0);b.setPan(b._iO.pan,
+!0);b.isHTML5?(h(),d=b._setup_html5(),b.setPosition(b._iO.position),d.play()):(d=i._start(b.id,b._iO.loops||1,9===j?b._iO.position:b._iO.position/1E3,b._iO.multiShot),9===j&&!d&&b._iO.onplayerror&&b._iO.onplayerror.apply(b))}return b};this.stop=function(a){var c=b._iO;if(1===b.playState){b._onbufferchange(0);b._resetOnPosition(0);b.paused=!1;if(!b.isHTML5)b.playState=0;q();c.to&&b.clearOnPosition(c.to);if(b.isHTML5){if(b._a)a=b.position,b.setPosition(0),b.position=a,b._a.pause(),b.playState=0,b._onTimer(),
+I()}else i._stop(b.id,a),c.serverURL&&b.unload();b.instanceCount=0;b._iO={};c.onstop&&c.onstop.apply(b)}return b};this.setAutoPlay=function(a){b._iO.autoPlay=a;b.isHTML5||(i._setAutoPlay(b.id,a),a&&!b.instanceCount&&1===b.readyState&&b.instanceCount++)};this.getAutoPlay=function(){return b._iO.autoPlay};this.setPosition=function(a){"undefined"===typeof a&&(a=0);var c=b.isHTML5?Math.max(a,0):Math.min(b.duration||b._iO.duration,Math.max(a,0));b.position=c;a=b.position/1E3;b._resetOnPosition(b.position);
+b._iO.position=c;if(b.isHTML5){if(b._a&&b._html5_canplay&&b._a.currentTime!==a)try{b._a.currentTime=a,(0===b.playState||b.paused)&&b._a.pause()}catch(e){}}else a=9===j?b.position:a,b.readyState&&2!==b.readyState&&i._setPosition(b.id,a,b.paused||!b.playState,b._iO.multiShot);b.isHTML5&&b.paused&&b._onTimer(!0);return b};this.pause=function(a){if(b.paused||0===b.playState&&1!==b.readyState)return b;b.paused=!0;b.isHTML5?(b._setup_html5().pause(),I()):(a||"undefined"===typeof a)&&i._pause(b.id,b._iO.multiShot);
+b._iO.onpause&&b._iO.onpause.apply(b);return b};this.resume=function(){var a=b._iO;if(!b.paused)return b;b.paused=!1;b.playState=1;b.isHTML5?(b._setup_html5().play(),h()):(a.isMovieStar&&!a.serverURL&&b.setPosition(b.position),i._pause(b.id,a.multiShot));!l&&a.onplay?(a.onplay.apply(b),l=!0):a.onresume&&a.onresume.apply(b);return b};this.togglePause=function(){if(0===b.playState)return b.play({position:9===j&&!b.isHTML5?b.position:b.position/1E3}),b;b.paused?b.resume():b.pause();return b};this.setPan=
+function(a,c){"undefined"===typeof a&&(a=0);"undefined"===typeof c&&(c=!1);b.isHTML5||i._setPan(b.id,a);b._iO.pan=a;if(!c)b.pan=a,b.options.pan=a;return b};this.setVolume=function(a,e){"undefined"===typeof a&&(a=100);"undefined"===typeof e&&(e=!1);if(b.isHTML5){if(b._a)b._a.volume=Math.max(0,Math.min(1,a/100))}else i._setVolume(b.id,c.muted&&!b.muted||b.muted?0:a);b._iO.volume=a;if(!e)b.volume=a,b.options.volume=a;return b};this.mute=function(){b.muted=!0;if(b.isHTML5){if(b._a)b._a.muted=!0}else i._setVolume(b.id,
+0);return b};this.unmute=function(){b.muted=!1;var a="undefined"!==typeof b._iO.volume;if(b.isHTML5){if(b._a)b._a.muted=!1}else i._setVolume(b.id,a?b._iO.volume:b.options.volume);return b};this.toggleMute=function(){return b.muted?b.unmute():b.mute()};this.onposition=this.onPosition=function(a,c,e){k.push({position:parseInt(a,10),method:c,scope:"undefined"!==typeof e?e:b,fired:!1});return b};this.clearOnPosition=function(b,a){var c,b=parseInt(b,10);if(isNaN(b))return!1;for(c=0;c<k.length;c++)if(b===
+k[c].position&&(!a||a===k[c].method))k[c].fired&&o--,k.splice(c,1)};this._processOnPosition=function(){var a,c;a=k.length;if(!a||!b.playState||o>=a)return!1;for(a-=1;0<=a;a--)if(c=k[a],!c.fired&&b.position>=c.position)c.fired=!0,o++,c.method.apply(c.scope,[c.position]);return!0};this._resetOnPosition=function(b){var a,c;a=k.length;if(!a)return!1;for(a-=1;0<=a;a--)if(c=k[a],c.fired&&b<=c.position)c.fired=!1,o--;return!0};s=function(){var a=b._iO,c=a.from,e=a.to,d,f;f=function(){b.clearOnPosition(e,
+f);b.stop()};d=function(){if(null!==e&&!isNaN(e))b.onPosition(e,f)};if(null!==c&&!isNaN(c))a.position=c,a.multiShot=!1,d();return a};m=function(){var a,c=b._iO.onposition;if(c)for(a in c)if(c.hasOwnProperty(a))b.onPosition(parseInt(a,10),c[a])};q=function(){var a,c=b._iO.onposition;if(c)for(a in c)c.hasOwnProperty(a)&&b.clearOnPosition(parseInt(a,10))};h=function(){b.isHTML5&&Ja(b)};I=function(){b.isHTML5&&Ka(b)};g=function(a){a||(k=[],o=0);l=!1;b._hasTimer=null;b._a=null;b._html5_canplay=!1;b.bytesLoaded=
+null;b.bytesTotal=null;b.duration=b._iO&&b._iO.duration?b._iO.duration:null;b.durationEstimate=null;b.buffered=[];b.eqData=[];b.eqData.left=[];b.eqData.right=[];b.failures=0;b.isBuffering=!1;b.instanceOptions={};b.instanceCount=0;b.loaded=!1;b.metadata={};b.readyState=0;b.muted=!1;b.paused=!1;b.peakData={left:0,right:0};b.waveformData={left:[],right:[]};b.playState=0;b.position=null;b.id3={}};g();this._onTimer=function(a){var c,f=!1,g={};if(b._hasTimer||a){if(b._a&&(a||(0<b.playState||1===b.readyState)&&
+!b.paused)){c=b._get_html5_duration();if(c!==e)e=c,b.duration=c,f=!0;b.durationEstimate=b.duration;c=1E3*b._a.currentTime||0;c!==d&&(d=c,f=!0);(f||a)&&b._whileplaying(c,g,g,g,g)}return f}};this._get_html5_duration=function(){var a=b._iO;return(a=b._a&&b._a.duration?1E3*b._a.duration:a&&a.duration?a.duration:null)&&!isNaN(a)&&Infinity!==a?a:null};this._apply_loop=function(b,a){b.loop=1<a?"loop":""};this._setup_html5=function(a){var a=r(b._iO,a),e=decodeURI,d=z?c._global_a:b._a,i=e(a.url),h=d&&d._t?
+d._t.instanceOptions:null,A;if(d){if(d._t){if(!z&&i===e(n))A=d;else if(z&&h.url===a.url&&(!n||n===h.url))A=d;if(A)return b._apply_loop(d,a.loops),A}z&&d._t&&d._t.playState&&a.url!==h.url&&d._t.stop();g(h&&h.url?a.url===h.url:n?n===a.url:!1);d.src=a.url;n=b.url=a.url;d._called_load=!1}else if(b._a=a.autoLoad||a.autoPlay?new Audio(a.url):ha&&10>opera.version()?new Audio(null):new Audio,d=b._a,d._called_load=!1,z)c._global_a=d;b.isHTML5=!0;b._a=d;d._t=b;f();b._apply_loop(d,a.loops);a.autoLoad||a.autoPlay?
+b.load():(d.autobuffer=!1,d.preload="auto");return d};f=function(){if(b._a._added_events)return!1;var a;b._a._added_events=!0;for(a in u)u.hasOwnProperty(a)&&b._a&&b._a.addEventListener(a,u[a],!1);return!0};A=function(){var a;b._a._added_events=!1;for(a in u)u.hasOwnProperty(a)&&b._a&&b._a.removeEventListener(a,u[a],!1)};this._onload=function(a){a=!!a||!b.isHTML5&&8===j&&b.duration;b.loaded=a;b.readyState=a?3:2;b._onbufferchange(0);b._iO.onload&&b._iO.onload.apply(b,[a]);return!0};this._onbufferchange=
+function(a){if(0===b.playState||a&&b.isBuffering||!a&&!b.isBuffering)return!1;b.isBuffering=1===a;b._iO.onbufferchange&&b._iO.onbufferchange.apply(b);return!0};this._onsuspend=function(){b._iO.onsuspend&&b._iO.onsuspend.apply(b);return!0};this._onfailure=function(a,c,e){b.failures++;if(b._iO.onfailure&&1===b.failures)b._iO.onfailure(b,a,c,e)};this._onfinish=function(){var a=b._iO.onfinish;b._onbufferchange(0);b._resetOnPosition(0);if(b.instanceCount){b.instanceCount--;if(!b.instanceCount&&(q(),b.playState=
+0,b.paused=!1,b.instanceCount=0,b.instanceOptions={},b._iO={},I(),b.isHTML5))b.position=0;(!b.instanceCount||b._iO.multiShotEvents)&&a&&a.apply(b)}};this._whileloading=function(a,c,e,d){var f=b._iO;b.bytesLoaded=a;b.bytesTotal=c;b.duration=Math.floor(e);b.bufferLength=d;b.durationEstimate=!b.isHTML5&&!f.isMovieStar?f.duration?b.duration>f.duration?b.duration:f.duration:parseInt(b.bytesTotal/b.bytesLoaded*b.duration,10):b.duration;if(!b.isHTML5)b.buffered=[{start:0,end:b.duration}];(3!==b.readyState||
+b.isHTML5)&&f.whileloading&&f.whileloading.apply(b)};this._whileplaying=function(a,c,e,d,f){var g=b._iO;if(isNaN(a)||null===a)return!1;b.position=Math.max(0,a);b._processOnPosition();if(!b.isHTML5&&8<j){if(g.usePeakData&&"undefined"!==typeof c&&c)b.peakData={left:c.leftPeak,right:c.rightPeak};if(g.useWaveformData&&"undefined"!==typeof e&&e)b.waveformData={left:e.split(","),right:d.split(",")};if(g.useEQData&&"undefined"!==typeof f&&f&&f.leftEQ&&(a=f.leftEQ.split(","),b.eqData=a,b.eqData.left=a,"undefined"!==
+typeof f.rightEQ&&f.rightEQ))b.eqData.right=f.rightEQ.split(",")}1===b.playState&&(!b.isHTML5&&8===j&&!b.position&&b.isBuffering&&b._onbufferchange(0),g.whileplaying&&g.whileplaying.apply(b));return!0};this._oncaptiondata=function(a){b.captiondata=a;b._iO.oncaptiondata&&b._iO.oncaptiondata.apply(b,[a])};this._onmetadata=function(a,c){var e={},d,f;for(d=0,f=a.length;d<f;d++)e[a[d]]=c[d];b.metadata=e;b._iO.onmetadata&&b._iO.onmetadata.apply(b)};this._onid3=function(a,c){var e=[],d,f;for(d=0,f=a.length;d<
+f;d++)e[a[d]]=c[d];b.id3=r(b.id3,e);b._iO.onid3&&b._iO.onid3.apply(b)};this._onconnect=function(a){a=1===a;if(b.connected=a)b.failures=0,p(b.id)&&(b.getAutoPlay()?b.play(void 0,b.getAutoPlay()):b._iO.autoLoad&&b.load()),b._iO.onconnect&&b._iO.onconnect.apply(b,[a])};this._ondataerror=function(){0<b.playState&&b._iO.ondataerror&&b._iO.ondataerror.apply(b)}};qa=function(){return m.body||m._docElement||m.getElementsByTagName("div")[0]};T=function(a){return m.getElementById(a)};r=function(a,e){var d=
+a||{},b,g;b="undefined"===typeof e?c.defaultOptions:e;for(g in b)b.hasOwnProperty(g)&&"undefined"===typeof d[g]&&(d[g]="object"!==typeof b[g]||null===b[g]?b[g]:r(d[g],b[g]));return d};U={onready:1,ontimeout:1,defaultOptions:1,flash9Options:1,movieStarOptions:1};ma=function(a,e){var d,b=!0,g="undefined"!==typeof e,f=c.setupOptions;for(d in a)if(a.hasOwnProperty(d))if("object"!==typeof a[d]||null===a[d]||a[d]instanceof Array)g&&"undefined"!==typeof U[e]?c[e][d]=a[d]:"undefined"!==typeof f[d]?(c.setupOptions[d]=
+a[d],c[d]=a[d]):"undefined"===typeof U[d]?(H(t("undefined"===typeof c[d]?"setupUndef":"setupError",d),2),b=!1):c[d]instanceof Function?c[d].apply(c,a[d]instanceof Array?a[d]:[a[d]]):c[d]=a[d];else if("undefined"===typeof U[d])H(t("undefined"===typeof c[d]?"setupUndef":"setupError",d),2),b=!1;else return ma(a[d],d);return b};o=function(){function a(a){var a=Wa.call(a),b=a.length;d?(a[1]="on"+a[1],3<b&&a.pop()):3===b&&a.push(!1);return a}function c(a,e){var h=a.shift(),i=[b[e]];if(d)h[i](a[0],a[1]);
+else h[i].apply(h,a)}var d=h.attachEvent,b={add:d?"attachEvent":"addEventListener",remove:d?"detachEvent":"removeEventListener"};return{add:function(){c(a(arguments),"add")},remove:function(){c(a(arguments),"remove")}}}();u={abort:l(function(){}),canplay:l(function(){var a=this._t,c;if(a._html5_canplay)return!0;a._html5_canplay=!0;a._onbufferchange(0);c="undefined"!==typeof a._iO.position&&!isNaN(a._iO.position)?a._iO.position/1E3:null;if(a.position&&this.currentTime!==c)try{this.currentTime=c}catch(d){}a._iO._oncanplay&&
+a._iO._oncanplay()}),canplaythrough:l(function(){var a=this._t;a.loaded||(a._onbufferchange(0),a._whileloading(a.bytesLoaded,a.bytesTotal,a._get_html5_duration()),a._onload(!0))}),ended:l(function(){this._t._onfinish()}),error:l(function(){this._t._onload(!1)}),loadeddata:l(function(){var a=this._t;if(!a._loaded&&!za)a.duration=a._get_html5_duration()}),loadedmetadata:l(function(){}),loadstart:l(function(){this._t._onbufferchange(1)}),play:l(function(){this._t._onbufferchange(0)}),playing:l(function(){this._t._onbufferchange(0)}),
+progress:l(function(a){var c=this._t,d,b,g=0,g=a.target.buffered;d=a.loaded||0;var f=a.total||1;c.buffered=[];if(g&&g.length){for(d=0,b=g.length;d<b;d++)c.buffered.push({start:1E3*g.start(d),end:1E3*g.end(d)});g=1E3*(g.end(0)-g.start(0));d=g/(1E3*a.target.duration)}isNaN(d)||(c._onbufferchange(0),c._whileloading(d,f,c._get_html5_duration()),d&&f&&d===f&&u.canplaythrough.call(this,a))}),ratechange:l(function(){}),suspend:l(function(a){var c=this._t;u.progress.call(this,a);c._onsuspend()}),stalled:l(function(){}),
+timeupdate:l(function(){this._t._onTimer()}),waiting:l(function(){this._t._onbufferchange(1)})};ca=function(a){return a.serverURL||a.type&&S(a.type)?!1:a.type?Q({type:a.type}):Q({url:a.url})||c.html5Only};va=function(a,c){if(a)a.src=c};Q=function(a){if(!c.useHTML5Audio||!c.hasHTML5)return!1;var e=a.url||null,a=a.type||null,d=c.audioFormats,b;if(a&&"undefined"!==typeof c.html5[a])return c.html5[a]&&!S(a);if(!w){w=[];for(b in d)d.hasOwnProperty(b)&&(w.push(b),d[b].related&&(w=w.concat(d[b].related)));
+w=RegExp("\\.("+w.join("|")+")(\\?.*)?$","i")}b=e?e.toLowerCase().match(w):null;!b||!b.length?a&&(e=a.indexOf(";"),b=(-1!==e?a.substr(0,e):a).substr(6)):b=b[1];b&&"undefined"!==typeof c.html5[b]?e=c.html5[b]&&!S(b):(a="audio/"+b,e=c.html5.canPlayType({type:a}),e=(c.html5[b]=e)&&c.html5[a]&&!S(a));return e};Na=function(){function a(a){var b,d,f=b=!1;if(!e||"function"!==typeof e.canPlayType)return b;if(a instanceof Array){for(b=0,d=a.length;b<d;b++)if(c.html5[a[b]]||e.canPlayType(a[b]).match(c.html5Test))f=
+!0,c.html5[a[b]]=!0,c.flash[a[b]]=!!a[b].match(Sa);b=f}else a=e&&"function"===typeof e.canPlayType?e.canPlayType(a):!1,b=!(!a||!a.match(c.html5Test));return b}if(!c.useHTML5Audio||!c.hasHTML5)return!1;var e="undefined"!==typeof Audio?ha&&10>opera.version()?new Audio(null):new Audio:null,d,b,g={},f;f=c.audioFormats;for(d in f)if(f.hasOwnProperty(d)&&(b="audio/"+d,g[d]=a(f[d].type),g[b]=g[d],d.match(Sa)?(c.flash[d]=!0,c.flash[b]=!0):(c.flash[d]=!1,c.flash[b]=!1),f[d]&&f[d].related))for(b=f[d].related.length-
+1;0<=b;b--)g["audio/"+f[d].related[b]]=g[d],c.html5[f[d].related[b]]=g[d],c.flash[f[d].related[b]]=g[d];g.canPlayType=e?a:null;c.html5=r(c.html5,g);return!0};t=function(){};Z=function(a){if(8===j&&1<a.loops&&a.stream)a.stream=!1;return a};$=function(a){if(a&&!a.usePolicyFile&&(a.onid3||a.usePeakData||a.useWaveformData||a.useEQData))a.usePolicyFile=!0;return a};H=function(){};ja=function(){return!1};Ha=function(a){for(var c in a)a.hasOwnProperty(c)&&"function"===typeof a[c]&&(a[c]=ja)};Y=function(a){"undefined"===
+typeof a&&(a=!1);(s||a)&&c.disable(a)};Ia=function(a){var e=null;if(a)if(a.match(/\.swf(\?.*)?$/i)){if(e=a.substr(a.toLowerCase().lastIndexOf(".swf?")+4))return a}else a.lastIndexOf("/")!==a.length-1&&(a+="/");a=(a&&-1!==a.lastIndexOf("/")?a.substr(0,a.lastIndexOf("/")+1):"./")+c.movieURL;c.noSWFCache&&(a+="?ts="+(new Date).getTime());return a};oa=function(){j=parseInt(c.flashVersion,10);if(8!==j&&9!==j)c.flashVersion=j=8;var a=c.debugMode||c.debugFlash?"_debug.swf":".swf";if(c.useHTML5Audio&&!c.html5Only&&
+c.audioFormats.mp4.required&&9>j)c.flashVersion=j=9;c.version=c.versionNumber+(c.html5Only?" (HTML5-only mode)":9===j?" (AS3/Flash 9)":" (AS2/Flash 8)");8<j?(c.defaultOptions=r(c.defaultOptions,c.flash9Options),c.features.buffering=!0,c.defaultOptions=r(c.defaultOptions,c.movieStarOptions),c.filePatterns.flash9=RegExp("\\.(mp3|"+Va.join("|")+")(\\?.*)?$","i"),c.features.movieStar=!0):c.features.movieStar=!1;c.filePattern=c.filePatterns[8!==j?"flash9":"flash8"];c.movieURL=(8===j?"soundmanager2.swf":
+"soundmanager2_flash9.swf").replace(".swf",a);c.features.peakData=c.features.waveformData=c.features.eqData=8<j};Ga=function(a,c){if(!i)return!1;i._setPolling(a,c)};ra=function(){if(c.debugURLParam.test(ia))c.debugMode=!0};p=this.getSoundById;G=function(){var a=[];c.debugMode&&a.push("sm2_debug");c.debugFlash&&a.push("flash_debug");c.useHighPerformance&&a.push("high_performance");return a.join(" ")};ta=function(){t("fbHandler");var a=c.getMoviePercent(),e={type:"FLASHBLOCK"};if(c.html5Only)return!1;
+if(c.ok()){if(c.oMC)c.oMC.className=[G(),"movieContainer","swf_loaded"+(c.didFlashBlock?" swf_unblocked":"")].join(" ")}else{if(n)c.oMC.className=G()+" movieContainer "+(null===a?"swf_timedout":"swf_error");c.didFlashBlock=!0;B({type:"ontimeout",ignoreInit:!0,error:e});F(e)}};na=function(a,c,d){"undefined"===typeof v[a]&&(v[a]=[]);v[a].push({method:c,scope:d||null,fired:!1})};B=function(a){a||(a={type:c.ok()?"onready":"ontimeout"});if(!k&&a&&!a.ignoreInit||"ontimeout"===a.type&&(c.ok()||s&&!a.ignoreInit))return!1;
+var e={success:a&&a.ignoreInit?c.ok():!s},d=a&&a.type?v[a.type]||[]:[],b=[],g,e=[e],f=n&&c.useFlashBlock&&!c.ok();if(a.error)e[0].error=a.error;for(a=0,g=d.length;a<g;a++)!0!==d[a].fired&&b.push(d[a]);if(b.length)for(a=0,g=b.length;a<g;a++)if(b[a].scope?b[a].method.apply(b[a].scope,e):b[a].method.apply(this,e),!f)b[a].fired=!0;return!0};C=function(){h.setTimeout(function(){c.useFlashBlock&&ta();B();"function"===typeof c.onload&&c.onload.apply(h);c.waitForWindowLoad&&o.add(h,"load",C)},1)};xa=function(){if("undefined"!==
+typeof y)return y;var a=!1,c=navigator,d=c.plugins,b,g=h.ActiveXObject;if(d&&d.length)(c=c.mimeTypes)&&c["application/x-shockwave-flash"]&&c["application/x-shockwave-flash"].enabledPlugin&&c["application/x-shockwave-flash"].enabledPlugin.description&&(a=!0);else if("undefined"!==typeof g){try{b=new g("ShockwaveFlash.ShockwaveFlash")}catch(f){}a=!!b}return y=a};Ma=function(){var a,e,d=c.audioFormats;if(ya&&q.match(/os (1|2|3_0|3_1)/i)){if(c.hasHTML5=!1,c.html5Only=!0,c.oMC)c.oMC.style.display="none"}else if(c.useHTML5Audio&&
+(!c.html5||!c.html5.canPlayType))c.hasHTML5=!1;if(c.useHTML5Audio&&c.hasHTML5)for(e in d)if(d.hasOwnProperty(e)&&(d[e].required&&!c.html5.canPlayType(d[e].type)||c.preferFlash&&(c.flash[e]||c.flash[d[e].type])))a=!0;c.ignoreFlash&&(a=!1);c.html5Only=c.hasHTML5&&c.useHTML5Audio&&!a;return!c.html5Only};ba=function(a){var e,d,b=0;if(a instanceof Array){for(e=0,d=a.length;e<d;e++)if(a[e]instanceof Object){if(c.canPlayMIME(a[e].type)){b=e;break}}else if(c.canPlayURL(a[e])){b=e;break}if(a[b].url)a[b]=a[b].url;
+a=a[b]}return a};Ja=function(a){if(!a._hasTimer)a._hasTimer=!0,!Aa&&c.html5PollingInterval&&(null===P&&0===aa&&(P=h.setInterval(La,c.html5PollingInterval)),aa++)};Ka=function(a){if(a._hasTimer)a._hasTimer=!1,!Aa&&c.html5PollingInterval&&aa--};La=function(){var a;if(null!==P&&!aa)return h.clearInterval(P),P=null,!1;for(a=c.soundIDs.length-1;0<=a;a--)c.sounds[c.soundIDs[a]].isHTML5&&c.sounds[c.soundIDs[a]]._hasTimer&&c.sounds[c.soundIDs[a]]._onTimer()};F=function(a){a="undefined"!==typeof a?a:{};"function"===
+typeof c.onerror&&c.onerror.apply(h,[{type:"undefined"!==typeof a.type?a.type:null}]);"undefined"!==typeof a.fatal&&a.fatal&&c.disable()};Oa=function(){if(!Qa||!xa())return!1;var a=c.audioFormats,e,d;for(d in a)if(a.hasOwnProperty(d)&&("mp3"===d||"mp4"===d))if(c.html5[d]=!1,a[d]&&a[d].related)for(e=a[d].related.length-1;0<=e;e--)c.html5[a[d].related[e]]=!1};this._setSandboxType=function(){};this._externalInterfaceOK=function(){if(c.swfLoaded)return!1;(new Date).getTime();c.swfLoaded=!0;da=!1;Qa&&
+Oa();setTimeout(ka,x?100:1)};X=function(a,e){function d(a,b){return'<param name="'+a+'" value="'+b+'" />'}if(J&&K)return!1;if(c.html5Only)return oa(),c.oMC=T(c.movieID),ka(),K=J=!0,!1;var b=e||c.url,g=c.altURL||b,f=qa(),h=G(),i=null,i=m.getElementsByTagName("html")[0],j,k,l,i=i&&i.dir&&i.dir.match(/rtl/i),a="undefined"===typeof a?c.id:a;oa();c.url=Ia(Ca?b:g);e=c.url;c.wmode=!c.wmode&&c.useHighPerformance?"transparent":c.wmode;if(null!==c.wmode&&(q.match(/msie 8/i)||!x&&!c.useHighPerformance)&&navigator.platform.match(/win32|win64/i))c.wmode=
+null;f={name:a,id:a,src:e,quality:"high",allowScriptAccess:c.allowScriptAccess,bgcolor:c.bgColor,pluginspage:Ta+"www.macromedia.com/go/getflashplayer",title:"JS/Flash audio component (SoundManager 2)",type:"application/x-shockwave-flash",wmode:c.wmode,hasPriority:"true"};if(c.debugFlash)f.FlashVars="debug=1";c.wmode||delete f.wmode;if(x)b=m.createElement("div"),k=['<object id="'+a+'" data="'+e+'" type="'+f.type+'" title="'+f.title+'" classid="clsid:D27CDB6E-AE6D-11cf-96B8-444553540000" codebase="'+
+Ta+'download.macromedia.com/pub/shockwave/cabs/flash/swflash.cab#version=6,0,40,0">',d("movie",e),d("AllowScriptAccess",c.allowScriptAccess),d("quality",f.quality),c.wmode?d("wmode",c.wmode):"",d("bgcolor",c.bgColor),d("hasPriority","true"),c.debugFlash?d("FlashVars",f.FlashVars):"","</object>"].join("");else for(j in b=m.createElement("embed"),f)f.hasOwnProperty(j)&&b.setAttribute(j,f[j]);ra();h=G();if(f=qa())if(c.oMC=T(c.movieID)||m.createElement("div"),c.oMC.id){l=c.oMC.className;c.oMC.className=
+(l?l+" ":"movieContainer")+(h?" "+h:"");c.oMC.appendChild(b);if(x)j=c.oMC.appendChild(m.createElement("div")),j.className="sm2-object-box",j.innerHTML=k;K=!0}else{c.oMC.id=c.movieID;c.oMC.className="movieContainer "+h;j=h=null;if(!c.useFlashBlock)if(c.useHighPerformance)h={position:"fixed",width:"8px",height:"8px",bottom:"0px",left:"0px",overflow:"hidden"};else if(h={position:"absolute",width:"6px",height:"6px",top:"-9999px",left:"-9999px"},i)h.left=Math.abs(parseInt(h.left,10))+"px";if(Xa)c.oMC.style.zIndex=
+1E4;if(!c.debugFlash)for(l in h)h.hasOwnProperty(l)&&(c.oMC.style[l]=h[l]);try{x||c.oMC.appendChild(b);f.appendChild(c.oMC);if(x)j=c.oMC.appendChild(m.createElement("div")),j.className="sm2-object-box",j.innerHTML=k;K=!0}catch(n){throw Error(t("domError")+" \n"+n.toString());}}return J=!0};W=function(){if(c.html5Only)return X(),!1;if(i||!c.url)return!1;i=c.getMovie(c.id);if(!i)N?(x?c.oMC.innerHTML=sa:c.oMC.appendChild(N),N=null,J=!0):X(c.id,c.url),i=c.getMovie(c.id);"function"===typeof c.oninitmovie&&
+setTimeout(c.oninitmovie,1);return!0};D=function(){setTimeout(Fa,1E3)};Fa=function(){var a,e=!1;if(!c.url||O)return!1;O=!0;o.remove(h,"load",D);if(da&&!Ba)return!1;k||(a=c.getMoviePercent(),0<a&&100>a&&(e=!0));setTimeout(function(){a=c.getMoviePercent();if(e)return O=!1,h.setTimeout(D,1),!1;!k&&Ra&&(null===a?c.useFlashBlock||0===c.flashLoadTimeout?c.useFlashBlock&&ta():Y(!0):0!==c.flashLoadTimeout&&Y(!0))},c.flashLoadTimeout)};V=function(){if(Ba||!da)return o.remove(h,"focus",V),!0;Ba=Ra=!0;O=!1;
+D();o.remove(h,"focus",V);return!0};Pa=function(){};L=function(a){if(k)return!1;if(c.html5Only)return k=!0,C(),!0;var e=!0,d;if(!c.useFlashBlock||!c.flashLoadTimeout||c.getMoviePercent())k=!0,s&&(d={type:!y&&n?"NO_FLASH":"INIT_TIMEOUT"});if(s||a){if(c.useFlashBlock&&c.oMC)c.oMC.className=G()+" "+(null===c.getMoviePercent()?"swf_timedout":"swf_error");B({type:"ontimeout",error:d,ignoreInit:!0});F(d);e=!1}s||(c.waitForWindowLoad&&!la?o.add(h,"load",C):C());return e};Ea=function(){var a,e=c.setupOptions;
+for(a in e)e.hasOwnProperty(a)&&("undefined"===typeof c[a]?c[a]=e[a]:c[a]!==e[a]&&(c.setupOptions[a]=c[a]))};ka=function(){if(k)return!1;if(c.html5Only){if(!k)o.remove(h,"load",c.beginDelayedInit),c.enabled=!0,L();return!0}W();try{i._externalInterfaceTest(!1),Ga(!0,c.flashPollingInterval||(c.useHighPerformance?10:50)),c.debugMode||i._disableDebug(),c.enabled=!0,c.html5Only||o.add(h,"unload",ja)}catch(a){return F({type:"JS_TO_FLASH_EXCEPTION",fatal:!0}),Y(!0),L(),!1}L();o.remove(h,"load",c.beginDelayedInit);
+return!0};E=function(){if(M)return!1;M=!0;Ea();ra();!y&&c.hasHTML5&&c.setup({useHTML5Audio:!0,preferFlash:!1});Na();c.html5.usingFlash=Ma();n=c.html5.usingFlash;Pa();!y&&n&&c.setup({flashLoadTimeout:1});m.removeEventListener&&m.removeEventListener("DOMContentLoaded",E,!1);W();return!0};wa=function(){"complete"===m.readyState&&(E(),m.detachEvent("onreadystatechange",wa));return!0};pa=function(){la=!0;o.remove(h,"load",pa)};xa();o.add(h,"focus",V);o.add(h,"load",D);o.add(h,"load",pa);m.addEventListener?
+m.addEventListener("DOMContentLoaded",E,!1):m.attachEvent?m.attachEvent("onreadystatechange",wa):F({type:"NO_DOM2_EVENTS",fatal:!0})}var ea=null;if("undefined"===typeof SM2_DEFER||!SM2_DEFER)ea=new R;fa.SoundManager=R;fa.soundManager=ea})(window);
\ No newline at end of file
diff --git a/timeside/player/static/timeside/js/libs/soundmanager2-nodebug.js b/timeside/player/static/timeside/js/libs/soundmanager2-nodebug.js
new file mode 100644 (file)
index 0000000..856175b
--- /dev/null
@@ -0,0 +1,2511 @@
+/** @license\r
+ *\r
+ * SoundManager 2: JavaScript Sound for the Web\r
+ * ----------------------------------------------\r
+ * http://schillmania.com/projects/soundmanager2/\r
+ *\r
+ * Copyright (c) 2007, Scott Schiller. All rights reserved.\r
+ * Code provided under the BSD License:\r
+ * http://schillmania.com/projects/soundmanager2/license.txt\r
+ *\r
+ * V2.97a.20120916\r
+ */\r
+\r
+/*global window, SM2_DEFER, sm2Debugger, console, document, navigator, setTimeout, setInterval, clearInterval, Audio */\r
+/*jslint regexp: true, sloppy: true, white: true, nomen: true, plusplus: true */\r
+\r
+(function(window) {\r
+var soundManager = null;\r
+function SoundManager(smURL, smID) {\r
+  this.setupOptions = {\r
+    'url': (smURL || null),\r
+    'flashVersion': 8,\r
+    'debugMode': true,\r
+    'debugFlash': false,\r
+    'useConsole': true,\r
+    'consoleOnly': true,\r
+    'waitForWindowLoad': false,\r
+    'bgColor': '#ffffff',\r
+    'useHighPerformance': false,\r
+    'flashPollingInterval': null,\r
+    'html5PollingInterval': null,\r
+    'flashLoadTimeout': 1000,\r
+    'wmode': null,\r
+    'allowScriptAccess': 'always',\r
+    'useFlashBlock': false,\r
+    'useHTML5Audio': true,\r
+    'html5Test': /^(probably|maybe)$/i,\r
+    'preferFlash': true,\r
+    'noSWFCache': false\r
+  };\r
+  this.defaultOptions = {\r
+    'autoLoad': false,\r
+    'autoPlay': false,\r
+    'from': null,\r
+    'loops': 1,\r
+    'onid3': null,\r
+    'onload': null,\r
+    'whileloading': null,\r
+    'onplay': null,\r
+    'onpause': null,\r
+    'onresume': null,\r
+    'whileplaying': null,\r
+    'onposition': null,\r
+    'onstop': null,\r
+    'onfailure': null,\r
+    'onfinish': null,\r
+    'multiShot': true,\r
+    'multiShotEvents': false,\r
+    'position': null,\r
+    'pan': 0,\r
+    'stream': true,\r
+    'to': null,\r
+    'type': null,\r
+    'usePolicyFile': false,\r
+    'volume': 100\r
+  };\r
+  this.flash9Options = {\r
+    'isMovieStar': null,\r
+    'usePeakData': false,\r
+    'useWaveformData': false,\r
+    'useEQData': false,\r
+    'onbufferchange': null,\r
+    'ondataerror': null\r
+  };\r
+  this.movieStarOptions = {\r
+    'bufferTime': 3,\r
+    'serverURL': null,\r
+    'onconnect': null,\r
+    'duration': null\r
+  };\r
+  this.audioFormats = {\r
+    'mp3': {\r
+      'type': ['audio/mpeg; codecs="mp3"', 'audio/mpeg', 'audio/mp3', 'audio/MPA', 'audio/mpa-robust'],\r
+      'required': true\r
+    },\r
+    'mp4': {\r
+      'related': ['aac','m4a','m4b'],\r
+      'type': ['audio/mp4; codecs="mp4a.40.2"', 'audio/aac', 'audio/x-m4a', 'audio/MP4A-LATM', 'audio/mpeg4-generic'],\r
+      'required': false\r
+    },\r
+    'ogg': {\r
+      'type': ['audio/ogg; codecs=vorbis'],\r
+      'required': false\r
+    },\r
+    'wav': {\r
+      'type': ['audio/wav; codecs="1"', 'audio/wav', 'audio/wave', 'audio/x-wav'],\r
+      'required': false\r
+    }\r
+  };\r
+  this.movieID = 'sm2-container';\r
+  this.id = (smID || 'sm2movie');\r
+  this.debugID = 'soundmanager-debug';\r
+  this.debugURLParam = /([#?&])debug=1/i;\r
+  this.versionNumber = 'V2.97a.20120916';\r
+  this.version = null;\r
+  this.movieURL = null;\r
+  this.altURL = null;\r
+  this.swfLoaded = false;\r
+  this.enabled = false;\r
+  this.oMC = null;\r
+  this.sounds = {};\r
+  this.soundIDs = [];\r
+  this.muted = false;\r
+  this.didFlashBlock = false;\r
+  this.filePattern = null;\r
+  this.filePatterns = {\r
+    'flash8': /\.mp3(\?.*)?$/i,\r
+    'flash9': /\.mp3(\?.*)?$/i\r
+  };\r
+  this.features = {\r
+    'buffering': false,\r
+    'peakData': false,\r
+    'waveformData': false,\r
+    'eqData': false,\r
+    'movieStar': false\r
+  };\r
+  this.sandbox = {\r
+  };\r
+  this.hasHTML5 = (function() {\r
+    try {\r
+      return (typeof Audio !== 'undefined' && typeof (_isOpera && opera.version() < 10 ? new Audio(null) : new Audio()).canPlayType !== 'undefined');\r
+    } catch(e) {\r
+      return false;\r
+    }\r
+  }());\r
+  this.html5 = {\r
+    'usingFlash': null\r
+  };\r
+  this.flash = {};\r
+  this.html5Only = false;\r
+  this.ignoreFlash = false;\r
+  var SMSound,\r
+  _s = this, _flash = null, _sm = 'soundManager', _smc = _sm+'::', _h5 = 'HTML5::', _id, _ua = navigator.userAgent, _win = window, _wl = _win.location.href.toString(), _doc = document, _doNothing, _setProperties, _init, _fV, _on_queue = [], _debugOpen = true, _debugTS, _didAppend = false, _appendSuccess = false, _didInit = false, _disabled = false, _windowLoaded = false, _wDS, _wdCount = 0, _initComplete, _mixin, _assign, _extraOptions, _addOnEvent, _processOnEvents, _initUserOnload, _delayWaitForEI, _waitForEI, _setVersionInfo, _handleFocus, _strings, _initMovie, _domContentLoaded, _winOnLoad, _didDCLoaded, _getDocument, _createMovie, _catchError, _setPolling, _initDebug, _debugLevels = ['log', 'info', 'warn', 'error'], _defaultFlashVersion = 8, _disableObject, _failSafely, _normalizeMovieURL, _oRemoved = null, _oRemovedHTML = null, _str, _flashBlockHandler, _getSWFCSS, _swfCSS, _toggleDebug, _loopFix, _policyFix, _complain, _idCheck, _waitingForEI = false, _initPending = false, _startTimer, _stopTimer, _timerExecute, _h5TimerCount = 0, _h5IntervalTimer = null, _parseURL,\r
+  _needsFlash = null, _featureCheck, _html5OK, _html5CanPlay, _html5Ext, _html5Unload, _domContentLoadedIE, _testHTML5, _event, _slice = Array.prototype.slice, _useGlobalHTML5Audio = false, _hasFlash, _detectFlash, _badSafariFix, _html5_events, _showSupport,\r
+  _is_iDevice = _ua.match(/(ipad|iphone|ipod)/i), _isIE = _ua.match(/msie/i), _isWebkit = _ua.match(/webkit/i), _isSafari = (_ua.match(/safari/i) && !_ua.match(/chrome/i)), _isOpera = (_ua.match(/opera/i)),\r
+  _mobileHTML5 = (_ua.match(/(mobile|pre\/|xoom)/i) || _is_iDevice),\r
+  _isBadSafari = (!_wl.match(/usehtml5audio/i) && !_wl.match(/sm2\-ignorebadua/i) && _isSafari && !_ua.match(/silk/i) && _ua.match(/OS X 10_6_([3-7])/i)),\r
+  _hasConsole = (typeof console !== 'undefined' && typeof console.log !== 'undefined'), _isFocused = (typeof _doc.hasFocus !== 'undefined'?_doc.hasFocus():null), _tryInitOnFocus = (_isSafari && (typeof _doc.hasFocus === 'undefined' || !_doc.hasFocus())), _okToDisable = !_tryInitOnFocus, _flashMIME = /(mp3|mp4|mpa|m4a|m4b)/i,\r
+  _emptyURL = 'about:blank',\r
+  _overHTTP = (_doc.location?_doc.location.protocol.match(/http/i):null),\r
+  _http = (!_overHTTP ? 'http:/'+'/' : ''),\r
+  _netStreamMimeTypes = /^\s*audio\/(?:x-)?(?:mpeg4|aac|flv|mov|mp4||m4v|m4a|m4b|mp4v|3gp|3g2)\s*(?:$|;)/i,\r
+  _netStreamTypes = ['mpeg4', 'aac', 'flv', 'mov', 'mp4', 'm4v', 'f4v', 'm4a', 'm4b', 'mp4v', '3gp', '3g2'],\r
+  _netStreamPattern = new RegExp('\\.(' + _netStreamTypes.join('|') + ')(\\?.*)?$', 'i');\r
+  this.mimePattern = /^\s*audio\/(?:x-)?(?:mp(?:eg|3))\s*(?:$|;)/i;\r
+  this.useAltURL = !_overHTTP;\r
+  this._global_a = null;\r
+  _swfCSS = {\r
+    'swfBox': 'sm2-object-box',\r
+    'swfDefault': 'movieContainer',\r
+    'swfError': 'swf_error',\r
+    'swfTimedout': 'swf_timedout',\r
+    'swfLoaded': 'swf_loaded',\r
+    'swfUnblocked': 'swf_unblocked',\r
+    'sm2Debug': 'sm2_debug',\r
+    'highPerf': 'high_performance',\r
+    'flashDebug': 'flash_debug'\r
+  };\r
+  if (_mobileHTML5) {\r
+    _s.useHTML5Audio = true;\r
+    _s.preferFlash = false;\r
+    if (_is_iDevice) {\r
+      _s.ignoreFlash = true;\r
+      _useGlobalHTML5Audio = true;\r
+    }\r
+  }\r
+  this.setup = function(options) {\r
+    var noURL = (!_s.url);\r
+    if (typeof options !== 'undefined' && _didInit && _needsFlash && _s.ok() && (typeof options.flashVersion !== 'undefined' || typeof options.url !== 'undefined')) {\r
+      _complain(_str('setupLate'));\r
+    }\r
+    _assign(options);\r
+    if (noURL && _didDCLoaded && typeof options.url !== 'undefined') {\r
+      _s.beginDelayedInit();\r
+    }\r
+    if (!_didDCLoaded && typeof options.url !== 'undefined' && _doc.readyState === 'complete') {\r
+      setTimeout(_domContentLoaded, 1);\r
+    }\r
+    return _s;\r
+  };\r
+  this.ok = function() {\r
+    return (_needsFlash?(_didInit && !_disabled):(_s.useHTML5Audio && _s.hasHTML5));\r
+  };\r
+  this.supported = this.ok;\r
+  this.getMovie = function(smID) {\r
+    return _id(smID) || _doc[smID] || _win[smID];\r
+  };\r
+  this.createSound = function(oOptions, _url) {\r
+    var _cs, _cs_string, thisOptions = null, oSound = null, _tO = null;\r
+    if (!_didInit || !_s.ok()) {\r
+      _complain(_cs_string);\r
+      return false;\r
+    }\r
+    if (typeof _url !== 'undefined') {\r
+      oOptions = {\r
+        'id': oOptions,\r
+        'url': _url\r
+      };\r
+    }\r
+    thisOptions = _mixin(oOptions);\r
+    thisOptions.url = _parseURL(thisOptions.url);\r
+    _tO = thisOptions;\r
+    if (_idCheck(_tO.id, true)) {\r
+      return _s.sounds[_tO.id];\r
+    }\r
+    function make() {\r
+      thisOptions = _loopFix(thisOptions);\r
+      _s.sounds[_tO.id] = new SMSound(_tO);\r
+      _s.soundIDs.push(_tO.id);\r
+      return _s.sounds[_tO.id];\r
+    }\r
+    if (_html5OK(_tO)) {\r
+      oSound = make();\r
+      oSound._setup_html5(_tO);\r
+    } else {\r
+      if (_fV > 8) {\r
+        if (_tO.isMovieStar === null) {\r
+          _tO.isMovieStar = !!(_tO.serverURL || (_tO.type ? _tO.type.match(_netStreamMimeTypes) : false) || _tO.url.match(_netStreamPattern));\r
+        }\r
+      }\r
+      _tO = _policyFix(_tO, _cs);\r
+      oSound = make();\r
+      if (_fV === 8) {\r
+        _flash._createSound(_tO.id, _tO.loops||1, _tO.usePolicyFile);\r
+      } else {\r
+        _flash._createSound(_tO.id, _tO.url, _tO.usePeakData, _tO.useWaveformData, _tO.useEQData, _tO.isMovieStar, (_tO.isMovieStar?_tO.bufferTime:false), _tO.loops||1, _tO.serverURL, _tO.duration||null, _tO.autoPlay, true, _tO.autoLoad, _tO.usePolicyFile);\r
+        if (!_tO.serverURL) {\r
+          oSound.connected = true;\r
+          if (_tO.onconnect) {\r
+            _tO.onconnect.apply(oSound);\r
+          }\r
+        }\r
+      }\r
+      if (!_tO.serverURL && (_tO.autoLoad || _tO.autoPlay)) {\r
+        oSound.load(_tO);\r
+      }\r
+    }\r
+    if (!_tO.serverURL && _tO.autoPlay) {\r
+      oSound.play();\r
+    }\r
+    return oSound;\r
+  };\r
+  this.destroySound = function(sID, _bFromSound) {\r
+    if (!_idCheck(sID)) {\r
+      return false;\r
+    }\r
+    var oS = _s.sounds[sID], i;\r
+    oS._iO = {};\r
+    oS.stop();\r
+    oS.unload();\r
+    for (i = 0; i < _s.soundIDs.length; i++) {\r
+      if (_s.soundIDs[i] === sID) {\r
+        _s.soundIDs.splice(i, 1);\r
+        break;\r
+      }\r
+    }\r
+    if (!_bFromSound) {\r
+      oS.destruct(true);\r
+    }\r
+    oS = null;\r
+    delete _s.sounds[sID];\r
+    return true;\r
+  };\r
+  this.load = function(sID, oOptions) {\r
+    if (!_idCheck(sID)) {\r
+      return false;\r
+    }\r
+    return _s.sounds[sID].load(oOptions);\r
+  };\r
+  this.unload = function(sID) {\r
+    if (!_idCheck(sID)) {\r
+      return false;\r
+    }\r
+    return _s.sounds[sID].unload();\r
+  };\r
+  this.onPosition = function(sID, nPosition, oMethod, oScope) {\r
+    if (!_idCheck(sID)) {\r
+      return false;\r
+    }\r
+    return _s.sounds[sID].onposition(nPosition, oMethod, oScope);\r
+  };\r
+  this.onposition = this.onPosition;\r
+  this.clearOnPosition = function(sID, nPosition, oMethod) {\r
+    if (!_idCheck(sID)) {\r
+      return false;\r
+    }\r
+    return _s.sounds[sID].clearOnPosition(nPosition, oMethod);\r
+  };\r
+  this.play = function(sID, oOptions) {\r
+    var result = false;\r
+    if (!_didInit || !_s.ok()) {\r
+      _complain(_sm+'.play(): ' + _str(!_didInit?'notReady':'notOK'));\r
+      return result;\r
+    }\r
+    if (!_idCheck(sID)) {\r
+      if (!(oOptions instanceof Object)) {\r
+        oOptions = {\r
+          url: oOptions\r
+        };\r
+      }\r
+      if (oOptions && oOptions.url) {\r
+        oOptions.id = sID;\r
+        result = _s.createSound(oOptions).play();\r
+      }\r
+      return result;\r
+    }\r
+    return _s.sounds[sID].play(oOptions);\r
+  };\r
+  this.start = this.play;\r
+  this.setPosition = function(sID, nMsecOffset) {\r
+    if (!_idCheck(sID)) {\r
+      return false;\r
+    }\r
+    return _s.sounds[sID].setPosition(nMsecOffset);\r
+  };\r
+  this.stop = function(sID) {\r
+    if (!_idCheck(sID)) {\r
+      return false;\r
+    }\r
+    return _s.sounds[sID].stop();\r
+  };\r
+  this.stopAll = function() {\r
+    var oSound;\r
+    for (oSound in _s.sounds) {\r
+      if (_s.sounds.hasOwnProperty(oSound)) {\r
+        _s.sounds[oSound].stop();\r
+      }\r
+    }\r
+  };\r
+  this.pause = function(sID) {\r
+    if (!_idCheck(sID)) {\r
+      return false;\r
+    }\r
+    return _s.sounds[sID].pause();\r
+  };\r
+  this.pauseAll = function() {\r
+    var i;\r
+    for (i = _s.soundIDs.length-1; i >= 0; i--) {\r
+      _s.sounds[_s.soundIDs[i]].pause();\r
+    }\r
+  };\r
+  this.resume = function(sID) {\r
+    if (!_idCheck(sID)) {\r
+      return false;\r
+    }\r
+    return _s.sounds[sID].resume();\r
+  };\r
+  this.resumeAll = function() {\r
+    var i;\r
+    for (i = _s.soundIDs.length-1; i >= 0; i--) {\r
+      _s.sounds[_s.soundIDs[i]].resume();\r
+    }\r
+  };\r
+  this.togglePause = function(sID) {\r
+    if (!_idCheck(sID)) {\r
+      return false;\r
+    }\r
+    return _s.sounds[sID].togglePause();\r
+  };\r
+  this.setPan = function(sID, nPan) {\r
+    if (!_idCheck(sID)) {\r
+      return false;\r
+    }\r
+    return _s.sounds[sID].setPan(nPan);\r
+  };\r
+  this.setVolume = function(sID, nVol) {\r
+    if (!_idCheck(sID)) {\r
+      return false;\r
+    }\r
+    return _s.sounds[sID].setVolume(nVol);\r
+  };\r
+  this.mute = function(sID) {\r
+    var i = 0;\r
+    if (typeof sID !== 'string') {\r
+      sID = null;\r
+    }\r
+    if (!sID) {\r
+      for (i = _s.soundIDs.length-1; i >= 0; i--) {\r
+        _s.sounds[_s.soundIDs[i]].mute();\r
+      }\r
+      _s.muted = true;\r
+    } else {\r
+      if (!_idCheck(sID)) {\r
+        return false;\r
+      }\r
+      return _s.sounds[sID].mute();\r
+    }\r
+    return true;\r
+  };\r
+  this.muteAll = function() {\r
+    _s.mute();\r
+  };\r
+  this.unmute = function(sID) {\r
+    var i;\r
+    if (typeof sID !== 'string') {\r
+      sID = null;\r
+    }\r
+    if (!sID) {\r
+      for (i = _s.soundIDs.length-1; i >= 0; i--) {\r
+        _s.sounds[_s.soundIDs[i]].unmute();\r
+      }\r
+      _s.muted = false;\r
+    } else {\r
+      if (!_idCheck(sID)) {\r
+        return false;\r
+      }\r
+      return _s.sounds[sID].unmute();\r
+    }\r
+    return true;\r
+  };\r
+  this.unmuteAll = function() {\r
+    _s.unmute();\r
+  };\r
+  this.toggleMute = function(sID) {\r
+    if (!_idCheck(sID)) {\r
+      return false;\r
+    }\r
+    return _s.sounds[sID].toggleMute();\r
+  };\r
+  this.getMemoryUse = function() {\r
+    var ram = 0;\r
+    if (_flash && _fV !== 8) {\r
+      ram = parseInt(_flash._getMemoryUse(), 10);\r
+    }\r
+    return ram;\r
+  };\r
+  this.disable = function(bNoDisable) {\r
+    var i;\r
+    if (typeof bNoDisable === 'undefined') {\r
+      bNoDisable = false;\r
+    }\r
+    if (_disabled) {\r
+      return false;\r
+    }\r
+    _disabled = true;\r
+    for (i = _s.soundIDs.length-1; i >= 0; i--) {\r
+      _disableObject(_s.sounds[_s.soundIDs[i]]);\r
+    }\r
+    _initComplete(bNoDisable);\r
+    _event.remove(_win, 'load', _initUserOnload);\r
+    return true;\r
+  };\r
+  this.canPlayMIME = function(sMIME) {\r
+    var result;\r
+    if (_s.hasHTML5) {\r
+      result = _html5CanPlay({type:sMIME});\r
+    }\r
+    if (!result && _needsFlash) {\r
+      result = (sMIME && _s.ok() ? !!((_fV > 8 ? sMIME.match(_netStreamMimeTypes) : null) || sMIME.match(_s.mimePattern)) : null);\r
+    }\r
+    return result;\r
+  };\r
+  this.canPlayURL = function(sURL) {\r
+    var result;\r
+    if (_s.hasHTML5) {\r
+      result = _html5CanPlay({url: sURL});\r
+    }\r
+    if (!result && _needsFlash) {\r
+      result = (sURL && _s.ok() ? !!(sURL.match(_s.filePattern)) : null);\r
+    }\r
+    return result;\r
+  };\r
+  this.canPlayLink = function(oLink) {\r
+    if (typeof oLink.type !== 'undefined' && oLink.type) {\r
+      if (_s.canPlayMIME(oLink.type)) {\r
+        return true;\r
+      }\r
+    }\r
+    return _s.canPlayURL(oLink.href);\r
+  };\r
+  this.getSoundById = function(sID, _suppressDebug) {\r
+    if (!sID) {\r
+      throw new Error(_sm+'.getSoundById(): sID is null/undefined');\r
+    }\r
+    var result = _s.sounds[sID];\r
+    return result;\r
+  };\r
+  this.onready = function(oMethod, oScope) {\r
+    var sType = 'onready',\r
+        result = false;\r
+    if (typeof oMethod === 'function') {\r
+      if (!oScope) {\r
+        oScope = _win;\r
+      }\r
+      _addOnEvent(sType, oMethod, oScope);\r
+      _processOnEvents();\r
+      result = true;\r
+    } else {\r
+      throw _str('needFunction', sType);\r
+    }\r
+    return result;\r
+  };\r
+  this.ontimeout = function(oMethod, oScope) {\r
+    var sType = 'ontimeout',\r
+        result = false;\r
+    if (typeof oMethod === 'function') {\r
+      if (!oScope) {\r
+        oScope = _win;\r
+      }\r
+      _addOnEvent(sType, oMethod, oScope);\r
+      _processOnEvents({type:sType});\r
+      result = true;\r
+    } else {\r
+      throw _str('needFunction', sType);\r
+    }\r
+    return result;\r
+  };\r
+  this._writeDebug = function(sText, sType, _bTimestamp) {\r
+    return true;\r
+  };\r
+  this._wD = this._writeDebug;\r
+  this._debug = function() {\r
+  };\r
+  this.reboot = function() {\r
+    var i, j;\r
+    for (i = _s.soundIDs.length-1; i >= 0; i--) {\r
+      _s.sounds[_s.soundIDs[i]].destruct();\r
+    }\r
+    if (_flash) {\r
+      try {\r
+        if (_isIE) {\r
+          _oRemovedHTML = _flash.innerHTML;\r
+        }\r
+        _oRemoved = _flash.parentNode.removeChild(_flash);\r
+      } catch(e) {\r
+      }\r
+    }\r
+    _oRemovedHTML = _oRemoved = _needsFlash = null;\r
+    _s.enabled = _didDCLoaded = _didInit = _waitingForEI = _initPending = _didAppend = _appendSuccess = _disabled = _s.swfLoaded = false;\r
+    _s.soundIDs = [];\r
+    _s.sounds = {};\r
+    _flash = null;\r
+    for (i in _on_queue) {\r
+      if (_on_queue.hasOwnProperty(i)) {\r
+        for (j = _on_queue[i].length-1; j >= 0; j--) {\r
+          _on_queue[i][j].fired = false;\r
+        }\r
+      }\r
+    }\r
+    _win.setTimeout(_s.beginDelayedInit, 20);\r
+  };\r
+  this.getMoviePercent = function() {\r
+    return (_flash && typeof _flash.PercentLoaded !== 'undefined' ? _flash.PercentLoaded() : null);\r
+  };\r
+  this.beginDelayedInit = function() {\r
+    _windowLoaded = true;\r
+    _domContentLoaded();\r
+    setTimeout(function() {\r
+      if (_initPending) {\r
+        return false;\r
+      }\r
+      _createMovie();\r
+      _initMovie();\r
+      _initPending = true;\r
+      return true;\r
+    }, 20);\r
+    _delayWaitForEI();\r
+  };\r
+  this.destruct = function() {\r
+    _s.disable(true);\r
+  };\r
+  SMSound = function(oOptions) {\r
+    var _t = this, _resetProperties, _add_html5_events, _remove_html5_events, _stop_html5_timer, _start_html5_timer, _attachOnPosition, _onplay_called = false, _onPositionItems = [], _onPositionFired = 0, _detachOnPosition, _applyFromTo, _lastURL = null, _lastHTML5State;\r
+    _lastHTML5State = {\r
+      duration: null,\r
+      time: null\r
+    };\r
+    this.id = oOptions.id;\r
+    this.sID = this.id;\r
+    this.url = oOptions.url;\r
+    this.options = _mixin(oOptions);\r
+    this.instanceOptions = this.options;\r
+    this._iO = this.instanceOptions;\r
+    this.pan = this.options.pan;\r
+    this.volume = this.options.volume;\r
+    this.isHTML5 = false;\r
+    this._a = null;\r
+    this.id3 = {};\r
+    this._debug = function() {\r
+    };\r
+    this.load = function(oOptions) {\r
+      var oS = null, _iO;\r
+      if (typeof oOptions !== 'undefined') {\r
+        _t._iO = _mixin(oOptions, _t.options);\r
+        _t.instanceOptions = _t._iO;\r
+      } else {\r
+        oOptions = _t.options;\r
+        _t._iO = oOptions;\r
+        _t.instanceOptions = _t._iO;\r
+        if (_lastURL && _lastURL !== _t.url) {\r
+          _t._iO.url = _t.url;\r
+          _t.url = null;\r
+        }\r
+      }\r
+      if (!_t._iO.url) {\r
+        _t._iO.url = _t.url;\r
+      }\r
+      _t._iO.url = _parseURL(_t._iO.url);\r
+      if (_t._iO.url === _t.url && _t.readyState !== 0 && _t.readyState !== 2) {\r
+        if (_t.readyState === 3 && _t._iO.onload) {\r
+          _t._iO.onload.apply(_t, [(!!_t.duration)]);\r
+        }\r
+        return _t;\r
+      }\r
+      _iO = _t._iO;\r
+      _lastURL = (_t.url && _t.url.toString ? _t.url.toString() : null);\r
+      _t.loaded = false;\r
+      _t.readyState = 1;\r
+      _t.playState = 0;\r
+      _t.id3 = {};\r
+      if (_html5OK(_iO)) {\r
+        oS = _t._setup_html5(_iO);\r
+        if (!oS._called_load) {\r
+          _t._html5_canplay = false;\r
+          if (_t._a.src !== _iO.url) {\r
+            _t._a.src = _iO.url;\r
+            _t.setPosition(0);\r
+          }\r
+          _t._a.autobuffer = 'auto';\r
+          _t._a.preload = 'auto';\r
+          oS._called_load = true;\r
+          if (_iO.autoPlay) {\r
+            _t.play();\r
+          }\r
+        } else {\r
+        }\r
+      } else {\r
+        try {\r
+          _t.isHTML5 = false;\r
+          _t._iO = _policyFix(_loopFix(_iO));\r
+          _iO = _t._iO;\r
+          if (_fV === 8) {\r
+            _flash._load(_t.id, _iO.url, _iO.stream, _iO.autoPlay, (_iO.whileloading?1:0), _iO.loops||1, _iO.usePolicyFile);\r
+          } else {\r
+            _flash._load(_t.id, _iO.url, !!(_iO.stream), !!(_iO.autoPlay), _iO.loops||1, !!(_iO.autoLoad), _iO.usePolicyFile);\r
+          }\r
+        } catch(e) {\r
+          _catchError({type:'SMSOUND_LOAD_JS_EXCEPTION', fatal:true});\r
+        }\r
+      }\r
+      _t.url = _iO.url;\r
+      return _t;\r
+    };\r
+    this.unload = function() {\r
+      if (_t.readyState !== 0) {\r
+        if (!_t.isHTML5) {\r
+          if (_fV === 8) {\r
+            _flash._unload(_t.id, _emptyURL);\r
+          } else {\r
+            _flash._unload(_t.id);\r
+          }\r
+        } else {\r
+          _stop_html5_timer();\r
+          if (_t._a) {\r
+            _t._a.pause();\r
+            _html5Unload(_t._a, _emptyURL);\r
+            _t.url = _emptyURL;\r
+          }\r
+        }\r
+        _resetProperties();\r
+      }\r
+      return _t;\r
+    };\r
+    this.destruct = function(_bFromSM) {\r
+      if (!_t.isHTML5) {\r
+        _t._iO.onfailure = null;\r
+        _flash._destroySound(_t.id);\r
+      } else {\r
+        _stop_html5_timer();\r
+        if (_t._a) {\r
+          _t._a.pause();\r
+          _html5Unload(_t._a);\r
+          if (!_useGlobalHTML5Audio) {\r
+            _remove_html5_events();\r
+          }\r
+          _t._a._t = null;\r
+          _t._a = null;\r
+        }\r
+      }\r
+      if (!_bFromSM) {\r
+        _s.destroySound(_t.id, true);\r
+      }\r
+    };\r
+    this.play = function(oOptions, _updatePlayState) {\r
+      var fN, allowMulti, a, onready, startOK = true,\r
+          exit = null;\r
+      _updatePlayState = (typeof _updatePlayState === 'undefined' ? true : _updatePlayState);\r
+      if (!oOptions) {\r
+        oOptions = {};\r
+      }\r
+      if (_t.url) {\r
+        _t._iO.url = _t.url;\r
+      }\r
+      _t._iO = _mixin(_t._iO, _t.options);\r
+      _t._iO = _mixin(oOptions, _t._iO);\r
+      _t._iO.url = _parseURL(_t._iO.url);\r
+      _t.instanceOptions = _t._iO;\r
+      if (_t._iO.serverURL && !_t.connected) {\r
+        if (!_t.getAutoPlay()) {\r
+          _t.setAutoPlay(true);\r
+        }\r
+        return _t;\r
+      }\r
+      if (_html5OK(_t._iO)) {\r
+        _t._setup_html5(_t._iO);\r
+        _start_html5_timer();\r
+      }\r
+      if (_t.playState === 1 && !_t.paused) {\r
+        allowMulti = _t._iO.multiShot;\r
+        if (!allowMulti) {\r
+          exit = _t;\r
+        } else {\r
+        }\r
+      }\r
+      if (exit !== null) {\r
+        return exit;\r
+      }\r
+      if (oOptions.url && oOptions.url !== _t.url) {\r
+        _t.load(_t._iO);\r
+      }\r
+      if (!_t.loaded) {\r
+        if (_t.readyState === 0) {\r
+          if (!_t.isHTML5) {\r
+            _t._iO.autoPlay = true;\r
+            _t.load(_t._iO);\r
+          } else {\r
+            _t.load(_t._iO);\r
+          }\r
+        } else if (_t.readyState === 2) {\r
+          exit = _t;\r
+        } else {\r
+        }\r
+      } else {\r
+      }\r
+      if (exit !== null) {\r
+        return exit;\r
+      }\r
+      if (!_t.isHTML5 && _fV === 9 && _t.position > 0 && _t.position === _t.duration) {\r
+        oOptions.position = 0;\r
+      }\r
+      if (_t.paused && _t.position >= 0 && (!_t._iO.serverURL || _t.position > 0)) {\r
+        _t.resume();\r
+      } else {\r
+        _t._iO = _mixin(oOptions, _t._iO);\r
+        if (_t._iO.from !== null && _t._iO.to !== null && _t.instanceCount === 0 && _t.playState === 0 && !_t._iO.serverURL) {\r
+          onready = function() {\r
+            _t._iO = _mixin(oOptions, _t._iO);\r
+            _t.play(_t._iO);\r
+          };\r
+          if (_t.isHTML5 && !_t._html5_canplay) {\r
+            _t.load({\r
+              _oncanplay: onready\r
+            });\r
+            exit = false;\r
+          } else if (!_t.isHTML5 && !_t.loaded && (!_t.readyState || _t.readyState !== 2)) {\r
+            _t.load({\r
+              onload: onready\r
+            });\r
+            exit = false;\r
+          }\r
+          if (exit !== null) {\r
+            return exit;\r
+          }\r
+          _t._iO = _applyFromTo();\r
+        }\r
+        if (!_t.instanceCount || _t._iO.multiShotEvents || (!_t.isHTML5 && _fV > 8 && !_t.getAutoPlay())) {\r
+          _t.instanceCount++;\r
+        }\r
+        if (_t._iO.onposition && _t.playState === 0) {\r
+          _attachOnPosition(_t);\r
+        }\r
+        _t.playState = 1;\r
+        _t.paused = false;\r
+        _t.position = (typeof _t._iO.position !== 'undefined' && !isNaN(_t._iO.position) ? _t._iO.position : 0);\r
+        if (!_t.isHTML5) {\r
+          _t._iO = _policyFix(_loopFix(_t._iO));\r
+        }\r
+        if (_t._iO.onplay && _updatePlayState) {\r
+          _t._iO.onplay.apply(_t);\r
+          _onplay_called = true;\r
+        }\r
+        _t.setVolume(_t._iO.volume, true);\r
+        _t.setPan(_t._iO.pan, true);\r
+        if (!_t.isHTML5) {\r
+          startOK = _flash._start(_t.id, _t._iO.loops || 1, (_fV === 9 ? _t._iO.position : _t._iO.position / 1000), _t._iO.multiShot);\r
+          if (_fV === 9 && !startOK) {\r
+            if (_t._iO.onplayerror) {\r
+              _t._iO.onplayerror.apply(_t);\r
+            }\r
+          }\r
+        } else {\r
+          _start_html5_timer();\r
+          a = _t._setup_html5();\r
+          _t.setPosition(_t._iO.position);\r
+          a.play();\r
+        }\r
+      }\r
+      return _t;\r
+    };\r
+    this.start = this.play;\r
+    this.stop = function(bAll) {\r
+      var _iO = _t._iO, _oP;\r
+      if (_t.playState === 1) {\r
+        _t._onbufferchange(0);\r
+        _t._resetOnPosition(0);\r
+        _t.paused = false;\r
+        if (!_t.isHTML5) {\r
+          _t.playState = 0;\r
+        }\r
+        _detachOnPosition();\r
+        if (_iO.to) {\r
+          _t.clearOnPosition(_iO.to);\r
+        }\r
+        if (!_t.isHTML5) {\r
+          _flash._stop(_t.id, bAll);\r
+          if (_iO.serverURL) {\r
+            _t.unload();\r
+          }\r
+        } else {\r
+          if (_t._a) {\r
+            _oP = _t.position;\r
+            _t.setPosition(0);\r
+            _t.position = _oP;\r
+            _t._a.pause();\r
+            _t.playState = 0;\r
+            _t._onTimer();\r
+            _stop_html5_timer();\r
+          }\r
+        }\r
+        _t.instanceCount = 0;\r
+        _t._iO = {};\r
+        if (_iO.onstop) {\r
+          _iO.onstop.apply(_t);\r
+        }\r
+      }\r
+      return _t;\r
+    };\r
+    this.setAutoPlay = function(autoPlay) {\r
+      _t._iO.autoPlay = autoPlay;\r
+      if (!_t.isHTML5) {\r
+        _flash._setAutoPlay(_t.id, autoPlay);\r
+        if (autoPlay) {\r
+          if (!_t.instanceCount && _t.readyState === 1) {\r
+            _t.instanceCount++;\r
+          }\r
+        }\r
+      }\r
+    };\r
+    this.getAutoPlay = function() {\r
+      return _t._iO.autoPlay;\r
+    };\r
+    this.setPosition = function(nMsecOffset) {\r
+      if (typeof nMsecOffset === 'undefined') {\r
+        nMsecOffset = 0;\r
+      }\r
+      var original_pos,\r
+          position, position1K,\r
+          offset = (_t.isHTML5 ? Math.max(nMsecOffset, 0) : Math.min(_t.duration || _t._iO.duration, Math.max(nMsecOffset, 0)));\r
+      original_pos = _t.position;\r
+      _t.position = offset;\r
+      position1K = _t.position/1000;\r
+      _t._resetOnPosition(_t.position);\r
+      _t._iO.position = offset;\r
+      if (!_t.isHTML5) {\r
+        position = (_fV === 9 ? _t.position : position1K);\r
+        if (_t.readyState && _t.readyState !== 2) {\r
+          _flash._setPosition(_t.id, position, (_t.paused || !_t.playState), _t._iO.multiShot);\r
+        }\r
+      } else if (_t._a) {\r
+        if (_t._html5_canplay) {\r
+          if (_t._a.currentTime !== position1K) {\r
+            try {\r
+              _t._a.currentTime = position1K;\r
+              if (_t.playState === 0 || _t.paused) {\r
+                _t._a.pause();\r
+              }\r
+            } catch(e) {\r
+            }\r
+          }\r
+        } else {\r
+        }\r
+      }\r
+      if (_t.isHTML5) {\r
+        if (_t.paused) {\r
+          _t._onTimer(true);\r
+        }\r
+      }\r
+      return _t;\r
+    };\r
+    this.pause = function(_bCallFlash) {\r
+      if (_t.paused || (_t.playState === 0 && _t.readyState !== 1)) {\r
+        return _t;\r
+      }\r
+      _t.paused = true;\r
+      if (!_t.isHTML5) {\r
+        if (_bCallFlash || typeof _bCallFlash === 'undefined') {\r
+          _flash._pause(_t.id, _t._iO.multiShot);\r
+        }\r
+      } else {\r
+        _t._setup_html5().pause();\r
+        _stop_html5_timer();\r
+      }\r
+      if (_t._iO.onpause) {\r
+        _t._iO.onpause.apply(_t);\r
+      }\r
+      return _t;\r
+    };\r
+    this.resume = function() {\r
+      var _iO = _t._iO;\r
+      if (!_t.paused) {\r
+        return _t;\r
+      }\r
+      _t.paused = false;\r
+      _t.playState = 1;\r
+      if (!_t.isHTML5) {\r
+        if (_iO.isMovieStar && !_iO.serverURL) {\r
+          _t.setPosition(_t.position);\r
+        }\r
+        _flash._pause(_t.id, _iO.multiShot);\r
+      } else {\r
+        _t._setup_html5().play();\r
+        _start_html5_timer();\r
+      }\r
+      if (!_onplay_called && _iO.onplay) {\r
+        _iO.onplay.apply(_t);\r
+        _onplay_called = true;\r
+      } else if (_iO.onresume) {\r
+        _iO.onresume.apply(_t);\r
+      }\r
+      return _t;\r
+    };\r
+    this.togglePause = function() {\r
+      if (_t.playState === 0) {\r
+        _t.play({\r
+          position: (_fV === 9 && !_t.isHTML5 ? _t.position : _t.position / 1000)\r
+        });\r
+        return _t;\r
+      }\r
+      if (_t.paused) {\r
+        _t.resume();\r
+      } else {\r
+        _t.pause();\r
+      }\r
+      return _t;\r
+    };\r
+    this.setPan = function(nPan, bInstanceOnly) {\r
+      if (typeof nPan === 'undefined') {\r
+        nPan = 0;\r
+      }\r
+      if (typeof bInstanceOnly === 'undefined') {\r
+        bInstanceOnly = false;\r
+      }\r
+      if (!_t.isHTML5) {\r
+        _flash._setPan(_t.id, nPan);\r
+      }\r
+      _t._iO.pan = nPan;\r
+      if (!bInstanceOnly) {\r
+        _t.pan = nPan;\r
+        _t.options.pan = nPan;\r
+      }\r
+      return _t;\r
+    };\r
+    this.setVolume = function(nVol, _bInstanceOnly) {\r
+      if (typeof nVol === 'undefined') {\r
+        nVol = 100;\r
+      }\r
+      if (typeof _bInstanceOnly === 'undefined') {\r
+        _bInstanceOnly = false;\r
+      }\r
+      if (!_t.isHTML5) {\r
+        _flash._setVolume(_t.id, (_s.muted && !_t.muted) || _t.muted?0:nVol);\r
+      } else if (_t._a) {\r
+        _t._a.volume = Math.max(0, Math.min(1, nVol/100));\r
+      }\r
+      _t._iO.volume = nVol;\r
+      if (!_bInstanceOnly) {\r
+        _t.volume = nVol;\r
+        _t.options.volume = nVol;\r
+      }\r
+      return _t;\r
+    };\r
+    this.mute = function() {\r
+      _t.muted = true;\r
+      if (!_t.isHTML5) {\r
+        _flash._setVolume(_t.id, 0);\r
+      } else if (_t._a) {\r
+        _t._a.muted = true;\r
+      }\r
+      return _t;\r
+    };\r
+    this.unmute = function() {\r
+      _t.muted = false;\r
+      var hasIO = (typeof _t._iO.volume !== 'undefined');\r
+      if (!_t.isHTML5) {\r
+        _flash._setVolume(_t.id, hasIO?_t._iO.volume:_t.options.volume);\r
+      } else if (_t._a) {\r
+        _t._a.muted = false;\r
+      }\r
+      return _t;\r
+    };\r
+    this.toggleMute = function() {\r
+      return (_t.muted?_t.unmute():_t.mute());\r
+    };\r
+    this.onPosition = function(nPosition, oMethod, oScope) {\r
+      _onPositionItems.push({\r
+        position: parseInt(nPosition, 10),\r
+        method: oMethod,\r
+        scope: (typeof oScope !== 'undefined' ? oScope : _t),\r
+        fired: false\r
+      });\r
+      return _t;\r
+    };\r
+    this.onposition = this.onPosition;\r
+    this.clearOnPosition = function(nPosition, oMethod) {\r
+      var i;\r
+      nPosition = parseInt(nPosition, 10);\r
+      if (isNaN(nPosition)) {\r
+        return false;\r
+      }\r
+      for (i=0; i < _onPositionItems.length; i++) {\r
+        if (nPosition === _onPositionItems[i].position) {\r
+          if (!oMethod || (oMethod === _onPositionItems[i].method)) {\r
+            if (_onPositionItems[i].fired) {\r
+              _onPositionFired--;\r
+            }\r
+            _onPositionItems.splice(i, 1);\r
+          }\r
+        }\r
+      }\r
+    };\r
+    this._processOnPosition = function() {\r
+      var i, item, j = _onPositionItems.length;\r
+      if (!j || !_t.playState || _onPositionFired >= j) {\r
+        return false;\r
+      }\r
+      for (i=j-1; i >= 0; i--) {\r
+        item = _onPositionItems[i];\r
+        if (!item.fired && _t.position >= item.position) {\r
+          item.fired = true;\r
+          _onPositionFired++;\r
+          item.method.apply(item.scope, [item.position]);\r
+        }\r
+      }\r
+      return true;\r
+    };\r
+    this._resetOnPosition = function(nPosition) {\r
+      var i, item, j = _onPositionItems.length;\r
+      if (!j) {\r
+        return false;\r
+      }\r
+      for (i=j-1; i >= 0; i--) {\r
+        item = _onPositionItems[i];\r
+        if (item.fired && nPosition <= item.position) {\r
+          item.fired = false;\r
+          _onPositionFired--;\r
+        }\r
+      }\r
+      return true;\r
+    };\r
+    _applyFromTo = function() {\r
+      var _iO = _t._iO,\r
+          f = _iO.from,\r
+          t = _iO.to,\r
+          start, end;\r
+      end = function() {\r
+        _t.clearOnPosition(t, end);\r
+        _t.stop();\r
+      };\r
+      start = function() {\r
+        if (t !== null && !isNaN(t)) {\r
+          _t.onPosition(t, end);\r
+        }\r
+      };\r
+      if (f !== null && !isNaN(f)) {\r
+        _iO.position = f;\r
+        _iO.multiShot = false;\r
+        start();\r
+      }\r
+      return _iO;\r
+    };\r
+    _attachOnPosition = function() {\r
+      var item,\r
+          op = _t._iO.onposition;\r
+      if (op) {\r
+        for (item in op) {\r
+          if (op.hasOwnProperty(item)) {\r
+            _t.onPosition(parseInt(item, 10), op[item]);\r
+          }\r
+        }\r
+      }\r
+    };\r
+    _detachOnPosition = function() {\r
+      var item,\r
+          op = _t._iO.onposition;\r
+      if (op) {\r
+        for (item in op) {\r
+          if (op.hasOwnProperty(item)) {\r
+            _t.clearOnPosition(parseInt(item, 10));\r
+          }\r
+        }\r
+      }\r
+    };\r
+    _start_html5_timer = function() {\r
+      if (_t.isHTML5) {\r
+        _startTimer(_t);\r
+      }\r
+    };\r
+    _stop_html5_timer = function() {\r
+      if (_t.isHTML5) {\r
+        _stopTimer(_t);\r
+      }\r
+    };\r
+    _resetProperties = function(retainPosition) {\r
+      if (!retainPosition) {\r
+        _onPositionItems = [];\r
+        _onPositionFired = 0;\r
+      }\r
+      _onplay_called = false;\r
+      _t._hasTimer = null;\r
+      _t._a = null;\r
+      _t._html5_canplay = false;\r
+      _t.bytesLoaded = null;\r
+      _t.bytesTotal = null;\r
+      _t.duration = (_t._iO && _t._iO.duration ? _t._iO.duration : null);\r
+      _t.durationEstimate = null;\r
+      _t.buffered = [];\r
+      _t.eqData = [];\r
+      _t.eqData.left = [];\r
+      _t.eqData.right = [];\r
+      _t.failures = 0;\r
+      _t.isBuffering = false;\r
+      _t.instanceOptions = {};\r
+      _t.instanceCount = 0;\r
+      _t.loaded = false;\r
+      _t.metadata = {};\r
+      _t.readyState = 0;\r
+      _t.muted = false;\r
+      _t.paused = false;\r
+      _t.peakData = {\r
+        left: 0,\r
+        right: 0\r
+      };\r
+      _t.waveformData = {\r
+        left: [],\r
+        right: []\r
+      };\r
+      _t.playState = 0;\r
+      _t.position = null;\r
+      _t.id3 = {};\r
+    };\r
+    _resetProperties();\r
+    this._onTimer = function(bForce) {\r
+      var duration, isNew = false, time, x = {};\r
+      if (_t._hasTimer || bForce) {\r
+        if (_t._a && (bForce || ((_t.playState > 0 || _t.readyState === 1) && !_t.paused))) {\r
+          duration = _t._get_html5_duration();\r
+          if (duration !== _lastHTML5State.duration) {\r
+            _lastHTML5State.duration = duration;\r
+            _t.duration = duration;\r
+            isNew = true;\r
+          }\r
+          _t.durationEstimate = _t.duration;\r
+          time = (_t._a.currentTime * 1000 || 0);\r
+          if (time !== _lastHTML5State.time) {\r
+            _lastHTML5State.time = time;\r
+            isNew = true;\r
+          }\r
+          if (isNew || bForce) {\r
+            _t._whileplaying(time,x,x,x,x);\r
+          }\r
+        }\r
+        return isNew;\r
+      }\r
+    };\r
+    this._get_html5_duration = function() {\r
+      var _iO = _t._iO,\r
+          d = (_t._a && _t._a.duration ? _t._a.duration*1000 : (_iO && _iO.duration ? _iO.duration : null)),\r
+          result = (d && !isNaN(d) && d !== Infinity ? d : null);\r
+      return result;\r
+    };\r
+    this._apply_loop = function(a, nLoops) {\r
+      a.loop = (nLoops > 1 ? 'loop' : '');\r
+    };\r
+    this._setup_html5 = function(oOptions) {\r
+      var _iO = _mixin(_t._iO, oOptions), d = decodeURI,\r
+          _a = _useGlobalHTML5Audio ? _s._global_a : _t._a,\r
+          _dURL = d(_iO.url),\r
+          _oldIO = (_a && _a._t ? _a._t.instanceOptions : null),\r
+          result;\r
+      if (_a) {\r
+        if (_a._t) {\r
+          if (!_useGlobalHTML5Audio && _dURL === d(_lastURL)) {\r
+            result = _a;\r
+          } else if (_useGlobalHTML5Audio && _oldIO.url === _iO.url && (!_lastURL || (_lastURL === _oldIO.url))) {\r
+            result = _a;\r
+          }\r
+          if (result) {\r
+            _t._apply_loop(_a, _iO.loops);\r
+            return result;\r
+          }\r
+        }\r
+        if (_useGlobalHTML5Audio && _a._t && _a._t.playState && _iO.url !== _oldIO.url) {\r
+          _a._t.stop();\r
+        }\r
+        _resetProperties((_oldIO && _oldIO.url ? _iO.url === _oldIO.url : (_lastURL ? _lastURL === _iO.url : false)));\r
+        _a.src = _iO.url;\r
+        _t.url = _iO.url;\r
+        _lastURL = _iO.url;\r
+        _a._called_load = false;\r
+      } else {\r
+        if (_iO.autoLoad || _iO.autoPlay) {\r
+          _t._a = new Audio(_iO.url);\r
+        } else {\r
+          _t._a = (_isOpera && opera.version() < 10 ? new Audio(null) : new Audio());\r
+        }\r
+        _a = _t._a;\r
+        _a._called_load = false;\r
+        if (_useGlobalHTML5Audio) {\r
+          _s._global_a = _a;\r
+        }\r
+      }\r
+      _t.isHTML5 = true;\r
+      _t._a = _a;\r
+      _a._t = _t;\r
+      _add_html5_events();\r
+      _t._apply_loop(_a, _iO.loops);\r
+      if (_iO.autoLoad || _iO.autoPlay) {\r
+        _t.load();\r
+      } else {\r
+        _a.autobuffer = false;\r
+        _a.preload = 'auto';\r
+      }\r
+      return _a;\r
+    };\r
+    _add_html5_events = function() {\r
+      if (_t._a._added_events) {\r
+        return false;\r
+      }\r
+      var f;\r
+      function add(oEvt, oFn, bCapture) {\r
+        return _t._a ? _t._a.addEventListener(oEvt, oFn, bCapture||false) : null;\r
+      }\r
+      _t._a._added_events = true;\r
+      for (f in _html5_events) {\r
+        if (_html5_events.hasOwnProperty(f)) {\r
+          add(f, _html5_events[f]);\r
+        }\r
+      }\r
+      return true;\r
+    };\r
+    _remove_html5_events = function() {\r
+      var f;\r
+      function remove(oEvt, oFn, bCapture) {\r
+        return (_t._a ? _t._a.removeEventListener(oEvt, oFn, bCapture||false) : null);\r
+      }\r
+      _t._a._added_events = false;\r
+      for (f in _html5_events) {\r
+        if (_html5_events.hasOwnProperty(f)) {\r
+          remove(f, _html5_events[f]);\r
+        }\r
+      }\r
+    };\r
+    this._onload = function(nSuccess) {\r
+      var fN,\r
+          loadOK = (!!(nSuccess) || (!_t.isHTML5 && _fV === 8 && _t.duration));\r
+      _t.loaded = loadOK;\r
+      _t.readyState = loadOK?3:2;\r
+      _t._onbufferchange(0);\r
+      if (_t._iO.onload) {\r
+        _t._iO.onload.apply(_t, [loadOK]);\r
+      }\r
+      return true;\r
+    };\r
+    this._onbufferchange = function(nIsBuffering) {\r
+      if (_t.playState === 0) {\r
+        return false;\r
+      }\r
+      if ((nIsBuffering && _t.isBuffering) || (!nIsBuffering && !_t.isBuffering)) {\r
+        return false;\r
+      }\r
+      _t.isBuffering = (nIsBuffering === 1);\r
+      if (_t._iO.onbufferchange) {\r
+        _t._iO.onbufferchange.apply(_t);\r
+      }\r
+      return true;\r
+    };\r
+    this._onsuspend = function() {\r
+      if (_t._iO.onsuspend) {\r
+        _t._iO.onsuspend.apply(_t);\r
+      }\r
+      return true;\r
+    };\r
+    this._onfailure = function(msg, level, code) {\r
+      _t.failures++;\r
+      if (_t._iO.onfailure && _t.failures === 1) {\r
+        _t._iO.onfailure(_t, msg, level, code);\r
+      } else {\r
+      }\r
+    };\r
+    this._onfinish = function() {\r
+      var _io_onfinish = _t._iO.onfinish;\r
+      _t._onbufferchange(0);\r
+      _t._resetOnPosition(0);\r
+      if (_t.instanceCount) {\r
+        _t.instanceCount--;\r
+        if (!_t.instanceCount) {\r
+          _detachOnPosition();\r
+          _t.playState = 0;\r
+          _t.paused = false;\r
+          _t.instanceCount = 0;\r
+          _t.instanceOptions = {};\r
+          _t._iO = {};\r
+          _stop_html5_timer();\r
+          if (_t.isHTML5) {\r
+            _t.position = 0;\r
+          }\r
+        }\r
+        if (!_t.instanceCount || _t._iO.multiShotEvents) {\r
+          if (_io_onfinish) {\r
+            _io_onfinish.apply(_t);\r
+          }\r
+        }\r
+      }\r
+    };\r
+    this._whileloading = function(nBytesLoaded, nBytesTotal, nDuration, nBufferLength) {\r
+      var _iO = _t._iO;\r
+      _t.bytesLoaded = nBytesLoaded;\r
+      _t.bytesTotal = nBytesTotal;\r
+      _t.duration = Math.floor(nDuration);\r
+      _t.bufferLength = nBufferLength;\r
+      if (!_t.isHTML5 && !_iO.isMovieStar) {\r
+        if (_iO.duration) {\r
+          _t.durationEstimate = (_t.duration > _iO.duration) ? _t.duration : _iO.duration;\r
+        } else {\r
+          _t.durationEstimate = parseInt((_t.bytesTotal / _t.bytesLoaded) * _t.duration, 10);\r
+        }\r
+      } else {\r
+        _t.durationEstimate = _t.duration;\r
+      }\r
+      if (!_t.isHTML5) {\r
+        _t.buffered = [{\r
+          'start': 0,\r
+          'end': _t.duration\r
+        }];\r
+      }\r
+      if ((_t.readyState !== 3 || _t.isHTML5) && _iO.whileloading) {\r
+        _iO.whileloading.apply(_t);\r
+      }\r
+    };\r
+    this._whileplaying = function(nPosition, oPeakData, oWaveformDataLeft, oWaveformDataRight, oEQData) {\r
+      var _iO = _t._iO,\r
+          eqLeft;\r
+      if (isNaN(nPosition) || nPosition === null) {\r
+        return false;\r
+      }\r
+      _t.position = Math.max(0, nPosition);\r
+      _t._processOnPosition();\r
+      if (!_t.isHTML5 && _fV > 8) {\r
+        if (_iO.usePeakData && typeof oPeakData !== 'undefined' && oPeakData) {\r
+          _t.peakData = {\r
+            left: oPeakData.leftPeak,\r
+            right: oPeakData.rightPeak\r
+          };\r
+        }\r
+        if (_iO.useWaveformData && typeof oWaveformDataLeft !== 'undefined' && oWaveformDataLeft) {\r
+          _t.waveformData = {\r
+            left: oWaveformDataLeft.split(','),\r
+            right: oWaveformDataRight.split(',')\r
+          };\r
+        }\r
+        if (_iO.useEQData) {\r
+          if (typeof oEQData !== 'undefined' && oEQData && oEQData.leftEQ) {\r
+            eqLeft = oEQData.leftEQ.split(',');\r
+            _t.eqData = eqLeft;\r
+            _t.eqData.left = eqLeft;\r
+            if (typeof oEQData.rightEQ !== 'undefined' && oEQData.rightEQ) {\r
+              _t.eqData.right = oEQData.rightEQ.split(',');\r
+            }\r
+          }\r
+        }\r
+      }\r
+      if (_t.playState === 1) {\r
+        if (!_t.isHTML5 && _fV === 8 && !_t.position && _t.isBuffering) {\r
+          _t._onbufferchange(0);\r
+        }\r
+        if (_iO.whileplaying) {\r
+          _iO.whileplaying.apply(_t);\r
+        }\r
+      }\r
+      return true;\r
+    };\r
+    this._oncaptiondata = function(oData) {\r
+      _t.captiondata = oData;\r
+      if (_t._iO.oncaptiondata) {\r
+        _t._iO.oncaptiondata.apply(_t, [oData]);\r
+      }\r
+       };\r
+    this._onmetadata = function(oMDProps, oMDData) {\r
+      var oData = {}, i, j;\r
+      for (i = 0, j = oMDProps.length; i < j; i++) {\r
+        oData[oMDProps[i]] = oMDData[i];\r
+      }\r
+      _t.metadata = oData;\r
+      if (_t._iO.onmetadata) {\r
+        _t._iO.onmetadata.apply(_t);\r
+      }\r
+       };\r
+    this._onid3 = function(oID3Props, oID3Data) {\r
+      var oData = [], i, j;\r
+      for (i = 0, j = oID3Props.length; i < j; i++) {\r
+        oData[oID3Props[i]] = oID3Data[i];\r
+      }\r
+      _t.id3 = _mixin(_t.id3, oData);\r
+      if (_t._iO.onid3) {\r
+        _t._iO.onid3.apply(_t);\r
+      }\r
+    };\r
+    this._onconnect = function(bSuccess) {\r
+      bSuccess = (bSuccess === 1);\r
+      _t.connected = bSuccess;\r
+      if (bSuccess) {\r
+        _t.failures = 0;\r
+        if (_idCheck(_t.id)) {\r
+          if (_t.getAutoPlay()) {\r
+            _t.play(undefined, _t.getAutoPlay());\r
+          } else if (_t._iO.autoLoad) {\r
+            _t.load();\r
+          }\r
+        }\r
+        if (_t._iO.onconnect) {\r
+          _t._iO.onconnect.apply(_t, [bSuccess]);\r
+        }\r
+      }\r
+    };\r
+    this._ondataerror = function(sError) {\r
+      if (_t.playState > 0) {\r
+        if (_t._iO.ondataerror) {\r
+          _t._iO.ondataerror.apply(_t);\r
+        }\r
+      }\r
+    };\r
+  };\r
+  _getDocument = function() {\r
+    return (_doc.body || _doc._docElement || _doc.getElementsByTagName('div')[0]);\r
+  };\r
+  _id = function(sID) {\r
+    return _doc.getElementById(sID);\r
+  };\r
+  _mixin = function(oMain, oAdd) {\r
+    var o1 = (oMain || {}), o2, o;\r
+    o2 = (typeof oAdd === 'undefined' ? _s.defaultOptions : oAdd);\r
+    for (o in o2) {\r
+      if (o2.hasOwnProperty(o) && typeof o1[o] === 'undefined') {\r
+        if (typeof o2[o] !== 'object' || o2[o] === null) {\r
+          o1[o] = o2[o];\r
+        } else {\r
+          o1[o] = _mixin(o1[o], o2[o]);\r
+        }\r
+      }\r
+    }\r
+    return o1;\r
+  };\r
+  _extraOptions = {\r
+    'onready': 1,\r
+    'ontimeout': 1,\r
+    'defaultOptions': 1,\r
+    'flash9Options': 1,\r
+    'movieStarOptions': 1\r
+  };\r
+  _assign = function(o, oParent) {\r
+    var i,\r
+        result = true,\r
+        hasParent = (typeof oParent !== 'undefined'),\r
+        setupOptions = _s.setupOptions,\r
+        extraOptions = _extraOptions;\r
+    for (i in o) {\r
+      if (o.hasOwnProperty(i)) {\r
+        if (typeof o[i] !== 'object' || o[i] === null || o[i] instanceof Array) {\r
+          if (hasParent && typeof extraOptions[oParent] !== 'undefined') {\r
+            _s[oParent][i] = o[i];\r
+          } else if (typeof setupOptions[i] !== 'undefined') {\r
+            _s.setupOptions[i] = o[i];\r
+            _s[i] = o[i];\r
+          } else if (typeof extraOptions[i] === 'undefined') {\r
+            _complain(_str((typeof _s[i] === 'undefined' ? 'setupUndef' : 'setupError'), i), 2);\r
+            result = false;\r
+          } else {\r
+            if (_s[i] instanceof Function) {\r
+              _s[i].apply(_s, (o[i] instanceof Array? o[i] : [o[i]]));\r
+            } else {\r
+              _s[i] = o[i];\r
+            }\r
+          }\r
+        } else {\r
+          if (typeof extraOptions[i] === 'undefined') {\r
+            _complain(_str((typeof _s[i] === 'undefined' ? 'setupUndef' : 'setupError'), i), 2);\r
+            result = false;\r
+          } else {\r
+            return _assign(o[i], i);\r
+          }\r
+        }\r
+      }\r
+    }\r
+    return result;\r
+  };\r
+  function _preferFlashCheck(kind) {\r
+    return (_s.preferFlash && _hasFlash && !_s.ignoreFlash && (typeof _s.flash[kind] !== 'undefined' && _s.flash[kind]));\r
+  }\r
+  _event = (function() {\r
+    var old = (_win.attachEvent),\r
+    evt = {\r
+      add: (old?'attachEvent':'addEventListener'),\r
+      remove: (old?'detachEvent':'removeEventListener')\r
+    };\r
+    function getArgs(oArgs) {\r
+      var args = _slice.call(oArgs),\r
+          len = args.length;\r
+      if (old) {\r
+        args[1] = 'on' + args[1];\r
+        if (len > 3) {\r
+          args.pop();\r
+        }\r
+      } else if (len === 3) {\r
+        args.push(false);\r
+      }\r
+      return args;\r
+    }\r
+    function apply(args, sType) {\r
+      var element = args.shift(),\r
+          method = [evt[sType]];\r
+      if (old) {\r
+        element[method](args[0], args[1]);\r
+      } else {\r
+        element[method].apply(element, args);\r
+      }\r
+    }\r
+    function add() {\r
+      apply(getArgs(arguments), 'add');\r
+    }\r
+    function remove() {\r
+      apply(getArgs(arguments), 'remove');\r
+    }\r
+    return {\r
+      'add': add,\r
+      'remove': remove\r
+    };\r
+  }());\r
+  function _html5_event(oFn) {\r
+    return function(e) {\r
+      var t = this._t,\r
+          result;\r
+      if (!t || !t._a) {\r
+        result = null;\r
+      } else {\r
+        result = oFn.call(this, e);\r
+      }\r
+      return result;\r
+    };\r
+  }\r
+  _html5_events = {\r
+    abort: _html5_event(function() {\r
+    }),\r
+    canplay: _html5_event(function() {\r
+      var t = this._t,\r
+          position1K;\r
+      if (t._html5_canplay) {\r
+        return true;\r
+      }\r
+      t._html5_canplay = true;\r
+      t._onbufferchange(0);\r
+      position1K = (typeof t._iO.position !== 'undefined' && !isNaN(t._iO.position)?t._iO.position/1000:null);\r
+      if (t.position && this.currentTime !== position1K) {\r
+        try {\r
+          this.currentTime = position1K;\r
+        } catch(ee) {\r
+        }\r
+      }\r
+      if (t._iO._oncanplay) {\r
+        t._iO._oncanplay();\r
+      }\r
+    }),\r
+    canplaythrough: _html5_event(function() {\r
+      var t = this._t;\r
+      if (!t.loaded) {\r
+        t._onbufferchange(0);\r
+        t._whileloading(t.bytesLoaded, t.bytesTotal, t._get_html5_duration());\r
+        t._onload(true);\r
+      }\r
+    }),\r
+    ended: _html5_event(function() {\r
+      var t = this._t;\r
+      t._onfinish();\r
+    }),\r
+    error: _html5_event(function() {\r
+      this._t._onload(false);\r
+    }),\r
+    loadeddata: _html5_event(function() {\r
+      var t = this._t;\r
+      if (!t._loaded && !_isSafari) {\r
+        t.duration = t._get_html5_duration();\r
+      }\r
+    }),\r
+    loadedmetadata: _html5_event(function() {\r
+    }),\r
+    loadstart: _html5_event(function() {\r
+      this._t._onbufferchange(1);\r
+    }),\r
+    play: _html5_event(function() {\r
+      this._t._onbufferchange(0);\r
+    }),\r
+    playing: _html5_event(function() {\r
+      this._t._onbufferchange(0);\r
+    }),\r
+    progress: _html5_event(function(e) {\r
+      var t = this._t,\r
+          i, j, str, buffered = 0,\r
+          isProgress = (e.type === 'progress'),\r
+          ranges = e.target.buffered,\r
+          loaded = (e.loaded||0),\r
+          total = (e.total||1),\r
+          scale = 1000;\r
+      t.buffered = [];\r
+      if (ranges && ranges.length) {\r
+        for (i=0, j=ranges.length; i<j; i++) {\r
+          t.buffered.push({\r
+            'start': ranges.start(i) * scale,\r
+            'end': ranges.end(i) * scale\r
+          });\r
+        }\r
+        buffered = (ranges.end(0) - ranges.start(0)) * scale;\r
+        loaded = buffered/(e.target.duration*scale);\r
+      }\r
+      if (!isNaN(loaded)) {\r
+        t._onbufferchange(0);\r
+        t._whileloading(loaded, total, t._get_html5_duration());\r
+        if (loaded && total && loaded === total) {\r
+          _html5_events.canplaythrough.call(this, e);\r
+        }\r
+      }\r
+    }),\r
+    ratechange: _html5_event(function() {\r
+    }),\r
+    suspend: _html5_event(function(e) {\r
+      var t = this._t;\r
+      _html5_events.progress.call(this, e);\r
+      t._onsuspend();\r
+    }),\r
+    stalled: _html5_event(function() {\r
+    }),\r
+    timeupdate: _html5_event(function() {\r
+      this._t._onTimer();\r
+    }),\r
+    waiting: _html5_event(function() {\r
+      var t = this._t;\r
+      t._onbufferchange(1);\r
+    })\r
+  };\r
+  _html5OK = function(iO) {\r
+    var result;\r
+    if (iO.serverURL || (iO.type && _preferFlashCheck(iO.type))) {\r
+      result = false;\r
+    } else {\r
+      result = ((iO.type ? _html5CanPlay({type:iO.type}) : _html5CanPlay({url:iO.url}) || _s.html5Only));\r
+    }\r
+    return result;\r
+  };\r
+  _html5Unload = function(oAudio, url) {\r
+    if (oAudio) {\r
+      oAudio.src = url;\r
+    }\r
+  };\r
+  _html5CanPlay = function(o) {\r
+    if (!_s.useHTML5Audio || !_s.hasHTML5) {\r
+      return false;\r
+    }\r
+    var url = (o.url || null),\r
+        mime = (o.type || null),\r
+        aF = _s.audioFormats,\r
+        result,\r
+        offset,\r
+        fileExt,\r
+        item;\r
+    if (mime && typeof _s.html5[mime] !== 'undefined') {\r
+      return (_s.html5[mime] && !_preferFlashCheck(mime));\r
+    }\r
+    if (!_html5Ext) {\r
+      _html5Ext = [];\r
+      for (item in aF) {\r
+        if (aF.hasOwnProperty(item)) {\r
+          _html5Ext.push(item);\r
+          if (aF[item].related) {\r
+            _html5Ext = _html5Ext.concat(aF[item].related);\r
+          }\r
+        }\r
+      }\r
+      _html5Ext = new RegExp('\\.('+_html5Ext.join('|')+')(\\?.*)?$','i');\r
+    }\r
+    fileExt = (url ? url.toLowerCase().match(_html5Ext) : null);\r
+    if (!fileExt || !fileExt.length) {\r
+      if (!mime) {\r
+        result = false;\r
+      } else {\r
+        offset = mime.indexOf(';');\r
+        fileExt = (offset !== -1?mime.substr(0,offset):mime).substr(6);\r
+      }\r
+    } else {\r
+      fileExt = fileExt[1];\r
+    }\r
+    if (fileExt && typeof _s.html5[fileExt] !== 'undefined') {\r
+      result = (_s.html5[fileExt] && !_preferFlashCheck(fileExt));\r
+    } else {\r
+      mime = 'audio/'+fileExt;\r
+      result = _s.html5.canPlayType({type:mime});\r
+      _s.html5[fileExt] = result;\r
+      result = (result && _s.html5[mime] && !_preferFlashCheck(mime));\r
+    }\r
+    return result;\r
+  };\r
+  _testHTML5 = function() {\r
+    if (!_s.useHTML5Audio || !_s.hasHTML5) {\r
+      return false;\r
+    }\r
+    var a = (typeof Audio !== 'undefined' ? (_isOpera && opera.version() < 10 ? new Audio(null) : new Audio()) : null),\r
+        item, lookup, support = {}, aF, i;\r
+    function _cp(m) {\r
+      var canPlay, i, j,\r
+          result = false,\r
+          isOK = false;\r
+      if (!a || typeof a.canPlayType !== 'function') {\r
+        return result;\r
+      }\r
+      if (m instanceof Array) {\r
+        for (i=0, j=m.length; i<j; i++) {\r
+          if (_s.html5[m[i]] || a.canPlayType(m[i]).match(_s.html5Test)) {\r
+            isOK = true;\r
+            _s.html5[m[i]] = true;\r
+            _s.flash[m[i]] = !!(m[i].match(_flashMIME));\r
+          }\r
+        }\r
+        result = isOK;\r
+      } else {\r
+        canPlay = (a && typeof a.canPlayType === 'function' ? a.canPlayType(m) : false);\r
+        result = !!(canPlay && (canPlay.match(_s.html5Test)));\r
+      }\r
+      return result;\r
+    }\r
+    aF = _s.audioFormats;\r
+    for (item in aF) {\r
+      if (aF.hasOwnProperty(item)) {\r
+        lookup = 'audio/' + item;\r
+        support[item] = _cp(aF[item].type);\r
+        support[lookup] = support[item];\r
+        if (item.match(_flashMIME)) {\r
+          _s.flash[item] = true;\r
+          _s.flash[lookup] = true;\r
+        } else {\r
+          _s.flash[item] = false;\r
+          _s.flash[lookup] = false;\r
+        }\r
+        if (aF[item] && aF[item].related) {\r
+          for (i=aF[item].related.length-1; i >= 0; i--) {\r
+            support['audio/'+aF[item].related[i]] = support[item];\r
+            _s.html5[aF[item].related[i]] = support[item];\r
+            _s.flash[aF[item].related[i]] = support[item];\r
+          }\r
+        }\r
+      }\r
+    }\r
+    support.canPlayType = (a?_cp:null);\r
+    _s.html5 = _mixin(_s.html5, support);\r
+    return true;\r
+  };\r
+  _strings = {\r
+  };\r
+  _str = function() {\r
+  };\r
+  _loopFix = function(sOpt) {\r
+    if (_fV === 8 && sOpt.loops > 1 && sOpt.stream) {\r
+      sOpt.stream = false;\r
+    }\r
+    return sOpt;\r
+  };\r
+  _policyFix = function(sOpt, sPre) {\r
+    if (sOpt && !sOpt.usePolicyFile && (sOpt.onid3 || sOpt.usePeakData || sOpt.useWaveformData || sOpt.useEQData)) {\r
+      sOpt.usePolicyFile = true;\r
+    }\r
+    return sOpt;\r
+  };\r
+  _complain = function(sMsg) {\r
+  };\r
+  _doNothing = function() {\r
+    return false;\r
+  };\r
+  _disableObject = function(o) {\r
+    var oProp;\r
+    for (oProp in o) {\r
+      if (o.hasOwnProperty(oProp) && typeof o[oProp] === 'function') {\r
+        o[oProp] = _doNothing;\r
+      }\r
+    }\r
+    oProp = null;\r
+  };\r
+  _failSafely = function(bNoDisable) {\r
+    if (typeof bNoDisable === 'undefined') {\r
+      bNoDisable = false;\r
+    }\r
+    if (_disabled || bNoDisable) {\r
+      _s.disable(bNoDisable);\r
+    }\r
+  };\r
+  _normalizeMovieURL = function(smURL) {\r
+    var urlParams = null, url;\r
+    if (smURL) {\r
+      if (smURL.match(/\.swf(\?.*)?$/i)) {\r
+        urlParams = smURL.substr(smURL.toLowerCase().lastIndexOf('.swf?') + 4);\r
+        if (urlParams) {\r
+          return smURL;\r
+        }\r
+      } else if (smURL.lastIndexOf('/') !== smURL.length - 1) {\r
+        smURL += '/';\r
+      }\r
+    }\r
+    url = (smURL && smURL.lastIndexOf('/') !== - 1 ? smURL.substr(0, smURL.lastIndexOf('/') + 1) : './') + _s.movieURL;\r
+    if (_s.noSWFCache) {\r
+      url += ('?ts=' + new Date().getTime());\r
+    }\r
+    return url;\r
+  };\r
+  _setVersionInfo = function() {\r
+    _fV = parseInt(_s.flashVersion, 10);\r
+    if (_fV !== 8 && _fV !== 9) {\r
+      _s.flashVersion = _fV = _defaultFlashVersion;\r
+    }\r
+    var isDebug = (_s.debugMode || _s.debugFlash?'_debug.swf':'.swf');\r
+    if (_s.useHTML5Audio && !_s.html5Only && _s.audioFormats.mp4.required && _fV < 9) {\r
+      _s.flashVersion = _fV = 9;\r
+    }\r
+    _s.version = _s.versionNumber + (_s.html5Only?' (HTML5-only mode)':(_fV === 9?' (AS3/Flash 9)':' (AS2/Flash 8)'));\r
+    if (_fV > 8) {\r
+      _s.defaultOptions = _mixin(_s.defaultOptions, _s.flash9Options);\r
+      _s.features.buffering = true;\r
+      _s.defaultOptions = _mixin(_s.defaultOptions, _s.movieStarOptions);\r
+      _s.filePatterns.flash9 = new RegExp('\\.(mp3|' + _netStreamTypes.join('|') + ')(\\?.*)?$', 'i');\r
+      _s.features.movieStar = true;\r
+    } else {\r
+      _s.features.movieStar = false;\r
+    }\r
+    _s.filePattern = _s.filePatterns[(_fV !== 8?'flash9':'flash8')];\r
+    _s.movieURL = (_fV === 8?'soundmanager2.swf':'soundmanager2_flash9.swf').replace('.swf', isDebug);\r
+    _s.features.peakData = _s.features.waveformData = _s.features.eqData = (_fV > 8);\r
+  };\r
+  _setPolling = function(bPolling, bHighPerformance) {\r
+    if (!_flash) {\r
+      return false;\r
+    }\r
+    _flash._setPolling(bPolling, bHighPerformance);\r
+  };\r
+  _initDebug = function() {\r
+    if (_s.debugURLParam.test(_wl)) {\r
+      _s.debugMode = true;\r
+    }\r
+  };\r
+  _idCheck = this.getSoundById;\r
+  _getSWFCSS = function() {\r
+    var css = [];\r
+    if (_s.debugMode) {\r
+      css.push(_swfCSS.sm2Debug);\r
+    }\r
+    if (_s.debugFlash) {\r
+      css.push(_swfCSS.flashDebug);\r
+    }\r
+    if (_s.useHighPerformance) {\r
+      css.push(_swfCSS.highPerf);\r
+    }\r
+    return css.join(' ');\r
+  };\r
+  _flashBlockHandler = function() {\r
+    var name = _str('fbHandler'),\r
+        p = _s.getMoviePercent(),\r
+        css = _swfCSS,\r
+        error = {type:'FLASHBLOCK'};\r
+    if (_s.html5Only) {\r
+      return false;\r
+    }\r
+    if (!_s.ok()) {\r
+      if (_needsFlash) {\r
+        _s.oMC.className = _getSWFCSS() + ' ' + css.swfDefault + ' ' + (p === null?css.swfTimedout:css.swfError);\r
+      }\r
+      _s.didFlashBlock = true;\r
+      _processOnEvents({type:'ontimeout', ignoreInit:true, error:error});\r
+      _catchError(error);\r
+    } else {\r
+      if (_s.oMC) {\r
+        _s.oMC.className = [_getSWFCSS(), css.swfDefault, css.swfLoaded + (_s.didFlashBlock?' '+css.swfUnblocked:'')].join(' ');\r
+      }\r
+    }\r
+  };\r
+  _addOnEvent = function(sType, oMethod, oScope) {\r
+    if (typeof _on_queue[sType] === 'undefined') {\r
+      _on_queue[sType] = [];\r
+    }\r
+    _on_queue[sType].push({\r
+      'method': oMethod,\r
+      'scope': (oScope || null),\r
+      'fired': false\r
+    });\r
+  };\r
+  _processOnEvents = function(oOptions) {\r
+    if (!oOptions) {\r
+      oOptions = {\r
+        type: (_s.ok() ? 'onready' : 'ontimeout')\r
+      };\r
+    }\r
+    if (!_didInit && oOptions && !oOptions.ignoreInit) {\r
+      return false;\r
+    }\r
+    if (oOptions.type === 'ontimeout' && (_s.ok() || (_disabled && !oOptions.ignoreInit))) {\r
+      return false;\r
+    }\r
+    var status = {\r
+          success: (oOptions && oOptions.ignoreInit?_s.ok():!_disabled)\r
+        },\r
+        srcQueue = (oOptions && oOptions.type?_on_queue[oOptions.type]||[]:[]),\r
+        queue = [], i, j,\r
+        args = [status],\r
+        canRetry = (_needsFlash && _s.useFlashBlock && !_s.ok());\r
+    if (oOptions.error) {\r
+      args[0].error = oOptions.error;\r
+    }\r
+    for (i = 0, j = srcQueue.length; i < j; i++) {\r
+      if (srcQueue[i].fired !== true) {\r
+        queue.push(srcQueue[i]);\r
+      }\r
+    }\r
+    if (queue.length) {\r
+      for (i = 0, j = queue.length; i < j; i++) {\r
+        if (queue[i].scope) {\r
+          queue[i].method.apply(queue[i].scope, args);\r
+        } else {\r
+          queue[i].method.apply(this, args);\r
+        }\r
+        if (!canRetry) {\r
+          queue[i].fired = true;\r
+        }\r
+      }\r
+    }\r
+    return true;\r
+  };\r
+  _initUserOnload = function() {\r
+    _win.setTimeout(function() {\r
+      if (_s.useFlashBlock) {\r
+        _flashBlockHandler();\r
+      }\r
+      _processOnEvents();\r
+      if (typeof _s.onload === 'function') {\r
+        _s.onload.apply(_win);\r
+      }\r
+      if (_s.waitForWindowLoad) {\r
+        _event.add(_win, 'load', _initUserOnload);\r
+      }\r
+    },1);\r
+  };\r
+  _detectFlash = function() {\r
+    if (typeof _hasFlash !== 'undefined') {\r
+      return _hasFlash;\r
+    }\r
+    var hasPlugin = false, n = navigator, nP = n.plugins, obj, type, types, AX = _win.ActiveXObject;\r
+    if (nP && nP.length) {\r
+      type = 'application/x-shockwave-flash';\r
+      types = n.mimeTypes;\r
+      if (types && types[type] && types[type].enabledPlugin && types[type].enabledPlugin.description) {\r
+        hasPlugin = true;\r
+      }\r
+    } else if (typeof AX !== 'undefined') {\r
+      try {\r
+        obj = new AX('ShockwaveFlash.ShockwaveFlash');\r
+      } catch(e) {\r
+      }\r
+      hasPlugin = (!!obj);\r
+    }\r
+    _hasFlash = hasPlugin;\r
+    return hasPlugin;\r
+  };\r
+  _featureCheck = function() {\r
+    var needsFlash,\r
+        item,\r
+        result = true,\r
+        formats = _s.audioFormats,\r
+        isSpecial = (_is_iDevice && !!(_ua.match(/os (1|2|3_0|3_1)/i)));\r
+    if (isSpecial) {\r
+      _s.hasHTML5 = false;\r
+      _s.html5Only = true;\r
+      if (_s.oMC) {\r
+        _s.oMC.style.display = 'none';\r
+      }\r
+      result = false;\r
+    } else {\r
+      if (_s.useHTML5Audio) {\r
+        if (!_s.html5 || !_s.html5.canPlayType) {\r
+          _s.hasHTML5 = false;\r
+        }\r
+      }\r
+    }\r
+    if (_s.useHTML5Audio && _s.hasHTML5) {\r
+      for (item in formats) {\r
+        if (formats.hasOwnProperty(item)) {\r
+          if ((formats[item].required && !_s.html5.canPlayType(formats[item].type)) || (_s.preferFlash && (_s.flash[item] || _s.flash[formats[item].type]))) {\r
+            needsFlash = true;\r
+          }\r
+        }\r
+      }\r
+    }\r
+    if (_s.ignoreFlash) {\r
+      needsFlash = false;\r
+    }\r
+    _s.html5Only = (_s.hasHTML5 && _s.useHTML5Audio && !needsFlash);\r
+    return (!_s.html5Only);\r
+  };\r
+  _parseURL = function(url) {\r
+    var i, j, urlResult = 0, result;\r
+    if (url instanceof Array) {\r
+      for (i=0, j=url.length; i<j; i++) {\r
+        if (url[i] instanceof Object) {\r
+          if (_s.canPlayMIME(url[i].type)) {\r
+            urlResult = i;\r
+            break;\r
+          }\r
+        } else if (_s.canPlayURL(url[i])) {\r
+          urlResult = i;\r
+          break;\r
+        }\r
+      }\r
+      if (url[urlResult].url) {\r
+        url[urlResult] = url[urlResult].url;\r
+      }\r
+      result = url[urlResult];\r
+    } else {\r
+      result = url;\r
+    }\r
+    return result;\r
+  };\r
+  _startTimer = function(oSound) {\r
+    if (!oSound._hasTimer) {\r
+      oSound._hasTimer = true;\r
+      if (!_mobileHTML5 && _s.html5PollingInterval) {\r
+        if (_h5IntervalTimer === null && _h5TimerCount === 0) {\r
+          _h5IntervalTimer = _win.setInterval(_timerExecute, _s.html5PollingInterval);\r
+        }\r
+        _h5TimerCount++;\r
+      }\r
+    }\r
+  };\r
+  _stopTimer = function(oSound) {\r
+    if (oSound._hasTimer) {\r
+      oSound._hasTimer = false;\r
+      if (!_mobileHTML5 && _s.html5PollingInterval) {\r
+        _h5TimerCount--;\r
+      }\r
+    }\r
+  };\r
+  _timerExecute = function() {\r
+    var i;\r
+    if (_h5IntervalTimer !== null && !_h5TimerCount) {\r
+      _win.clearInterval(_h5IntervalTimer);\r
+      _h5IntervalTimer = null;\r
+      return false;\r
+    }\r
+    for (i = _s.soundIDs.length-1; i >= 0; i--) {\r
+      if (_s.sounds[_s.soundIDs[i]].isHTML5 && _s.sounds[_s.soundIDs[i]]._hasTimer) {\r
+        _s.sounds[_s.soundIDs[i]]._onTimer();\r
+      }\r
+    }\r
+  };\r
+  _catchError = function(options) {\r
+    options = (typeof options !== 'undefined' ? options : {});\r
+    if (typeof _s.onerror === 'function') {\r
+      _s.onerror.apply(_win, [{type:(typeof options.type !== 'undefined' ? options.type : null)}]);\r
+    }\r
+    if (typeof options.fatal !== 'undefined' && options.fatal) {\r
+      _s.disable();\r
+    }\r
+  };\r
+  _badSafariFix = function() {\r
+    if (!_isBadSafari || !_detectFlash()) {\r
+      return false;\r
+    }\r
+    var aF = _s.audioFormats, i, item;\r
+    for (item in aF) {\r
+      if (aF.hasOwnProperty(item)) {\r
+        if (item === 'mp3' || item === 'mp4') {\r
+          _s.html5[item] = false;\r
+          if (aF[item] && aF[item].related) {\r
+            for (i = aF[item].related.length-1; i >= 0; i--) {\r
+              _s.html5[aF[item].related[i]] = false;\r
+            }\r
+          }\r
+        }\r
+      }\r
+    }\r
+  };\r
+  this._setSandboxType = function(sandboxType) {\r
+  };\r
+  this._externalInterfaceOK = function(flashDate, swfVersion) {\r
+    if (_s.swfLoaded) {\r
+      return false;\r
+    }\r
+    var e, eiTime = new Date().getTime();\r
+    _s.swfLoaded = true;\r
+    _tryInitOnFocus = false;\r
+    if (_isBadSafari) {\r
+      _badSafariFix();\r
+    }\r
+    setTimeout(_init, _isIE ? 100 : 1);\r
+  };\r
+  _createMovie = function(smID, smURL) {\r
+    if (_didAppend && _appendSuccess) {\r
+      return false;\r
+    }\r
+    function _initMsg() {\r
+    }\r
+    if (_s.html5Only) {\r
+      _setVersionInfo();\r
+      _initMsg();\r
+      _s.oMC = _id(_s.movieID);\r
+      _init();\r
+      _didAppend = true;\r
+      _appendSuccess = true;\r
+      return false;\r
+    }\r
+    var remoteURL = (smURL || _s.url),\r
+    localURL = (_s.altURL || remoteURL),\r
+    swfTitle = 'JS/Flash audio component (SoundManager 2)',\r
+    oTarget = _getDocument(),\r
+    extraClass = _getSWFCSS(),\r
+    isRTL = null,\r
+    html = _doc.getElementsByTagName('html')[0],\r
+    oEmbed, oMovie, tmp, movieHTML, oEl, s, x, sClass;\r
+    isRTL = (html && html.dir && html.dir.match(/rtl/i));\r
+    smID = (typeof smID === 'undefined'?_s.id:smID);\r
+    function param(name, value) {\r
+      return '<param name="'+name+'" value="'+value+'" />';\r
+    }\r
+    _setVersionInfo();\r
+    _s.url = _normalizeMovieURL(_overHTTP?remoteURL:localURL);\r
+    smURL = _s.url;\r
+    _s.wmode = (!_s.wmode && _s.useHighPerformance ? 'transparent' : _s.wmode);\r
+    if (_s.wmode !== null && (_ua.match(/msie 8/i) || (!_isIE && !_s.useHighPerformance)) && navigator.platform.match(/win32|win64/i)) {\r
+      _s.wmode = null;\r
+    }\r
+    oEmbed = {\r
+      'name': smID,\r
+      'id': smID,\r
+      'src': smURL,\r
+      'quality': 'high',\r
+      'allowScriptAccess': _s.allowScriptAccess,\r
+      'bgcolor': _s.bgColor,\r
+      'pluginspage': _http+'www.macromedia.com/go/getflashplayer',\r
+      'title': swfTitle,\r
+      'type': 'application/x-shockwave-flash',\r
+      'wmode': _s.wmode,\r
+      'hasPriority': 'true'\r
+    };\r
+    if (_s.debugFlash) {\r
+      oEmbed.FlashVars = 'debug=1';\r
+    }\r
+    if (!_s.wmode) {\r
+      delete oEmbed.wmode;\r
+    }\r
+    if (_isIE) {\r
+      oMovie = _doc.createElement('div');\r
+      movieHTML = [\r
+        '<object id="' + smID + '" data="' + smURL + '" type="' + oEmbed.type + '" title="' + oEmbed.title +'" classid="clsid:D27CDB6E-AE6D-11cf-96B8-444553540000" codebase="' + _http+'download.macromedia.com/pub/shockwave/cabs/flash/swflash.cab#version=6,0,40,0">',\r
+        param('movie', smURL),\r
+        param('AllowScriptAccess', _s.allowScriptAccess),\r
+        param('quality', oEmbed.quality),\r
+        (_s.wmode? param('wmode', _s.wmode): ''),\r
+        param('bgcolor', _s.bgColor),\r
+        param('hasPriority', 'true'),\r
+        (_s.debugFlash ? param('FlashVars', oEmbed.FlashVars) : ''),\r
+        '</object>'\r
+      ].join('');\r
+    } else {\r
+      oMovie = _doc.createElement('embed');\r
+      for (tmp in oEmbed) {\r
+        if (oEmbed.hasOwnProperty(tmp)) {\r
+          oMovie.setAttribute(tmp, oEmbed[tmp]);\r
+        }\r
+      }\r
+    }\r
+    _initDebug();\r
+    extraClass = _getSWFCSS();\r
+    oTarget = _getDocument();\r
+    if (oTarget) {\r
+      _s.oMC = (_id(_s.movieID) || _doc.createElement('div'));\r
+      if (!_s.oMC.id) {\r
+        _s.oMC.id = _s.movieID;\r
+        _s.oMC.className = _swfCSS.swfDefault + ' ' + extraClass;\r
+        s = null;\r
+        oEl = null;\r
+        if (!_s.useFlashBlock) {\r
+          if (_s.useHighPerformance) {\r
+            s = {\r
+              'position': 'fixed',\r
+              'width': '8px',\r
+              'height': '8px',\r
+              'bottom': '0px',\r
+              'left': '0px',\r
+              'overflow': 'hidden'\r
+            };\r
+          } else {\r
+            s = {\r
+              'position': 'absolute',\r
+              'width': '6px',\r
+              'height': '6px',\r
+              'top': '-9999px',\r
+              'left': '-9999px'\r
+            };\r
+            if (isRTL) {\r
+              s.left = Math.abs(parseInt(s.left,10))+'px';\r
+            }\r
+          }\r
+        }\r
+        if (_isWebkit) {\r
+          _s.oMC.style.zIndex = 10000;\r
+        }\r
+        if (!_s.debugFlash) {\r
+          for (x in s) {\r
+            if (s.hasOwnProperty(x)) {\r
+              _s.oMC.style[x] = s[x];\r
+            }\r
+          }\r
+        }\r
+        try {\r
+          if (!_isIE) {\r
+            _s.oMC.appendChild(oMovie);\r
+          }\r
+          oTarget.appendChild(_s.oMC);\r
+          if (_isIE) {\r
+            oEl = _s.oMC.appendChild(_doc.createElement('div'));\r
+            oEl.className = _swfCSS.swfBox;\r
+            oEl.innerHTML = movieHTML;\r
+          }\r
+          _appendSuccess = true;\r
+        } catch(e) {\r
+          throw new Error(_str('domError')+' \n'+e.toString());\r
+        }\r
+      } else {\r
+        sClass = _s.oMC.className;\r
+        _s.oMC.className = (sClass?sClass+' ':_swfCSS.swfDefault) + (extraClass?' '+extraClass:'');\r
+        _s.oMC.appendChild(oMovie);\r
+        if (_isIE) {\r
+          oEl = _s.oMC.appendChild(_doc.createElement('div'));\r
+          oEl.className = _swfCSS.swfBox;\r
+          oEl.innerHTML = movieHTML;\r
+        }\r
+        _appendSuccess = true;\r
+      }\r
+    }\r
+    _didAppend = true;\r
+    _initMsg();\r
+    return true;\r
+  };\r
+  _initMovie = function() {\r
+    if (_s.html5Only) {\r
+      _createMovie();\r
+      return false;\r
+    }\r
+    if (_flash) {\r
+      return false;\r
+    }\r
+    if (!_s.url) {\r
+       return false;\r
+    }\r
+    _flash = _s.getMovie(_s.id);\r
+    if (!_flash) {\r
+      if (!_oRemoved) {\r
+        _createMovie(_s.id, _s.url);\r
+      } else {\r
+        if (!_isIE) {\r
+          _s.oMC.appendChild(_oRemoved);\r
+        } else {\r
+          _s.oMC.innerHTML = _oRemovedHTML;\r
+        }\r
+        _oRemoved = null;\r
+        _didAppend = true;\r
+      }\r
+      _flash = _s.getMovie(_s.id);\r
+    }\r
+    if (typeof _s.oninitmovie === 'function') {\r
+      setTimeout(_s.oninitmovie, 1);\r
+    }\r
+    return true;\r
+  };\r
+  _delayWaitForEI = function() {\r
+    setTimeout(_waitForEI, 1000);\r
+  };\r
+  _waitForEI = function() {\r
+    var p,\r
+        loadIncomplete = false;\r
+    if (!_s.url) {\r
+      return false;\r
+    }\r
+    if (_waitingForEI) {\r
+      return false;\r
+    }\r
+    _waitingForEI = true;\r
+    _event.remove(_win, 'load', _delayWaitForEI);\r
+    if (_tryInitOnFocus && !_isFocused) {\r
+      return false;\r
+    }\r
+    if (!_didInit) {\r
+      p = _s.getMoviePercent();\r
+      if (p > 0 && p < 100) {\r
+        loadIncomplete = true;\r
+      }\r
+    }\r
+    setTimeout(function() {\r
+      p = _s.getMoviePercent();\r
+      if (loadIncomplete) {\r
+        _waitingForEI = false;\r
+        _win.setTimeout(_delayWaitForEI, 1);\r
+        return false;\r
+      }\r
+      if (!_didInit && _okToDisable) {\r
+        if (p === null) {\r
+          if (_s.useFlashBlock || _s.flashLoadTimeout === 0) {\r
+            if (_s.useFlashBlock) {\r
+              _flashBlockHandler();\r
+            }\r
+          } else {\r
+            _failSafely(true);\r
+          }\r
+        } else {\r
+          if (_s.flashLoadTimeout === 0) {\r
+          } else {\r
+            _failSafely(true);\r
+          }\r
+        }\r
+      }\r
+    }, _s.flashLoadTimeout);\r
+  };\r
+  _handleFocus = function() {\r
+    function cleanup() {\r
+      _event.remove(_win, 'focus', _handleFocus);\r
+    }\r
+    if (_isFocused || !_tryInitOnFocus) {\r
+      cleanup();\r
+      return true;\r
+    }\r
+    _okToDisable = true;\r
+    _isFocused = true;\r
+    _waitingForEI = false;\r
+    _delayWaitForEI();\r
+    cleanup();\r
+    return true;\r
+  };\r
+  _showSupport = function() {\r
+  };\r
+  _initComplete = function(bNoDisable) {\r
+    if (_didInit) {\r
+      return false;\r
+    }\r
+    if (_s.html5Only) {\r
+      _didInit = true;\r
+      _initUserOnload();\r
+      return true;\r
+    }\r
+    var wasTimeout = (_s.useFlashBlock && _s.flashLoadTimeout && !_s.getMoviePercent()),\r
+        result = true,\r
+        error;\r
+    if (!wasTimeout) {\r
+      _didInit = true;\r
+      if (_disabled) {\r
+        error = {type: (!_hasFlash && _needsFlash ? 'NO_FLASH' : 'INIT_TIMEOUT')};\r
+      }\r
+    }\r
+    if (_disabled || bNoDisable) {\r
+      if (_s.useFlashBlock && _s.oMC) {\r
+        _s.oMC.className = _getSWFCSS() + ' ' + (_s.getMoviePercent() === null?_swfCSS.swfTimedout:_swfCSS.swfError);\r
+      }\r
+      _processOnEvents({type:'ontimeout', error:error, ignoreInit: true});\r
+      _catchError(error);\r
+      result = false;\r
+    } else {\r
+    }\r
+    if (!_disabled) {\r
+      if (_s.waitForWindowLoad && !_windowLoaded) {\r
+        _event.add(_win, 'load', _initUserOnload);\r
+      } else {\r
+        _initUserOnload();\r
+      }\r
+    }\r
+    return result;\r
+  };\r
+  _setProperties = function() {\r
+    var i,\r
+        o = _s.setupOptions;\r
+    for (i in o) {\r
+      if (o.hasOwnProperty(i)) {\r
+        if (typeof _s[i] === 'undefined') {\r
+          _s[i] = o[i];\r
+        } else if (_s[i] !== o[i]) {\r
+          _s.setupOptions[i] = _s[i];\r
+        }\r
+      }\r
+    }\r
+  };\r
+  _init = function() {\r
+    if (_didInit) {\r
+      return false;\r
+    }\r
+    function _cleanup() {\r
+      _event.remove(_win, 'load', _s.beginDelayedInit);\r
+    }\r
+    if (_s.html5Only) {\r
+      if (!_didInit) {\r
+        _cleanup();\r
+        _s.enabled = true;\r
+        _initComplete();\r
+      }\r
+      return true;\r
+    }\r
+    _initMovie();\r
+    try {\r
+      _flash._externalInterfaceTest(false);\r
+      _setPolling(true, (_s.flashPollingInterval || (_s.useHighPerformance ? 10 : 50)));\r
+      if (!_s.debugMode) {\r
+        _flash._disableDebug();\r
+      }\r
+      _s.enabled = true;\r
+      if (!_s.html5Only) {\r
+        _event.add(_win, 'unload', _doNothing);\r
+      }\r
+    } catch(e) {\r
+      _catchError({type:'JS_TO_FLASH_EXCEPTION', fatal:true});\r
+      _failSafely(true);\r
+      _initComplete();\r
+      return false;\r
+    }\r
+    _initComplete();\r
+    _cleanup();\r
+    return true;\r
+  };\r
+  _domContentLoaded = function() {\r
+    if (_didDCLoaded) {\r
+      return false;\r
+    }\r
+    _didDCLoaded = true;\r
+    _setProperties();\r
+    _initDebug();\r
+    if (!_hasFlash && _s.hasHTML5) {\r
+      _s.setup({\r
+        'useHTML5Audio': true,\r
+        'preferFlash': false\r
+      });\r
+    }\r
+    _testHTML5();\r
+    _s.html5.usingFlash = _featureCheck();\r
+    _needsFlash = _s.html5.usingFlash;\r
+    _showSupport();\r
+    if (!_hasFlash && _needsFlash) {\r
+      _s.setup({\r
+        'flashLoadTimeout': 1\r
+      });\r
+    }\r
+    if (_doc.removeEventListener) {\r
+      _doc.removeEventListener('DOMContentLoaded', _domContentLoaded, false);\r
+    }\r
+    _initMovie();\r
+    return true;\r
+  };\r
+  _domContentLoadedIE = function() {\r
+    if (_doc.readyState === 'complete') {\r
+      _domContentLoaded();\r
+      _doc.detachEvent('onreadystatechange', _domContentLoadedIE);\r
+    }\r
+    return true;\r
+  };\r
+  _winOnLoad = function() {\r
+    _windowLoaded = true;\r
+    _event.remove(_win, 'load', _winOnLoad);\r
+  };\r
+  _detectFlash();\r
+  _event.add(_win, 'focus', _handleFocus);\r
+  _event.add(_win, 'load', _delayWaitForEI);\r
+  _event.add(_win, 'load', _winOnLoad);\r
+  if (_doc.addEventListener) {\r
+    _doc.addEventListener('DOMContentLoaded', _domContentLoaded, false);\r
+  } else if (_doc.attachEvent) {\r
+    _doc.attachEvent('onreadystatechange', _domContentLoadedIE);\r
+  } else {\r
+    _catchError({type:'NO_DOM2_EVENTS', fatal:true});\r
+  }\r
+}\r
+// SM2_DEFER details: http://www.schillmania.com/projects/soundmanager2/doc/getstarted/#lazy-loading\r
+if (typeof SM2_DEFER === 'undefined' || !SM2_DEFER) {\r
+  soundManager = new SoundManager();\r
+}\r
+window.SoundManager = SoundManager;\r
+window.soundManager = soundManager;\r
+}(window));
\ No newline at end of file
diff --git a/timeside/player/static/timeside/js/libs/soundmanager2.js b/timeside/player/static/timeside/js/libs/soundmanager2.js
new file mode 100644 (file)
index 0000000..d9d4422
--- /dev/null
@@ -0,0 +1,5530 @@
+/** @license\r
+ *\r
+ * SoundManager 2: JavaScript Sound for the Web\r
+ * ----------------------------------------------\r
+ * http://schillmania.com/projects/soundmanager2/\r
+ *\r
+ * Copyright (c) 2007, Scott Schiller. All rights reserved.\r
+ * Code provided under the BSD License:\r
+ * http://schillmania.com/projects/soundmanager2/license.txt\r
+ *\r
+ * V2.97a.20120916\r
+ */\r
+\r
+/*global window, SM2_DEFER, sm2Debugger, console, document, navigator, setTimeout, setInterval, clearInterval, Audio */\r
+/*jslint regexp: true, sloppy: true, white: true, nomen: true, plusplus: true */\r
+\r
+/**\r
+ * About this file\r
+ * ---------------\r
+ * This is the fully-commented source version of the SoundManager 2 API,\r
+ * recommended for use during development and testing.\r
+ *\r
+ * See soundmanager2-nodebug-jsmin.js for an optimized build (~11KB with gzip.)\r
+ * http://schillmania.com/projects/soundmanager2/doc/getstarted/#basic-inclusion\r
+ * Alternately, serve this file with gzip for 75% compression savings (~30KB over HTTP.)\r
+ *\r
+ * You may notice <d> and </d> comments in this source; these are delimiters for\r
+ * debug blocks which are removed in the -nodebug builds, further optimizing code size.\r
+ *\r
+ * Also, as you may note: Whoa, reliable cross-platform/device audio support is hard! ;)\r
+ */\r
+\r
+(function(window) {\r
+\r
+var soundManager = null;\r
+\r
+/**\r
+ * The SoundManager constructor.\r
+ *\r
+ * @constructor\r
+ * @param {string} smURL Optional: Path to SWF files\r
+ * @param {string} smID Optional: The ID to use for the SWF container element\r
+ * @this {SoundManager}\r
+ * @return {SoundManager} The new SoundManager instance\r
+ */\r
+\r
+function SoundManager(smURL, smID) {\r
+\r
+  /**\r
+   * soundManager configuration options list\r
+   * defines top-level configuration properties to be applied to the soundManager instance (eg. soundManager.flashVersion)\r
+   * to set these properties, use the setup() method - eg., soundManager.setup({url: '/swf/', flashVersion: 9})\r
+   */\r
+\r
+  this.setupOptions = {\r
+\r
+    'url': (smURL || null),             // path (directory) where SoundManager 2 SWFs exist, eg., /path/to/swfs/\r
+    'flashVersion': 8,                  // flash build to use (8 or 9.) Some API features require 9.\r
+    'debugMode': true,                  // enable debugging output (console.log() with HTML fallback)\r
+    'debugFlash': false,                // enable debugging output inside SWF, troubleshoot Flash/browser issues\r
+    'useConsole': true,                 // use console.log() if available (otherwise, writes to #soundmanager-debug element)\r
+    'consoleOnly': true,                // if console is being used, do not create/write to #soundmanager-debug\r
+    'waitForWindowLoad': false,         // force SM2 to wait for window.onload() before trying to call soundManager.onload()\r
+    'bgColor': '#ffffff',               // SWF background color. N/A when wmode = 'transparent'\r
+    'useHighPerformance': false,        // position:fixed flash movie can help increase js/flash speed, minimize lag\r
+    'flashPollingInterval': null,       // msec affecting whileplaying/loading callback frequency. If null, default of 50 msec is used.\r
+    'html5PollingInterval': null,       // msec affecting whileplaying() for HTML5 audio, excluding mobile devices. If null, native HTML5 update events are used.\r
+    'flashLoadTimeout': 1000,           // msec to wait for flash movie to load before failing (0 = infinity)\r
+    'wmode': null,                      // flash rendering mode - null, 'transparent', or 'opaque' (last two allow z-index to work)\r
+    'allowScriptAccess': 'always',      // for scripting the SWF (object/embed property), 'always' or 'sameDomain'\r
+    'useFlashBlock': false,             // *requires flashblock.css, see demos* - allow recovery from flash blockers. Wait indefinitely and apply timeout CSS to SWF, if applicable.\r
+    'useHTML5Audio': true,              // use HTML5 Audio() where API is supported (most Safari, Chrome versions), Firefox (no MP3/MP4.) Ideally, transparent vs. Flash API where possible.\r
+    'html5Test': /^(probably|maybe)$/i, // HTML5 Audio() format support test. Use /^probably$/i; if you want to be more conservative.\r
+    'preferFlash': true,                // overrides useHTML5audio. if true and flash support present, will try to use flash for MP3/MP4 as needed since HTML5 audio support is still quirky in browsers.\r
+    'noSWFCache': false                 // if true, appends ?ts={date} to break aggressive SWF caching.\r
+\r
+  };\r
+\r
+  this.defaultOptions = {\r
+\r
+    /**\r
+     * the default configuration for sound objects made with createSound() and related methods\r
+     * eg., volume, auto-load behaviour and so forth\r
+     */\r
+\r
+    'autoLoad': false,        // enable automatic loading (otherwise .load() will be called on demand with .play(), the latter being nicer on bandwidth - if you want to .load yourself, you also can)\r
+    'autoPlay': false,        // enable playing of file as soon as possible (much faster if "stream" is true)\r
+    'from': null,             // position to start playback within a sound (msec), default = beginning\r
+    'loops': 1,               // how many times to repeat the sound (position will wrap around to 0, setPosition() will break out of loop when >0)\r
+    'onid3': null,            // callback function for "ID3 data is added/available"\r
+    'onload': null,           // callback function for "load finished"\r
+    'whileloading': null,     // callback function for "download progress update" (X of Y bytes received)\r
+    'onplay': null,           // callback for "play" start\r
+    'onpause': null,          // callback for "pause"\r
+    'onresume': null,         // callback for "resume" (pause toggle)\r
+    'whileplaying': null,     // callback during play (position update)\r
+    'onposition': null,       // object containing times and function callbacks for positions of interest\r
+    'onstop': null,           // callback for "user stop"\r
+    'onfailure': null,        // callback function for when playing fails\r
+    'onfinish': null,         // callback function for "sound finished playing"\r
+    'multiShot': true,        // let sounds "restart" or layer on top of each other when played multiple times, rather than one-shot/one at a time\r
+    'multiShotEvents': false, // fire multiple sound events (currently onfinish() only) when multiShot is enabled\r
+    'position': null,         // offset (milliseconds) to seek to within loaded sound data.\r
+    'pan': 0,                 // "pan" settings, left-to-right, -100 to 100\r
+    'stream': true,           // allows playing before entire file has loaded (recommended)\r
+    'to': null,               // position to end playback within a sound (msec), default = end\r
+    'type': null,             // MIME-like hint for file pattern / canPlay() tests, eg. audio/mp3\r
+    'usePolicyFile': false,   // enable crossdomain.xml request for audio on remote domains (for ID3/waveform access)\r
+    'volume': 100             // self-explanatory. 0-100, the latter being the max.\r
+\r
+  };\r
+\r
+  this.flash9Options = {\r
+\r
+    /**\r
+     * flash 9-only options,\r
+     * merged into defaultOptions if flash 9 is being used\r
+     */\r
+\r
+    'isMovieStar': null,      // "MovieStar" MPEG4 audio mode. Null (default) = auto detect MP4, AAC etc. based on URL. true = force on, ignore URL\r
+    'usePeakData': false,     // enable left/right channel peak (level) data\r
+    'useWaveformData': false, // enable sound spectrum (raw waveform data) - NOTE: May increase CPU load.\r
+    'useEQData': false,       // enable sound EQ (frequency spectrum data) - NOTE: May increase CPU load.\r
+    'onbufferchange': null,   // callback for "isBuffering" property change\r
+    'ondataerror': null       // callback for waveform/eq data access error (flash playing audio in other tabs/domains)\r
+\r
+  };\r
+\r
+  this.movieStarOptions = {\r
+\r
+    /**\r
+     * flash 9.0r115+ MPEG4 audio options,\r
+     * merged into defaultOptions if flash 9+movieStar mode is enabled\r
+     */\r
+\r
+    'bufferTime': 3,          // seconds of data to buffer before playback begins (null = flash default of 0.1 seconds - if AAC playback is gappy, try increasing.)\r
+    'serverURL': null,        // rtmp: FMS or FMIS server to connect to, required when requesting media via RTMP or one of its variants\r
+    'onconnect': null,        // rtmp: callback for connection to flash media server\r
+    'duration': null          // rtmp: song duration (msec)\r
+\r
+  };\r
+\r
+  this.audioFormats = {\r
+\r
+    /**\r
+     * determines HTML5 support + flash requirements.\r
+     * if no support (via flash and/or HTML5) for a "required" format, SM2 will fail to start.\r
+     * flash fallback is used for MP3 or MP4 if HTML5 can't play it (or if preferFlash = true)\r
+     */\r
+\r
+    'mp3': {\r
+      'type': ['audio/mpeg; codecs="mp3"', 'audio/mpeg', 'audio/mp3', 'audio/MPA', 'audio/mpa-robust'],\r
+      'required': true\r
+    },\r
+\r
+    'mp4': {\r
+      'related': ['aac','m4a','m4b'], // additional formats under the MP4 container\r
+      'type': ['audio/mp4; codecs="mp4a.40.2"', 'audio/aac', 'audio/x-m4a', 'audio/MP4A-LATM', 'audio/mpeg4-generic'],\r
+      'required': false\r
+    },\r
+\r
+    'ogg': {\r
+      'type': ['audio/ogg; codecs=vorbis'],\r
+      'required': false\r
+    },\r
+\r
+    'wav': {\r
+      'type': ['audio/wav; codecs="1"', 'audio/wav', 'audio/wave', 'audio/x-wav'],\r
+      'required': false\r
+    }\r
+\r
+  };\r
+\r
+  // HTML attributes (id + class names) for the SWF container\r
+\r
+  this.movieID = 'sm2-container';\r
+  this.id = (smID || 'sm2movie');\r
+\r
+  this.debugID = 'soundmanager-debug';\r
+  this.debugURLParam = /([#?&])debug=1/i;\r
+\r
+  // dynamic attributes\r
+\r
+  this.versionNumber = 'V2.97a.20120916';\r
+  this.version = null;\r
+  this.movieURL = null;\r
+  this.altURL = null;\r
+  this.swfLoaded = false;\r
+  this.enabled = false;\r
+  this.oMC = null;\r
+  this.sounds = {};\r
+  this.soundIDs = [];\r
+  this.muted = false;\r
+  this.didFlashBlock = false;\r
+  this.filePattern = null;\r
+\r
+  this.filePatterns = {\r
+\r
+    'flash8': /\.mp3(\?.*)?$/i,\r
+    'flash9': /\.mp3(\?.*)?$/i\r
+\r
+  };\r
+\r
+  // support indicators, set at init\r
+\r
+  this.features = {\r
+\r
+    'buffering': false,\r
+    'peakData': false,\r
+    'waveformData': false,\r
+    'eqData': false,\r
+    'movieStar': false\r
+\r
+  };\r
+\r
+  // flash sandbox info, used primarily in troubleshooting\r
+\r
+  this.sandbox = {\r
+\r
+    // <d>\r
+    'type': null,\r
+    'types': {\r
+      'remote': 'remote (domain-based) rules',\r
+      'localWithFile': 'local with file access (no internet access)',\r
+      'localWithNetwork': 'local with network (internet access only, no local access)',\r
+      'localTrusted': 'local, trusted (local+internet access)'\r
+    },\r
+    'description': null,\r
+    'noRemote': null,\r
+    'noLocal': null\r
+    // </d>\r
+\r
+  };\r
+\r
+  /**\r
+   * basic HTML5 Audio() support test\r
+   * try...catch because of IE 9 "not implemented" nonsense\r
+   * https://github.com/Modernizr/Modernizr/issues/224\r
+   */\r
+\r
+  this.hasHTML5 = (function() {\r
+    try {\r
+      // new Audio(null) for stupid Opera 9.64 case, which throws not_enough_arguments exception otherwise.\r
+      return (typeof Audio !== 'undefined' && typeof (_isOpera && opera.version() < 10 ? new Audio(null) : new Audio()).canPlayType !== 'undefined');\r
+    } catch(e) {\r
+      return false;\r
+    }\r
+  }());\r
+\r
+  /**\r
+   * format support (html5/flash)\r
+   * stores canPlayType() results based on audioFormats.\r
+   * eg. { mp3: boolean, mp4: boolean }\r
+   * treat as read-only.\r
+   */\r
+\r
+  this.html5 = {\r
+    'usingFlash': null // set if/when flash fallback is needed\r
+  };\r
+\r
+  // file type support hash\r
+  this.flash = {};\r
+\r
+  // determined at init time\r
+  this.html5Only = false;\r
+\r
+  // used for special cases (eg. iPad/iPhone/palm OS?)\r
+  this.ignoreFlash = false;\r
+\r
+  /**\r
+   * a few private internals (OK, a lot. :D)\r
+   */\r
+\r
+  var SMSound,\r
+  _s = this, _flash = null, _sm = 'soundManager', _smc = _sm+'::', _h5 = 'HTML5::', _id, _ua = navigator.userAgent, _win = window, _wl = _win.location.href.toString(), _doc = document, _doNothing, _setProperties, _init, _fV, _on_queue = [], _debugOpen = true, _debugTS, _didAppend = false, _appendSuccess = false, _didInit = false, _disabled = false, _windowLoaded = false, _wDS, _wdCount = 0, _initComplete, _mixin, _assign, _extraOptions, _addOnEvent, _processOnEvents, _initUserOnload, _delayWaitForEI, _waitForEI, _setVersionInfo, _handleFocus, _strings, _initMovie, _domContentLoaded, _winOnLoad, _didDCLoaded, _getDocument, _createMovie, _catchError, _setPolling, _initDebug, _debugLevels = ['log', 'info', 'warn', 'error'], _defaultFlashVersion = 8, _disableObject, _failSafely, _normalizeMovieURL, _oRemoved = null, _oRemovedHTML = null, _str, _flashBlockHandler, _getSWFCSS, _swfCSS, _toggleDebug, _loopFix, _policyFix, _complain, _idCheck, _waitingForEI = false, _initPending = false, _startTimer, _stopTimer, _timerExecute, _h5TimerCount = 0, _h5IntervalTimer = null, _parseURL,\r
+  _needsFlash = null, _featureCheck, _html5OK, _html5CanPlay, _html5Ext, _html5Unload, _domContentLoadedIE, _testHTML5, _event, _slice = Array.prototype.slice, _useGlobalHTML5Audio = false, _hasFlash, _detectFlash, _badSafariFix, _html5_events, _showSupport,\r
+  _is_iDevice = _ua.match(/(ipad|iphone|ipod)/i), _isIE = _ua.match(/msie/i), _isWebkit = _ua.match(/webkit/i), _isSafari = (_ua.match(/safari/i) && !_ua.match(/chrome/i)), _isOpera = (_ua.match(/opera/i)), \r
+  _mobileHTML5 = (_ua.match(/(mobile|pre\/|xoom)/i) || _is_iDevice),\r
+  _isBadSafari = (!_wl.match(/usehtml5audio/i) && !_wl.match(/sm2\-ignorebadua/i) && _isSafari && !_ua.match(/silk/i) && _ua.match(/OS X 10_6_([3-7])/i)), // Safari 4 and 5 (excluding Kindle Fire, "Silk") occasionally fail to load/play HTML5 audio on Snow Leopard 10.6.3 through 10.6.7 due to bug(s) in QuickTime X and/or other underlying frameworks. :/ Confirmed bug. https://bugs.webkit.org/show_bug.cgi?id=32159\r
+  _hasConsole = (typeof console !== 'undefined' && typeof console.log !== 'undefined'), _isFocused = (typeof _doc.hasFocus !== 'undefined'?_doc.hasFocus():null), _tryInitOnFocus = (_isSafari && (typeof _doc.hasFocus === 'undefined' || !_doc.hasFocus())), _okToDisable = !_tryInitOnFocus, _flashMIME = /(mp3|mp4|mpa|m4a|m4b)/i,\r
+  _emptyURL = 'about:blank', // safe URL to unload, or load nothing from (flash 8 + most HTML5 UAs)\r
+  _overHTTP = (_doc.location?_doc.location.protocol.match(/http/i):null),\r
+  _http = (!_overHTTP ? 'http:/'+'/' : ''),\r
+  // mp3, mp4, aac etc.\r
+  _netStreamMimeTypes = /^\s*audio\/(?:x-)?(?:mpeg4|aac|flv|mov|mp4||m4v|m4a|m4b|mp4v|3gp|3g2)\s*(?:$|;)/i,\r
+  // Flash v9.0r115+ "moviestar" formats\r
+  _netStreamTypes = ['mpeg4', 'aac', 'flv', 'mov', 'mp4', 'm4v', 'f4v', 'm4a', 'm4b', 'mp4v', '3gp', '3g2'],\r
+  _netStreamPattern = new RegExp('\\.(' + _netStreamTypes.join('|') + ')(\\?.*)?$', 'i');\r
+\r
+  this.mimePattern = /^\s*audio\/(?:x-)?(?:mp(?:eg|3))\s*(?:$|;)/i; // default mp3 set\r
+\r
+  // use altURL if not "online"\r
+  this.useAltURL = !_overHTTP;\r
+\r
+  this._global_a = null;\r
+\r
+  _swfCSS = {\r
+\r
+    'swfBox': 'sm2-object-box',\r
+    'swfDefault': 'movieContainer',\r
+    'swfError': 'swf_error', // SWF loaded, but SM2 couldn't start (other error)\r
+    'swfTimedout': 'swf_timedout',\r
+    'swfLoaded': 'swf_loaded',\r
+    'swfUnblocked': 'swf_unblocked', // or loaded OK\r
+    'sm2Debug': 'sm2_debug',\r
+    'highPerf': 'high_performance',\r
+    'flashDebug': 'flash_debug'\r
+\r
+  };\r
+\r
+  if (_mobileHTML5) {\r
+\r
+    // prefer HTML5 for mobile + tablet-like devices, probably more reliable vs. flash at this point.\r
+    _s.useHTML5Audio = true;\r
+    _s.preferFlash = false;\r
+\r
+    if (_is_iDevice) {\r
+      // by default, use global feature. iOS onfinish() -> next may fail otherwise.\r
+      _s.ignoreFlash = true;\r
+      _useGlobalHTML5Audio = true;\r
+    }\r
+\r
+  }\r
+\r
+  /**\r
+   * Public SoundManager API\r
+   * -----------------------\r
+   */\r
+\r
+  /**\r
+   * Configures top-level soundManager properties.\r
+   *\r
+   * @param {object} options Option parameters, eg. { flashVersion: 9, url: '/path/to/swfs/' }\r
+   * onready and ontimeout are also accepted parameters. call soundManager.setup() to see the full list.\r
+   */\r
+\r
+  this.setup = function(options) {\r
+\r
+    var noURL = (!_s.url);\r
+\r
+    // warn if flash options have already been applied\r
+\r
+    if (typeof options !== 'undefined' && _didInit && _needsFlash && _s.ok() && (typeof options.flashVersion !== 'undefined' || typeof options.url !== 'undefined')) {\r
+      _complain(_str('setupLate'));\r
+    }\r
+\r
+    // TODO: defer: true?\r
+\r
+    _assign(options);\r
+\r
+    // special case 1: "Late setup". SM2 loaded normally, but user didn't assign flash URL eg., setup({url:...}) before SM2 init. Treat as delayed init.\r
+\r
+    if (noURL && _didDCLoaded && typeof options.url !== 'undefined') {\r
+      _s.beginDelayedInit();\r
+    }\r
+\r
+    // special case 2: If lazy-loading SM2 (DOMContentLoaded has already happened) and user calls setup() with url: parameter, try to init ASAP.\r
+\r
+    if (!_didDCLoaded && typeof options.url !== 'undefined' && _doc.readyState === 'complete') {\r
+      setTimeout(_domContentLoaded, 1);\r
+    }\r
+\r
+    return _s;\r
+\r
+  };\r
+\r
+  this.ok = function() {\r
+\r
+    return (_needsFlash?(_didInit && !_disabled):(_s.useHTML5Audio && _s.hasHTML5));\r
+\r
+  };\r
+\r
+  this.supported = this.ok; // legacy\r
+\r
+  this.getMovie = function(smID) {\r
+\r
+    // safety net: some old browsers differ on SWF references, possibly related to ExternalInterface / flash version\r
+    return _id(smID) || _doc[smID] || _win[smID];\r
+\r
+  };\r
+\r
+  /**\r
+   * Creates a SMSound sound object instance.\r
+   *\r
+   * @param {object} oOptions Sound options (at minimum, id and url parameters are required.)\r
+   * @return {object} SMSound The new SMSound object.\r
+   */\r
+\r
+  this.createSound = function(oOptions, _url) {\r
+\r
+    var _cs, _cs_string, thisOptions = null, oSound = null, _tO = null;\r
+\r
+    // <d>\r
+    _cs = _sm+'.createSound(): ';\r
+    _cs_string = _cs + _str(!_didInit?'notReady':'notOK');\r
+    // </d>\r
+\r
+    if (!_didInit || !_s.ok()) {\r
+      _complain(_cs_string);\r
+      return false;\r
+    }\r
+\r
+    if (typeof _url !== 'undefined') {\r
+      // function overloading in JS! :) ..assume simple createSound(id,url) use case\r
+      oOptions = {\r
+        'id': oOptions,\r
+        'url': _url\r
+      };\r
+    }\r
+\r
+    // inherit from defaultOptions\r
+    thisOptions = _mixin(oOptions);\r
+\r
+    thisOptions.url = _parseURL(thisOptions.url);\r
+\r
+    // local shortcut\r
+    _tO = thisOptions;\r
+\r
+    // <d>\r
+    if (_tO.id.toString().charAt(0).match(/^[0-9]$/)) {\r
+      _s._wD(_cs + _str('badID', _tO.id), 2);\r
+    }\r
+\r
+    _s._wD(_cs + _tO.id + ' (' + _tO.url + ')', 1);\r
+    // </d>\r
+\r
+    if (_idCheck(_tO.id, true)) {\r
+      _s._wD(_cs + _tO.id + ' exists', 1);\r
+      return _s.sounds[_tO.id];\r
+    }\r
+\r
+    function make() {\r
+\r
+      thisOptions = _loopFix(thisOptions);\r
+      _s.sounds[_tO.id] = new SMSound(_tO);\r
+      _s.soundIDs.push(_tO.id);\r
+      return _s.sounds[_tO.id];\r
+\r
+    }\r
+\r
+    if (_html5OK(_tO)) {\r
+\r
+      oSound = make();\r
+      _s._wD('Creating sound '+_tO.id+', using HTML5');\r
+      oSound._setup_html5(_tO);\r
+\r
+    } else {\r
+\r
+      if (_fV > 8) {\r
+        if (_tO.isMovieStar === null) {\r
+          // attempt to detect MPEG-4 formats\r
+          _tO.isMovieStar = !!(_tO.serverURL || (_tO.type ? _tO.type.match(_netStreamMimeTypes) : false) || _tO.url.match(_netStreamPattern));\r
+        }\r
+        // <d>\r
+        if (_tO.isMovieStar) {\r
+          _s._wD(_cs + 'using MovieStar handling');\r
+          if (_tO.loops > 1) {\r
+            _wDS('noNSLoop');\r
+          }\r
+        }\r
+        // </d>\r
+      }\r
+\r
+      _tO = _policyFix(_tO, _cs);\r
+      oSound = make();\r
+\r
+      if (_fV === 8) {\r
+        _flash._createSound(_tO.id, _tO.loops||1, _tO.usePolicyFile);\r
+      } else {\r
+        _flash._createSound(_tO.id, _tO.url, _tO.usePeakData, _tO.useWaveformData, _tO.useEQData, _tO.isMovieStar, (_tO.isMovieStar?_tO.bufferTime:false), _tO.loops||1, _tO.serverURL, _tO.duration||null, _tO.autoPlay, true, _tO.autoLoad, _tO.usePolicyFile);\r
+        if (!_tO.serverURL) {\r
+          // We are connected immediately\r
+          oSound.connected = true;\r
+          if (_tO.onconnect) {\r
+            _tO.onconnect.apply(oSound);\r
+          }\r
+        }\r
+      }\r
+\r
+      if (!_tO.serverURL && (_tO.autoLoad || _tO.autoPlay)) {\r
+        // call load for non-rtmp streams\r
+        oSound.load(_tO);\r
+      }\r
+\r
+    }\r
+\r
+    // rtmp will play in onconnect\r
+    if (!_tO.serverURL && _tO.autoPlay) {\r
+      oSound.play();\r
+    }\r
+\r
+    return oSound;\r
+\r
+  };\r
+\r
+  /**\r
+   * Destroys a SMSound sound object instance.\r
+   *\r
+   * @param {string} sID The ID of the sound to destroy\r
+   */\r
+\r
+  this.destroySound = function(sID, _bFromSound) {\r
+\r
+    // explicitly destroy a sound before normal page unload, etc.\r
+\r
+    if (!_idCheck(sID)) {\r
+      return false;\r
+    }\r
+\r
+    var oS = _s.sounds[sID], i;\r
+\r
+    // Disable all callbacks while the sound is being destroyed\r
+    oS._iO = {};\r
+\r
+    oS.stop();\r
+    oS.unload();\r
+\r
+    for (i = 0; i < _s.soundIDs.length; i++) {\r
+      if (_s.soundIDs[i] === sID) {\r
+        _s.soundIDs.splice(i, 1);\r
+        break;\r
+      }\r
+    }\r
+\r
+    if (!_bFromSound) {\r
+      // ignore if being called from SMSound instance\r
+      oS.destruct(true);\r
+    }\r
+\r
+    oS = null;\r
+    delete _s.sounds[sID];\r
+\r
+    return true;\r
+\r
+  };\r
+\r
+  /**\r
+   * Calls the load() method of a SMSound object by ID.\r
+   *\r
+   * @param {string} sID The ID of the sound\r
+   * @param {object} oOptions Optional: Sound options\r
+   */\r
+\r
+  this.load = function(sID, oOptions) {\r
+\r
+    if (!_idCheck(sID)) {\r
+      return false;\r
+    }\r
+    return _s.sounds[sID].load(oOptions);\r
+\r
+  };\r
+\r
+  /**\r
+   * Calls the unload() method of a SMSound object by ID.\r
+   *\r
+   * @param {string} sID The ID of the sound\r
+   */\r
+\r
+  this.unload = function(sID) {\r
+\r
+    if (!_idCheck(sID)) {\r
+      return false;\r
+    }\r
+    return _s.sounds[sID].unload();\r
+\r
+  };\r
+\r
+  /**\r
+   * Calls the onPosition() method of a SMSound object by ID.\r
+   *\r
+   * @param {string} sID The ID of the sound\r
+   * @param {number} nPosition The position to watch for\r
+   * @param {function} oMethod The relevant callback to fire\r
+   * @param {object} oScope Optional: The scope to apply the callback to\r
+   * @return {SMSound} The SMSound object\r
+   */\r
+\r
+  this.onPosition = function(sID, nPosition, oMethod, oScope) {\r
+\r
+    if (!_idCheck(sID)) {\r
+      return false;\r
+    }\r
+    return _s.sounds[sID].onposition(nPosition, oMethod, oScope);\r
+\r
+  };\r
+\r
+  // legacy/backwards-compability: lower-case method name\r
+  this.onposition = this.onPosition;\r
+\r
+  /**\r
+   * Calls the clearOnPosition() method of a SMSound object by ID.\r
+   *\r
+   * @param {string} sID The ID of the sound\r
+   * @param {number} nPosition The position to watch for\r
+   * @param {function} oMethod Optional: The relevant callback to fire\r
+   * @return {SMSound} The SMSound object\r
+   */\r
+\r
+  this.clearOnPosition = function(sID, nPosition, oMethod) {\r
+\r
+    if (!_idCheck(sID)) {\r
+      return false;\r
+    }\r
+    return _s.sounds[sID].clearOnPosition(nPosition, oMethod);\r
+\r
+  };\r
+\r
+  /**\r
+   * Calls the play() method of a SMSound object by ID.\r
+   *\r
+   * @param {string} sID The ID of the sound\r
+   * @param {object} oOptions Optional: Sound options\r
+   * @return {SMSound} The SMSound object\r
+   */\r
+\r
+  this.play = function(sID, oOptions) {\r
+\r
+    var result = false;\r
+\r
+    if (!_didInit || !_s.ok()) {\r
+      _complain(_sm+'.play(): ' + _str(!_didInit?'notReady':'notOK'));\r
+      return result;\r
+    }\r
+\r
+    if (!_idCheck(sID)) {\r
+      if (!(oOptions instanceof Object)) {\r
+        // overloading use case: play('mySound','/path/to/some.mp3');\r
+        oOptions = {\r
+          url: oOptions\r
+        };\r
+      }\r
+      if (oOptions && oOptions.url) {\r
+        // overloading use case, create+play: .play('someID',{url:'/path/to.mp3'});\r
+        _s._wD(_sm+'.play(): attempting to create "' + sID + '"', 1);\r
+        oOptions.id = sID;\r
+        result = _s.createSound(oOptions).play();\r
+      }\r
+      return result;\r
+    }\r
+\r
+    return _s.sounds[sID].play(oOptions);\r
+\r
+  };\r
+\r
+  this.start = this.play; // just for convenience\r
+\r
+  /**\r
+   * Calls the setPosition() method of a SMSound object by ID.\r
+   *\r
+   * @param {string} sID The ID of the sound\r
+   * @param {number} nMsecOffset Position (milliseconds)\r
+   * @return {SMSound} The SMSound object\r
+   */\r
+\r
+  this.setPosition = function(sID, nMsecOffset) {\r
+\r
+    if (!_idCheck(sID)) {\r
+      return false;\r
+    }\r
+    return _s.sounds[sID].setPosition(nMsecOffset);\r
+\r
+  };\r
+\r
+  /**\r
+   * Calls the stop() method of a SMSound object by ID.\r
+   *\r
+   * @param {string} sID The ID of the sound\r
+   * @return {SMSound} The SMSound object\r
+   */\r
+\r
+  this.stop = function(sID) {\r
+\r
+    if (!_idCheck(sID)) {\r
+      return false;\r
+    }\r
+\r
+    _s._wD(_sm+'.stop(' + sID + ')', 1);\r
+    return _s.sounds[sID].stop();\r
+\r
+  };\r
+\r
+  /**\r
+   * Stops all currently-playing sounds.\r
+   */\r
+\r
+  this.stopAll = function() {\r
+\r
+    var oSound;\r
+    _s._wD(_sm+'.stopAll()', 1);\r
+\r
+    for (oSound in _s.sounds) {\r
+      if (_s.sounds.hasOwnProperty(oSound)) {\r
+        // apply only to sound objects\r
+        _s.sounds[oSound].stop();\r
+      }\r
+    }\r
+\r
+  };\r
+\r
+  /**\r
+   * Calls the pause() method of a SMSound object by ID.\r
+   *\r
+   * @param {string} sID The ID of the sound\r
+   * @return {SMSound} The SMSound object\r
+   */\r
+\r
+  this.pause = function(sID) {\r
+\r
+    if (!_idCheck(sID)) {\r
+      return false;\r
+    }\r
+    return _s.sounds[sID].pause();\r
+\r
+  };\r
+\r
+  /**\r
+   * Pauses all currently-playing sounds.\r
+   */\r
+\r
+  this.pauseAll = function() {\r
+\r
+    var i;\r
+    for (i = _s.soundIDs.length-1; i >= 0; i--) {\r
+      _s.sounds[_s.soundIDs[i]].pause();\r
+    }\r
+\r
+  };\r
+\r
+  /**\r
+   * Calls the resume() method of a SMSound object by ID.\r
+   *\r
+   * @param {string} sID The ID of the sound\r
+   * @return {SMSound} The SMSound object\r
+   */\r
+\r
+  this.resume = function(sID) {\r
+\r
+    if (!_idCheck(sID)) {\r
+      return false;\r
+    }\r
+    return _s.sounds[sID].resume();\r
+\r
+  };\r
+\r
+  /**\r
+   * Resumes all currently-paused sounds.\r
+   */\r
+\r
+  this.resumeAll = function() {\r
+\r
+    var i;\r
+    for (i = _s.soundIDs.length-1; i >= 0; i--) {\r
+      _s.sounds[_s.soundIDs[i]].resume();\r
+    }\r
+\r
+  };\r
+\r
+  /**\r
+   * Calls the togglePause() method of a SMSound object by ID.\r
+   *\r
+   * @param {string} sID The ID of the sound\r
+   * @return {SMSound} The SMSound object\r
+   */\r
+\r
+  this.togglePause = function(sID) {\r
+\r
+    if (!_idCheck(sID)) {\r
+      return false;\r
+    }\r
+    return _s.sounds[sID].togglePause();\r
+\r
+  };\r
+\r
+  /**\r
+   * Calls the setPan() method of a SMSound object by ID.\r
+   *\r
+   * @param {string} sID The ID of the sound\r
+   * @param {number} nPan The pan value (-100 to 100)\r
+   * @return {SMSound} The SMSound object\r
+   */\r
+\r
+  this.setPan = function(sID, nPan) {\r
+\r
+    if (!_idCheck(sID)) {\r
+      return false;\r
+    }\r
+    return _s.sounds[sID].setPan(nPan);\r
+\r
+  };\r
+\r
+  /**\r
+   * Calls the setVolume() method of a SMSound object by ID.\r
+   *\r
+   * @param {string} sID The ID of the sound\r
+   * @param {number} nVol The volume value (0 to 100)\r
+   * @return {SMSound} The SMSound object\r
+   */\r
+\r
+  this.setVolume = function(sID, nVol) {\r
+\r
+    if (!_idCheck(sID)) {\r
+      return false;\r
+    }\r
+    return _s.sounds[sID].setVolume(nVol);\r
+\r
+  };\r
+\r
+  /**\r
+   * Calls the mute() method of either a single SMSound object by ID, or all sound objects.\r
+   *\r
+   * @param {string} sID Optional: The ID of the sound (if omitted, all sounds will be used.)\r
+   */\r
+\r
+  this.mute = function(sID) {\r
+\r
+    var i = 0;\r
+\r
+    if (typeof sID !== 'string') {\r
+      sID = null;\r
+    }\r
+\r
+    if (!sID) {\r
+      _s._wD(_sm+'.mute(): Muting all sounds');\r
+      for (i = _s.soundIDs.length-1; i >= 0; i--) {\r
+        _s.sounds[_s.soundIDs[i]].mute();\r
+      }\r
+      _s.muted = true;\r
+    } else {\r
+      if (!_idCheck(sID)) {\r
+        return false;\r
+      }\r
+      _s._wD(_sm+'.mute(): Muting "' + sID + '"');\r
+      return _s.sounds[sID].mute();\r
+    }\r
+\r
+    return true;\r
+\r
+  };\r
+\r
+  /**\r
+   * Mutes all sounds.\r
+   */\r
+\r
+  this.muteAll = function() {\r
+\r
+    _s.mute();\r
+\r
+  };\r
+\r
+  /**\r
+   * Calls the unmute() method of either a single SMSound object by ID, or all sound objects.\r
+   *\r
+   * @param {string} sID Optional: The ID of the sound (if omitted, all sounds will be used.)\r
+   */\r
+\r
+  this.unmute = function(sID) {\r
+\r
+    var i;\r
+\r
+    if (typeof sID !== 'string') {\r
+      sID = null;\r
+    }\r
+\r
+    if (!sID) {\r
+\r
+      _s._wD(_sm+'.unmute(): Unmuting all sounds');\r
+      for (i = _s.soundIDs.length-1; i >= 0; i--) {\r
+        _s.sounds[_s.soundIDs[i]].unmute();\r
+      }\r
+      _s.muted = false;\r
+\r
+    } else {\r
+\r
+      if (!_idCheck(sID)) {\r
+        return false;\r
+      }\r
+      _s._wD(_sm+'.unmute(): Unmuting "' + sID + '"');\r
+      return _s.sounds[sID].unmute();\r
+\r
+    }\r
+\r
+    return true;\r
+\r
+  };\r
+\r
+  /**\r
+   * Unmutes all sounds.\r
+   */\r
+\r
+  this.unmuteAll = function() {\r
+\r
+    _s.unmute();\r
+\r
+  };\r
+\r
+  /**\r
+   * Calls the toggleMute() method of a SMSound object by ID.\r
+   *\r
+   * @param {string} sID The ID of the sound\r
+   * @return {SMSound} The SMSound object\r
+   */\r
+\r
+  this.toggleMute = function(sID) {\r
+\r
+    if (!_idCheck(sID)) {\r
+      return false;\r
+    }\r
+    return _s.sounds[sID].toggleMute();\r
+\r
+  };\r
+\r
+  /**\r
+   * Retrieves the memory used by the flash plugin.\r
+   *\r
+   * @return {number} The amount of memory in use\r
+   */\r
+\r
+  this.getMemoryUse = function() {\r
+\r
+    // flash-only\r
+    var ram = 0;\r
+\r
+    if (_flash && _fV !== 8) {\r
+      ram = parseInt(_flash._getMemoryUse(), 10);\r
+    }\r
+\r
+    return ram;\r
+\r
+  };\r
+\r
+  /**\r
+   * Undocumented: NOPs soundManager and all SMSound objects.\r
+   */\r
+\r
+  this.disable = function(bNoDisable) {\r
+\r
+    // destroy all functions\r
+    var i;\r
+\r
+    if (typeof bNoDisable === 'undefined') {\r
+      bNoDisable = false;\r
+    }\r
+\r
+    if (_disabled) {\r
+      return false;\r
+    }\r
+\r
+    _disabled = true;\r
+    _wDS('shutdown', 1);\r
+\r
+    for (i = _s.soundIDs.length-1; i >= 0; i--) {\r
+      _disableObject(_s.sounds[_s.soundIDs[i]]);\r
+    }\r
+\r
+    // fire "complete", despite fail\r
+    _initComplete(bNoDisable);\r
+    _event.remove(_win, 'load', _initUserOnload);\r
+\r
+    return true;\r
+\r
+  };\r
+\r
+  /**\r
+   * Determines playability of a MIME type, eg. 'audio/mp3'.\r
+   */\r
+\r
+  this.canPlayMIME = function(sMIME) {\r
+\r
+    var result;\r
+\r
+    if (_s.hasHTML5) {\r
+      result = _html5CanPlay({type:sMIME});\r
+    }\r
+\r
+    if (!result && _needsFlash) {\r
+      // if flash 9, test netStream (movieStar) types as well.\r
+      result = (sMIME && _s.ok() ? !!((_fV > 8 ? sMIME.match(_netStreamMimeTypes) : null) || sMIME.match(_s.mimePattern)) : null);\r
+    }\r
+\r
+    return result;\r
+\r
+  };\r
+\r
+  /**\r
+   * Determines playability of a URL based on audio support.\r
+   *\r
+   * @param {string} sURL The URL to test\r
+   * @return {boolean} URL playability\r
+   */\r
+\r
+  this.canPlayURL = function(sURL) {\r
+\r
+    var result;\r
+\r
+    if (_s.hasHTML5) {\r
+      result = _html5CanPlay({url: sURL});\r
+    }\r
+\r
+    if (!result && _needsFlash) {\r
+      result = (sURL && _s.ok() ? !!(sURL.match(_s.filePattern)) : null);\r
+    }\r
+\r
+    return result;\r
+\r
+  };\r
+\r
+  /**\r
+   * Determines playability of an HTML DOM &lt;a&gt; object (or similar object literal) based on audio support.\r
+   *\r
+   * @param {object} oLink an HTML DOM &lt;a&gt; object or object literal including href and/or type attributes\r
+   * @return {boolean} URL playability\r
+   */\r
+\r
+  this.canPlayLink = function(oLink) {\r
+\r
+    if (typeof oLink.type !== 'undefined' && oLink.type) {\r
+      if (_s.canPlayMIME(oLink.type)) {\r
+        return true;\r
+      }\r
+    }\r
+\r
+    return _s.canPlayURL(oLink.href);\r
+\r
+  };\r
+\r
+  /**\r
+   * Retrieves a SMSound object by ID.\r
+   *\r
+   * @param {string} sID The ID of the sound\r
+   * @return {SMSound} The SMSound object\r
+   */\r
+\r
+  this.getSoundById = function(sID, _suppressDebug) {\r
+\r
+    if (!sID) {\r
+      throw new Error(_sm+'.getSoundById(): sID is null/undefined');\r
+    }\r
+\r
+    var result = _s.sounds[sID];\r
+\r
+    // <d>\r
+    if (!result && !_suppressDebug) {\r
+      _s._wD('"' + sID + '" is an invalid sound ID.', 2);\r
+    }\r
+    // </d>\r
+\r
+    return result;\r
+\r
+  };\r
+\r
+  /**\r
+   * Queues a callback for execution when SoundManager has successfully initialized.\r
+   *\r
+   * @param {function} oMethod The callback method to fire\r
+   * @param {object} oScope Optional: The scope to apply to the callback\r
+   */\r
+\r
+  this.onready = function(oMethod, oScope) {\r
+\r
+    var sType = 'onready',\r
+        result = false;\r
+\r
+    if (typeof oMethod === 'function') {\r
+\r
+      // <d>\r
+      if (_didInit) {\r
+        _s._wD(_str('queue', sType));\r
+      }\r
+      // </d>\r
+\r
+      if (!oScope) {\r
+        oScope = _win;\r
+      }\r
+\r
+      _addOnEvent(sType, oMethod, oScope);\r
+      _processOnEvents();\r
+\r
+      result = true;\r
+\r
+    } else {\r
+\r
+      throw _str('needFunction', sType);\r
+\r
+    }\r
+\r
+    return result;\r
+\r
+  };\r
+\r
+  /**\r
+   * Queues a callback for execution when SoundManager has failed to initialize.\r
+   *\r
+   * @param {function} oMethod The callback method to fire\r
+   * @param {object} oScope Optional: The scope to apply to the callback\r
+   */\r
+\r
+  this.ontimeout = function(oMethod, oScope) {\r
+\r
+    var sType = 'ontimeout',\r
+        result = false;\r
+\r
+    if (typeof oMethod === 'function') {\r
+\r
+      // <d>\r
+      if (_didInit) {\r
+        _s._wD(_str('queue', sType));\r
+      }\r
+      // </d>\r
+\r
+      if (!oScope) {\r
+        oScope = _win;\r
+      }\r
+\r
+      _addOnEvent(sType, oMethod, oScope);\r
+      _processOnEvents({type:sType});\r
+\r
+      result = true;\r
+\r
+    } else {\r
+\r
+      throw _str('needFunction', sType);\r
+\r
+    }\r
+\r
+    return result;\r
+\r
+  };\r
+\r
+  /**\r
+   * Writes console.log()-style debug output to a console or in-browser element.\r
+   * Applies when debugMode = true\r
+   *\r
+   * @param {string} sText The console message\r
+   * @param {string} sType Optional: Log type of 'info', 'warn' or 'error'\r
+   * @param {object} Optional: The scope to apply to the callback\r
+   */\r
+\r
+  this._writeDebug = function(sText, sType, _bTimestamp) {\r
+\r
+    // pseudo-private console.log()-style output\r
+    // <d>\r
+\r
+    var sDID = 'soundmanager-debug', o, oItem, sMethod;\r
+\r
+    if (!_s.debugMode) {\r
+      return false;\r
+    }\r
+\r
+    if (typeof _bTimestamp !== 'undefined' && _bTimestamp) {\r
+      sText = sText + ' | ' + new Date().getTime();\r
+    }\r
+\r
+    if (_hasConsole && _s.useConsole) {\r
+      sMethod = _debugLevels[sType];\r
+      if (typeof console[sMethod] !== 'undefined') {\r
+        console[sMethod](sText);\r
+      } else {\r
+        console.log(sText);\r
+      }\r
+      if (_s.consoleOnly) {\r
+        return true;\r
+      }\r
+    }\r
+\r
+    try {\r
+\r
+      o = _id(sDID);\r
+\r
+      if (!o) {\r
+        return false;\r
+      }\r
+\r
+      oItem = _doc.createElement('div');\r
+\r
+      if (++_wdCount % 2 === 0) {\r
+        oItem.className = 'sm2-alt';\r
+      }\r
+\r
+      if (typeof sType === 'undefined') {\r
+        sType = 0;\r
+      } else {\r
+        sType = parseInt(sType, 10);\r
+      }\r
+\r
+      oItem.appendChild(_doc.createTextNode(sText));\r
+\r
+      if (sType) {\r
+        if (sType >= 2) {\r
+          oItem.style.fontWeight = 'bold';\r
+        }\r
+        if (sType === 3) {\r
+          oItem.style.color = '#ff3333';\r
+        }\r
+      }\r
+\r
+      // top-to-bottom\r
+      // o.appendChild(oItem);\r
+\r
+      // bottom-to-top\r
+      o.insertBefore(oItem, o.firstChild);\r
+\r
+    } catch(e) {\r
+      // oh well\r
+    }\r
+\r
+    o = null;\r
+    // </d>\r
+\r
+    return true;\r
+\r
+  };\r
+\r
+  // alias\r
+  this._wD = this._writeDebug;\r
+\r
+  /**\r
+   * Provides debug / state information on all SMSound objects.\r
+   */\r
+\r
+  this._debug = function() {\r
+\r
+    // <d>\r
+    var i, j;\r
+    _wDS('currentObj', 1);\r
+\r
+    for (i = 0, j = _s.soundIDs.length; i < j; i++) {\r
+      _s.sounds[_s.soundIDs[i]]._debug();\r
+    }\r
+    // </d>\r
+\r
+  };\r
+\r
+  /**\r
+   * Restarts and re-initializes the SoundManager instance.\r
+   */\r
+\r
+  this.reboot = function() {\r
+\r
+    // attempt to reset and init SM2\r
+    _s._wD(_sm+'.reboot()');\r
+\r
+    // <d>\r
+    if (_s.soundIDs.length) {\r
+      _s._wD('Destroying ' + _s.soundIDs.length + ' SMSound objects...');\r
+    }\r
+    // </d>\r
+\r
+    var i, j;\r
+\r
+    for (i = _s.soundIDs.length-1; i >= 0; i--) {\r
+      _s.sounds[_s.soundIDs[i]].destruct();\r
+    }\r
+\r
+    // trash ze flash\r
+\r
+    if (_flash) {\r
+      try {\r
+        if (_isIE) {\r
+          _oRemovedHTML = _flash.innerHTML;\r
+        }\r
+        _oRemoved = _flash.parentNode.removeChild(_flash);\r
+        _s._wD('Flash movie removed.');\r
+      } catch(e) {\r
+        // uh-oh.\r
+        _wDS('badRemove', 2);\r
+      }\r
+    }\r
+\r
+    // actually, force recreate of movie.\r
+    _oRemovedHTML = _oRemoved = _needsFlash = null;\r
+\r
+    _s.enabled = _didDCLoaded = _didInit = _waitingForEI = _initPending = _didAppend = _appendSuccess = _disabled = _s.swfLoaded = false;\r
+    _s.soundIDs = [];\r
+    _s.sounds = {};\r
+    _flash = null;\r
+\r
+    for (i in _on_queue) {\r
+      if (_on_queue.hasOwnProperty(i)) {\r
+        for (j = _on_queue[i].length-1; j >= 0; j--) {\r
+          _on_queue[i][j].fired = false;\r
+        }\r
+      }\r
+    }\r
+\r
+    _s._wD(_sm + ': Rebooting...');\r
+    _win.setTimeout(_s.beginDelayedInit, 20);\r
+\r
+  };\r
+\r
+  /**\r
+   * Undocumented: Determines the SM2 flash movie's load progress.\r
+   *\r
+   * @return {number or null} Percent loaded, or if invalid/unsupported, null.\r
+   */\r
+\r
+  this.getMoviePercent = function() {\r
+\r
+    // interesting note: flash/ExternalInterface bridge methods are not typeof "function" nor instanceof Function, but are still valid.\r
+    return (_flash && typeof _flash.PercentLoaded !== 'undefined' ? _flash.PercentLoaded() : null);\r
+\r
+  };\r
+\r
+  /**\r
+   * Additional helper for manually invoking SM2's init process after DOM Ready / window.onload().\r
+   */\r
+\r
+  this.beginDelayedInit = function() {\r
+\r
+    _windowLoaded = true;\r
+    _domContentLoaded();\r
+\r
+    setTimeout(function() {\r
+\r
+      if (_initPending) {\r
+        return false;\r
+      }\r
+\r
+      _createMovie();\r
+      _initMovie();\r
+      _initPending = true;\r
+\r
+      return true;\r
+\r
+    }, 20);\r
+\r
+    _delayWaitForEI();\r
+\r
+  };\r
+\r
+  /**\r
+   * Destroys the SoundManager instance and all SMSound instances.\r
+   */\r
+\r
+  this.destruct = function() {\r
+\r
+    _s._wD(_sm+'.destruct()');\r
+    _s.disable(true);\r
+\r
+  };\r
+\r
+  /**\r
+   * SMSound() (sound object) constructor\r
+   * ------------------------------------\r
+   *\r
+   * @param {object} oOptions Sound options (id and url are required attributes)\r
+   * @return {SMSound} The new SMSound object\r
+   */\r
+\r
+  SMSound = function(oOptions) {\r
+\r
+    var _t = this, _resetProperties, _add_html5_events, _remove_html5_events, _stop_html5_timer, _start_html5_timer, _attachOnPosition, _onplay_called = false, _onPositionItems = [], _onPositionFired = 0, _detachOnPosition, _applyFromTo, _lastURL = null, _lastHTML5State;\r
+\r
+    _lastHTML5State = {\r
+      // tracks duration + position (time)\r
+      duration: null,\r
+      time: null\r
+    };\r
+\r
+    this.id = oOptions.id;\r
+\r
+    // legacy\r
+    this.sID = this.id;\r
+\r
+    this.url = oOptions.url;\r
+    this.options = _mixin(oOptions);\r
+\r
+    // per-play-instance-specific options\r
+    this.instanceOptions = this.options;\r
+\r
+    // short alias\r
+    this._iO = this.instanceOptions;\r
+\r
+    // assign property defaults\r
+    this.pan = this.options.pan;\r
+    this.volume = this.options.volume;\r
+\r
+    // whether or not this object is using HTML5\r
+    this.isHTML5 = false;\r
+\r
+    // internal HTML5 Audio() object reference\r
+    this._a = null;\r
+\r
+    /**\r
+     * SMSound() public methods\r
+     * ------------------------\r
+     */\r
+\r
+    this.id3 = {};\r
+\r
+    /**\r
+     * Writes SMSound object parameters to debug console\r
+     */\r
+\r
+    this._debug = function() {\r
+\r
+      // <d>\r
+      // pseudo-private console.log()-style output\r
+\r
+      if (_s.debugMode) {\r
+\r
+        var stuff = null, msg = [], sF, sfBracket, maxLength = 64;\r
+\r
+        for (stuff in _t.options) {\r
+          if (_t.options[stuff] !== null) {\r
+            if (typeof _t.options[stuff] === 'function') {\r
+              // handle functions specially\r
+              sF = _t.options[stuff].toString();\r
+              // normalize spaces\r
+              sF = sF.replace(/\s\s+/g, ' ');\r
+              sfBracket = sF.indexOf('{');\r
+              msg.push(' ' + stuff + ': {' + sF.substr(sfBracket + 1, (Math.min(Math.max(sF.indexOf('\n') - 1, maxLength), maxLength))).replace(/\n/g, '') + '... }');\r
+            } else {\r
+              msg.push(' ' + stuff + ': ' + _t.options[stuff]);\r
+            }\r
+          }\r
+        }\r
+\r
+        _s._wD('SMSound() merged options: {\n' + msg.join(', \n') + '\n}');\r
+\r
+      }\r
+      // </d>\r
+\r
+    };\r
+\r
+    // <d>\r
+    this._debug();\r
+    // </d>\r
+\r
+    /**\r
+     * Begins loading a sound per its *url*.\r
+     *\r
+     * @param {object} oOptions Optional: Sound options\r
+     * @return {SMSound} The SMSound object\r
+     */\r
+\r
+    this.load = function(oOptions) {\r
+\r
+      var oS = null, _iO;\r
+\r
+      if (typeof oOptions !== 'undefined') {\r
+        _t._iO = _mixin(oOptions, _t.options);\r
+        _t.instanceOptions = _t._iO;\r
+      } else {\r
+        oOptions = _t.options;\r
+        _t._iO = oOptions;\r
+        _t.instanceOptions = _t._iO;\r
+        if (_lastURL && _lastURL !== _t.url) {\r
+          _wDS('manURL');\r
+          _t._iO.url = _t.url;\r
+          _t.url = null;\r
+        }\r
+      }\r
+\r
+      if (!_t._iO.url) {\r
+        _t._iO.url = _t.url;\r
+      }\r
+\r
+      _t._iO.url = _parseURL(_t._iO.url);\r
+\r
+      _s._wD('SMSound.load(): ' + _t._iO.url, 1);\r
+\r
+      if (_t._iO.url === _t.url && _t.readyState !== 0 && _t.readyState !== 2) {\r
+        _wDS('onURL', 1);\r
+        // if loaded and an onload() exists, fire immediately.\r
+        if (_t.readyState === 3 && _t._iO.onload) {\r
+          // assume success based on truthy duration.\r
+          _t._iO.onload.apply(_t, [(!!_t.duration)]);\r
+        }\r
+        return _t;\r
+      }\r
+\r
+      // local shortcut\r
+      _iO = _t._iO;\r
+\r
+      // make a local copy of the old url before we re-assign it\r
+      _lastURL = (_t.url && _t.url.toString ? _t.url.toString() : null);\r
+\r
+      // reset a few state properties\r
+\r
+      _t.loaded = false;\r
+      _t.readyState = 1;\r
+      _t.playState = 0;\r
+      _t.id3 = {};\r
+\r
+      // TODO: If switching from HTML5 -> flash (or vice versa), stop currently-playing audio.\r
+\r
+      if (_html5OK(_iO)) {\r
+\r
+        oS = _t._setup_html5(_iO);\r
+\r
+        if (!oS._called_load) {\r
+\r
+          _s._wD(_h5+'load: '+_t.id);\r
+\r
+          _t._html5_canplay = false;\r
+\r
+          // TODO: review called_load / html5_canplay logic\r
+\r
+          // if url provided directly to load(), assign it here.\r
+\r
+          if (_t._a.src !== _iO.url) {\r
+\r
+            _s._wD(_wDS('manURL') + ': ' + _iO.url);\r
+\r
+            _t._a.src = _iO.url;\r
+\r
+            // TODO: review / re-apply all relevant options (volume, loop, onposition etc.)\r
+\r
+            // reset position for new URL\r
+            _t.setPosition(0);\r
+\r
+          }\r
+\r
+          // given explicit load call, try to preload.\r
+\r
+          // early HTML5 implementation (non-standard)\r
+          _t._a.autobuffer = 'auto';\r
+\r
+          // standard\r
+          _t._a.preload = 'auto';\r
+\r
+          oS._called_load = true;\r
+\r
+          if (_iO.autoPlay) {\r
+            _t.play();\r
+          }\r
+\r
+        } else {\r
+\r
+          _s._wD(_h5+'ignoring request to load again: '+_t.id);\r
+\r
+        }\r
+\r
+      } else {\r
+\r
+        try {\r
+          _t.isHTML5 = false;\r
+          _t._iO = _policyFix(_loopFix(_iO));\r
+          // re-assign local shortcut\r
+          _iO = _t._iO;\r
+          if (_fV === 8) {\r
+            _flash._load(_t.id, _iO.url, _iO.stream, _iO.autoPlay, (_iO.whileloading?1:0), _iO.loops||1, _iO.usePolicyFile);\r
+          } else {\r
+            _flash._load(_t.id, _iO.url, !!(_iO.stream), !!(_iO.autoPlay), _iO.loops||1, !!(_iO.autoLoad), _iO.usePolicyFile);\r
+          }\r
+        } catch(e) {\r
+          _wDS('smError', 2);\r
+          _debugTS('onload', false);\r
+          _catchError({type:'SMSOUND_LOAD_JS_EXCEPTION', fatal:true});\r
+\r
+        }\r
+\r
+      }\r
+\r
+      // after all of this, ensure sound url is up to date.\r
+      _t.url = _iO.url;\r
+\r
+      return _t;\r
+\r
+    };\r
+\r
+    /**\r
+     * Unloads a sound, canceling any open HTTP requests.\r
+     *\r
+     * @return {SMSound} The SMSound object\r
+     */\r
+\r
+    this.unload = function() {\r
+\r
+      // Flash 8/AS2 can't "close" a stream - fake it by loading an empty URL\r
+      // Flash 9/AS3: Close stream, preventing further load\r
+      // HTML5: Most UAs will use empty URL\r
+\r
+      if (_t.readyState !== 0) {\r
+\r
+        _s._wD('SMSound.unload(): "' + _t.id + '"');\r
+\r
+        if (!_t.isHTML5) {\r
+\r
+          if (_fV === 8) {\r
+            _flash._unload(_t.id, _emptyURL);\r
+          } else {\r
+            _flash._unload(_t.id);\r
+          }\r
+\r
+        } else {\r
+\r
+          _stop_html5_timer();\r
+\r
+          if (_t._a) {\r
+\r
+            _t._a.pause();\r
+            _html5Unload(_t._a, _emptyURL);\r
+\r
+            // reset local URL for next load / play call, too\r
+            _t.url = _emptyURL;\r
+\r
+          }\r
+\r
+        }\r
+\r
+        // reset load/status flags\r
+        _resetProperties();\r
+\r
+      }\r
+\r
+      return _t;\r
+\r
+    };\r
+\r
+    /**\r
+     * Unloads and destroys a sound.\r
+     */\r
+\r
+    this.destruct = function(_bFromSM) {\r
+\r
+      _s._wD('SMSound.destruct(): "' + _t.id + '"');\r
+\r
+      if (!_t.isHTML5) {\r
+\r
+        // kill sound within Flash\r
+        // Disable the onfailure handler\r
+        _t._iO.onfailure = null;\r
+        _flash._destroySound(_t.id);\r
+\r
+      } else {\r
+\r
+        _stop_html5_timer();\r
+\r
+        if (_t._a) {\r
+          _t._a.pause();\r
+          _html5Unload(_t._a);\r
+          if (!_useGlobalHTML5Audio) {\r
+            _remove_html5_events();\r
+          }\r
+          // break obvious circular reference\r
+          _t._a._t = null;\r
+          _t._a = null;\r
+        }\r
+\r
+      }\r
+\r
+      if (!_bFromSM) {\r
+        // ensure deletion from controller\r
+        _s.destroySound(_t.id, true);\r
+\r
+      }\r
+\r
+    };\r
+\r
+    /**\r
+     * Begins playing a sound.\r
+     *\r
+     * @param {object} oOptions Optional: Sound options\r
+     * @return {SMSound} The SMSound object\r
+     */\r
+\r
+    this.play = function(oOptions, _updatePlayState) {\r
+\r
+      var fN, allowMulti, a, onready, startOK = true,\r
+          exit = null;\r
+\r
+      // <d>\r
+      fN = 'SMSound.play(): ';\r
+      // </d>\r
+\r
+      // default to true\r
+      _updatePlayState = (typeof _updatePlayState === 'undefined' ? true : _updatePlayState);\r
+\r
+      if (!oOptions) {\r
+        oOptions = {};\r
+      }\r
+\r
+      // first, use local URL (if specified)\r
+      if (_t.url) {\r
+        _t._iO.url = _t.url;\r
+      }\r
+\r
+      // mix in any options defined at createSound()\r
+      _t._iO = _mixin(_t._iO, _t.options);\r
+\r
+      // mix in any options specific to this method\r
+      _t._iO = _mixin(oOptions, _t._iO);\r
+\r
+      _t._iO.url = _parseURL(_t._iO.url);\r
+\r
+      _t.instanceOptions = _t._iO;\r
+\r
+      // RTMP-only\r
+      if (_t._iO.serverURL && !_t.connected) {\r
+        if (!_t.getAutoPlay()) {\r
+          _s._wD(fN+' Netstream not connected yet - setting autoPlay');\r
+          _t.setAutoPlay(true);\r
+        }\r
+        // play will be called in _onconnect()\r
+        return _t;\r
+      }\r
+\r
+      if (_html5OK(_t._iO)) {\r
+        _t._setup_html5(_t._iO);\r
+        _start_html5_timer();\r
+      }\r
+\r
+      if (_t.playState === 1 && !_t.paused) {\r
+        allowMulti = _t._iO.multiShot;\r
+        if (!allowMulti) {\r
+          _s._wD(fN + '"' + _t.id + '" already playing (one-shot)', 1);\r
+          exit = _t;\r
+        } else {\r
+          _s._wD(fN + '"' + _t.id + '" already playing (multi-shot)', 1);\r
+        }\r
+      }\r
+\r
+      if (exit !== null) {\r
+        return exit;\r
+      }\r
+\r
+      // edge case: play() with explicit URL parameter\r
+      if (oOptions.url && oOptions.url !== _t.url) {\r
+        // load using merged options\r
+        _t.load(_t._iO);\r
+      }\r
+\r
+      if (!_t.loaded) {\r
+\r
+        if (_t.readyState === 0) {\r
+\r
+          _s._wD(fN + 'Attempting to load "' + _t.id + '"', 1);\r
+\r
+          // try to get this sound playing ASAP\r
+          if (!_t.isHTML5) {\r
+            // assign directly because setAutoPlay() increments the instanceCount\r
+            _t._iO.autoPlay = true;\r
+            _t.load(_t._iO);\r
+          } else {\r
+            // iOS needs this when recycling sounds, loading a new URL on an existing object.\r
+            _t.load(_t._iO);\r
+          }\r
+\r
+        } else if (_t.readyState === 2) {\r
+\r
+          _s._wD(fN + 'Could not load "' + _t.id + '" - exiting', 2);\r
+          exit = _t;\r
+\r
+        } else {\r
+\r
+          _s._wD(fN + '"' + _t.id + '" is loading - attempting to play..', 1);\r
+\r
+        }\r
+\r
+      } else {\r
+\r
+        _s._wD(fN + '"' + _t.id + '"');\r
+\r
+      }\r
+\r
+      if (exit !== null) {\r
+        return exit;\r
+      }\r
+\r
+      if (!_t.isHTML5 && _fV === 9 && _t.position > 0 && _t.position === _t.duration) {\r
+        // flash 9 needs a position reset if play() is called while at the end of a sound.\r
+        _s._wD(fN + '"' + _t.id + '": Sound at end, resetting to position:0');\r
+        oOptions.position = 0;\r
+      }\r
+\r
+      /**\r
+       * Streams will pause when their buffer is full if they are being loaded.\r
+       * In this case paused is true, but the song hasn't started playing yet.\r
+       * If we just call resume() the onplay() callback will never be called.\r
+       * So only call resume() if the position is > 0.\r
+       * Another reason is because options like volume won't have been applied yet.\r
+       * For normal sounds, just resume.\r
+       */\r
+\r
+      if (_t.paused && _t.position >= 0 && (!_t._iO.serverURL || _t.position > 0)) {\r
+\r
+        // https://gist.github.com/37b17df75cc4d7a90bf6\r
+        _s._wD(fN + '"' + _t.id + '" is resuming from paused state',1);\r
+        _t.resume();\r
+\r
+      } else {\r
+\r
+        _t._iO = _mixin(oOptions, _t._iO);\r
+\r
+        // apply from/to parameters, if they exist (and not using RTMP)\r
+        if (_t._iO.from !== null && _t._iO.to !== null && _t.instanceCount === 0 && _t.playState === 0 && !_t._iO.serverURL) {\r
+\r
+          onready = function() {\r
+            // sound "canplay" or onload()\r
+            // re-apply from/to to instance options, and start playback\r
+            _t._iO = _mixin(oOptions, _t._iO);\r
+            _t.play(_t._iO);\r
+          };\r
+\r
+          // HTML5 needs to at least have "canplay" fired before seeking.\r
+          if (_t.isHTML5 && !_t._html5_canplay) {\r
+\r
+            // this hasn't been loaded yet. load it first, and then do this again.\r
+            _s._wD(fN+'Beginning load of "'+ _t.id+'" for from/to case');\r
+\r
+            _t.load({\r
+              _oncanplay: onready\r
+            });\r
+\r
+            exit = false;\r
+\r
+          } else if (!_t.isHTML5 && !_t.loaded && (!_t.readyState || _t.readyState !== 2)) {\r
+\r
+            // to be safe, preload the whole thing in Flash.\r
+\r
+            _s._wD(fN+'Preloading "'+ _t.id+'" for from/to case');\r
+\r
+            _t.load({\r
+              onload: onready\r
+            });\r
+\r
+            exit = false;\r
+\r
+          }\r
+\r
+          if (exit !== null) {\r
+            return exit;\r
+          }\r
+\r
+          // otherwise, we're ready to go. re-apply local options, and continue\r
+\r
+          _t._iO = _applyFromTo();\r
+\r
+        }\r
+\r
+        _s._wD(fN+'"'+ _t.id+'" is starting to play');\r
+\r
+        if (!_t.instanceCount || _t._iO.multiShotEvents || (!_t.isHTML5 && _fV > 8 && !_t.getAutoPlay())) {\r
+          _t.instanceCount++;\r
+        }\r
+\r
+        // if first play and onposition parameters exist, apply them now\r
+        if (_t._iO.onposition && _t.playState === 0) {\r
+          _attachOnPosition(_t);\r
+        }\r
+\r
+        _t.playState = 1;\r
+        _t.paused = false;\r
+\r
+        _t.position = (typeof _t._iO.position !== 'undefined' && !isNaN(_t._iO.position) ? _t._iO.position : 0);\r
+\r
+        if (!_t.isHTML5) {\r
+          _t._iO = _policyFix(_loopFix(_t._iO));\r
+        }\r
+\r
+        if (_t._iO.onplay && _updatePlayState) {\r
+          _t._iO.onplay.apply(_t);\r
+          _onplay_called = true;\r
+        }\r
+\r
+        _t.setVolume(_t._iO.volume, true);\r
+        _t.setPan(_t._iO.pan, true);\r
+\r
+        if (!_t.isHTML5) {\r
+\r
+          startOK = _flash._start(_t.id, _t._iO.loops || 1, (_fV === 9 ? _t._iO.position : _t._iO.position / 1000), _t._iO.multiShot);\r
+\r
+          if (_fV === 9 && !startOK) {\r
+            // edge case: no sound hardware, or 32-channel flash ceiling hit.\r
+            // applies only to Flash 9, non-NetStream/MovieStar sounds.\r
+            // http://help.adobe.com/en_US/FlashPlatform/reference/actionscript/3/flash/media/Sound.html#play%28%29\r
+            _s._wD(fN+ _t.id+': No sound hardware, or 32-sound ceiling hit');\r
+            if (_t._iO.onplayerror) {\r
+              _t._iO.onplayerror.apply(_t);\r
+            }\r
+\r
+          }\r
+\r
+        } else {\r
+\r
+          _start_html5_timer();\r
+\r
+          a = _t._setup_html5();\r
+\r
+          _t.setPosition(_t._iO.position);\r
+\r
+          a.play();\r
+\r
+        }\r
+\r
+      }\r
+\r
+      return _t;\r
+\r
+    };\r
+\r
+    // just for convenience\r
+    this.start = this.play;\r
+\r
+    /**\r
+     * Stops playing a sound (and optionally, all sounds)\r
+     *\r
+     * @param {boolean} bAll Optional: Whether to stop all sounds\r
+     * @return {SMSound} The SMSound object\r
+     */\r
+\r
+    this.stop = function(bAll) {\r
+\r
+      var _iO = _t._iO, _oP;\r
+\r
+      if (_t.playState === 1) {\r
+\r
+        _t._onbufferchange(0);\r
+        _t._resetOnPosition(0);\r
+        _t.paused = false;\r
+\r
+        if (!_t.isHTML5) {\r
+          _t.playState = 0;\r
+        }\r
+\r
+        // remove onPosition listeners, if any\r
+        _detachOnPosition();\r
+\r
+        // and "to" position, if set\r
+        if (_iO.to) {\r
+          _t.clearOnPosition(_iO.to);\r
+        }\r
+\r
+        if (!_t.isHTML5) {\r
+\r
+          _flash._stop(_t.id, bAll);\r
+\r
+          // hack for netStream: just unload\r
+          if (_iO.serverURL) {\r
+            _t.unload();\r
+          }\r
+\r
+        } else {\r
+\r
+          if (_t._a) {\r
+\r
+            _oP = _t.position;\r
+\r
+            // act like Flash, though\r
+            _t.setPosition(0);\r
+\r
+            // hack: reflect old position for onstop() (also like Flash)\r
+            _t.position = _oP;\r
+\r
+            // html5 has no stop()\r
+            // NOTE: pausing means iOS requires interaction to resume.\r
+            _t._a.pause();\r
+\r
+            _t.playState = 0;\r
+\r
+            // and update UI\r
+            _t._onTimer();\r
+\r
+            _stop_html5_timer();\r
+\r
+          }\r
+\r
+        }\r
+\r
+        _t.instanceCount = 0;\r
+        _t._iO = {};\r
+\r
+        if (_iO.onstop) {\r
+          _iO.onstop.apply(_t);\r
+        }\r
+\r
+      }\r
+\r
+      return _t;\r
+\r
+    };\r
+\r
+    /**\r
+     * Undocumented/internal: Sets autoPlay for RTMP.\r
+     *\r
+     * @param {boolean} autoPlay state\r
+     */\r
+\r
+    this.setAutoPlay = function(autoPlay) {\r
+\r
+      _s._wD('sound '+_t.id+' turned autoplay ' + (autoPlay ? 'on' : 'off'));\r
+      _t._iO.autoPlay = autoPlay;\r
+\r
+      if (!_t.isHTML5) {\r
+        _flash._setAutoPlay(_t.id, autoPlay);\r
+        if (autoPlay) {\r
+          // only increment the instanceCount if the sound isn't loaded (TODO: verify RTMP)\r
+          if (!_t.instanceCount && _t.readyState === 1) {\r
+            _t.instanceCount++;\r
+            _s._wD('sound '+_t.id+' incremented instance count to '+_t.instanceCount);\r
+          }\r
+        }\r
+      }\r
+\r
+    };\r
+\r
+    /**\r
+     * Undocumented/internal: Returns the autoPlay boolean.\r
+     *\r
+     * @return {boolean} The current autoPlay value\r
+     */\r
+\r
+    this.getAutoPlay = function() {\r
+\r
+      return _t._iO.autoPlay;\r
+\r
+    };\r
+\r
+    /**\r
+     * Sets the position of a sound.\r
+     *\r
+     * @param {number} nMsecOffset Position (milliseconds)\r
+     * @return {SMSound} The SMSound object\r
+     */\r
+\r
+    this.setPosition = function(nMsecOffset) {\r
+\r
+      if (typeof nMsecOffset === 'undefined') {\r
+        nMsecOffset = 0;\r
+      }\r
+\r
+      var original_pos,\r
+          position, position1K,\r
+          // Use the duration from the instance options, if we don't have a track duration yet.\r
+          // position >= 0 and <= current available (loaded) duration\r
+          offset = (_t.isHTML5 ? Math.max(nMsecOffset, 0) : Math.min(_t.duration || _t._iO.duration, Math.max(nMsecOffset, 0)));\r
+\r
+      original_pos = _t.position;\r
+      _t.position = offset;\r
+      position1K = _t.position/1000;\r
+      _t._resetOnPosition(_t.position);\r
+      _t._iO.position = offset;\r
+\r
+      if (!_t.isHTML5) {\r
+\r
+        position = (_fV === 9 ? _t.position : position1K);\r
+        if (_t.readyState && _t.readyState !== 2) {\r
+          // if paused or not playing, will not resume (by playing)\r
+          _flash._setPosition(_t.id, position, (_t.paused || !_t.playState), _t._iO.multiShot);\r
+        }\r
+\r
+      } else if (_t._a) {\r
+\r
+        // Set the position in the canplay handler if the sound is not ready yet\r
+        if (_t._html5_canplay) {\r
+          if (_t._a.currentTime !== position1K) {\r
+            /**\r
+             * DOM/JS errors/exceptions to watch out for:\r
+             * if seek is beyond (loaded?) position, "DOM exception 11"\r
+             * "INDEX_SIZE_ERR": DOM exception 1\r
+             */\r
+            _s._wD('setPosition('+position1K+'): setting position');\r
+            try {\r
+              _t._a.currentTime = position1K;\r
+              if (_t.playState === 0 || _t.paused) {\r
+                // allow seek without auto-play/resume\r
+                _t._a.pause();\r
+              }\r
+            } catch(e) {\r
+              _s._wD('setPosition('+position1K+'): setting position failed: '+e.message, 2);\r
+            }\r
+          }\r
+        } else {\r
+          _s._wD('setPosition('+position1K+'): delaying, sound not ready');\r
+        }\r
+\r
+      }\r
+\r
+      if (_t.isHTML5) {\r
+        if (_t.paused) {\r
+          // if paused, refresh UI right away\r
+          // force update\r
+          _t._onTimer(true);\r
+        }\r
+      }\r
+\r
+      return _t;\r
+\r
+    };\r
+\r
+    /**\r
+     * Pauses sound playback.\r
+     *\r
+     * @return {SMSound} The SMSound object\r
+     */\r
+\r
+    this.pause = function(_bCallFlash) {\r
+\r
+      if (_t.paused || (_t.playState === 0 && _t.readyState !== 1)) {\r
+        return _t;\r
+      }\r
+\r
+      _s._wD('SMSound.pause()');\r
+      _t.paused = true;\r
+\r
+      if (!_t.isHTML5) {\r
+        if (_bCallFlash || typeof _bCallFlash === 'undefined') {\r
+          _flash._pause(_t.id, _t._iO.multiShot);\r
+        }\r
+      } else {\r
+        _t._setup_html5().pause();\r
+        _stop_html5_timer();\r
+      }\r
+\r
+      if (_t._iO.onpause) {\r
+        _t._iO.onpause.apply(_t);\r
+      }\r
+\r
+      return _t;\r
+\r
+    };\r
+\r
+    /**\r
+     * Resumes sound playback.\r
+     *\r
+     * @return {SMSound} The SMSound object\r
+     */\r
+\r
+    /**\r
+     * When auto-loaded streams pause on buffer full they have a playState of 0.\r
+     * We need to make sure that the playState is set to 1 when these streams "resume".\r
+     * When a paused stream is resumed, we need to trigger the onplay() callback if it\r
+     * hasn't been called already. In this case since the sound is being played for the\r
+     * first time, I think it's more appropriate to call onplay() rather than onresume().\r
+     */\r
+\r
+    this.resume = function() {\r
+\r
+      var _iO = _t._iO;\r
+\r
+      if (!_t.paused) {\r
+        return _t;\r
+      }\r
+\r
+      _s._wD('SMSound.resume()');\r
+      _t.paused = false;\r
+      _t.playState = 1;\r
+\r
+      if (!_t.isHTML5) {\r
+        if (_iO.isMovieStar && !_iO.serverURL) {\r
+          // Bizarre Webkit bug (Chrome reported via 8tracks.com dudes): AAC content paused for 30+ seconds(?) will not resume without a reposition.\r
+          _t.setPosition(_t.position);\r
+        }\r
+        // flash method is toggle-based (pause/resume)\r
+        _flash._pause(_t.id, _iO.multiShot);\r
+      } else {\r
+        _t._setup_html5().play();\r
+        _start_html5_timer();\r
+      }\r
+\r
+      if (!_onplay_called && _iO.onplay) {\r
+        _iO.onplay.apply(_t);\r
+        _onplay_called = true;\r
+      } else if (_iO.onresume) {\r
+        _iO.onresume.apply(_t);\r
+      }\r
+\r
+      return _t;\r
+\r
+    };\r
+\r
+    /**\r
+     * Toggles sound playback.\r
+     *\r
+     * @return {SMSound} The SMSound object\r
+     */\r
+\r
+    this.togglePause = function() {\r
+\r
+      _s._wD('SMSound.togglePause()');\r
+\r
+      if (_t.playState === 0) {\r
+        _t.play({\r
+          position: (_fV === 9 && !_t.isHTML5 ? _t.position : _t.position / 1000)\r
+        });\r
+        return _t;\r
+      }\r
+\r
+      if (_t.paused) {\r
+        _t.resume();\r
+      } else {\r
+        _t.pause();\r
+      }\r
+\r
+      return _t;\r
+\r
+    };\r
+\r
+    /**\r
+     * Sets the panning (L-R) effect.\r
+     *\r
+     * @param {number} nPan The pan value (-100 to 100)\r
+     * @return {SMSound} The SMSound object\r
+     */\r
+\r
+    this.setPan = function(nPan, bInstanceOnly) {\r
+\r
+      if (typeof nPan === 'undefined') {\r
+        nPan = 0;\r
+      }\r
+\r
+      if (typeof bInstanceOnly === 'undefined') {\r
+        bInstanceOnly = false;\r
+      }\r
+\r
+      if (!_t.isHTML5) {\r
+        _flash._setPan(_t.id, nPan);\r
+      } // else { no HTML5 pan? }\r
+\r
+      _t._iO.pan = nPan;\r
+\r
+      if (!bInstanceOnly) {\r
+        _t.pan = nPan;\r
+        _t.options.pan = nPan;\r
+      }\r
+\r
+      return _t;\r
+\r
+    };\r
+\r
+    /**\r
+     * Sets the volume.\r
+     *\r
+     * @param {number} nVol The volume value (0 to 100)\r
+     * @return {SMSound} The SMSound object\r
+     */\r
+\r
+    this.setVolume = function(nVol, _bInstanceOnly) {\r
+\r
+      /**\r
+       * Note: Setting volume has no effect on iOS "special snowflake" devices.\r
+       * Hardware volume control overrides software, and volume\r
+       * will always return 1 per Apple docs. (iOS 4 + 5.)\r
+       * http://developer.apple.com/library/safari/documentation/AudioVideo/Conceptual/HTML-canvas-guide/AddingSoundtoCanvasAnimations/AddingSoundtoCanvasAnimations.html\r
+       */\r
+\r
+      if (typeof nVol === 'undefined') {\r
+        nVol = 100;\r
+      }\r
+\r
+      if (typeof _bInstanceOnly === 'undefined') {\r
+        _bInstanceOnly = false;\r
+      }\r
+\r
+      if (!_t.isHTML5) {\r
+        _flash._setVolume(_t.id, (_s.muted && !_t.muted) || _t.muted?0:nVol);\r
+      } else if (_t._a) {\r
+        // valid range: 0-1\r
+        _t._a.volume = Math.max(0, Math.min(1, nVol/100));\r
+      }\r
+\r
+      _t._iO.volume = nVol;\r
+\r
+      if (!_bInstanceOnly) {\r
+        _t.volume = nVol;\r
+        _t.options.volume = nVol;\r
+      }\r
+\r
+      return _t;\r
+\r
+    };\r
+\r
+    /**\r
+     * Mutes the sound.\r
+     *\r
+     * @return {SMSound} The SMSound object\r
+     */\r
+\r
+    this.mute = function() {\r
+\r
+      _t.muted = true;\r
+\r
+      if (!_t.isHTML5) {\r
+        _flash._setVolume(_t.id, 0);\r
+      } else if (_t._a) {\r
+        _t._a.muted = true;\r
+      }\r
+\r
+      return _t;\r
+\r
+    };\r
+\r
+    /**\r
+     * Unmutes the sound.\r
+     *\r
+     * @return {SMSound} The SMSound object\r
+     */\r
+\r
+    this.unmute = function() {\r
+\r
+      _t.muted = false;\r
+      var hasIO = (typeof _t._iO.volume !== 'undefined');\r
+\r
+      if (!_t.isHTML5) {\r
+        _flash._setVolume(_t.id, hasIO?_t._iO.volume:_t.options.volume);\r
+      } else if (_t._a) {\r
+        _t._a.muted = false;\r
+      }\r
+\r
+      return _t;\r
+\r
+    };\r
+\r
+    /**\r
+     * Toggles the muted state of a sound.\r
+     *\r
+     * @return {SMSound} The SMSound object\r
+     */\r
+\r
+    this.toggleMute = function() {\r
+\r
+      return (_t.muted?_t.unmute():_t.mute());\r
+\r
+    };\r
+\r
+    /**\r
+     * Registers a callback to be fired when a sound reaches a given position during playback.\r
+     *\r
+     * @param {number} nPosition The position to watch for\r
+     * @param {function} oMethod The relevant callback to fire\r
+     * @param {object} oScope Optional: The scope to apply the callback to\r
+     * @return {SMSound} The SMSound object\r
+     */\r
+\r
+    this.onPosition = function(nPosition, oMethod, oScope) {\r
+\r
+      // TODO: basic dupe checking?\r
+\r
+      _onPositionItems.push({\r
+        position: parseInt(nPosition, 10),\r
+        method: oMethod,\r
+        scope: (typeof oScope !== 'undefined' ? oScope : _t),\r
+        fired: false\r
+      });\r
+\r
+      return _t;\r
+\r
+    };\r
+\r
+    // legacy/backwards-compability: lower-case method name\r
+    this.onposition = this.onPosition;\r
+\r
+    /**\r
+     * Removes registered callback(s) from a sound, by position and/or callback.\r
+     *\r
+     * @param {number} nPosition The position to clear callback(s) for\r
+     * @param {function} oMethod Optional: Identify one callback to be removed when multiple listeners exist for one position\r
+     * @return {SMSound} The SMSound object\r
+     */\r
+\r
+    this.clearOnPosition = function(nPosition, oMethod) {\r
+\r
+      var i;\r
+\r
+      nPosition = parseInt(nPosition, 10);\r
+\r
+      if (isNaN(nPosition)) {\r
+        // safety check\r
+        return false;\r
+      }\r
+\r
+      for (i=0; i < _onPositionItems.length; i++) {\r
+\r
+        if (nPosition === _onPositionItems[i].position) {\r
+          // remove this item if no method was specified, or, if the method matches\r
+          if (!oMethod || (oMethod === _onPositionItems[i].method)) {\r
+            if (_onPositionItems[i].fired) {\r
+              // decrement "fired" counter, too\r
+              _onPositionFired--;\r
+            }\r
+            _onPositionItems.splice(i, 1);\r
+          }\r
+        }\r
+\r
+      }\r
+\r
+    };\r
+\r
+    this._processOnPosition = function() {\r
+\r
+      var i, item, j = _onPositionItems.length;\r
+\r
+      if (!j || !_t.playState || _onPositionFired >= j) {\r
+        return false;\r
+      }\r
+\r
+      for (i=j-1; i >= 0; i--) {\r
+        item = _onPositionItems[i];\r
+        if (!item.fired && _t.position >= item.position) {\r
+          item.fired = true;\r
+          _onPositionFired++;\r
+          item.method.apply(item.scope, [item.position]);\r
+        }\r
+      }\r
+\r
+      return true;\r
+\r
+    };\r
+\r
+    this._resetOnPosition = function(nPosition) {\r
+\r
+      // reset "fired" for items interested in this position\r
+      var i, item, j = _onPositionItems.length;\r
+\r
+      if (!j) {\r
+        return false;\r
+      }\r
+\r
+      for (i=j-1; i >= 0; i--) {\r
+        item = _onPositionItems[i];\r
+        if (item.fired && nPosition <= item.position) {\r
+          item.fired = false;\r
+          _onPositionFired--;\r
+        }\r
+      }\r
+\r
+      return true;\r
+\r
+    };\r
+\r
+    /**\r
+     * SMSound() private internals\r
+     * --------------------------------\r
+     */\r
+\r
+    _applyFromTo = function() {\r
+\r
+      var _iO = _t._iO,\r
+          f = _iO.from,\r
+          t = _iO.to,\r
+          start, end;\r
+\r
+      end = function() {\r
+\r
+        // end has been reached.\r
+        _s._wD(_t.id + ': "to" time of ' + t + ' reached.');\r
+\r
+        // detach listener\r
+        _t.clearOnPosition(t, end);\r
+\r
+        // stop should clear this, too\r
+        _t.stop();\r
+\r
+      };\r
+\r
+      start = function() {\r
+\r
+        _s._wD(_t.id + ': playing "from" ' + f);\r
+\r
+        // add listener for end\r
+        if (t !== null && !isNaN(t)) {\r
+          _t.onPosition(t, end);\r
+        }\r
+\r
+      };\r
+\r
+      if (f !== null && !isNaN(f)) {\r
+\r
+        // apply to instance options, guaranteeing correct start position.\r
+        _iO.position = f;\r
+\r
+        // multiShot timing can't be tracked, so prevent that.\r
+        _iO.multiShot = false;\r
+\r
+        start();\r
+\r
+      }\r
+\r
+      // return updated instanceOptions including starting position\r
+      return _iO;\r
+\r
+    };\r
+\r
+    _attachOnPosition = function() {\r
+\r
+      var item,\r
+          op = _t._iO.onposition;\r
+\r
+      // attach onposition things, if any, now.\r
+\r
+      if (op) {\r
+\r
+        for (item in op) {\r
+          if (op.hasOwnProperty(item)) {\r
+            _t.onPosition(parseInt(item, 10), op[item]); \r
+          }\r
+        }\r
+\r
+      }\r
+\r
+    };\r
+\r
+    _detachOnPosition = function() {\r
+\r
+      var item,\r
+          op = _t._iO.onposition;\r
+\r
+      // detach any onposition()-style listeners.\r
+\r
+      if (op) {\r
+\r
+        for (item in op) {\r
+          if (op.hasOwnProperty(item)) {\r
+            _t.clearOnPosition(parseInt(item, 10));\r
+          }\r
+        }\r
+\r
+      }\r
+\r
+    };\r
+\r
+    _start_html5_timer = function() {\r
+\r
+      if (_t.isHTML5) {\r
+        _startTimer(_t);\r
+      }\r
+\r
+    };\r
+\r
+    _stop_html5_timer = function() {\r
+\r
+      if (_t.isHTML5) {\r
+        _stopTimer(_t);\r
+      }\r
+\r
+    };\r
+\r
+    _resetProperties = function(retainPosition) {\r
+\r
+      if (!retainPosition) {\r
+        _onPositionItems = [];\r
+        _onPositionFired = 0;\r
+      }\r
+\r
+      _onplay_called = false;\r
+\r
+      _t._hasTimer = null;\r
+      _t._a = null;\r
+      _t._html5_canplay = false;\r
+      _t.bytesLoaded = null;\r
+      _t.bytesTotal = null;\r
+      _t.duration = (_t._iO && _t._iO.duration ? _t._iO.duration : null);\r
+      _t.durationEstimate = null;\r
+      _t.buffered = [];\r
+\r
+      // legacy: 1D array\r
+      _t.eqData = [];\r
+\r
+      _t.eqData.left = [];\r
+      _t.eqData.right = [];\r
+\r
+      _t.failures = 0;\r
+      _t.isBuffering = false;\r
+      _t.instanceOptions = {};\r
+      _t.instanceCount = 0;\r
+      _t.loaded = false;\r
+      _t.metadata = {};\r
+\r
+      // 0 = uninitialised, 1 = loading, 2 = failed/error, 3 = loaded/success\r
+      _t.readyState = 0;\r
+\r
+      _t.muted = false;\r
+      _t.paused = false;\r
+\r
+      _t.peakData = {\r
+        left: 0,\r
+        right: 0\r
+      };\r
+\r
+      _t.waveformData = {\r
+        left: [],\r
+        right: []\r
+      };\r
+\r
+      _t.playState = 0;\r
+      _t.position = null;\r
+\r
+      _t.id3 = {};\r
+\r
+    };\r
+\r
+    _resetProperties();\r
+\r
+    /**\r
+     * Pseudo-private SMSound internals\r
+     * --------------------------------\r
+     */\r
+\r
+    this._onTimer = function(bForce) {\r
+\r
+      /**\r
+       * HTML5-only _whileplaying() etc.\r
+       * called from both HTML5 native events, and polling/interval-based timers\r
+       * mimics flash and fires only when time/duration change, so as to be polling-friendly\r
+       */\r
+\r
+      var duration, isNew = false, time, x = {};\r
+\r
+      if (_t._hasTimer || bForce) {\r
+\r
+        // TODO: May not need to track readyState (1 = loading)\r
+\r
+        if (_t._a && (bForce || ((_t.playState > 0 || _t.readyState === 1) && !_t.paused))) {\r
+\r
+          duration = _t._get_html5_duration();\r
+\r
+          if (duration !== _lastHTML5State.duration) {\r
+\r
+            _lastHTML5State.duration = duration;\r
+            _t.duration = duration;\r
+            isNew = true;\r
+\r
+          }\r
+\r
+          // TODO: investigate why this goes wack if not set/re-set each time.\r
+          _t.durationEstimate = _t.duration;\r
+\r
+          time = (_t._a.currentTime * 1000 || 0);\r
+\r
+          if (time !== _lastHTML5State.time) {\r
+\r
+            _lastHTML5State.time = time;\r
+            isNew = true;\r
+\r
+          }\r
+\r
+          if (isNew || bForce) {\r
+\r
+            _t._whileplaying(time,x,x,x,x);\r
+\r
+          }\r
+\r
+        }/* else {\r
+\r
+          // _s._wD('_onTimer: Warn for "'+_t.id+'": '+(!_t._a?'Could not find element. ':'')+(_t.playState === 0?'playState bad, 0?':'playState = '+_t.playState+', OK'));\r
+\r
+          return false;\r
+\r
+        }*/\r
+\r
+        return isNew;\r
+\r
+      }\r
+\r
+    };\r
+\r
+    this._get_html5_duration = function() {\r
+\r
+      var _iO = _t._iO,\r
+          // if audio object exists, use its duration - else, instance option duration (if provided - it's a hack, really, and should be retired) OR null\r
+          d = (_t._a && _t._a.duration ? _t._a.duration*1000 : (_iO && _iO.duration ? _iO.duration : null)),\r
+          result = (d && !isNaN(d) && d !== Infinity ? d : null);\r
+\r
+      return result;\r
+\r
+    };\r
+\r
+    this._apply_loop = function(a, nLoops) {\r
+\r
+      /**\r
+       * boolean instead of "loop", for webkit? - spec says string. http://www.w3.org/TR/html-markup/audio.html#audio.attrs.loop\r
+       * note that loop is either off or infinite under HTML5, unlike Flash which allows arbitrary loop counts to be specified.\r
+       */\r
+\r
+      // <d>\r
+      if (!a.loop && nLoops > 1) {\r
+        _s._wD('Note: Native HTML5 looping is infinite.');\r
+      }\r
+      // </d>\r
+\r
+      a.loop = (nLoops > 1 ? 'loop' : '');\r
+\r
+    };\r
+\r
+    this._setup_html5 = function(oOptions) {\r
+\r
+      var _iO = _mixin(_t._iO, oOptions), d = decodeURI,\r
+          _a = _useGlobalHTML5Audio ? _s._global_a : _t._a,\r
+          _dURL = d(_iO.url),\r
+          _oldIO = (_a && _a._t ? _a._t.instanceOptions : null),\r
+          result;\r
+\r
+      if (_a) {\r
+\r
+        if (_a._t) {\r
+\r
+          if (!_useGlobalHTML5Audio && _dURL === d(_lastURL)) {\r
+\r
+            // same url, ignore request\r
+            result = _a; \r
+\r
+          } else if (_useGlobalHTML5Audio && _oldIO.url === _iO.url && (!_lastURL || (_lastURL === _oldIO.url))) {\r
+\r
+            // iOS-type reuse case\r
+            result = _a;\r
+\r
+          }\r
+\r
+          if (result) {\r
+\r
+            _t._apply_loop(_a, _iO.loops);\r
+            return result;\r
+\r
+          }\r
+\r
+        }\r
+\r
+        _s._wD('setting URL on existing object: ' + _dURL + (_lastURL ? ', old URL: ' + _lastURL : ''));\r
+\r
+        /**\r
+         * "First things first, I, Poppa.." (reset the previous state of the old sound, if playing)\r
+         * Fixes case with devices that can only play one sound at a time\r
+         * Otherwise, other sounds in mid-play will be terminated without warning and in a stuck state\r
+         */\r
+\r
+        if (_useGlobalHTML5Audio && _a._t && _a._t.playState && _iO.url !== _oldIO.url) {\r
+\r
+          _a._t.stop();\r
+\r
+        }\r
+\r
+        // reset load/playstate, onPosition etc. if the URL is new.\r
+        // somewhat-tricky object re-use vs. new SMSound object, old vs. new URL comparisons\r
+        _resetProperties((_oldIO && _oldIO.url ? _iO.url === _oldIO.url : (_lastURL ? _lastURL === _iO.url : false)));\r
+\r
+        _a.src = _iO.url;\r
+        _t.url = _iO.url;\r
+        _lastURL = _iO.url;\r
+        _a._called_load = false;\r
+\r
+      } else {\r
+\r
+        _wDS('h5a');\r
+\r
+        if (_iO.autoLoad || _iO.autoPlay) {\r
+\r
+          _t._a = new Audio(_iO.url);\r
+\r
+        } else {\r
+\r
+          // null for stupid Opera 9.64 case\r
+          _t._a = (_isOpera && opera.version() < 10 ? new Audio(null) : new Audio());\r
+\r
+        }\r
+\r
+        // assign local reference\r
+        _a = _t._a;\r
+\r
+        _a._called_load = false;\r
+\r
+        if (_useGlobalHTML5Audio) {\r
+\r
+          _s._global_a = _a;\r
+\r
+        }\r
+\r
+      }\r
+\r
+      _t.isHTML5 = true;\r
+\r
+      // store a ref on the track\r
+      _t._a = _a;\r
+\r
+      // store a ref on the audio\r
+      _a._t = _t;\r
+\r
+      _add_html5_events();\r
+\r
+      _t._apply_loop(_a, _iO.loops);\r
+\r
+      if (_iO.autoLoad || _iO.autoPlay) {\r
+\r
+        _t.load();\r
+\r
+      } else {\r
+\r
+        // early HTML5 implementation (non-standard)\r
+        _a.autobuffer = false;\r
+\r
+        // standard ('none' is also an option.)\r
+        _a.preload = 'auto';\r
+\r
+      }\r
+\r
+      return _a;\r
+\r
+    };\r
+\r
+    _add_html5_events = function() {\r
+\r
+      if (_t._a._added_events) {\r
+        return false;\r
+      }\r
+\r
+      var f;\r
+\r
+      function add(oEvt, oFn, bCapture) {\r
+        return _t._a ? _t._a.addEventListener(oEvt, oFn, bCapture||false) : null;\r
+      }\r
+\r
+      _t._a._added_events = true;\r
+\r
+      for (f in _html5_events) {\r
+        if (_html5_events.hasOwnProperty(f)) {\r
+          add(f, _html5_events[f]);\r
+        }\r
+      }\r
+\r
+      return true;\r
+\r
+    };\r
+\r
+    _remove_html5_events = function() {\r
+\r
+      // Remove event listeners\r
+\r
+      var f;\r
+\r
+      function remove(oEvt, oFn, bCapture) {\r
+        return (_t._a ? _t._a.removeEventListener(oEvt, oFn, bCapture||false) : null);\r
+      }\r
+\r
+      _s._wD(_h5+'removing event listeners: '+_t.id);\r
+      _t._a._added_events = false;\r
+\r
+      for (f in _html5_events) {\r
+        if (_html5_events.hasOwnProperty(f)) {\r
+          remove(f, _html5_events[f]);\r
+        }\r
+      }\r
+\r
+    };\r
+\r
+    /**\r
+     * Pseudo-private event internals\r
+     * ------------------------------\r
+     */\r
+\r
+    this._onload = function(nSuccess) {\r
+\r
+\r
+      var fN,\r
+          // check for duration to prevent false positives from flash 8 when loading from cache.\r
+          loadOK = (!!(nSuccess) || (!_t.isHTML5 && _fV === 8 && _t.duration));\r
+\r
+      // <d>\r
+      fN = 'SMSound._onload(): ';\r
+      _s._wD(fN + '"' + _t.id + '"' + (loadOK?' loaded.':' failed to load? - ' + _t.url), (loadOK?1:2));\r
+      if (!loadOK && !_t.isHTML5) {\r
+        if (_s.sandbox.noRemote === true) {\r
+          _s._wD(fN + _str('noNet'), 1);\r
+        }\r
+        if (_s.sandbox.noLocal === true) {\r
+          _s._wD(fN + _str('noLocal'), 1);\r
+        }\r
+      }\r
+      // </d>\r
+\r
+      _t.loaded = loadOK;\r
+      _t.readyState = loadOK?3:2;\r
+      _t._onbufferchange(0);\r
+\r
+      if (_t._iO.onload) {\r
+        _t._iO.onload.apply(_t, [loadOK]);\r
+      }\r
+\r
+      return true;\r
+\r
+    };\r
+\r
+    this._onbufferchange = function(nIsBuffering) {\r
+\r
+      if (_t.playState === 0) {\r
+        // ignore if not playing\r
+        return false;\r
+      }\r
+\r
+      if ((nIsBuffering && _t.isBuffering) || (!nIsBuffering && !_t.isBuffering)) {\r
+        return false;\r
+      }\r
+\r
+      _t.isBuffering = (nIsBuffering === 1);\r
+      if (_t._iO.onbufferchange) {\r
+        _s._wD('SMSound._onbufferchange(): ' + nIsBuffering);\r
+        _t._iO.onbufferchange.apply(_t);\r
+      }\r
+\r
+      return true;\r
+\r
+    };\r
+\r
+    /**\r
+     * Notify Mobile Safari that user action is required\r
+     * to continue playing / loading the audio file.\r
+     */\r
+\r
+    this._onsuspend = function() {\r
+\r
+      if (_t._iO.onsuspend) {\r
+        _s._wD('SMSound._onsuspend()');\r
+        _t._iO.onsuspend.apply(_t);\r
+      }\r
+\r
+      return true;\r
+\r
+    };\r
+\r
+    /**\r
+     * flash 9/movieStar + RTMP-only method, should fire only once at most\r
+     * at this point we just recreate failed sounds rather than trying to reconnect\r
+     */\r
+\r
+    this._onfailure = function(msg, level, code) {\r
+\r
+      _t.failures++;\r
+      _s._wD('SMSound._onfailure(): "'+_t.id+'" count '+_t.failures);\r
+\r
+      if (_t._iO.onfailure && _t.failures === 1) {\r
+        _t._iO.onfailure(_t, msg, level, code);\r
+      } else {\r
+        _s._wD('SMSound._onfailure(): ignoring');\r
+      }\r
+\r
+    };\r
+\r
+    this._onfinish = function() {\r
+\r
+      // store local copy before it gets trashed..\r
+      var _io_onfinish = _t._iO.onfinish;\r
+\r
+      _t._onbufferchange(0);\r
+      _t._resetOnPosition(0);\r
+\r
+      // reset some state items\r
+      if (_t.instanceCount) {\r
+\r
+        _t.instanceCount--;\r
+\r
+        if (!_t.instanceCount) {\r
+\r
+          // remove onPosition listeners, if any\r
+          _detachOnPosition();\r
+\r
+          // reset instance options\r
+          _t.playState = 0;\r
+          _t.paused = false;\r
+          _t.instanceCount = 0;\r
+          _t.instanceOptions = {};\r
+          _t._iO = {};\r
+          _stop_html5_timer();\r
+\r
+          // reset position, too\r
+          if (_t.isHTML5) {\r
+            _t.position = 0;\r
+          }\r
+\r
+        }\r
+\r
+        if (!_t.instanceCount || _t._iO.multiShotEvents) {\r
+          // fire onfinish for last, or every instance\r
+          if (_io_onfinish) {\r
+            _s._wD('SMSound._onfinish(): "' + _t.id + '"');\r
+            _io_onfinish.apply(_t);\r
+          }\r
+        }\r
+\r
+      }\r
+\r
+    };\r
+\r
+    this._whileloading = function(nBytesLoaded, nBytesTotal, nDuration, nBufferLength) {\r
+\r
+      var _iO = _t._iO;\r
+\r
+      _t.bytesLoaded = nBytesLoaded;\r
+      _t.bytesTotal = nBytesTotal;\r
+      _t.duration = Math.floor(nDuration);\r
+      _t.bufferLength = nBufferLength;\r
+\r
+      if (!_t.isHTML5 && !_iO.isMovieStar) {\r
+\r
+        if (_iO.duration) {\r
+          // use duration from options, if specified and larger. nobody should be specifying duration in options, actually, and it should be retired.\r
+          _t.durationEstimate = (_t.duration > _iO.duration) ? _t.duration : _iO.duration;\r
+        } else {\r
+          _t.durationEstimate = parseInt((_t.bytesTotal / _t.bytesLoaded) * _t.duration, 10);\r
+        }\r
+\r
+      } else {\r
+\r
+        _t.durationEstimate = _t.duration;\r
+\r
+      }\r
+\r
+      // for flash, reflect sequential-load-style buffering\r
+      if (!_t.isHTML5) {\r
+        _t.buffered = [{\r
+          'start': 0,\r
+          'end': _t.duration\r
+        }];\r
+      }\r
+\r
+      // allow whileloading to fire even if "load" fired under HTML5, due to HTTP range/partials\r
+      if ((_t.readyState !== 3 || _t.isHTML5) && _iO.whileloading) {\r
+        _iO.whileloading.apply(_t);\r
+      }\r
+\r
+    };\r
+\r
+    this._whileplaying = function(nPosition, oPeakData, oWaveformDataLeft, oWaveformDataRight, oEQData) {\r
+\r
+      var _iO = _t._iO,\r
+          eqLeft;\r
+\r
+      if (isNaN(nPosition) || nPosition === null) {\r
+        // flash safety net\r
+        return false;\r
+      }\r
+\r
+      // Safari HTML5 play() may return small -ve values when starting from position: 0, eg. -50.120396875. Unexpected/invalid per W3, I think. Normalize to 0.\r
+      _t.position = Math.max(0, nPosition);\r
+\r
+      _t._processOnPosition();\r
+\r
+      if (!_t.isHTML5 && _fV > 8) {\r
+\r
+        if (_iO.usePeakData && typeof oPeakData !== 'undefined' && oPeakData) {\r
+          _t.peakData = {\r
+            left: oPeakData.leftPeak,\r
+            right: oPeakData.rightPeak\r
+          };\r
+        }\r
+\r
+        if (_iO.useWaveformData && typeof oWaveformDataLeft !== 'undefined' && oWaveformDataLeft) {\r
+          _t.waveformData = {\r
+            left: oWaveformDataLeft.split(','),\r
+            right: oWaveformDataRight.split(',')\r
+          };\r
+        }\r
+\r
+        if (_iO.useEQData) {\r
+          if (typeof oEQData !== 'undefined' && oEQData && oEQData.leftEQ) {\r
+            eqLeft = oEQData.leftEQ.split(',');\r
+            _t.eqData = eqLeft;\r
+            _t.eqData.left = eqLeft;\r
+            if (typeof oEQData.rightEQ !== 'undefined' && oEQData.rightEQ) {\r
+              _t.eqData.right = oEQData.rightEQ.split(',');\r
+            }\r
+          }\r
+        }\r
+\r
+      }\r
+\r
+      if (_t.playState === 1) {\r
+\r
+        // special case/hack: ensure buffering is false if loading from cache (and not yet started)\r
+        if (!_t.isHTML5 && _fV === 8 && !_t.position && _t.isBuffering) {\r
+          _t._onbufferchange(0);\r
+        }\r
+\r
+        if (_iO.whileplaying) {\r
+          // flash may call after actual finish\r
+          _iO.whileplaying.apply(_t);\r
+        }\r
+\r
+      }\r
+\r
+      return true;\r
+\r
+    };\r
+\r
+    this._oncaptiondata = function(oData) {\r
+\r
+      /**\r
+       * internal: flash 9 + NetStream (MovieStar/RTMP-only) feature\r
+       * \r
+       * @param {object} oData\r
+       */\r
+\r
+      _s._wD('SMSound._oncaptiondata(): "' + this.id + '" caption data received.');\r
+\r
+      _t.captiondata = oData;\r
+\r
+      if (_t._iO.oncaptiondata) {\r
+        _t._iO.oncaptiondata.apply(_t, [oData]);\r
+      }\r
+\r
+       };\r
+\r
+    this._onmetadata = function(oMDProps, oMDData) {\r
+\r
+      /**\r
+       * internal: flash 9 + NetStream (MovieStar/RTMP-only) feature\r
+       * RTMP may include song title, MovieStar content may include encoding info\r
+       * \r
+       * @param {array} oMDProps (names)\r
+       * @param {array} oMDData (values)\r
+       */\r
+\r
+      _s._wD('SMSound._onmetadata(): "' + this.id + '" metadata received.');\r
+\r
+      var oData = {}, i, j;\r
+\r
+      for (i = 0, j = oMDProps.length; i < j; i++) {\r
+        oData[oMDProps[i]] = oMDData[i];\r
+      }\r
+      _t.metadata = oData;\r
+\r
+      if (_t._iO.onmetadata) {\r
+        _t._iO.onmetadata.apply(_t);\r
+      }\r
+\r
+       };\r
+\r
+    this._onid3 = function(oID3Props, oID3Data) {\r
+\r
+      /**\r
+       * internal: flash 8 + flash 9 ID3 feature\r
+       * may include artist, song title etc.\r
+       * \r
+       * @param {array} oID3Props (names)\r
+       * @param {array} oID3Data (values)\r
+       */\r
+\r
+      _s._wD('SMSound._onid3(): "' + this.id + '" ID3 data received.');\r
+\r
+      var oData = [], i, j;\r
+\r
+      for (i = 0, j = oID3Props.length; i < j; i++) {\r
+        oData[oID3Props[i]] = oID3Data[i];\r
+      }\r
+      _t.id3 = _mixin(_t.id3, oData);\r
+\r
+      if (_t._iO.onid3) {\r
+        _t._iO.onid3.apply(_t);\r
+      }\r
+\r
+    };\r
+\r
+    // flash/RTMP-only\r
+\r
+    this._onconnect = function(bSuccess) {\r
+\r
+      bSuccess = (bSuccess === 1);\r
+      _s._wD('SMSound._onconnect(): "'+_t.id+'"'+(bSuccess?' connected.':' failed to connect? - '+_t.url), (bSuccess?1:2));\r
+      _t.connected = bSuccess;\r
+\r
+      if (bSuccess) {\r
+\r
+        _t.failures = 0;\r
+\r
+        if (_idCheck(_t.id)) {\r
+          if (_t.getAutoPlay()) {\r
+            // only update the play state if auto playing\r
+            _t.play(undefined, _t.getAutoPlay());\r
+          } else if (_t._iO.autoLoad) {\r
+            _t.load();\r
+          }\r
+        }\r
+\r
+        if (_t._iO.onconnect) {\r
+          _t._iO.onconnect.apply(_t, [bSuccess]);\r
+        }\r
+\r
+      }\r
+\r
+    };\r
+\r
+    this._ondataerror = function(sError) {\r
+\r
+      // flash 9 wave/eq data handler\r
+      // hack: called at start, and end from flash at/after onfinish()\r
+      if (_t.playState > 0) {\r
+        _s._wD('SMSound._ondataerror(): ' + sError);\r
+        if (_t._iO.ondataerror) {\r
+          _t._iO.ondataerror.apply(_t);\r
+        }\r
+      }\r
+\r
+    };\r
+\r
+  }; // SMSound()\r
+\r
+  /**\r
+   * Private SoundManager internals\r
+   * ------------------------------\r
+   */\r
+\r
+  _getDocument = function() {\r
+\r
+    return (_doc.body || _doc._docElement || _doc.getElementsByTagName('div')[0]);\r
+\r
+  };\r
+\r
+  _id = function(sID) {\r
+\r
+    return _doc.getElementById(sID);\r
+\r
+  };\r
+\r
+  _mixin = function(oMain, oAdd) {\r
+\r
+    // non-destructive merge\r
+    var o1 = (oMain || {}), o2, o;\r
+\r
+    // if unspecified, o2 is the default options object\r
+    o2 = (typeof oAdd === 'undefined' ? _s.defaultOptions : oAdd);\r
+\r
+    for (o in o2) {\r
+\r
+      if (o2.hasOwnProperty(o) && typeof o1[o] === 'undefined') {\r
+\r
+        if (typeof o2[o] !== 'object' || o2[o] === null) {\r
+\r
+          // assign directly\r
+          o1[o] = o2[o];\r
+\r
+        } else {\r
+\r
+          // recurse through o2\r
+          o1[o] = _mixin(o1[o], o2[o]);\r
+\r
+        }\r
+\r
+      }\r
+\r
+    }\r
+\r
+    return o1;\r
+\r
+  };\r
+\r
+  // additional soundManager properties that soundManager.setup() will accept\r
+\r
+  _extraOptions = {\r
+    'onready': 1,\r
+    'ontimeout': 1,\r
+    'defaultOptions': 1,\r
+    'flash9Options': 1,\r
+    'movieStarOptions': 1\r
+  };\r
+\r
+  _assign = function(o, oParent) {\r
+\r
+    /**\r
+     * recursive assignment of properties, soundManager.setup() helper\r
+     * allows property assignment based on whitelist\r
+     */\r
+\r
+    var i,\r
+        result = true,\r
+        hasParent = (typeof oParent !== 'undefined'),\r
+        setupOptions = _s.setupOptions,\r
+        extraOptions = _extraOptions;\r
+\r
+    // <d>\r
+\r
+    // if soundManager.setup() called, show accepted parameters.\r
+\r
+    if (typeof o === 'undefined') {\r
+\r
+      result = [];\r
+\r
+      for (i in setupOptions) {\r
+\r
+        if (setupOptions.hasOwnProperty(i)) {\r
+          result.push(i);\r
+        }\r
+\r
+      }\r
+\r
+      for (i in extraOptions) {\r
+\r
+        if (extraOptions.hasOwnProperty(i)) {\r
+\r
+          if (typeof _s[i] === 'object') {\r
+\r
+            result.push(i+': {...}');\r
+\r
+          } else if (_s[i] instanceof Function) {\r
+\r
+            result.push(i+': function() {...}');\r
+\r
+          } else {\r
+\r
+            result.push(i);\r
+\r
+          }\r
+\r
+        }\r
+\r
+      }\r
+\r
+      _s._wD(_str('setup', result.join(', ')));\r
+\r
+      return false;\r
+\r
+    }\r
+\r
+    // </d>\r
+\r
+    for (i in o) {\r
+\r
+      if (o.hasOwnProperty(i)) {\r
+\r
+        // if not an {object} we want to recurse through...\r
+\r
+        if (typeof o[i] !== 'object' || o[i] === null || o[i] instanceof Array) {\r
+\r
+          // check "allowed" options\r
+\r
+          if (hasParent && typeof extraOptions[oParent] !== 'undefined') {\r
+\r
+            // valid recursive / nested object option, eg., { defaultOptions: { volume: 50 } }\r
+            _s[oParent][i] = o[i];\r
+\r
+          } else if (typeof setupOptions[i] !== 'undefined') {\r
+\r
+            // special case: assign to setupOptions object, which soundManager property references\r
+            _s.setupOptions[i] = o[i];\r
+\r
+            // assign directly to soundManager, too\r
+            _s[i] = o[i];\r
+\r
+          } else if (typeof extraOptions[i] === 'undefined') {\r
+\r
+            // invalid or disallowed parameter. complain.\r
+            _complain(_str((typeof _s[i] === 'undefined' ? 'setupUndef' : 'setupError'), i), 2);\r
+\r
+            result = false;\r
+\r
+          } else {\r
+\r
+            /**\r
+             * valid extraOptions parameter.\r
+             * is it a method, like onready/ontimeout? call it.\r
+             * multiple parameters should be in an array, eg. soundManager.setup({onready: [myHandler, myScope]});\r
+             */\r
+\r
+            if (_s[i] instanceof Function) {\r
+\r
+              _s[i].apply(_s, (o[i] instanceof Array? o[i] : [o[i]]));\r
+\r
+            } else {\r
+\r
+              // good old-fashioned direct assignment\r
+              _s[i] = o[i];\r
+\r
+            }\r
+\r
+          }\r
+\r
+        } else {\r
+\r
+          // recursion case, eg., { defaultOptions: { ... } }\r
+\r
+          if (typeof extraOptions[i] === 'undefined') {\r
+\r
+            // invalid or disallowed parameter. complain.\r
+            _complain(_str((typeof _s[i] === 'undefined' ? 'setupUndef' : 'setupError'), i), 2);\r
+\r
+            result = false;\r
+\r
+          } else {\r
+\r
+            // recurse through object\r
+            return _assign(o[i], i);\r
+\r
+          }\r
+\r
+        }\r
+\r
+      }\r
+\r
+    }\r
+\r
+    return result;\r
+\r
+  };\r
+\r
+  function _preferFlashCheck(kind) {\r
+\r
+    // whether flash should play a given type\r
+    return (_s.preferFlash && _hasFlash && !_s.ignoreFlash && (typeof _s.flash[kind] !== 'undefined' && _s.flash[kind]));\r
+\r
+  }\r
+\r
+  /**\r
+   * Internal DOM2-level event helpers\r
+   * ---------------------------------\r
+   */\r
+\r
+  _event = (function() {\r
+\r
+    var old = (_win.attachEvent),\r
+    evt = {\r
+      add: (old?'attachEvent':'addEventListener'),\r
+      remove: (old?'detachEvent':'removeEventListener')\r
+    };\r
+\r
+    function getArgs(oArgs) {\r
+\r
+      var args = _slice.call(oArgs),\r
+          len = args.length;\r
+\r
+      if (old) {\r
+        // prefix\r
+        args[1] = 'on' + args[1];\r
+        if (len > 3) {\r
+          // no capture\r
+          args.pop();\r
+        }\r
+      } else if (len === 3) {\r
+        args.push(false);\r
+      }\r
+\r
+      return args;\r
+\r
+    }\r
+\r
+    function apply(args, sType) {\r
+\r
+      var element = args.shift(),\r
+          method = [evt[sType]];\r
+\r
+      if (old) {\r
+        element[method](args[0], args[1]);\r
+      } else {\r
+        element[method].apply(element, args);\r
+      }\r
+\r
+    }\r
+\r
+    function add() {\r
+\r
+      apply(getArgs(arguments), 'add');\r
+\r
+    }\r
+\r
+    function remove() {\r
+\r
+      apply(getArgs(arguments), 'remove');\r
+\r
+    }\r
+\r
+    return {\r
+      'add': add,\r
+      'remove': remove\r
+    };\r
+\r
+  }());\r
+\r
+  /**\r
+   * Internal HTML5 event handling\r
+   * -----------------------------\r
+   */\r
+\r
+  function _html5_event(oFn) {\r
+\r
+    // wrap html5 event handlers so we don't call them on destroyed sounds\r
+\r
+    return function(e) {\r
+\r
+      var t = this._t,\r
+          result;\r
+\r
+      if (!t || !t._a) {\r
+        // <d>\r
+        if (t && t.id) {\r
+          _s._wD(_h5+'ignoring '+e.type+': '+t.id);\r
+        } else {\r
+          _s._wD(_h5+'ignoring '+e.type);\r
+        }\r
+        // </d>\r
+        result = null;\r
+      } else {\r
+        result = oFn.call(this, e);\r
+      }\r
+\r
+      return result;\r
+\r
+    };\r
+\r
+  }\r
+\r
+  _html5_events = {\r
+\r
+    // HTML5 event-name-to-handler map\r
+\r
+    abort: _html5_event(function() {\r
+\r
+      _s._wD(_h5+'abort: '+this._t.id);\r
+\r
+    }),\r
+\r
+    // enough has loaded to play\r
+\r
+    canplay: _html5_event(function() {\r
+\r
+      var t = this._t,\r
+          position1K;\r
+\r
+      if (t._html5_canplay) {\r
+        // this event has already fired. ignore.\r
+        return true;\r
+      }\r
+\r
+      t._html5_canplay = true;\r
+      _s._wD(_h5+'canplay: '+t.id+', '+t.url);\r
+      t._onbufferchange(0);\r
+\r
+      // position according to instance options\r
+      position1K = (typeof t._iO.position !== 'undefined' && !isNaN(t._iO.position)?t._iO.position/1000:null);\r
+\r
+      // set the position if position was set before the sound loaded\r
+      if (t.position && this.currentTime !== position1K) {\r
+        _s._wD(_h5+'canplay: setting position to '+position1K);\r
+        try {\r
+          this.currentTime = position1K;\r
+        } catch(ee) {\r
+          _s._wD(_h5+'setting position of ' + position1K + ' failed: '+ee.message, 2);\r
+        }\r
+      }\r
+\r
+      // hack for HTML5 from/to case\r
+      if (t._iO._oncanplay) {\r
+        t._iO._oncanplay();\r
+      }\r
+\r
+    }),\r
+\r
+    canplaythrough: _html5_event(function() {\r
+\r
+      var t = this._t;\r
+\r
+      if (!t.loaded) {\r
+        t._onbufferchange(0);\r
+        t._whileloading(t.bytesLoaded, t.bytesTotal, t._get_html5_duration());\r
+        t._onload(true);\r
+      }\r
+\r
+    }),\r
+\r
+    // TODO: Reserved for potential use\r
+    /*\r
+    emptied: _html5_event(function() {\r
+\r
+      _s._wD(_h5+'emptied: '+this._t.id);\r
+\r
+    }),\r
+    */\r
+\r
+    ended: _html5_event(function() {\r
+\r
+      var t = this._t;\r
+\r
+      _s._wD(_h5+'ended: '+t.id);\r
+      t._onfinish();\r
+\r
+    }),\r
+\r
+    error: _html5_event(function() {\r
+\r
+      _s._wD(_h5+'error: '+this.error.code);\r
+      // call load with error state?\r
+      this._t._onload(false);\r
+\r
+    }),\r
+\r
+    loadeddata: _html5_event(function() {\r
+\r
+      var t = this._t;\r
+\r
+      _s._wD(_h5+'loadeddata: '+this._t.id);\r
+\r
+      // safari seems to nicely report progress events, eventually totalling 100%\r
+      if (!t._loaded && !_isSafari) {\r
+        t.duration = t._get_html5_duration();\r
+      }\r
+\r
+    }),\r
+\r
+    loadedmetadata: _html5_event(function() {\r
+\r
+      _s._wD(_h5+'loadedmetadata: '+this._t.id);\r
+\r
+    }),\r
+\r
+    loadstart: _html5_event(function() {\r
+\r
+      _s._wD(_h5+'loadstart: '+this._t.id);\r
+      // assume buffering at first\r
+      this._t._onbufferchange(1);\r
+\r
+    }),\r
+\r
+    play: _html5_event(function() {\r
+\r
+      _s._wD(_h5+'play: '+this._t.id+', '+this._t.url);\r
+      // once play starts, no buffering\r
+      this._t._onbufferchange(0);\r
+\r
+    }),\r
+\r
+    playing: _html5_event(function() {\r
+\r
+      _s._wD(_h5+'playing: '+this._t.id);\r
+\r
+      // once play starts, no buffering\r
+      this._t._onbufferchange(0);\r
+\r
+    }),\r
+\r
+    progress: _html5_event(function(e) {\r
+\r
+      // note: can fire repeatedly after "loaded" event, due to use of HTTP range/partials\r
+\r
+      var t = this._t,\r
+          i, j, str, buffered = 0,\r
+          isProgress = (e.type === 'progress'),\r
+          ranges = e.target.buffered,\r
+          // firefox 3.6 implements e.loaded/total (bytes)\r
+          loaded = (e.loaded||0),\r
+          total = (e.total||1),\r
+          // HTML5 returns msec. SM2 API uses seconds for setPosition() etc., whether Flash or HTML5.\r
+          scale = 1000;\r
+\r
+      // reset the "buffered" (loaded byte ranges) array\r
+      t.buffered = [];\r
+\r
+      if (ranges && ranges.length) {\r
+\r
+        // if loaded is 0, try TimeRanges implementation as % of load\r
+        // https://developer.mozilla.org/en/DOM/TimeRanges\r
+\r
+        // re-build "buffered" array\r
+        for (i=0, j=ranges.length; i<j; i++) {\r
+          t.buffered.push({\r
+            'start': ranges.start(i) * scale,\r
+            'end': ranges.end(i) * scale\r
+          });\r
+        }\r
+\r
+        // use the last value locally\r
+        buffered = (ranges.end(0) - ranges.start(0)) * scale;\r
+\r
+        // linear case, buffer sum; does not account for seeking and HTTP partials / byte ranges\r
+        loaded = buffered/(e.target.duration*scale);\r
+\r
+        // <d>\r
+        if (isProgress && ranges.length > 1) {\r
+          str = [];\r
+          j = ranges.length;\r
+          for (i=0; i<j; i++) {\r
+            str.push(e.target.buffered.start(i)*scale +'-'+ e.target.buffered.end(i)*scale);\r
+          }\r
+          _s._wD(_h5+'progress: timeRanges: '+str.join(', '));\r
+        }\r
+\r
+        if (isProgress && !isNaN(loaded)) {\r
+          _s._wD(_h5+'progress: '+t.id+': ' + Math.floor(loaded*100)+'% loaded');\r
+        }\r
+        // </d>\r
+\r
+      }\r
+\r
+      if (!isNaN(loaded)) {\r
+\r
+        // if progress, likely not buffering\r
+        t._onbufferchange(0);\r
+        // TODO: prevent calls with duplicate values.\r
+        t._whileloading(loaded, total, t._get_html5_duration());\r
+        if (loaded && total && loaded === total) {\r
+          // in case "onload" doesn't fire (eg. gecko 1.9.2)\r
+          _html5_events.canplaythrough.call(this, e);\r
+        }\r
+\r
+      }\r
+\r
+    }),\r
+\r
+    ratechange: _html5_event(function() {\r
+\r
+      _s._wD(_h5+'ratechange: '+this._t.id);\r
+\r
+    }),\r
+\r
+    suspend: _html5_event(function(e) {\r
+\r
+      // download paused/stopped, may have finished (eg. onload)\r
+      var t = this._t;\r
+\r
+      _s._wD(_h5+'suspend: '+t.id);\r
+      _html5_events.progress.call(this, e);\r
+      t._onsuspend();\r
+\r
+    }),\r
+\r
+    stalled: _html5_event(function() {\r
+\r
+      _s._wD(_h5+'stalled: '+this._t.id);\r
+\r
+    }),\r
+\r
+    timeupdate: _html5_event(function() {\r
+\r
+      this._t._onTimer();\r
+\r
+    }),\r
+\r
+    waiting: _html5_event(function() {\r
+\r
+      var t = this._t;\r
+\r
+      // see also: seeking\r
+      _s._wD(_h5+'waiting: '+t.id);\r
+\r
+      // playback faster than download rate, etc.\r
+      t._onbufferchange(1);\r
+\r
+    })\r
+\r
+  };\r
+\r
+  _html5OK = function(iO) {\r
+\r
+    // playability test based on URL or MIME type\r
+\r
+    var result;\r
+\r
+    if (iO.serverURL || (iO.type && _preferFlashCheck(iO.type))) {\r
+\r
+      // RTMP, or preferring flash\r
+      result = false;\r
+\r
+    } else {\r
+\r
+      // Use type, if specified. If HTML5-only mode, no other options, so just give 'er\r
+      result = ((iO.type ? _html5CanPlay({type:iO.type}) : _html5CanPlay({url:iO.url}) || _s.html5Only));\r
+\r
+    }\r
+\r
+    return result;\r
+\r
+  };\r
+\r
+  _html5Unload = function(oAudio, url) {\r
+\r
+    /**\r
+     * Internal method: Unload media, and cancel any current/pending network requests.\r
+     * Firefox can load an empty URL, which allegedly destroys the decoder and stops the download.\r
+     * https://developer.mozilla.org/En/Using_audio_and_video_in_Firefox#Stopping_the_download_of_media\r
+     * However, Firefox has been seen loading a relative URL from '' and thus requesting the hosting page on unload.\r
+     * Other UA behaviour is unclear, so everyone else gets an about:blank-style URL.\r
+     */\r
+\r
+    if (oAudio) {\r
+      // Firefox likes '' for unload (used to work?) - however, may request hosting page URL (bad.) Most other UAs dislike '' and fail to unload.\r
+      oAudio.src = url;\r
+    }\r
+\r
+  };\r
+\r
+  _html5CanPlay = function(o) {\r
+\r
+    /**\r
+     * Try to find MIME, test and return truthiness\r
+     * o = {\r
+     *  url: '/path/to/an.mp3',\r
+     *  type: 'audio/mp3'\r
+     * }\r
+     */\r
+\r
+    if (!_s.useHTML5Audio || !_s.hasHTML5) {\r
+      return false;\r
+    }\r
+\r
+    var url = (o.url || null),\r
+        mime = (o.type || null),\r
+        aF = _s.audioFormats,\r
+        result,\r
+        offset,\r
+        fileExt,\r
+        item;\r
+\r
+    // account for known cases like audio/mp3\r
+\r
+    if (mime && typeof _s.html5[mime] !== 'undefined') {\r
+      return (_s.html5[mime] && !_preferFlashCheck(mime));\r
+    }\r
+\r
+    if (!_html5Ext) {\r
+      _html5Ext = [];\r
+      for (item in aF) {\r
+        if (aF.hasOwnProperty(item)) {\r
+          _html5Ext.push(item);\r
+          if (aF[item].related) {\r
+            _html5Ext = _html5Ext.concat(aF[item].related);\r
+          }\r
+        }\r
+      }\r
+      _html5Ext = new RegExp('\\.('+_html5Ext.join('|')+')(\\?.*)?$','i');\r
+    }\r
+\r
+    // TODO: Strip URL queries, etc.\r
+    fileExt = (url ? url.toLowerCase().match(_html5Ext) : null);\r
+\r
+    if (!fileExt || !fileExt.length) {\r
+      if (!mime) {\r
+        result = false;\r
+      } else {\r
+        // audio/mp3 -> mp3, result should be known\r
+        offset = mime.indexOf(';');\r
+        // strip "audio/X; codecs.."\r
+        fileExt = (offset !== -1?mime.substr(0,offset):mime).substr(6);\r
+      }\r
+    } else {\r
+      // match the raw extension name - "mp3", for example\r
+      fileExt = fileExt[1];\r
+    }\r
+\r
+    if (fileExt && typeof _s.html5[fileExt] !== 'undefined') {\r
+      // result known\r
+      result = (_s.html5[fileExt] && !_preferFlashCheck(fileExt));\r
+    } else {\r
+      mime = 'audio/'+fileExt;\r
+      result = _s.html5.canPlayType({type:mime});\r
+      _s.html5[fileExt] = result;\r
+      // _s._wD('canPlayType, found result: '+result);\r
+      result = (result && _s.html5[mime] && !_preferFlashCheck(mime));\r
+    }\r
+\r
+    return result;\r
+\r
+  };\r
+\r
+  _testHTML5 = function() {\r
+\r
+    /**\r
+     * Internal: Iterates over audioFormats, determining support eg. audio/mp3, audio/mpeg and so on\r
+     * assigns results to html5[] and flash[].\r
+     */\r
+\r
+    if (!_s.useHTML5Audio || !_s.hasHTML5) {\r
+      return false;\r
+    }\r
+\r
+    // double-whammy: Opera 9.64 throws WRONG_ARGUMENTS_ERR if no parameter passed to Audio(), and Webkit + iOS happily tries to load "null" as a URL. :/\r
+    var a = (typeof Audio !== 'undefined' ? (_isOpera && opera.version() < 10 ? new Audio(null) : new Audio()) : null),\r
+        item, lookup, support = {}, aF, i;\r
+\r
+    function _cp(m) {\r
+\r
+      var canPlay, i, j,\r
+          result = false,\r
+          isOK = false;\r
+\r
+      if (!a || typeof a.canPlayType !== 'function') {\r
+        return result;\r
+      }\r
+\r
+      if (m instanceof Array) {\r
+        // iterate through all mime types, return any successes\r
+        for (i=0, j=m.length; i<j; i++) {\r
+          if (_s.html5[m[i]] || a.canPlayType(m[i]).match(_s.html5Test)) {\r
+            isOK = true;\r
+            _s.html5[m[i]] = true;\r
+            // note flash support, too\r
+            _s.flash[m[i]] = !!(m[i].match(_flashMIME));\r
+          }\r
+        }\r
+        result = isOK;\r
+      } else {\r
+        canPlay = (a && typeof a.canPlayType === 'function' ? a.canPlayType(m) : false);\r
+        result = !!(canPlay && (canPlay.match(_s.html5Test)));\r
+      }\r
+\r
+      return result;\r
+\r
+    }\r
+\r
+    // test all registered formats + codecs\r
+\r
+    aF = _s.audioFormats;\r
+\r
+    for (item in aF) {\r
+\r
+      if (aF.hasOwnProperty(item)) {\r
+\r
+        lookup = 'audio/' + item;\r
+\r
+        support[item] = _cp(aF[item].type);\r
+\r
+        // write back generic type too, eg. audio/mp3\r
+        support[lookup] = support[item];\r
+\r
+        // assign flash\r
+        if (item.match(_flashMIME)) {\r
+\r
+          _s.flash[item] = true;\r
+          _s.flash[lookup] = true;\r
+\r
+        } else {\r
+\r
+          _s.flash[item] = false;\r
+          _s.flash[lookup] = false;\r
+\r
+        }\r
+\r
+        // assign result to related formats, too\r
+\r
+        if (aF[item] && aF[item].related) {\r
+\r
+          for (i=aF[item].related.length-1; i >= 0; i--) {\r
+\r
+            // eg. audio/m4a\r
+            support['audio/'+aF[item].related[i]] = support[item];\r
+            _s.html5[aF[item].related[i]] = support[item];\r
+            _s.flash[aF[item].related[i]] = support[item];\r
+\r
+          }\r
+\r
+        }\r
+\r
+      }\r
+\r
+    }\r
+\r
+    support.canPlayType = (a?_cp:null);\r
+    _s.html5 = _mixin(_s.html5, support);\r
+\r
+    return true;\r
+\r
+  };\r
+\r
+  _strings = {\r
+\r
+    // <d>\r
+    notReady: 'Not loaded yet - wait for soundManager.onready()',\r
+    notOK: 'Audio support is not available.',\r
+    domError: _smc + 'createMovie(): appendChild/innerHTML call failed. DOM not ready or other error.',\r
+    spcWmode: _smc + 'createMovie(): Removing wmode, preventing known SWF loading issue(s)',\r
+    swf404: _sm + ': Verify that %s is a valid path.',\r
+    tryDebug: 'Try ' + _sm + '.debugFlash = true for more security details (output goes to SWF.)',\r
+    checkSWF: 'See SWF output for more debug info.',\r
+    localFail: _sm + ': Non-HTTP page (' + _doc.location.protocol + ' URL?) Review Flash player security settings for this special case:\nhttp://www.macromedia.com/support/documentation/en/flashplayer/help/settings_manager04.html\nMay need to add/allow path, eg. c:/sm2/ or /users/me/sm2/',\r
+    waitFocus: _sm + ': Special case: Waiting for SWF to load with window focus...',\r
+    waitImpatient: _sm + ': Getting impatient, still waiting for Flash%s...',\r
+    waitForever: _sm + ': Waiting indefinitely for Flash (will recover if unblocked)...',\r
+    waitSWF: _sm + ': Retrying, waiting for 100% SWF load...',\r
+    needFunction: _sm + ': Function object expected for %s',\r
+    badID: 'Warning: Sound ID "%s" should be a string, starting with a non-numeric character',\r
+    currentObj: '--- ' + _sm + '._debug(): Current sound objects ---',\r
+    waitEI: _smc + 'initMovie(): Waiting for ExternalInterface call from Flash...',\r
+    waitOnload: _sm + ': Waiting for window.onload()',\r
+    docLoaded: _sm + ': Document already loaded',\r
+    onload: _smc + 'initComplete(): calling soundManager.onload()',\r
+    onloadOK: _sm + '.onload() complete',\r
+    init: _smc + 'init()',\r
+    didInit: _smc + 'init(): Already called?',\r
+    flashJS: _sm + ': Attempting JS to Flash call...',\r
+    secNote: 'Flash security note: Network/internet URLs will not load due to security restrictions. Access can be configured via Flash Player Global Security Settings Page: http://www.macromedia.com/support/documentation/en/flashplayer/help/settings_manager04.html',\r
+    badRemove: 'Warning: Failed to remove flash movie.',\r
+    shutdown: _sm + '.disable(): Shutting down',\r
+    queue: _sm + ': Queueing %s handler',\r
+    smFail: _sm + ': Failed to initialise.',\r
+    smError: 'SMSound.load(): Exception: JS-Flash communication failed, or JS error.',\r
+    fbTimeout: 'No flash response, applying .'+_swfCSS.swfTimedout+' CSS...',\r
+    fbLoaded: 'Flash loaded',\r
+    fbHandler: _smc+'flashBlockHandler()',\r
+    manURL: 'SMSound.load(): Using manually-assigned URL',\r
+    onURL: _sm + '.load(): current URL already assigned.',\r
+    badFV: _sm + '.flashVersion must be 8 or 9. "%s" is invalid. Reverting to %s.',\r
+    as2loop: 'Note: Setting stream:false so looping can work (flash 8 limitation)',\r
+    noNSLoop: 'Note: Looping not implemented for MovieStar formats',\r
+    needfl9: 'Note: Switching to flash 9, required for MP4 formats.',\r
+    mfTimeout: 'Setting flashLoadTimeout = 0 (infinite) for off-screen, mobile flash case',\r
+    needFlash: _sm + ': Fatal error: Flash is needed to play some required formats, but is not available.',\r
+    gotFocus: _sm + ': Got window focus.',\r
+    mfOn: 'mobileFlash::enabling on-screen flash repositioning',\r
+    policy: 'Enabling usePolicyFile for data access',\r
+    setup: _sm + '.setup(): allowed parameters: %s',\r
+    setupError: _sm + '.setup(): "%s" cannot be assigned with this method.',\r
+    setupUndef: _sm + '.setup(): Could not find option "%s"',\r
+    setupLate: _sm + '.setup(): url + flashVersion changes will not take effect until reboot().',\r
+    h5a: 'creating HTML5 Audio() object',\r
+    noURL: _sm + ': Flash URL required. Call soundManager.setup({url:...}) to get started.'\r
+    // </d>\r
+\r
+  };\r
+\r
+  _str = function() {\r
+\r
+    // internal string replace helper.\r
+    // arguments: o [,items to replace]\r
+    // <d>\r
+\r
+    // real array, please\r
+    var args = _slice.call(arguments),\r
+\r
+    // first arg\r
+    o = args.shift(),\r
+\r
+    str = (_strings && _strings[o]?_strings[o]:''), i, j;\r
+    if (str && args && args.length) {\r
+      for (i = 0, j = args.length; i < j; i++) {\r
+        str = str.replace('%s', args[i]);\r
+      }\r
+    }\r
+\r
+    return str;\r
+    // </d>\r
+\r
+  };\r
+\r
+  _loopFix = function(sOpt) {\r
+\r
+    // flash 8 requires stream = false for looping to work\r
+    if (_fV === 8 && sOpt.loops > 1 && sOpt.stream) {\r
+      _wDS('as2loop');\r
+      sOpt.stream = false;\r
+    }\r
+\r
+    return sOpt;\r
+\r
+  };\r
+\r
+  _policyFix = function(sOpt, sPre) {\r
+\r
+    if (sOpt && !sOpt.usePolicyFile && (sOpt.onid3 || sOpt.usePeakData || sOpt.useWaveformData || sOpt.useEQData)) {\r
+      _s._wD((sPre || '') + _str('policy'));\r
+      sOpt.usePolicyFile = true;\r
+    }\r
+\r
+    return sOpt;\r
+\r
+  };\r
+\r
+  _complain = function(sMsg) {\r
+\r
+    // <d>\r
+    if (typeof console !== 'undefined' && typeof console.warn !== 'undefined') {\r
+      console.warn(sMsg);\r
+    } else {\r
+      _s._wD(sMsg);\r
+    }\r
+    // </d>\r
+\r
+  };\r
+\r
+  _doNothing = function() {\r
+\r
+    return false;\r
+\r
+  };\r
+\r
+  _disableObject = function(o) {\r
+\r
+    var oProp;\r
+\r
+    for (oProp in o) {\r
+      if (o.hasOwnProperty(oProp) && typeof o[oProp] === 'function') {\r
+        o[oProp] = _doNothing;\r
+      }\r
+    }\r
+\r
+    oProp = null;\r
+\r
+  };\r
+\r
+  _failSafely = function(bNoDisable) {\r
+\r
+    // general failure exception handler\r
+\r
+    if (typeof bNoDisable === 'undefined') {\r
+      bNoDisable = false;\r
+    }\r
+\r
+    if (_disabled || bNoDisable) {\r
+      _wDS('smFail', 2);\r
+      _s.disable(bNoDisable);\r
+    }\r
+\r
+  };\r
+\r
+  _normalizeMovieURL = function(smURL) {\r
+\r
+    var urlParams = null, url;\r
+\r
+    if (smURL) {\r
+      if (smURL.match(/\.swf(\?.*)?$/i)) {\r
+        urlParams = smURL.substr(smURL.toLowerCase().lastIndexOf('.swf?') + 4);\r
+        if (urlParams) {\r
+          // assume user knows what they're doing\r
+          return smURL;\r
+        }\r
+      } else if (smURL.lastIndexOf('/') !== smURL.length - 1) {\r
+        // append trailing slash, if needed\r
+        smURL += '/';\r
+      }\r
+    }\r
+\r
+    url = (smURL && smURL.lastIndexOf('/') !== - 1 ? smURL.substr(0, smURL.lastIndexOf('/') + 1) : './') + _s.movieURL;\r
+\r
+    if (_s.noSWFCache) {\r
+      url += ('?ts=' + new Date().getTime());\r
+    }\r
+\r
+    return url;\r
+\r
+  };\r
+\r
+  _setVersionInfo = function() {\r
+\r
+    // short-hand for internal use\r
+\r
+    _fV = parseInt(_s.flashVersion, 10);\r
+\r
+    if (_fV !== 8 && _fV !== 9) {\r
+      _s._wD(_str('badFV', _fV, _defaultFlashVersion));\r
+      _s.flashVersion = _fV = _defaultFlashVersion;\r
+    }\r
+\r
+    // debug flash movie, if applicable\r
+\r
+    var isDebug = (_s.debugMode || _s.debugFlash?'_debug.swf':'.swf');\r
+\r
+    if (_s.useHTML5Audio && !_s.html5Only && _s.audioFormats.mp4.required && _fV < 9) {\r
+      _s._wD(_str('needfl9'));\r
+      _s.flashVersion = _fV = 9;\r
+    }\r
+\r
+    _s.version = _s.versionNumber + (_s.html5Only?' (HTML5-only mode)':(_fV === 9?' (AS3/Flash 9)':' (AS2/Flash 8)'));\r
+\r
+    // set up default options\r
+    if (_fV > 8) {\r
+      // +flash 9 base options\r
+      _s.defaultOptions = _mixin(_s.defaultOptions, _s.flash9Options);\r
+      _s.features.buffering = true;\r
+      // +moviestar support\r
+      _s.defaultOptions = _mixin(_s.defaultOptions, _s.movieStarOptions);\r
+      _s.filePatterns.flash9 = new RegExp('\\.(mp3|' + _netStreamTypes.join('|') + ')(\\?.*)?$', 'i');\r
+      _s.features.movieStar = true;\r
+    } else {\r
+      _s.features.movieStar = false;\r
+    }\r
+\r
+    // regExp for flash canPlay(), etc.\r
+    _s.filePattern = _s.filePatterns[(_fV !== 8?'flash9':'flash8')];\r
+\r
+    // if applicable, use _debug versions of SWFs\r
+    _s.movieURL = (_fV === 8?'soundmanager2.swf':'soundmanager2_flash9.swf').replace('.swf', isDebug);\r
+\r
+    _s.features.peakData = _s.features.waveformData = _s.features.eqData = (_fV > 8);\r
+\r
+  };\r
+\r
+  _setPolling = function(bPolling, bHighPerformance) {\r
+\r
+    if (!_flash) {\r
+      return false;\r
+    }\r
+\r
+    _flash._setPolling(bPolling, bHighPerformance);\r
+\r
+  };\r
+\r
+  _initDebug = function() {\r
+\r
+    // starts debug mode, creating output <div> for UAs without console object\r
+\r
+    // allow force of debug mode via URL\r
+    if (_s.debugURLParam.test(_wl)) {\r
+      _s.debugMode = true;\r
+    }\r
+\r
+    // <d>\r
+    if (_id(_s.debugID)) {\r
+      return false;\r
+    }\r
+\r
+    var oD, oDebug, oTarget, oToggle, tmp;\r
+\r
+    if (_s.debugMode && !_id(_s.debugID) && (!_hasConsole || !_s.useConsole || !_s.consoleOnly)) {\r
+\r
+      oD = _doc.createElement('div');\r
+      oD.id = _s.debugID + '-toggle';\r
+\r
+      oToggle = {\r
+        'position': 'fixed',\r
+        'bottom': '0px',\r
+        'right': '0px',\r
+        'width': '1.2em',\r
+        'height': '1.2em',\r
+        'lineHeight': '1.2em',\r
+        'margin': '2px',\r
+        'textAlign': 'center',\r
+        'border': '1px solid #999',\r
+        'cursor': 'pointer',\r
+        'background': '#fff',\r
+        'color': '#333',\r
+        'zIndex': 10001\r
+      };\r
+\r
+      oD.appendChild(_doc.createTextNode('-'));\r
+      oD.onclick = _toggleDebug;\r
+      oD.title = 'Toggle SM2 debug console';\r
+\r
+      if (_ua.match(/msie 6/i)) {\r
+        oD.style.position = 'absolute';\r
+        oD.style.cursor = 'hand';\r
+      }\r
+\r
+      for (tmp in oToggle) {\r
+        if (oToggle.hasOwnProperty(tmp)) {\r
+          oD.style[tmp] = oToggle[tmp];\r
+        }\r
+      }\r
+\r
+      oDebug = _doc.createElement('div');\r
+      oDebug.id = _s.debugID;\r
+      oDebug.style.display = (_s.debugMode?'block':'none');\r
+\r
+      if (_s.debugMode && !_id(oD.id)) {\r
+        try {\r
+          oTarget = _getDocument();\r
+          oTarget.appendChild(oD);\r
+        } catch(e2) {\r
+          throw new Error(_str('domError')+' \n'+e2.toString());\r
+        }\r
+        oTarget.appendChild(oDebug);\r
+      }\r
+\r
+    }\r
+\r
+    oTarget = null;\r
+    // </d>\r
+\r
+  };\r
+\r
+  _idCheck = this.getSoundById;\r
+\r
+  // <d>\r
+  _wDS = function(o, errorLevel) {\r
+\r
+    return (!o ? '' : _s._wD(_str(o), errorLevel));\r
+\r
+  };\r
+\r
+  // last-resort debugging option\r
+\r
+  if (_wl.indexOf('sm2-debug=alert') + 1 && _s.debugMode) {\r
+    _s._wD = function(sText) {window.alert(sText);};\r
+  }\r
+\r
+  _toggleDebug = function() {\r
+\r
+    var o = _id(_s.debugID),\r
+    oT = _id(_s.debugID + '-toggle');\r
+\r
+    if (!o) {\r
+      return false;\r
+    }\r
+\r
+    if (_debugOpen) {\r
+      // minimize\r
+      oT.innerHTML = '+';\r
+      o.style.display = 'none';\r
+    } else {\r
+      oT.innerHTML = '-';\r
+      o.style.display = 'block';\r
+    }\r
+\r
+    _debugOpen = !_debugOpen;\r
+\r
+  };\r
+\r
+  _debugTS = function(sEventType, bSuccess, sMessage) {\r
+\r
+    // troubleshooter debug hooks\r
+\r
+    if (typeof sm2Debugger !== 'undefined') {\r
+      try {\r
+        sm2Debugger.handleEvent(sEventType, bSuccess, sMessage);\r
+      } catch(e) {\r
+        // oh well\r
+      }\r
+    }\r
+\r
+    return true;\r
+\r
+  };\r
+  // </d>\r
+\r
+  _getSWFCSS = function() {\r
+\r
+    var css = [];\r
+\r
+    if (_s.debugMode) {\r
+      css.push(_swfCSS.sm2Debug);\r
+    }\r
+\r
+    if (_s.debugFlash) {\r
+      css.push(_swfCSS.flashDebug);\r
+    }\r
+\r
+    if (_s.useHighPerformance) {\r
+      css.push(_swfCSS.highPerf);\r
+    }\r
+\r
+    return css.join(' ');\r
+\r
+  };\r
+\r
+  _flashBlockHandler = function() {\r
+\r
+    // *possible* flash block situation.\r
+\r
+    var name = _str('fbHandler'),\r
+        p = _s.getMoviePercent(),\r
+        css = _swfCSS,\r
+        error = {type:'FLASHBLOCK'};\r
+\r
+    if (_s.html5Only) {\r
+      return false;\r
+    }\r
+\r
+    if (!_s.ok()) {\r
+\r
+      if (_needsFlash) {\r
+        // make the movie more visible, so user can fix\r
+        _s.oMC.className = _getSWFCSS() + ' ' + css.swfDefault + ' ' + (p === null?css.swfTimedout:css.swfError);\r
+        _s._wD(name+': '+_str('fbTimeout')+(p?' ('+_str('fbLoaded')+')':''));\r
+      }\r
+\r
+      _s.didFlashBlock = true;\r
+\r
+      // fire onready(), complain lightly\r
+      _processOnEvents({type:'ontimeout', ignoreInit:true, error:error});\r
+      _catchError(error);\r
+\r
+    } else {\r
+\r
+      // SM2 loaded OK (or recovered)\r
+\r
+      // <d>\r
+      if (_s.didFlashBlock) {\r
+        _s._wD(name+': Unblocked');\r
+      }\r
+      // </d>\r
+\r
+      if (_s.oMC) {\r
+        _s.oMC.className = [_getSWFCSS(), css.swfDefault, css.swfLoaded + (_s.didFlashBlock?' '+css.swfUnblocked:'')].join(' ');\r
+      }\r
+\r
+    }\r
+\r
+  };\r
+\r
+  _addOnEvent = function(sType, oMethod, oScope) {\r
+\r
+    if (typeof _on_queue[sType] === 'undefined') {\r
+      _on_queue[sType] = [];\r
+    }\r
+\r
+    _on_queue[sType].push({\r
+      'method': oMethod,\r
+      'scope': (oScope || null),\r
+      'fired': false\r
+    });\r
+\r
+  };\r
+\r
+  _processOnEvents = function(oOptions) {\r
+\r
+    // if unspecified, assume OK/error\r
+\r
+    if (!oOptions) {\r
+      oOptions = {\r
+        type: (_s.ok() ? 'onready' : 'ontimeout')\r
+      };\r
+    }\r
+\r
+    if (!_didInit && oOptions && !oOptions.ignoreInit) {\r
+      // not ready yet.\r
+      return false;\r
+    }\r
+\r
+    if (oOptions.type === 'ontimeout' && (_s.ok() || (_disabled && !oOptions.ignoreInit))) {\r
+      // invalid case\r
+      return false;\r
+    }\r
+\r
+    var status = {\r
+          success: (oOptions && oOptions.ignoreInit?_s.ok():!_disabled)\r
+        },\r
+\r
+        // queue specified by type, or none\r
+        srcQueue = (oOptions && oOptions.type?_on_queue[oOptions.type]||[]:[]),\r
+\r
+        queue = [], i, j,\r
+        args = [status],\r
+        canRetry = (_needsFlash && _s.useFlashBlock && !_s.ok());\r
+\r
+    if (oOptions.error) {\r
+      args[0].error = oOptions.error;\r
+    }\r
+\r
+    for (i = 0, j = srcQueue.length; i < j; i++) {\r
+      if (srcQueue[i].fired !== true) {\r
+        queue.push(srcQueue[i]);\r
+      }\r
+    }\r
+\r
+    if (queue.length) {\r
+      _s._wD(_sm + ': Firing ' + queue.length + ' '+oOptions.type+'() item' + (queue.length === 1?'':'s'));\r
+      for (i = 0, j = queue.length; i < j; i++) {\r
+        if (queue[i].scope) {\r
+          queue[i].method.apply(queue[i].scope, args);\r
+        } else {\r
+          queue[i].method.apply(this, args);\r
+        }\r
+        if (!canRetry) {\r
+          // flashblock case doesn't count here\r
+          queue[i].fired = true;\r
+        }\r
+      }\r
+    }\r
+\r
+    return true;\r
+\r
+  };\r
+\r
+  _initUserOnload = function() {\r
+\r
+    _win.setTimeout(function() {\r
+\r
+      if (_s.useFlashBlock) {\r
+        _flashBlockHandler();\r
+      }\r
+\r
+      _processOnEvents();\r
+\r
+      // call user-defined "onload", scoped to window\r
+\r
+      if (typeof _s.onload === 'function') {\r
+        _wDS('onload', 1);\r
+        _s.onload.apply(_win);\r
+        _wDS('onloadOK', 1);\r
+      }\r
+\r
+      if (_s.waitForWindowLoad) {\r
+        _event.add(_win, 'load', _initUserOnload);\r
+      }\r
+\r
+    },1);\r
+\r
+  };\r
+\r
+  _detectFlash = function() {\r
+\r
+    // hat tip: Flash Detect library (BSD, (C) 2007) by Carl "DocYes" S. Yestrau - http://featureblend.com/javascript-flash-detection-library.html / http://featureblend.com/license.txt\r
+\r
+    if (typeof _hasFlash !== 'undefined') {\r
+      // this work has already been done.\r
+      return _hasFlash;\r
+    }\r
+\r
+    var hasPlugin = false, n = navigator, nP = n.plugins, obj, type, types, AX = _win.ActiveXObject;\r
+\r
+    if (nP && nP.length) {\r
+      type = 'application/x-shockwave-flash';\r
+      types = n.mimeTypes;\r
+      if (types && types[type] && types[type].enabledPlugin && types[type].enabledPlugin.description) {\r
+        hasPlugin = true;\r
+      }\r
+    } else if (typeof AX !== 'undefined') {\r
+      try {\r
+        obj = new AX('ShockwaveFlash.ShockwaveFlash');\r
+      } catch(e) {\r
+        // oh well\r
+      }\r
+      hasPlugin = (!!obj);\r
+    }\r
+\r
+    _hasFlash = hasPlugin;\r
+\r
+    return hasPlugin;\r
+\r
+  };\r
+\r
+  _featureCheck = function() {\r
+\r
+    var needsFlash,\r
+        item,\r
+        result = true,\r
+        formats = _s.audioFormats,\r
+        // iPhone <= 3.1 has broken HTML5 audio(), but firmware 3.2 (original iPad) + iOS4 works.\r
+        isSpecial = (_is_iDevice && !!(_ua.match(/os (1|2|3_0|3_1)/i)));\r
+\r
+    if (isSpecial) {\r
+\r
+      // has Audio(), but is broken; let it load links directly.\r
+      _s.hasHTML5 = false;\r
+\r
+      // ignore flash case, however\r
+      _s.html5Only = true;\r
+\r
+      if (_s.oMC) {\r
+        _s.oMC.style.display = 'none';\r
+      }\r
+\r
+      result = false;\r
+\r
+    } else {\r
+\r
+      if (_s.useHTML5Audio) {\r
+\r
+        if (!_s.html5 || !_s.html5.canPlayType) {\r
+          _s._wD('SoundManager: No HTML5 Audio() support detected.');\r
+          _s.hasHTML5 = false;\r
+        }\r
+\r
+        // <d>\r
+        if (_isBadSafari) {\r
+          _s._wD(_smc+'Note: Buggy HTML5 Audio in Safari on this OS X release, see https://bugs.webkit.org/show_bug.cgi?id=32159 - '+(!_hasFlash?' would use flash fallback for MP3/MP4, but none detected.':'will use flash fallback for MP3/MP4, if available'),1);\r
+        }\r
+        // </d>\r
+\r
+      }\r
+\r
+    }\r
+\r
+    if (_s.useHTML5Audio && _s.hasHTML5) {\r
+\r
+      for (item in formats) {\r
+        if (formats.hasOwnProperty(item)) {\r
+          if ((formats[item].required && !_s.html5.canPlayType(formats[item].type)) || (_s.preferFlash && (_s.flash[item] || _s.flash[formats[item].type]))) {\r
+            // flash may be required, or preferred for this format\r
+            needsFlash = true;\r
+          }\r
+        }\r
+      }\r
+\r
+    }\r
+\r
+    // sanity check...\r
+    if (_s.ignoreFlash) {\r
+      needsFlash = false;\r
+    }\r
+\r
+    _s.html5Only = (_s.hasHTML5 && _s.useHTML5Audio && !needsFlash);\r
+\r
+    return (!_s.html5Only);\r
+\r
+  };\r
+\r
+  _parseURL = function(url) {\r
+\r
+    /**\r
+     * Internal: Finds and returns the first playable URL (or failing that, the first URL.)\r
+     * @param {string or array} url A single URL string, OR, an array of URL strings or {url:'/path/to/resource', type:'audio/mp3'} objects.\r
+     */\r
+\r
+    var i, j, urlResult = 0, result;\r
+\r
+    if (url instanceof Array) {\r
+\r
+      // find the first good one\r
+      for (i=0, j=url.length; i<j; i++) {\r
+\r
+        if (url[i] instanceof Object) {\r
+          // MIME check\r
+          if (_s.canPlayMIME(url[i].type)) {\r
+            urlResult = i;\r
+            break;\r
+          }\r
+\r
+        } else if (_s.canPlayURL(url[i])) {\r
+          // URL string check\r
+          urlResult = i;\r
+          break;\r
+        }\r
+\r
+      }\r
+\r
+      // normalize to string\r
+      if (url[urlResult].url) {\r
+        url[urlResult] = url[urlResult].url;\r
+      }\r
+\r
+      result = url[urlResult];\r
+\r
+    } else {\r
+\r
+      // single URL case\r
+      result = url;\r
+\r
+    }\r
+\r
+    return result;\r
+\r
+  };\r
+\r
+\r
+  _startTimer = function(oSound) {\r
+\r
+    /**\r
+     * attach a timer to this sound, and start an interval if needed\r
+     */\r
+\r
+    if (!oSound._hasTimer) {\r
+\r
+      oSound._hasTimer = true;\r
+\r
+      if (!_mobileHTML5 && _s.html5PollingInterval) {\r
+\r
+        if (_h5IntervalTimer === null && _h5TimerCount === 0) {\r
+\r
+          _h5IntervalTimer = _win.setInterval(_timerExecute, _s.html5PollingInterval);\r
+   \r
+        }\r
+\r
+        _h5TimerCount++;\r
+\r
+      }\r
+\r
+    }\r
+\r
+  };\r
+\r
+  _stopTimer = function(oSound) {\r
+\r
+    /**\r
+     * detach a timer\r
+     */\r
+\r
+    if (oSound._hasTimer) {\r
+\r
+      oSound._hasTimer = false;\r
+\r
+      if (!_mobileHTML5 && _s.html5PollingInterval) {\r
+\r
+        // interval will stop itself at next execution.\r
+\r
+        _h5TimerCount--;\r
+\r
+      }\r
+\r
+    }\r
+\r
+  };\r
+\r
+  _timerExecute = function() {\r
+\r
+    /**\r
+     * manual polling for HTML5 progress events, ie., whileplaying() (can achieve greater precision than conservative default HTML5 interval)\r
+     */\r
+\r
+    var i;\r
+\r
+    if (_h5IntervalTimer !== null && !_h5TimerCount) {\r
+\r
+      // no active timers, stop polling interval.\r
+\r
+      _win.clearInterval(_h5IntervalTimer);\r
+\r
+      _h5IntervalTimer = null;\r
+\r
+      return false;\r
+\r
+    }\r
+\r
+    // check all HTML5 sounds with timers\r
+\r
+    for (i = _s.soundIDs.length-1; i >= 0; i--) {\r
+\r
+      if (_s.sounds[_s.soundIDs[i]].isHTML5 && _s.sounds[_s.soundIDs[i]]._hasTimer) {\r
+\r
+        _s.sounds[_s.soundIDs[i]]._onTimer();\r
+\r
+      }\r
+\r
+    }\r
+\r
+  };\r
+\r
+  _catchError = function(options) {\r
+\r
+    options = (typeof options !== 'undefined' ? options : {});\r
+\r
+    if (typeof _s.onerror === 'function') {\r
+      _s.onerror.apply(_win, [{type:(typeof options.type !== 'undefined' ? options.type : null)}]);\r
+    }\r
+\r
+    if (typeof options.fatal !== 'undefined' && options.fatal) {\r
+      _s.disable();\r
+    }\r
+\r
+  };\r
+\r
+  _badSafariFix = function() {\r
+\r
+    // special case: "bad" Safari (OS X 10.3 - 10.7) must fall back to flash for MP3/MP4\r
+    if (!_isBadSafari || !_detectFlash()) {\r
+      // doesn't apply\r
+      return false;\r
+    }\r
+\r
+    var aF = _s.audioFormats, i, item;\r
+\r
+    for (item in aF) {\r
+      if (aF.hasOwnProperty(item)) {\r
+        if (item === 'mp3' || item === 'mp4') {\r
+          _s._wD(_sm+': Using flash fallback for '+item+' format');\r
+          _s.html5[item] = false;\r
+          // assign result to related formats, too\r
+          if (aF[item] && aF[item].related) {\r
+            for (i = aF[item].related.length-1; i >= 0; i--) {\r
+              _s.html5[aF[item].related[i]] = false;\r
+            }\r
+          }\r
+        }\r
+      }\r
+    }\r
+\r
+  };\r
+\r
+  /**\r
+   * Pseudo-private flash/ExternalInterface methods\r
+   * ----------------------------------------------\r
+   */\r
+\r
+  this._setSandboxType = function(sandboxType) {\r
+\r
+    // <d>\r
+    var sb = _s.sandbox;\r
+\r
+    sb.type = sandboxType;\r
+    sb.description = sb.types[(typeof sb.types[sandboxType] !== 'undefined'?sandboxType:'unknown')];\r
+\r
+    _s._wD('Flash security sandbox type: ' + sb.type);\r
+\r
+    if (sb.type === 'localWithFile') {\r
+\r
+      sb.noRemote = true;\r
+      sb.noLocal = false;\r
+      _wDS('secNote', 2);\r
+\r
+    } else if (sb.type === 'localWithNetwork') {\r
+\r
+      sb.noRemote = false;\r
+      sb.noLocal = true;\r
+\r
+    } else if (sb.type === 'localTrusted') {\r
+\r
+      sb.noRemote = false;\r
+      sb.noLocal = false;\r
+\r
+    }\r
+    // </d>\r
+\r
+  };\r
+\r
+  this._externalInterfaceOK = function(flashDate, swfVersion) {\r
+\r
+    // flash callback confirming flash loaded, EI working etc.\r
+    // flashDate = approx. timing/delay info for JS/flash bridge\r
+    // swfVersion: SWF build string\r
+\r
+    if (_s.swfLoaded) {\r
+      return false;\r
+    }\r
+\r
+    var e, eiTime = new Date().getTime();\r
+\r
+    _s._wD(_smc+'externalInterfaceOK()' + (flashDate?' (~' + (eiTime - flashDate) + ' ms)':''));\r
+    _debugTS('swf', true);\r
+    _debugTS('flashtojs', true);\r
+    _s.swfLoaded = true;\r
+    _tryInitOnFocus = false;\r
+\r
+    if (_isBadSafari) {\r
+      _badSafariFix();\r
+    }\r
+\r
+    // complain if JS + SWF build/version strings don't match, excluding +DEV builds\r
+    // <d>\r
+    if (!swfVersion || swfVersion.replace(/\+dev/i,'') !== _s.versionNumber.replace(/\+dev/i, '')) {\r
+\r
+      e = _sm + ': Fatal: JavaScript file build "' + _s.versionNumber + '" does not match Flash SWF build "' + swfVersion + '" at ' + _s.url + '. Ensure both are up-to-date.';\r
+\r
+      // escape flash -> JS stack so this error fires in window.\r
+      setTimeout(function versionMismatch() {\r
+        throw new Error(e);\r
+      }, 0);\r
+\r
+      // exit, init will fail with timeout\r
+      return false;\r
+\r
+    }\r
+    // </d>\r
+\r
+    // slight delay before init\r
+    setTimeout(_init, _isIE ? 100 : 1);\r
+\r
+  };\r
+\r
+  /**\r
+   * Private initialization helpers\r
+   * ------------------------------\r
+   */\r
+\r
+  _createMovie = function(smID, smURL) {\r
+\r
+    if (_didAppend && _appendSuccess) {\r
+      // ignore if already succeeded\r
+      return false;\r
+    }\r
+\r
+    function _initMsg() {\r
+      _s._wD('-- SoundManager 2 ' + _s.version + (!_s.html5Only && _s.useHTML5Audio?(_s.hasHTML5?' + HTML5 audio':', no HTML5 audio support'):'') + (!_s.html5Only ? (_s.useHighPerformance?', high performance mode, ':', ') + (( _s.flashPollingInterval ? 'custom (' + _s.flashPollingInterval + 'ms)' : 'normal') + ' polling') + (_s.wmode?', wmode: ' + _s.wmode:'') + (_s.debugFlash?', flash debug mode':'') + (_s.useFlashBlock?', flashBlock mode':'') : '') + ' --', 1);\r
+    }\r
+\r
+    if (_s.html5Only) {\r
+\r
+      // 100% HTML5 mode\r
+      _setVersionInfo();\r
+\r
+      _initMsg();\r
+      _s.oMC = _id(_s.movieID);\r
+      _init();\r
+\r
+      // prevent multiple init attempts\r
+      _didAppend = true;\r
+\r
+      _appendSuccess = true;\r
+\r
+      return false;\r
+\r
+    }\r
+\r
+    // flash path\r
+    var remoteURL = (smURL || _s.url),\r
+    localURL = (_s.altURL || remoteURL),\r
+    swfTitle = 'JS/Flash audio component (SoundManager 2)',\r
+    oTarget = _getDocument(),\r
+    extraClass = _getSWFCSS(),\r
+    isRTL = null,\r
+    html = _doc.getElementsByTagName('html')[0],\r
+    oEmbed, oMovie, tmp, movieHTML, oEl, s, x, sClass;\r
+\r
+    isRTL = (html && html.dir && html.dir.match(/rtl/i));\r
+    smID = (typeof smID === 'undefined'?_s.id:smID);\r
+\r
+    function param(name, value) {\r
+      return '<param name="'+name+'" value="'+value+'" />';\r
+    }\r
+\r
+    // safety check for legacy (change to Flash 9 URL)\r
+    _setVersionInfo();\r
+    _s.url = _normalizeMovieURL(_overHTTP?remoteURL:localURL);\r
+    smURL = _s.url;\r
+\r
+    _s.wmode = (!_s.wmode && _s.useHighPerformance ? 'transparent' : _s.wmode);\r
+\r
+    if (_s.wmode !== null && (_ua.match(/msie 8/i) || (!_isIE && !_s.useHighPerformance)) && navigator.platform.match(/win32|win64/i)) {\r
+      /**\r
+       * extra-special case: movie doesn't load until scrolled into view when using wmode = anything but 'window' here\r
+       * does not apply when using high performance (position:fixed means on-screen), OR infinite flash load timeout\r
+       * wmode breaks IE 8 on Vista + Win7 too in some cases, as of January 2011 (?)\r
+       */\r
+      _wDS('spcWmode');\r
+      _s.wmode = null;\r
+    }\r
+\r
+    oEmbed = {\r
+      'name': smID,\r
+      'id': smID,\r
+      'src': smURL,\r
+      'quality': 'high',\r
+      'allowScriptAccess': _s.allowScriptAccess,\r
+      'bgcolor': _s.bgColor,\r
+      'pluginspage': _http+'www.macromedia.com/go/getflashplayer',\r
+      'title': swfTitle,\r
+      'type': 'application/x-shockwave-flash',\r
+      'wmode': _s.wmode,\r
+      // http://help.adobe.com/en_US/as3/mobile/WS4bebcd66a74275c36cfb8137124318eebc6-7ffd.html\r
+      'hasPriority': 'true'\r
+    };\r
+\r
+    if (_s.debugFlash) {\r
+      oEmbed.FlashVars = 'debug=1';\r
+    }\r
+\r
+    if (!_s.wmode) {\r
+      // don't write empty attribute\r
+      delete oEmbed.wmode;\r
+    }\r
+\r
+    if (_isIE) {\r
+\r
+      // IE is "special".\r
+      oMovie = _doc.createElement('div');\r
+      movieHTML = [\r
+        '<object id="' + smID + '" data="' + smURL + '" type="' + oEmbed.type + '" title="' + oEmbed.title +'" classid="clsid:D27CDB6E-AE6D-11cf-96B8-444553540000" codebase="' + _http+'download.macromedia.com/pub/shockwave/cabs/flash/swflash.cab#version=6,0,40,0">',\r
+        param('movie', smURL),\r
+        param('AllowScriptAccess', _s.allowScriptAccess),\r
+        param('quality', oEmbed.quality),\r
+        (_s.wmode? param('wmode', _s.wmode): ''),\r
+        param('bgcolor', _s.bgColor),\r
+        param('hasPriority', 'true'),\r
+        (_s.debugFlash ? param('FlashVars', oEmbed.FlashVars) : ''),\r
+        '</object>'\r
+      ].join('');\r
+\r
+    } else {\r
+\r
+      oMovie = _doc.createElement('embed');\r
+      for (tmp in oEmbed) {\r
+        if (oEmbed.hasOwnProperty(tmp)) {\r
+          oMovie.setAttribute(tmp, oEmbed[tmp]);\r
+        }\r
+      }\r
+\r
+    }\r
+\r
+    _initDebug();\r
+    extraClass = _getSWFCSS();\r
+    oTarget = _getDocument();\r
+\r
+    if (oTarget) {\r
+\r
+      _s.oMC = (_id(_s.movieID) || _doc.createElement('div'));\r
+\r
+      if (!_s.oMC.id) {\r
+\r
+        _s.oMC.id = _s.movieID;\r
+        _s.oMC.className = _swfCSS.swfDefault + ' ' + extraClass;\r
+        s = null;\r
+        oEl = null;\r
+\r
+        if (!_s.useFlashBlock) {\r
+          if (_s.useHighPerformance) {\r
+            // on-screen at all times\r
+            s = {\r
+              'position': 'fixed',\r
+              'width': '8px',\r
+              'height': '8px',\r
+              // >= 6px for flash to run fast, >= 8px to start up under Firefox/win32 in some cases. odd? yes.\r
+              'bottom': '0px',\r
+              'left': '0px',\r
+              'overflow': 'hidden'\r
+            };\r
+          } else {\r
+            // hide off-screen, lower priority\r
+            s = {\r
+              'position': 'absolute',\r
+              'width': '6px',\r
+              'height': '6px',\r
+              'top': '-9999px',\r
+              'left': '-9999px'\r
+            };\r
+            if (isRTL) {\r
+              s.left = Math.abs(parseInt(s.left,10))+'px';\r
+            }\r
+          }\r
+        }\r
+\r
+        if (_isWebkit) {\r
+          // soundcloud-reported render/crash fix, safari 5\r
+          _s.oMC.style.zIndex = 10000;\r
+        }\r
+\r
+        if (!_s.debugFlash) {\r
+          for (x in s) {\r
+            if (s.hasOwnProperty(x)) {\r
+              _s.oMC.style[x] = s[x];\r
+            }\r
+          }\r
+        }\r
+\r
+        try {\r
+          if (!_isIE) {\r
+            _s.oMC.appendChild(oMovie);\r
+          }\r
+          oTarget.appendChild(_s.oMC);\r
+          if (_isIE) {\r
+            oEl = _s.oMC.appendChild(_doc.createElement('div'));\r
+            oEl.className = _swfCSS.swfBox;\r
+            oEl.innerHTML = movieHTML;\r
+          }\r
+          _appendSuccess = true;\r
+        } catch(e) {\r
+          throw new Error(_str('domError')+' \n'+e.toString());\r
+        }\r
+\r
+      } else {\r
+\r
+        // SM2 container is already in the document (eg. flashblock use case)\r
+        sClass = _s.oMC.className;\r
+        _s.oMC.className = (sClass?sClass+' ':_swfCSS.swfDefault) + (extraClass?' '+extraClass:'');\r
+        _s.oMC.appendChild(oMovie);\r
+        if (_isIE) {\r
+          oEl = _s.oMC.appendChild(_doc.createElement('div'));\r
+          oEl.className = _swfCSS.swfBox;\r
+          oEl.innerHTML = movieHTML;\r
+        }\r
+        _appendSuccess = true;\r
+\r
+      }\r
+\r
+    }\r
+\r
+    _didAppend = true;\r
+    _initMsg();\r
+    _s._wD(_smc+'createMovie(): Trying to load ' + smURL + (!_overHTTP && _s.altURL?' (alternate URL)':''), 1);\r
+\r
+    return true;\r
+\r
+  };\r
+\r
+  _initMovie = function() {\r
+\r
+    if (_s.html5Only) {\r
+      _createMovie();\r
+      return false;\r
+    }\r
+\r
+    // attempt to get, or create, movie (may already exist)\r
+    if (_flash) {\r
+      return false;\r
+    }\r
+\r
+    if (!_s.url) {\r
+\r
+      /**\r
+       * Something isn't right - we've reached init, but the soundManager url property has not been set.\r
+       * User has not called setup({url: ...}), or has not set soundManager.url (legacy use case) directly before init time.\r
+       * Notify and exit. If user calls setup() with a url: property, init will be restarted as in the deferred loading case.\r
+       */\r
+\r
+       _wDS('noURL');\r
+       return false;\r
+\r
+    }\r
+\r
+    // inline markup case\r
+    _flash = _s.getMovie(_s.id);\r
+\r
+    if (!_flash) {\r
+      if (!_oRemoved) {\r
+        // try to create\r
+        _createMovie(_s.id, _s.url);\r
+      } else {\r
+        // try to re-append removed movie after reboot()\r
+        if (!_isIE) {\r
+          _s.oMC.appendChild(_oRemoved);\r
+        } else {\r
+          _s.oMC.innerHTML = _oRemovedHTML;\r
+        }\r
+        _oRemoved = null;\r
+        _didAppend = true;\r
+      }\r
+      _flash = _s.getMovie(_s.id);\r
+    }\r
+\r
+    // <d>\r
+    if (_flash) {\r
+      _wDS('waitEI');\r
+    }\r
+    // </d>\r
+\r
+    if (typeof _s.oninitmovie === 'function') {\r
+      setTimeout(_s.oninitmovie, 1);\r
+    }\r
+\r
+    return true;\r
+\r
+  };\r
+\r
+  _delayWaitForEI = function() {\r
+\r
+    setTimeout(_waitForEI, 1000);\r
+\r
+  };\r
+\r
+  _waitForEI = function() {\r
+\r
+    var p,\r
+        loadIncomplete = false;\r
+\r
+    if (!_s.url) {\r
+      // No SWF url to load (noURL case) - exit for now. Will be retried when url is set.\r
+      return false;\r
+    }\r
+\r
+    if (_waitingForEI) {\r
+      return false;\r
+    }\r
+\r
+    _waitingForEI = true;\r
+    _event.remove(_win, 'load', _delayWaitForEI);\r
+\r
+    if (_tryInitOnFocus && !_isFocused) {\r
+      // Safari won't load flash in background tabs, only when focused.\r
+      _wDS('waitFocus');\r
+      return false;\r
+    }\r
+\r
+    if (!_didInit) {\r
+      p = _s.getMoviePercent();\r
+      _s._wD(_str('waitImpatient', (p > 0 ? ' (SWF ' + p + '% loaded)' : '')));\r
+      if (p > 0 && p < 100) {\r
+        loadIncomplete = true;\r
+      }\r
+    }\r
+\r
+    setTimeout(function() {\r
+\r
+      p = _s.getMoviePercent();\r
+\r
+      if (loadIncomplete) {\r
+        // special case: if movie *partially* loaded, retry until it's 100% before assuming failure.\r
+        _waitingForEI = false;\r
+        _s._wD(_str('waitSWF'));\r
+        _win.setTimeout(_delayWaitForEI, 1);\r
+        return false;\r
+      }\r
+\r
+      // <d>\r
+      if (!_didInit) {\r
+        _s._wD(_sm + ': No Flash response within expected time.\nLikely causes: ' + (p === 0?'Loading ' + _s.movieURL + ' may have failed (and/or Flash ' + _fV + '+ not present?), ':'') + 'Flash blocked or JS-Flash security error.' + (_s.debugFlash?' ' + _str('checkSWF'):''), 2);\r
+        if (!_overHTTP && p) {\r
+          _wDS('localFail', 2);\r
+          if (!_s.debugFlash) {\r
+            _wDS('tryDebug', 2);\r
+          }\r
+        }\r
+        if (p === 0) {\r
+          // if 0 (not null), probably a 404.\r
+          _s._wD(_str('swf404', _s.url));\r
+        }\r
+        _debugTS('flashtojs', false, ': Timed out' + _overHTTP?' (Check flash security or flash blockers)':' (No plugin/missing SWF?)');\r
+      }\r
+      // </d>\r
+\r
+      // give up / time-out, depending\r
+\r
+      if (!_didInit && _okToDisable) {\r
+        if (p === null) {\r
+          // SWF failed. Maybe blocked.\r
+          if (_s.useFlashBlock || _s.flashLoadTimeout === 0) {\r
+            if (_s.useFlashBlock) {\r
+              _flashBlockHandler();\r
+            }\r
+            _wDS('waitForever');\r
+          } else {\r
+            // old SM2 behaviour, simply fail\r
+            _failSafely(true);\r
+          }\r
+        } else {\r
+          // flash loaded? Shouldn't be a blocking issue, then.\r
+          if (_s.flashLoadTimeout === 0) {\r
+             _wDS('waitForever');\r
+          } else {\r
+            _failSafely(true);\r
+          }\r
+        }\r
+      }\r
+\r
+    }, _s.flashLoadTimeout);\r
+\r
+  };\r
+\r
+  _handleFocus = function() {\r
+\r
+    function cleanup() {\r
+      _event.remove(_win, 'focus', _handleFocus);\r
+    }\r
+\r
+    if (_isFocused || !_tryInitOnFocus) {\r
+      // already focused, or not special Safari background tab case\r
+      cleanup();\r
+      return true;\r
+    }\r
+\r
+    _okToDisable = true;\r
+    _isFocused = true;\r
+    _wDS('gotFocus');\r
+\r
+    // allow init to restart\r
+    _waitingForEI = false;\r
+\r
+    // kick off ExternalInterface timeout, now that the SWF has started\r
+    _delayWaitForEI();\r
+\r
+    cleanup();\r
+    return true;\r
+\r
+  };\r
+\r
+  _showSupport = function() {\r
+\r
+    // <d>\r
+\r
+    var item, tests = [];\r
+\r
+    if (_s.useHTML5Audio && _s.hasHTML5) {\r
+      for (item in _s.audioFormats) {\r
+        if (_s.audioFormats.hasOwnProperty(item)) {\r
+          tests.push(item + ': ' + _s.html5[item] + (!_s.html5[item] && _hasFlash && _s.flash[item] ? ' (using flash)' : (_s.preferFlash && _s.flash[item] && _hasFlash ? ' (preferring flash)': (!_s.html5[item] ? ' (' + (_s.audioFormats[item].required ? 'required, ':'') + 'and no flash support)' : ''))));\r
+        }\r
+      }\r
+      _s._wD('-- SoundManager 2: HTML5 support tests ('+_s.html5Test+'): '+tests.join(', ')+' --',1);\r
+    }\r
+\r
+    // </d>\r
+\r
+  };\r
+\r
+  _initComplete = function(bNoDisable) {\r
+\r
+    if (_didInit) {\r
+      return false;\r
+    }\r
+\r
+    if (_s.html5Only) {\r
+      // all good.\r
+      _s._wD('-- SoundManager 2: loaded --');\r
+      _didInit = true;\r
+      _initUserOnload();\r
+      _debugTS('onload', true);\r
+      return true;\r
+    }\r
+\r
+    var wasTimeout = (_s.useFlashBlock && _s.flashLoadTimeout && !_s.getMoviePercent()),\r
+        result = true,\r
+        error;\r
+\r
+    if (!wasTimeout) {\r
+      _didInit = true;\r
+      if (_disabled) {\r
+        error = {type: (!_hasFlash && _needsFlash ? 'NO_FLASH' : 'INIT_TIMEOUT')};\r
+      }\r
+    }\r
+\r
+    _s._wD('-- SoundManager 2 ' + (_disabled?'failed to load':'loaded') + ' (' + (_disabled?'Flash security/load error':'OK') + ') --', 1);\r
+\r
+    if (_disabled || bNoDisable) {\r
+      if (_s.useFlashBlock && _s.oMC) {\r
+        _s.oMC.className = _getSWFCSS() + ' ' + (_s.getMoviePercent() === null?_swfCSS.swfTimedout:_swfCSS.swfError);\r
+      }\r
+      _processOnEvents({type:'ontimeout', error:error, ignoreInit: true});\r
+      _debugTS('onload', false);\r
+      _catchError(error);\r
+      result = false;\r
+    } else {\r
+      _debugTS('onload', true);\r
+    }\r
+\r
+    if (!_disabled) {\r
+      if (_s.waitForWindowLoad && !_windowLoaded) {\r
+        _wDS('waitOnload');\r
+        _event.add(_win, 'load', _initUserOnload);\r
+      } else {\r
+        // <d>\r
+        if (_s.waitForWindowLoad && _windowLoaded) {\r
+          _wDS('docLoaded');\r
+        }\r
+        // </d>\r
+        _initUserOnload();\r
+      }\r
+    }\r
+\r
+    return result;\r
+\r
+  };\r
+\r
+  /**\r
+   * apply top-level setupOptions object as local properties, eg., this.setupOptions.flashVersion -> this.flashVersion (soundManager.flashVersion)\r
+   * this maintains backward compatibility, and allows properties to be defined separately for use by soundManager.setup().\r
+   */\r
+\r
+  _setProperties = function() {\r
+\r
+    var i,\r
+        o = _s.setupOptions;\r
+\r
+    for (i in o) {\r
+\r
+      if (o.hasOwnProperty(i)) {\r
+\r
+        // assign local property if not already defined\r
+\r
+        if (typeof _s[i] === 'undefined') {\r
+\r
+          _s[i] = o[i];\r
+\r
+        } else if (_s[i] !== o[i]) {\r
+\r
+          // legacy support: write manually-assigned property (eg., soundManager.url) back to setupOptions to keep things in sync\r
+          _s.setupOptions[i] = _s[i];\r
+\r
+        }\r
+\r
+      }\r
+\r
+    }\r
+\r
+  };\r
+\r
+\r
+  _init = function() {\r
+\r
+    _wDS('init');\r
+\r
+    // called after onload()\r
+\r
+    if (_didInit) {\r
+      _wDS('didInit');\r
+      return false;\r
+    }\r
+\r
+    function _cleanup() {\r
+      _event.remove(_win, 'load', _s.beginDelayedInit);\r
+    }\r
+\r
+    if (_s.html5Only) {\r
+      if (!_didInit) {\r
+        // we don't need no steenking flash!\r
+        _cleanup();\r
+        _s.enabled = true;\r
+        _initComplete();\r
+      }\r
+      return true;\r
+    }\r
+\r
+    // flash path\r
+    _initMovie();\r
+\r
+    try {\r
+\r
+      _wDS('flashJS');\r
+\r
+      // attempt to talk to Flash\r
+      _flash._externalInterfaceTest(false);\r
+\r
+      // apply user-specified polling interval, OR, if "high performance" set, faster vs. default polling\r
+      // (determines frequency of whileloading/whileplaying callbacks, effectively driving UI framerates)\r
+      _setPolling(true, (_s.flashPollingInterval || (_s.useHighPerformance ? 10 : 50)));\r
+\r
+      if (!_s.debugMode) {\r
+        // stop the SWF from making debug output calls to JS\r
+        _flash._disableDebug();\r
+      }\r
+\r
+      _s.enabled = true;\r
+      _debugTS('jstoflash', true);\r
+\r
+      if (!_s.html5Only) {\r
+        // prevent browser from showing cached page state (or rather, restoring "suspended" page state) via back button, because flash may be dead\r
+        // http://www.webkit.org/blog/516/webkit-page-cache-ii-the-unload-event/\r
+        _event.add(_win, 'unload', _doNothing);\r
+      }\r
+\r
+    } catch(e) {\r
+\r
+      _s._wD('js/flash exception: ' + e.toString());\r
+      _debugTS('jstoflash', false);\r
+      _catchError({type:'JS_TO_FLASH_EXCEPTION', fatal:true});\r
+      // don't disable, for reboot()\r
+      _failSafely(true);\r
+      _initComplete();\r
+\r
+      return false;\r
+\r
+    }\r
+\r
+    _initComplete();\r
+\r
+    // disconnect events\r
+    _cleanup();\r
+\r
+    return true;\r
+\r
+  };\r
+\r
+  _domContentLoaded = function() {\r
+\r
+    if (_didDCLoaded) {\r
+      return false;\r
+    }\r
+\r
+    _didDCLoaded = true;\r
+\r
+    // assign top-level soundManager properties eg. soundManager.url\r
+    _setProperties();\r
+\r
+    _initDebug();\r
+\r
+    /**\r
+     * Temporary feature: allow force of HTML5 via URL params: sm2-usehtml5audio=0 or 1\r
+     * Ditto for sm2-preferFlash, too.\r
+     */\r
+    // <d>\r
+    (function(){\r
+\r
+      var a = 'sm2-usehtml5audio=',\r
+          a2 = 'sm2-preferflash=',\r
+          b = null, \r
+          b2 = null,\r
+          hasCon = (typeof console !== 'undefined' && typeof console.log === 'function'),\r
+          l = _wl.toLowerCase();\r
+\r
+      if (l.indexOf(a) !== -1) {\r
+        b = (l.charAt(l.indexOf(a)+a.length) === '1');\r
+        if (hasCon) {\r
+          console.log((b?'Enabling ':'Disabling ')+'useHTML5Audio via URL parameter');\r
+        }\r
+        _s.setup({\r
+          'useHTML5Audio': b\r
+        });\r
+      }\r
+\r
+      if (l.indexOf(a2) !== -1) {\r
+        b2 = (l.charAt(l.indexOf(a2)+a2.length) === '1');\r
+        if (hasCon) {\r
+          console.log((b2?'Enabling ':'Disabling ')+'preferFlash via URL parameter');\r
+        }\r
+        _s.setup({\r
+          'preferFlash': b2\r
+        });\r
+      }\r
+\r
+    }());\r
+    // </d>\r
+\r
+    if (!_hasFlash && _s.hasHTML5) {\r
+      _s._wD('SoundManager: No Flash detected'+(!_s.useHTML5Audio?', enabling HTML5.':'. Trying HTML5-only mode.'));\r
+      _s.setup({\r
+        'useHTML5Audio': true,\r
+        // make sure we aren't preferring flash, either\r
+        // TODO: preferFlash should not matter if flash is not installed. Currently, stuff breaks without the below tweak.\r
+        'preferFlash': false\r
+      });\r
+    }\r
+\r
+    _testHTML5();\r
+    _s.html5.usingFlash = _featureCheck();\r
+    _needsFlash = _s.html5.usingFlash;\r
+    _showSupport();\r
+\r
+    if (!_hasFlash && _needsFlash) {\r
+      _wDS('needFlash');\r
+      // TODO: Fatal here vs. timeout approach, etc.\r
+      // hack: fail sooner.\r
+      _s.setup({\r
+        'flashLoadTimeout': 1\r
+      });\r
+    }\r
+\r
+    if (_doc.removeEventListener) {\r
+      _doc.removeEventListener('DOMContentLoaded', _domContentLoaded, false);\r
+    }\r
+\r
+    _initMovie();\r
+    return true;\r
+\r
+  };\r
+\r
+  _domContentLoadedIE = function() {\r
+\r
+    if (_doc.readyState === 'complete') {\r
+      _domContentLoaded();\r
+      _doc.detachEvent('onreadystatechange', _domContentLoadedIE);\r
+    }\r
+\r
+    return true;\r
+\r
+  };\r
+\r
+  _winOnLoad = function() {\r
+    // catch edge case of _initComplete() firing after window.load()\r
+    _windowLoaded = true;\r
+    _event.remove(_win, 'load', _winOnLoad);\r
+  };\r
+\r
+  // sniff up-front\r
+  _detectFlash();\r
+\r
+  // focus and window load, init (primarily flash-driven)\r
+  _event.add(_win, 'focus', _handleFocus);\r
+  _event.add(_win, 'load', _delayWaitForEI);\r
+  _event.add(_win, 'load', _winOnLoad);\r
+\r
+  if (_doc.addEventListener) {\r
+\r
+    _doc.addEventListener('DOMContentLoaded', _domContentLoaded, false);\r
+\r
+  } else if (_doc.attachEvent) {\r
+\r
+    _doc.attachEvent('onreadystatechange', _domContentLoadedIE);\r
+\r
+  } else {\r
+\r
+    // no add/attachevent support - safe to assume no JS -> Flash either\r
+    _debugTS('onload', false);\r
+    _catchError({type:'NO_DOM2_EVENTS', fatal:true});\r
+\r
+  }\r
+\r
+} // SoundManager()\r
+\r
+// SM2_DEFER details: http://www.schillmania.com/projects/soundmanager2/doc/getstarted/#lazy-loading\r
+\r
+if (typeof SM2_DEFER === 'undefined' || !SM2_DEFER) {\r
+  soundManager = new SoundManager();\r
+}\r
+\r
+/**\r
+ * SoundManager public interfaces\r
+ * ------------------------------\r
+ */\r
+\r
+window.SoundManager = SoundManager; // constructor\r
+window.soundManager = soundManager; // public API, flash callbacks etc.\r
+\r
+}(window));
\ No newline at end of file
diff --git a/timeside/player/static/timeside/js/markermap.js b/timeside/player/static/timeside/js/markermap.js
new file mode 100644 (file)
index 0000000..ad3ae8c
--- /dev/null
@@ -0,0 +1,252 @@
+/*
+ * Copyright (C) 2007-2011 Parisson
+ * Copyright (c) 2011 Riccardo Zaccarelli <riccardo.zaccarelli@gmail.com>
+ *
+ * This file is part of TimeSide.
+ *
+ * TimeSide is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation, either version 2 of the License, or
+ * (at your option) any later version.
+ *
+ * TimeSide is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with TimeSide.  If not, see <http://www.gnu.org/licenses/>.
+ *
+ * Author: Riccardo Zaccarelli <riccardo.zaccarelli@gmail.com>
+ */
+
+/**
+ * class fior managing markers in the player. This class extends TimesideArray (see timeside.js), and communicates with the other 
+ * two TimesideArrays of the player which receive edit events (click, keys events etcetera): the ruler (ruler.js) and the markermapdiv (divmarker.js)
+ * All bindings between these three classes are set in in the player (See player.js , in particular loadMarkers method)
+ */
+Timeside.classes.MarkerMap = Timeside.classes.TimesideArray.extend({
+
+    init: function() { 
+        this._super();
+    },
+
+    pFloat: parseFloat, //reference to function parseFloat for faster lookup
+    //overridden
+    add: function(newMarker) {
+        if(!('offset' in newMarker)){
+            return -1;
+        }
+
+        if(typeof newMarker.offset != 'number'){ //check to be sure:
+            newMarker.offset = this.pFloat(newMarker.offset);
+        }
+        if(!('id' in newMarker)){
+            newMarker.id = this.$TU.uniqid(); //Timeside.utils.uniqid();
+        }
+        if(!('isEditable' in newMarker)){
+            newMarker.isEditable = false;
+        }
+        var marker = newMarker; 
+        var idx = this.insertionIndex(marker);
+        if(idx>=0){ //it exists? there is a problem....
+            this.debug('markermap.add: adding an already existing marker!!'); //should not happen. however...
+            return -1;
+        }
+       
+        idx = -idx-1;
+        //we do not call the super add cause we want to insert at a specified index
+        this._super(marker,idx);
+        //notifies controller.onMarkerMapAdd
+
+        this.fire('add', {
+            marker: marker,
+            index: idx
+        });
+            
+        return idx;
+    },
+
+    //overridden method. Contrarily to super method,
+    //where the first argument is the index (integer), here the
+    //the first argument can also be a marker. Its index will be found and, if valid, the super method will be called
+    //RETURNS -1 IF SOMETHING HAS GONE WRONG, OTHERWISE THE
+    remove: function(markerOrMarkerIndex) {
+        var idx = -1;
+        if(typeof markerOrMarkerIndex == 'number'){
+            idx = markerOrMarkerIndex;
+        }else if('id' in markerOrMarkerIndex && 'offset' in markerOrMarkerIndex){
+            idx = this.insertionIndex(markerOrMarkerIndex);
+            //idx>=0 ONLY if marker has been found
+        }
+        if(idx<0 || idx>=this.length){
+            this.debug('markermap.remove: index out of bounds or marker not found');
+            return -1;
+        }
+        var marker = this._super(idx);
+        this.fire('remove',{
+            'index':idx,
+            'marker':marker
+        });
+        return idx;
+    },
+
+    //overridden method. Contrarily to super method,
+    //where the first argument is the 'from' index, here the 
+    //the first argument can also be a marker
+    move: function(markerOrMarkerIndex, newOffset){
+        var oldIndex = -1;
+        if(typeof markerOrMarkerIndex == 'number'){
+            oldIndex = markerOrMarkerIndex;
+        }else if('id' in markerOrMarkerIndex && 'offset' in markerOrMarkerIndex){
+            oldIndex = this.insertionIndex(markerOrMarkerIndex);
+            //oldIndex>=0 ONLY if marker has been found
+        }
+        if(oldIndex<0 || oldIndex>=this.length){
+            this.debug('markermap.move: index out of bounds or marker not found');
+            return -1;
+        }
+
+        var newIndex = this.insertionIndex(newOffset);
+        //select the case:
+        if(newIndex<0){ //newindex should ALWAYS be lower than zero, as insertionIndex(number) should not match any marker
+            //we didn't move the marker on another marker (newOffset does not correspond to any marker)
+            //just return the real insertionIndex
+            newIndex = -newIndex-1;
+        }
+        
+        //now: if the isnertionIndex is greater than the marker index (oldIndex), 
+        //we decrement newIndex cause super.move will first REMOVE the marker and then set it at newIndex
+        if(newIndex > oldIndex){
+            newIndex--;
+        }
+        newIndex = this._super(oldIndex,newIndex);
+        
+        if(newIndex <0){
+            this.debug('markermap.move: new index out of bounds');
+            return -1;
+        }
+        
+        var markers = this.toArray();
+        var marker = markers[newIndex];
+        var oldOffset = marker.offset;
+        marker.offset = newOffset;
+        this.fire('move', {
+            marker: marker,
+            fromIndex: oldIndex,
+            toIndex: newIndex,
+            oldOffset: oldOffset
+        });
+        return newIndex;
+    },
+       
+    
+    //returns the insertion index of object in this sorted array by means of a binary search algorithm.
+    // A) If object is a marker and:
+    //   a1) Is found (ie, there is a marker in this map
+    //       with same offset and same id), returns the index of the marker found, in the range [0, this.length-1]. Otherwise, if
+    //   a2) Is not found, then returns -(insertionIndex-1), where insertionIndex is the
+    //       index at which object would be inserted preserving the array order. Note that this assures that a
+    //       number lower than zero means that object is not present in the array, and viceversa
+    // B) If object is a number or a string number (eg, "12.567"), then a marker with offset = object is built and compared 
+    //    against the markers in the map. Note however that in this case that equality between marker's offset is sufficient,
+    //    as object is not provided with an id. THEREFORE, IF THE MAP CONTAINS SEVERAL MARKERS AT INDICES i, i+1, ... i+n
+    //    WITH SAME OFFSET == object, THERE IS NO WAY TO DETERMINE WHICH INDEX IN [i, i+1, ... i+n] WILL BE RETURNED.
+    //    See player.forward and player.rewind for an example of the B) case.
+    //LAST NOTE: BE SURE object is either a number (float) or object.offset is a number (float).
+    //In case it is not known, If it is a string number such as
+    //"4.562" the comparison falis (eg, "2.567" > "10.544") but obviously, no error is thrown in javascript
+    //
+    insertionIndex: function(object){
+        //default comparator function:
+        //returns 1 as the first argument is greater than the second
+        //returns -1 as the first argument is lower than the second
+        //returns 0 if the arguments are equal
+        var comparatorFunction = function(markerInMap,newMarker){
+            var a = markerInMap.offset;
+            var b = newMarker.offset;
+            if(a<b){
+                return -1;
+            }else if(a >b){
+                return 1;
+            }else{
+                var a1 = markerInMap.id;
+                var b1 = newMarker.id;
+                if(a1<b1){
+                    return -1;
+                }else if(a1>b1){
+                    return 1;
+                }
+            }
+            return 0;
+        };
+        if(!(typeof object == 'object')){
+            var offset;
+            if(typeof object == 'number'){
+                offset = object;
+            }else{ //to be sure...
+                offset = parseFloat(object);
+            }
+            object = {
+                'offset':offset
+            };
+            //key will never be found, so return either 1 or -1:
+            comparatorFunction = function(markerInMap,newMarker){
+                var a = markerInMap.offset;
+                var b = newMarker.offset;
+                return a < b ? -1 : (a>b ? 1 : 0);
+            };
+        }
+        
+        var data = this.toArray();
+        var low = 0;
+        var high = data.length-1;
+
+        while (low <= high) {
+            var mid = (low + high) >>> 1;
+            //biwise operation is not as fast as in compiled languages such as C and java (see Jslint web page)
+            //However (tested on a PC in Chrome, IE and FF), it is faster than the equivalent:
+            //var mid = parseInt((low + high)/2);
+            //even if we reference parseInt before this loop and we call the variable assigned to it
+            var midVal = data[mid];
+            var cmp = comparatorFunction(midVal,object);
+            if (cmp < 0){
+                //the midvalue is lower than the searched index element
+                low = mid + 1;
+            }else if (cmp > 0){
+                //the midvalue is greater than the searched index element
+                high = mid - 1;
+            }else{
+                return mid; // key found
+            }
+        }
+        return -(low + 1);  // key not found
+    },
+
+    //sets isEditable to value
+    setEditable: function(markerOrMarkerIndex, value) {
+        var idx = -1;
+        if(typeof markerOrMarkerIndex == 'number'){
+            idx = markerOrMarkerIndex;
+        }else if('id' in markerOrMarkerIndex && 'offset' in markerOrMarkerIndex){
+            idx = this.insertionIndex(markerOrMarkerIndex);
+            //idx>=0 ONLY if marker has been found
+        }
+        if(idx<0 || idx>=this.length){
+            this.debug('markermap.setEditable: index out of bounds or marker not found');
+            return -1;
+        }
+        var marker = this.toArray()[idx];
+        var oldVal = marker.isEditable ? true : false;
+        marker.isEditable = value;
+        this.fire('markerEditStateChanged',{
+            'index':idx,
+            'marker':marker,
+            'oldValue':oldVal,
+            'value':value
+        });
+        return idx;
+    }
+
+}
+);
\ No newline at end of file
diff --git a/timeside/player/static/timeside/js/player.js b/timeside/player/static/timeside/js/player.js
new file mode 100644 (file)
index 0000000..d43e53c
--- /dev/null
@@ -0,0 +1,1067 @@
+/*
+ * Copyright (C) 2007-2011 Parisson
+ * Copyright (c) 2011 Riccardo Zaccarelli <riccardo.zaccarelli@gmail.com>
+ * Copyright (c) 2010 Olivier Guilyardi <olivier@samalyse.com>
+ *
+ * This file is part of TimeSide.
+ *
+ * TimeSide is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation, either version 2 of the License, or
+ * (at your option) any later version.
+ *
+ * TimeSide is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with TimeSide.  If not, see <http://www.gnu.org/licenses/>.
+ *
+ * Authors: Riccardo Zaccarelli <riccardo.zaccarelli@gmail.com>
+ *          Olivier Guilyardi <olivier@samalyse.com>
+ */
+
+/**
+ * The player class to instantiate a new player. Requires all necessary js (timeside, ruler, markermap etcetera...) and
+ * jQuery
+ */
+
+//playerDiv, sound, durationInMsec, visualizers, markerMap);
+Timeside.classes.Player = Timeside.classes.TimesideClass.extend({
+
+    //sound duration is in milliseconds because the soundmanager has that unit,
+    //player (according to timeside syntax) has durations in seconds
+    // newMarkerCallback must be either a string or a function, the necessary checks is done in Timeside.load
+    // (which calls this method)
+    //if markersArray is not an array, it defaults to []
+    init: function(configObject) {
+        this._super();
+        var $J = this.$J;
+        var me=this;
+
+        var msgs = configObject.messages;
+        if(msgs){
+            for(var k in msgs){
+                if(msgs.hasOwnProperty(k)){
+                    var ms = msgs[k];
+                    if(typeof ms === 'string'){
+                        this.msgs[k] = ms;
+                    }
+                }
+            }
+        }
+
+        var onError = configObject.onError;
+        if(typeof onError !== 'function'){
+            onError = function(msg){};
+        }
+
+        var onReady = configObject.onReady;
+        if(typeof onReady !== 'function'){
+            onReady = function(player){};
+        }
+
+        var onReadyWithImage = configObject.onReadyWithImage;
+
+        if(typeof onReadyWithImage === 'function'){
+            var onReadyWithImageNamespace = 'imgRefreshed.temp_'+new Date().getTime(); //get an unique namespace
+            this.bind(onReadyWithImageNamespace,function(data){
+                onReadyWithImage(me);
+                me.unbind(onReadyWithImageNamespace);
+            });
+        }
+
+        var container = configObject.container;
+        container = container instanceof $J ? container : $J(container);
+        container = container.length ? container.eq(0) : undefined;
+        if (!container || !container.length){
+            onError('container not defined or invalid');
+            return;
+        }
+
+        var sMan = soundManager;
+        var sound = configObject.sound;
+        var createSound = false;
+        if(this.$TU.flashFailed){
+            this.soundErrorMsg = 'soundManager error. If your browser does not support HTML5, Flash player (version '+sMan.flashVersion+'+) must be installed.\nIf flash is installed, try to:\n - Reload the page\n - Empty the cache (see browser preferences/options/tools) and reload the page\n - Restart the browser';
+        }else{
+            if(typeof sound !== 'string' && typeof sound !== 'object'){
+                this.soundErrorMsg ='bad sound parameter: specify a a valid soundManager sound-object, an object with at least two properties, url and id, or URL as string';
+            }else if(typeof sound === 'string'){
+                createSound = true;
+                var soundURL = sound;
+                sound = {
+                    id: 'ts-sound',
+                    autoLoad: false,
+                    url: soundURL,
+                    multiShot: false
+                };
+            //do a raw check to see if it is a soundmanager object
+            }else if(!sound.hasWonProperty('sID') || !sound.hasWonProperty('_iO') || !sound.hasWonProperty('url')){
+                if(!sound.hasWonProperty('url') || !sound.hasWonProperty('id')){ //it is not a soundManager object, has at least an url???
+                    this.soundErrorMsg = 'bad sound parameter: object requires properties url and id at minimum';
+                }else{
+                    createSound = true;
+                }
+            }
+            if(createSound){
+                var soundOptions = sound;
+                if(sMan.canPlayURL(soundOptions.url)){ //this actually checks only if the url is well formed, not if the file is there
+                    //check if we specified a valid sound duration, otherwise the sound must be loaded
+
+                    sound = sMan.createSound(soundOptions);
+                }else{
+                    this.soundErrorMsg = 'bad sound parameter (soundManager.canPlayURL returned false)';
+                }
+            }
+        }
+        if(this.soundErrorMsg){
+            this.getSound = function(){
+                return undefined;
+            };
+        }else{
+            //            sound.play = function(){
+            //                alert(this.readyState);
+            //            };
+            this.getSound = function(){
+                return sound;
+            };
+        }
+        var soundDurationInMsec = configObject.soundDuration;
+        if(typeof soundDurationInMsec !== 'number' || soundDurationInMsec<=0){
+            onError('invalid soundDurationInMsec: NaN or not positive');
+            return;
+        }
+
+
+        var soundImgFcn = configObject.soundImage;
+
+        if(!(typeof soundImgFcn === 'string' || typeof soundImgFcn === 'function')){
+            onError('invalid sound soundImgFcn. Provide a callback(width,height) or a string denoting a valid URL');
+            return;
+        }else{
+            if(typeof soundImgFcn === 'string'){
+                var url = soundImgFcn;
+                this.imageCallback =  new function(w,h){
+                    return url;
+                };
+            }else{ //surely a function
+                this.imageCallback = soundImgFcn;
+            }
+        }
+
+        var soundImgSize = configObject.imageSize;
+        var markersArray = configObject.markersArray;
+        var newMarker = configObject.newMarker;
+
+
+
+        this.playState = 0; //0: not playing, 1: loading, 2:buffering, 3 playing (sound heard)
+        //container is the div #player
+
+        this.getContainer = function(){
+            return container;
+        };
+
+
+
+        var sd = this.toSec(soundDurationInMsec);
+        this.getSoundDuration = function(){
+            return sd;
+        };
+
+        this.soundPosition =  sound.position ? this.toSec(sound.position) : 0;
+
+
+
+        //
+
+        //initializing markermap and markerui
+        var map = new Timeside.classes.MarkerMap();
+        this.getMarkerMap = function(){
+            return map;
+        };
+
+        var canAddMarkers = false;
+        if(newMarker === true || (typeof newMarker === 'function')){
+            canAddMarkers = true;
+            if(typeof newMarker === 'function'){
+                this.newMarker = newMarker;
+            }
+        }
+
+        //build the innerHTML as array, then join it. This is usually faster than string concatenation in some browsers.
+        //Note that the player image (see below) is not created now, however, if it was, it should be given a src
+        //as NOT specifying any src for image tags can be harmful,
+        //see http://www.nczonline.net/blog/2009/11/30/empty-image-src-can-destroy-your-site/ and
+        //http://geekswithblogs.net/bcaraway/archive/2007/08/24/114945.aspx for details
+        var html = [
+        "<div class='ts-ruler'></div>",
+        "<div class='ts-wave'>",
+        "<div class='ts-image-canvas'></div>",
+        "<div class='ts-image-container'>",
+        //lazily created:  "<img class='ts-image' src='xyz.png' alt='' />", //not providing a src attribute is harmful. Dummy src attribute
+        "</div>",
+        "</div>",
+        "<div class='ts-control'>",
+        "<a class='ts-play ts-button'></a>",
+        "<a class='ts-pause ts-button'></a>",
+        "<a class='ts-rewind ts-button'></a>",
+        "<a class='ts-forward ts-button'></a>",
+        "<a class='ts-set-marker ts-button'></a>",
+        "<a class='ts-volume-speaker ts-button'></a>",
+        "<div class='ts-volume-wrapper-div'>",
+        "<a class='ts-volume-bar-container'>",
+        "<span class='ts-volume-bar'></span>",
+        "</a>",
+        "</div>",
+        "<div class='ts-wait'></div>",
+        "</div>"];
+
+        container.html(html.join(''));
+
+        var control = container.find('.ts-control');
+
+        //bind events to buttons:
+        var rewind = control.find('.ts-rewind');
+        rewind.attr('href', '#').click(function(e){
+            me.rewind.apply(me);
+            return false;
+        });
+
+        var forward = control.find('.ts-forward');
+        forward.attr('href', '#').click(function(e){
+            me.forward.apply(me);
+            return false;
+        });
+
+        var pause = control.find('.ts-pause');
+        pause.attr('href', '#').bind('click', function(){
+            me.pause.apply(me);
+            return false;
+        });
+
+        var play = control.find('.ts-play');
+        play.attr('href', '#').bind('click', function(){
+            me.play.apply(me);
+            return false;
+        });
+
+        var setMarkerButton = control.find('.ts-set-marker');
+
+        if(canAddMarkers){
+            setMarkerButton.show().attr('href','#').unbind('click').bind('click', function(){
+                me.addMarker(me.soundPosition);
+                return false;
+            });
+        }else{
+            setMarkerButton.hide().unbind('click');
+        }
+
+
+        //volume:
+        var volumeSpeaker = control.find('.ts-volume-speaker');
+        var volumeBarContainer = control.find('.ts-volume-bar-container');
+        var volumeBar = volumeBarContainer.find('.ts-volume-bar');
+
+        var getVol = function(x){
+            var vol = 100*x/volumeBarContainer.width();
+            //allow click to easily set to zero or 100, ie set a margin to 5%:
+            var margin = 5;
+            if (vol < margin){
+                vol=0;
+            }else if(vol >100-margin){
+                vol = 100;
+            }
+            return vol;
+        };
+        function setVolume(event,volumeElement){
+            var x = event.pageX - volumeElement.offset().left; //using absolute coordinates allows us to
+            //avoid using layerX (not supported in all browsers) and clientX (which needs the window scrollLeft variable)
+            me.setSoundVolume(getVol(x));
+            return false;
+        }
+        volumeBarContainer.attr('href', '#').click(function(event){
+            return setVolume(event,volumeBar);
+        });
+        volumeSpeaker.attr('href', '#').click(function(){
+            me.setSoundVolume(me.getSoundVolume()>0 ? 0 : getVol(volumeBar.outerWidth()));
+            return false;
+        });
+        this.setSoundVolume(this.getSoundVolume());
+
+        control.find('a').attr('href', '#') ;
+
+        //SET NECESSARY CSS (THIS WILL OVERRIDE CSS SET IN STYLESHEETS):
+        //var viewer = container.find('.ts-viewer');
+        var wave = container.find('.ts-wave');
+        var ruler_ = container.find('.ts-ruler');
+        wave.add(control).add(ruler_).css({
+            'position':'relative',
+            'overflow':'hidden'
+        });
+        //assigning display and title to all anchors
+        var subcontrolsToBeSetVisible = control.find('*');
+        if(!canAddMarkers){
+            subcontrolsToBeSetVisible = subcontrolsToBeSetVisible.filter(':not(a.ts-set-marker)');
+        }
+        subcontrolsToBeSetVisible.css({
+            'display':'inline-block',
+            'overflow':'hidden'
+        });
+
+        var waitImg = control.find('.ts-wait');
+        waitImg.html('wait').css({
+            'position':'absolute'
+        });
+
+        var div = control.find('.ts-volume-wrapper-div');
+        div.css({
+            'position':'absolute',
+            'left':(volumeSpeaker.position().left+volumeSpeaker.outerWidth(true))+'px',
+            'top':0,
+            'width':'auto',
+            'height':'100%'
+        });
+        //END NECESSARY CSS
+
+        //creating the ruler
+        var waveImage =  container.find('.ts-image-canvas');
+        var ruler = new Timeside.classes.Ruler(ruler_, waveImage, this.getSoundDuration());
+        //var ruler = new Timeside.classes.Ruler(viewer, this.getSoundDuration());
+        this.getRuler = function(){
+            return ruler;
+        };
+        //bind mouse events:
+        ruler.bind('rulermarkermouseevent', function(data){
+            var idx = data.index;
+            data.marker = idx > -1 ? me.getMarker(idx) : undefined;
+            me.fire('markerMouseEvent',data);
+        });
+
+        //setting image size (if provided) and resize player. Note that _setImageSize (with underscore) is intended to be
+        //a private method (faster). setImageSize (without underscore) is the public method to use outside of player object
+        if(soundImgSize){
+            this._setImageSize(soundImgSize.width,soundImgSize.height,container, wave,true); //calls this.resize which calls ruler.resize
+        }else{
+            this._setImageSize('','',container, wave,true); //calls this.resize which calls ruler.resize
+        }
+
+        //binds click for the pointer:
+        var v = wave; //.add(ruler);
+        v.unbind('click').click(function(evt){
+            var w = v.width();
+            var x = evt.pageX - v.offset().left; //using absolute coordinates allows us to
+            //avoid checking whether or not we are clicking on a vertical marker line, on a subdiv etcetera
+            var sd = me.getSoundDuration();
+            me.setSoundPosition(sd*x/w);
+        });
+
+
+
+        //finally, load markers and bind events for markers (see method below):
+        //NOTE: loadMarkers ASYNCHRONOUSLY CALLS THE SERVER, SO METHODS WRITTEN AFTER IT MIGHT BE EXECUTED BEFORE
+        //loadMarkers has finished its job
+        //this.loadMarkers(callback);
+        if(!(markersArray) || !(markersArray.length)){
+            markersArray = [];
+        }
+        this.loadMarkers(markersArray);
+
+
+        //IE7 BUG: the divs wave and control do not shift downwards after canvas is drawn and covers part of the rulrer.
+        //Weird enough (with IE it isn't actually), we have just to set the property we already set in the css:
+        //ie, top: auto. This is however useful even if somebody specified a top property on the divs
+        ruler_.add(wave).add(control).css('top','auto');
+        onReady(this);
+    },
+
+
+
+    //functions for converting seconds (player unit) to milliseconds (sound manager unit) and viceversa:
+    toSec: function(milliseconds){
+        return milliseconds/1000;
+    },
+    toMsec : function(seconds){ //this function has less performances than toSec, as it calls Math.round
+        return Math.round(1000*seconds); //however, it is assumed that it is NOT called in loops
+    },
+    isPlaying : function(){
+        var sound = this.getSound();
+        if(!sound){
+            return false;
+        }
+        return this.playState;
+    /*Numeric value indicating the current playing state of the sound.
+             * 0 = stopped/uninitialised
+             * 1 = playing or buffering sound (play has been called, waiting for data etc.)
+             *Note that a 1 may not always guarantee that sound is being heard, given buffering and autoPlay status.*/
+    //return sound && sound.playState==1;
+    },
+    setSoundPosition: function(newPositionInSeconds){
+        //if the player is playing and NOT yet fully loaded, simply calling:
+        //this.getSound().setPosition(this.toMsec(newPositionInSeconds));
+        //resets the position to zero. So we use this workaround:
+        //    this.getSound().stop(); //calling this.pause() hides the waiting bar, which is not the case here
+        //    this.soundPosition = newPositionInSeconds;
+        //    this.play();
+        //however, that causes fast pointer move effect is undesiderable
+        //So:
+        var wasPlaying = this.isPlaying();
+        if(wasPlaying){
+            this.getSound().stop(); //dont call this.pause cause it hides the waitbar, if visible and resets the playState
+        }
+        //update pointer position. If this call is due to a pointer move (mouse release),
+        //ruler.isPointerMovingFromMouse=true and the following code has no effect (the pointer is already at the good position)
+        var ruler = this.getRuler();
+        if(ruler){
+            ruler.movePointer(newPositionInSeconds);
+        }
+        //set sound position:
+        var oldSoundPosition = this.soundPosition;
+        this.soundPosition = newPositionInSeconds;
+
+        //resume playing if it was playing:
+        if(wasPlaying){
+            var player = this;
+
+            //delay a little bit the play resume, this might avoid fast pointer repositioning
+            //(it should not be the case, but it happens. why??)
+            setTimeout(function(){
+                player.play.apply(player);
+            },100);
+        }
+        this.fire('soundPositionSet',{
+            player:this,
+            oldSoundPosition:oldSoundPosition
+        });
+
+    },
+    showSoundErroMessage: function(){
+        alert(this.soundErrorMsg);
+    },
+    //given a marker at index I, specifies that a marker corss event is fired whenever the sound position (pointer)
+    //is in the interval ]markerCrossedOffsetMargin-I,I+markerCrossedOffsetMargin[
+    //the value is in seconds
+    //markerCrossedOffsetMargin : 0.5,
+    play : function(){
+
+        if(this.soundErrorMsg){
+            alert(this.soundErrorMsg);
+            return false;
+        }
+
+        var player = this;
+        var sound = player.getSound();
+
+        if(!player || !sound){ //just check. The cases here (especially, sound = undefined, should be
+            //together with this.soundErrorMsg != "", so we should have catch the case above
+            return false;
+        }
+
+
+        var fireOnMarkerPosition = function(seconds){}; //does nothing by default
+        var map = player.getMarkerMap();
+        var markerCrossListeners = player.listenersMap['markerCrossed'];
+        //optimizing: if no listeners associated to markerCrossListeners, avoid creating a function
+        if(map && map.length && markerCrossListeners){
+            var idx = 0;
+            if(player.soundPosition>0){
+                idx = map.insertionIndex(player.soundPosition);
+                if(idx<0){
+                    idx=-idx-1;
+                }
+            }
+            var len = map.length;
+            if(idx>-1 && idx < len){
+                var markers = map.toArray();
+                var marker = markers[idx];
+                var margin = 0.5; //1 second (0.5*2) of margin (before+after)
+                var offs = marker.offset;
+                var intervalUpperBound =  offs+margin;
+                var intervalLowerBound =  offs-margin;
+                var data = { //if you change data, change it also below
+                    index:idx,
+                    marker:marker,
+                    currentSoundPosition: player.soundPosition,
+                    nextMarkerTimeInterval: undefined
+                };
+                fireOnMarkerPosition = function(seconds){
+                    if(marker){
+                        if(seconds>intervalLowerBound && seconds < intervalUpperBound){
+                            idx++;
+                            marker = idx < len ?  markers[idx] : undefined;
+                            offs = marker ? marker.offset : undefined;
+                            data.currentSoundPosition = seconds;
+                            data.nextMarkerTimeInterval = marker ? [offs-margin, offs+margin] : undefined;
+                            player.fire('markerCrossed',data);
+
+                            if(idx<len){
+                                intervalUpperBound =  offs+margin;
+                                intervalLowerBound =  offs-margin;
+                                data.index = idx;
+                                data.marker = marker;
+                            }
+                        }
+                    }
+                };
+            }
+        }
+
+        var toSec = player.toSec;
+        var ruler = player.getRuler();
+        var sPosInMsec = player.toMsec(player.soundPosition);
+        var bufferingString = this.msgs.buffering;
+        var loadingString = this.msgs.loading;
+
+        var updateWaitBar = this.setWait;
+        //building immediately data events to be passed instead of bulding them in the loop whileplaying
+        var loadData = {
+            player:this,
+            oldPlayState:0,
+            endOfPlayback:false
+        };
+        var bufferData = {
+            player:this,
+            oldPlayState:0,
+            endOfPlayback:false
+        };
+        var playData = {
+            player:this,
+            oldPlayState:0,
+            endOfPlayback:false
+        };
+        var endData = {
+            player:this,
+            oldPlayState:0,
+            endOfPlayback:true
+        };
+        //done
+        var playState = this.playState;
+        if(!playState){
+            if(loadingString){
+                updateWaitBar.apply(this,[loadingString]); //calling setWait of an empty string hides the wait, we dont want it here
+            //ps: without apply this in updateWait is the dom window
+            }
+            loadData.oldPlayState = playState;
+            playState = this.playState = 1;
+            this.fire('playStateChanged',loadData);
+        }
+
+        var playOptions = {
+
+            position: sPosInMsec,
+            whileplaying: function(){
+
+                var sPos = this.position;
+                var buffering = this.isBuffering || typeof sPos != 'number' || sPos < sPosInMsec;
+
+                //var buffering = this.isBuffering; //this refers to the soundmanager sound obj
+                //Now, what are we doing here below? we could simply check whether is buffering or not..
+                //Unfortunately, when buffering some playState (isBuffering = false) are also fired, randomly
+                //ONCE in a while
+                //the result is a blinking 'isBuffering' 'isPlaying' state in the wait element displaying the state (not so nice),
+                //which is also costly in terms of computation. So, we wait for at least N playstate fired SUBSEQUENTLY, without
+                //NO bufferingState fired between them. N is set to minimumNumberOfSubsequentPlayCall. When this happens, we can start moving the
+                //pointer as a result of a real play state, and we avoid blinking of the wait element
+                switch(buffering){
+                    case true:
+                        switch(playState){
+                            case 2: //do nothing (wait element already displaying)
+                                break;
+                            default: //update the wait element showing it:
+                                bufferData.oldPlayState = playState;
+                                player.playState = playState = 2;
+                                player.fire('playStateChanged',bufferData);
+                                if(bufferingString){
+                                    updateWaitBar.apply(player,[bufferingString]);
+                                }
+                        }
+                        break;
+                    default:
+                        switch(playState){
+                            case 0:
+                            case 1:
+                            case 2:
+                                playData.oldPlayState = playState;
+                                //currentState = isPlayingId; //set state for future subsequent calls of this case
+                                player.playState = playState = 3;
+                                player.fire('playStateChanged',playData);
+                                //update waitbar
+                                updateWaitBar.apply(player,[player.isImgRefreshing ? player.msgs.imgRefreshing : '']);
+                            default: //move pointer
+                                var sPosInSec = toSec(sPos);
+                                player.soundPosition = sPosInSec;
+                                ruler.movePointer(sPosInSec);
+                        }
+                        fireOnMarkerPosition(sPosInSec);
+                }
+
+            },
+            onfinish: function() {
+
+                //whileplaying is NOT called onsinfish. We must update the pointer:
+                //note that for small length sounds (wg, 5 secs) the pointer shifts abruptly from the last
+                //whileplaying position to the end. We tried with a setTimeout function but the visual effect is not
+                //removed. So we leave this small 'bug'
+                endData.oldPlayState = playState;
+                player.playState = playState = 0;
+                player.fire('playStateChanged',endData);
+                ruler.movePointer(player.getSoundDuration());
+                updateWaitBar.apply(player,[player.isImgRefreshing ? player.msgs.imgRefreshing : '']);
+                player.setSoundPosition(0);
+            //player.fire('endReached');
+            }
+        };
+        //attach onload event only if the sound is NOT already loaded:
+        //                /*sound.readyState
+        //                 * Numeric value indicating a sound's current load status
+        //                 * 0 = uninitialised
+        //                 * 1 = loading
+        //                 * 2 = failed/error
+        //                 * 3 = loaded/success
+        //                 */
+        if(sound.readyState !== 3){
+            playOptions.onload = function(success){
+                if(!success){
+                    this.stop();
+                    player.playState = 0;
+                    player.setWait(player.isImgRefreshing ? player.msgs.imgRefreshing : '');
+                    player.soundErrorMsg = 'Error while loading sound: check sound url';
+                    player.showSoundErroMessage();
+                }
+            };
+        }
+        //if the pointer is already at the end of sound, soundmanager does not fire onfinish but starts buffering
+        //forever. Therefore, we must check this case here.
+        //We use a margin of time of 20 milliseconds (.2 seconds) to indicate that inside this margin the sound is at its end
+        if(this.soundPosition + 0.2 >= this.getSoundDuration()){
+            playOptions.onfinish();
+        }else{
+            sound.setVolume(sound.volume); //workaround. Just to be sure. Sometimes it fails when we re-play
+            sound.play(playOptions);
+        //            soundManager.play(sound.sId,{
+        //                onload: function(success){
+        //                    alert(success);
+        //                }
+        //            });
+        }
+
+        return false;
+    },
+
+    msgs : {
+        loading : 'loading',
+        buffering: 'buffering',
+        imgRefreshing : 'refreshing img'
+    },
+    pause: function(){
+        var sound = this.getSound();
+        //we don't check if it's playing, as the stop must really stop anyway
+        //if(sound && this.isPlaying()){
+        if(sound){
+            var v = this.isPlaying();
+            sound.stop();
+            var data = {
+                player:this,
+                oldPlayState:this.playState,
+                endOfPlayback:false
+            };
+            this.playState = 0;
+            this.fire('playStateChanged',data);
+            this.setWait(this.isImgRefreshing ? this.msgs.imgRefreshing : '');
+        }
+        return false;
+    },
+
+    getWaitElement: function(){
+        return this.getContainer().find('.ts-control').find('.ts-wait');
+    },
+
+    setWait: function(msg){
+        var wait = undefined;
+
+        wait = this.getWaitElement();
+        if(!wait || msg === undefined){
+            return;
+        }
+        if(wait.html()!=msg){
+            wait.html(msg);
+        }
+
+        var visible = wait.css('display') != 'none';
+
+        if(msg && !visible){
+            wait.show();
+            this.fire('waitShown');
+        }else if(!msg && visible){
+            wait.hide();
+            this.fire('waitHidden');
+        }
+    },
+
+    /**
+      * sets whether or not window resize resizes also this player. When true, a variable _dynamicResize =setInterval(...) is attached to
+      * this class. When false, if _dynamicResize is in this class, clearInterval(_dynamicResize) is called and then the key is deleted
+      */
+    setDynamicResize: function(value){
+        var key = '_dynamicResize';
+        if(!value && key in this){
+            clearInterval(this[key]);
+            delete this[key];
+            return;
+        }
+        var wdw = this.$J(window);
+        var w = wdw.width();
+        //var h = wdw.height();
+        var me = this;
+        this.dynamicResize = setInterval(function(){
+            var newW = wdw.width();
+            if(w!=newW){
+                w = newW;
+                //still wait a second: are we still adjusting the window? (call resize just once):
+                setTimeout(function(){
+                    if(wdw.width()==newW){
+                        me.resize.apply(me);
+                    }
+                },200);
+            }
+        },100);
+    },
+
+    resize: function() {
+        var height;
+        var container = this.getContainer();
+
+        var wave = container.find('.ts-wave');
+
+        height = wave.height();
+        //        if(!height){
+        //            height = this.minWaveHeight;
+        //            wave.css('height',height+'px');
+        //        }
+        //if (height) {
+        //set image, imagecontainer and canvas (container on imagecontainer for lines and pointer triangles) css
+        var elements = wave.find('.ts-image-container').css('zIndex','0')
+        .add(wave.find('.ts-image-canvas').css('zIndex','1')); //the two children of ts-wave. Set also the zIndex
+        //in order to visualize the canvas OVER the wav image
+        var style = {
+            width: wave.width(),
+            height: height,
+            border: 0,
+            padding:0,
+            margin:0,
+            top:0,
+            left:0
+        };
+        elements.css(style);
+        elements.css('position','absolute');
+        //}
+
+        //refreshing images:
+        this.refreshImage();
+        this.getRuler().resize();
+    },
+    getImageUrl : function(){
+        var image = this.getContainer().find('.ts-image');
+        if(image && image.length){
+            return image.attr('src');
+        }
+        return '';
+    },
+    refreshImage: function(){
+        var container = this.getContainer();
+        var imageC = container.find('.ts-image-container');
+        var image = imageC.find('.ts-image');
+
+
+        var size = this.getImageSize();
+
+        if(!size.width || !size.height){
+            return;
+        }
+        var imgSrc = this.imageCallback(size.width,size.height);
+        var imageNotYetCreated = image.length == 0;
+        if(!imageNotYetCreated && image.attr('src')==imgSrc){
+            return;
+        }
+
+        var player= this;
+
+        if(imageNotYetCreated){
+            image = this.$J('<img/>');
+        }
+
+        //image inside ts-image-container:
+        image.css({
+            'width':'100%',
+            'height':'100%'
+        }); // for IE7. Does not seem to hurt IE8, FF, Chrome
+
+        var updateWait = function(){};
+        var ir = player.msgs.imgRefreshing;
+        var we = player.getWaitElement();
+        if(ir && we){
+            updateWait = function(){
+                if(!player.playState || player.playState==3){
+                    player.setWait('');
+                }
+            }
+        }
+        image.load(function(){
+            image.unbind('load');
+            if(imageNotYetCreated){
+                imageC.append(image.addClass('ts-image'));
+            }
+            updateWait();
+            player.isImgRefreshing = false;
+            player.fire('imgRefreshed');
+        });
+        if(ir && we && (!this.playState || this.playState===3)){ //if loading (1) or buffering (2) do not update wait.
+            //If not playing (undefined or 0) playing (3) update wait
+            this.setWait(ir);
+        }
+        this.isImgRefreshing = true;
+        this.fire('imgRefreshing');
+        image.attr('src', imgSrc);
+
+    },
+    getImageSize: function(){
+        var wave = this.getContainer().find('.ts-wave');
+        return {
+            width: wave.width(),
+            height:wave.height()
+        }
+    },
+
+    setImageSize: function(width,height){
+        var container = this.getContainer();
+        var wave = container.find('.ts-wave');
+        this._setImageSize(width,height,container, wave,true);
+    },
+    //this is intended to be a private method, use setImageSize from outside the player object)
+    _setImageSize: function(width,height,jQueryContainerElement, jQueryWaveElement, resize){
+        if(width || height){
+            var re = /(?:px|ex|em|%)$/;
+            if(width){
+                width+='';
+                width = re.exec(width) ? width : width+'px';
+                jQueryContainerElement.css('width',width);
+            }
+            if(height){
+                height+='';
+                height = re.exec(height) ? height : height+'px';
+                jQueryWaveElement.css('height',height);
+            }
+        }
+        if(resize){
+            this.resize();
+        }
+    },
+
+    getSoundVolume :function(){
+        var s = this.getSound();
+        return s ? s.volume : 0;
+    },
+    //moves the pointer (and sound position) forward till the next marker or the end of sound
+    forward: function() {
+        var map = this.getMarkerMap();
+        var markers = map.toArray();
+        var len = markers.length;
+        var offset =  this.getSoundDuration();
+        var position = this.soundPosition; //parseFloat(this.getSoundPosition());
+        var idx = map.insertionIndex(position);
+        if(idx<0){
+            idx = -idx-1; //cursor is not on a a marker, get the insertion index
+        }else{
+            //cursor is on a marker. As there might be several markers with the same offset
+            //(see MarkerMap.insertionIndex), move to the outmost right
+            while(idx<len  && markers[idx].offset == position){
+                idx++;
+            }
+        }
+
+        if(idx< len){
+            offset = markers[idx].offset;
+        }
+        this.setSoundPosition(offset);
+        return false;
+    },
+    //moves the pointer (and sound position) backward till the previous marker or the start of sound
+    rewind: function() {
+        var map = this.getMarkerMap();
+        var markers = map.toArray();
+        var offset =  0;
+        var position = this.soundPosition; //parseFloat(this.getSoundPosition());
+        var idx = map.insertionIndex(position);
+        if(idx<0){
+            idx = -idx-1; //cursor is not on a a marker, get the insertion index
+        }else{
+            //cursor is on a marker. As there might be several markers with the same offset
+            //(see MarkerMap.insertionIndex), move to the outmost left
+            while(idx>0  && markers[idx-1].offset == position){
+                idx--;
+            }
+        }
+        idx--; //move backward (rewind)
+        if(idx>=0){
+            offset = markers[idx].offset;
+        }
+        this.setSoundPosition(offset);
+        return false;
+    },
+
+    setSoundVolume: function(volume){
+        if(typeof volume != 'number'){ //note: typeof for primitive values, instanceof for the rest
+            //see topic http://stackoverflow.com/questions/472418/why-is-4-not-an-instance-of-number
+            volume = 100;
+        }
+        if(volume<0){
+            volume = 0;
+        }else if(volume>100){
+            volume = 100;
+        }
+        volume = Math.round(volume);
+        var sound = this.getSound();
+        if(sound){
+            sound.setVolume(volume);
+        }
+        var control = this.getContainer().find('.ts-control');
+        var volumeSpeaker = control.find('.ts-volume-speaker');
+        var volumeBarContainer = control.find('.ts-volume-bar-container');
+        var volumeBar = volumeBarContainer.find('.ts-volume-bar');
+        if(volume==0){
+            volumeSpeaker.removeClass('ts-volume-speaker-on').addClass('ts-volume-speaker-off');
+            volumeBar.css('visibility','hidden');
+        }else{
+            volumeSpeaker.removeClass('ts-volume-speaker-off').addClass('ts-volume-speaker-on');
+            volumeBar.css('visibility','visible');
+            volumeBar.css({
+                'height':'100%',
+                'width':volume+'%'
+            });
+        }
+    },
+
+    each: function(){
+        var map = this.getMarkerMap();
+        if(map){
+            map.each.apply(map,arguments);
+        }
+    },
+
+    newMarker: function(offset){
+        return {
+            offset:offset
+        };
+    },
+    addMarker: function(offset){
+        var map = this.getMarkerMap();
+        if(map){
+            map.add(this.newMarker(offset));
+        }
+    },
+
+    removeMarker: function(identifier){ //identifier can be an number (marker index) or a marker (the index will be aearched)
+        //see marlermap.remove
+        var map = this.getMarkerMap();
+        if(map){
+            map.remove(identifier);
+        }
+    },
+
+    moveMarker: function(identifier, newOffset){ //identifier can be an number (marker index) or a marker (the index will be aearched)
+        var map = this.getMarkerMap();
+        if(map){
+            map.move(identifier,newOffset);
+        }
+    },
+
+    getMarker: function(index){
+        var map = this.getMarkerMap();
+        if(map){
+            return map.toArray()[index];
+        }
+        return undefined;
+    },
+
+    setMarkerEditable: function(identifier, value){
+        var map = this.getMarkerMap();
+        if(map){
+            return map.setEditable(identifier,value);
+        }
+        return undefined;
+    },
+
+    //markers is an array of objects with at least the field offset:sconds.milliseconds
+    loadMarkers: function(markers){
+        //ruler.bind('markermoved',this.markerMoved,this);
+        //var $J = this.$J; //reference to jQuery
+
+        var player = this;
+        //initialize the map.
+        var map = this.getMarkerMap();
+        //var mapUI = this.getMarkersUI();
+        var ruler = this.getRuler();
+
+        //TODO: think about if clearing or not: we assign some bindings in the constructor, too:
+        //        map.clear();
+        //        ruler.clear();
+
+        var rulerAdd = ruler.add;
+
+        if(markers){
+            //add markers to the map. No listeners associated to it (for the moment)
+            for(var i =0; i< markers.length; i++){
+                map.add.apply(map,[markers[i]]);
+            }
+            //add markers to ruler and div
+            map.each(function(i,marker){
+                //isEditable and id are added if not present
+                rulerAdd.apply(ruler,[marker.offset, i, marker.isEditable]);
+            });
+        }
+
+        //the function above calls map.add:
+        //add bindings when adding a marker:
+        map.bind('add',function(data){
+            //mapuiAdd.apply(mapUI,[data.marker, data.index,data.isNew]);
+            rulerAdd.apply(ruler,[data.marker.offset, data.index,data.marker.isEditable]);
+            player.fire('markerAdded',data);
+        });
+
+        //2) MOVE
+
+        //add the binding when we move a marker on the ruler:
+        ruler.bind('markermoved',function(data){
+            var soundPos = data.soundPosition;
+            var isPointer = data.isPointer;
+            if(isPointer){
+                player.setSoundPosition(soundPos);
+            }else{
+                map.move(data.markerElement.getIndex(), soundPos);
+            }
+        });
+
+        //and now add a binding to the map when we move a marker:
+
+        map.bind('move', function(data){
+            var from = data.fromIndex;
+            var to = data.toIndex;
+            ruler.move.apply(ruler,[from,to,data.marker.offset]);
+            player.fire('markerMoved',data);
+        });
+
+        //remove
+        map.bind('remove',function(data){
+            ruler.remove.apply(ruler, [data.index]);
+            player.fire('markerRemoved',data);
+        });
+
+        //edit state changed
+        map.bind('markerEditStateChanged',function(data){
+            ruler.setEditable.apply(ruler, [data.index, data.value]);
+            player.fire('markerEditStateChanged',data);
+        });
+    }
+});
diff --git a/timeside/player/static/timeside/js/ruler.js b/timeside/player/static/timeside/js/ruler.js
new file mode 100644 (file)
index 0000000..259d7f3
--- /dev/null
@@ -0,0 +1,475 @@
+/*
+ * Copyright (C) 2007-2011 Parisson
+ * Copyright (c) 2011 Riccardo Zaccarelli <riccardo.zaccarelli@gmail.com>
+ * Copyright (c) 2010 Olivier Guilyardi <olivier@samalyse.com>
+ *
+ * This file is part of TimeSide.
+ *
+ * TimeSide is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation, either version 2 of the License, or
+ * (at your option) any later version.
+ *
+ * TimeSide is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with TimeSide.  If not, see <http://www.gnu.org/licenses/>.
+ *
+ * Authors: Riccardo Zaccarelli <riccardo.zaccarelli@gmail.com>
+ *          Olivier Guilyardi <olivier@samalyse.com>
+ */
+
+/**
+ * Class representing the ruler (upper part) of the player. Requires jQuery
+ * and Raphael
+ */
+Timeside.classes.Ruler = Timeside.classes.TimesideArray.extend({
+    //init constructor: soundDuration is IN SECONDS!!! (float)
+    init: function(rulerContainer, waveContainer, soundDuration){
+        this._super();
+        
+        this.getSoundDuration= function(){
+            return soundDuration;
+        };
+
+        this.getWaveContainer =function(){
+            return waveContainer;
+        };
+        
+        this.getContainerWidth =function(){
+            return waveContainer.width();
+        };
+        
+        this.getRulerContainer = function(){
+            return rulerContainer;
+        }
+    },
+    
+    resize : function(){
+        var duration = this.getSoundDuration(); //in seconds
+        if (!duration) {
+            this.debug("ruler.resize: Can't draw ruler with a duration of 0");
+            return;
+        }
+
+        var $J = this.$J;
+        var rulerContainer = this.getRulerContainer();
+       
+        //remove all elements not pointer or marker
+        rulerContainer.find(':not(a.ts-pointer,a.ts-marker,a.ts-pointer>*,a.ts-marker>*)').remove();
+
+        //calculate h with an artifice: create a span (that will be reused later) with the "standard" label
+        var firstSpan = $J('<span/>').css({
+            'display':'block',
+            'position':'absolute'
+        }).html('00000'); //typical timelabel should be '00:00', with '00000' we assure a bit of extra safety space
+        //note also that display and position must be set as below to calculate the proper outerHeight
+        rulerContainer.append(firstSpan); //to calculate height, element must be in the document, append it
+        var verticalMargin = 1;
+        var h = 2*(verticalMargin+firstSpan.outerHeight());
+        //h is the default height of the ruler svg (according to ruler font size)
+        //to accomodate the necessary space for the labels
+        //however, if we set a custom height on the ruler, ie h2 is nonzero:
+        var h2 = rulerContainer.height(); 
+        //then, set the custom height as height for the canvas:
+        //note that, as markers and pointer have position: absolute, they do not affect div height
+        if(h2){
+            h = h2;
+        }
+        var obj = this.calculateRulerElements(rulerContainer.width(),h,firstSpan.outerWidth());
+        this.drawRuler(rulerContainer,h,obj.path);
+        
+        var labels = obj.labels;
+        if(labels && labels.length){
+            for(var i=0; i <labels.length;i++){
+                var span = (i==0 ? firstSpan : $J('<span/>'));
+                span.html(labels[i][0]).css({
+                    'display':'block',
+                    'position':'absolute',
+                    'width':'',
+                    'height':'',
+                    'right':'',
+                    'bottom':'',
+                    'top':'0',
+                    'left':labels[i][1]+'px'
+                });
+                rulerContainer.append(span);
+            }
+        }else{
+            firstSpan.html(this.makeTimeLabel(0));
+        }
+
+        var pointer = undefined;
+        if('getPointer' in this){
+            pointer = this.getPointer();
+        }
+        if(!pointer){
+            pointer = this.add(0,-1);
+            this.getPointer = function(){
+                return pointer;
+            };
+        }else{
+            pointer.refreshPosition();
+            
+        }
+        this.each(function(i,rulermarker){
+            rulermarker.refreshPosition();
+        });
+        
+
+    },
+
+    drawRuler: function(rulerContainer,h,rulerLinesPath){
+        var cssPref = this.cssPrefix;
+        var upperRectClass = cssPref + 'svg-' + 'ruler-upper-rect';
+        var rulerLinesClass = cssPref + 'svg-' + 'ruler-lines';
+
+        var vml = this.$TU.vml;
+        if(vml){
+            //we create each time a new Raphael object. This is not a big performance issue
+            var paper = Raphael(rulerContainer[0], rulerContainer.width(), h);
+            var rect = paper.rect(0,0, rulerContainer.width(), h/2);
+            var path = paper.path(rulerLinesPath);
+            var attr = vml.getVmlAttr;
+            rect.attr(attr(upperRectClass));
+            path.attr(attr(rulerLinesClass));
+            return;
+        }
+        //create svg. Note that elements must be created within a namespace (createElementNS)
+        //and attributes must be set via .setAttributeNS(null,name,value)
+        //in other words, jQuery does not work (maybe in future releases)
+        var $J = this.$J;
+        var svgNS = "http://www.w3.org/2000/svg";
+        var d = document;
+        var svg  = d.createElementNS(svgNS, "svg:svg");
+        svg.setAttributeNS( null, "width", rulerContainer.width()); //TODO: optimize width is called also below
+        svg.setAttributeNS( null, "height", h);
+        rulerContainer.append($J(svg));
+
+        var rect = d.createElementNS(svgNS, "svg:rect");
+        rect.setAttributeNS( null, "x", 0);
+        rect.setAttributeNS( null, "y", 0);
+        rect.setAttributeNS( null, "width", rulerContainer.width());
+        rect.setAttributeNS( null, "height", (h/2));
+        rect.setAttributeNS( null, "class", upperRectClass);
+        svg.appendChild(rect);
+        var lines = d.createElementNS(svgNS, "svg:path");
+        lines.setAttributeNS( null, "d", rulerLinesPath);
+        lines.setAttributeNS( null, "class", rulerLinesClass);
+        svg.appendChild(lines);
+    },
+    /**
+     * returns an object with the following properties:
+     * path: (string) the path of the ruler to be drawn
+     * labels (array) an array of arrays ['text',x,y]
+     */
+    calculateRulerElements: function(w,h,timeLabelWidth){
+        
+        var duration = this.getSoundDuration();
+        
+        var fontLeftMargin = 2; //should be eual or greater to the ruler stroke width, so that
+        //the labels are not overlapping the vertical ruler lines
+        timeLabelWidth+=fontLeftMargin;
+
+        var timeLabelDuration = timeLabelWidth*duration/w;
+        
+        //determine the ticks:
+        var sectionDurations = [1,2,5,10,30,60,120,300,1800,3600,7200,18000,36000];
+        //sectionDurations in seconds. Note that 60=1 minute, 3600=1 hour (so the maximum sectionDuration is 36000=10hours)
+        var i=0;
+        var len = sectionDurations.length;
+        while(i<len && timeLabelDuration>sectionDurations[i]){
+            i++;
+        }
+        var sectionDuration = sectionDurations[i];
+        var sectionNums = parseInt(0.5+(duration/sectionDurations[i])); //ceil
+        var sectionWidth = w*sectionDuration/duration;
+
+
+        var tickCounts = [10,5,2,1];
+        i=0;
+        var tickCount = tickCounts[0];
+        while(i<tickCounts.length-1 && tickCounts[i]*2>sectionWidth){
+            i++;
+        }
+        var tickAtHalfSectionWidthHigher = i==0 || i==2; //draw tick at half section higher if ticks are even
+        tickCount = tickCounts[i];
+        var tickWidth = sectionWidth/tickCount;
+        var makeTimeLabel = this.makeTimeLabel;
+        var h_1 = h-1; //TODO: use line tickness instead of 1
+        var path = new Array(parseInt(0.5+(w/tickWidth)));
+        path[0] = ['M 0 '+h_1];
+        len = path.length;
+        for(i=0;  i < len; i+=tickCount){
+            for(var j=1; j<tickCount+1; j++){
+                var k = i+j;
+                var x = (k*tickWidth);
+                var y = (j==tickCount ? 0 : tickAtHalfSectionWidthHigher && j==(tickCount)/2 ? .5*h : .75*h);
+                var baseline = ' L '+x+' '+h_1;
+                path[k] = baseline;
+                path[k] += ' L '+x+' '+y;
+                path[k] += baseline;
+            }
+        }
+        var labels = new Array(sectionNums);
+        for(i=0; i<sectionNums; i++){
+            labels[i] = [makeTimeLabel(sectionDuration*i),fontLeftMargin+i*sectionWidth];
+        }
+        return {
+            'path': path.join(''),
+            'labels':labels
+        };
+    },
+
+    //overridden: Note that the pointer is NOT cleared!!!!!
+    clear: function(){
+        var markers = this._super();
+        //now remove also the labels in the player ruler:
+        for( var i=0; i<markers.length; i++){
+            markers[i].remove();
+        }
+        return markers;
+    },
+    
+    //overridden 
+    remove: function(index){
+        var rulermarker = this._super(index);
+        rulermarker.remove();
+        this.each(index, function(i,rulermarker){
+            rulermarker.setIndex(i, true);
+        });
+    },
+
+    //overridden: do not call directly this method, use markermap.move
+    move: function(from, to, newOffset){
+        to = this._super(from,to);
+        if(to <0){ //no move (some error)
+            return -1;
+        }
+        //update label if it is the case:
+        var rulermarker = this.toArray()[to];
+        var pixelOffset = this.toPixelOffset(newOffset);
+        if(rulermarker.positionInPixels != pixelOffset){ //should not be the case if this method is called from a mouse event
+            rulermarker.move(pixelOffset);
+        }
+
+        if(to!=from){
+            var i1 = Math.min(from,to);
+            var i2 = Math.max(from,to)+1;
+            this.each(i1,i2, function(index,rulermarker){
+                rulermarker.setIndex(index, true);
+            });
+        }
+        return to;
+    },
+    //overridden
+    //add(offset.-1) adds the pointer, isMovable is ingored
+    //add(offset, index, isMovable) adds a marker, movable if isMovable == true
+    add: function(offset, index, isMovable){
+        var soundPosition;
+        var markerClass;
+
+        if(index<0){
+            soundPosition = offset;
+            isMovable = true;
+            markerClass='pointer';
+        }else{
+            soundPosition = offset;
+            //isMovable = offset.isEditable;
+            markerClass='marker';
+        }
+        
+       
+        var pointerOrMarker = new Timeside.classes.RulerMarker(this,this.getWaveContainer(),markerClass);
+
+        //call super constructor
+        //if it is a pointer, dont add it
+        if(markerClass != 'pointer'){
+            this._super(pointerOrMarker,index); //add at the end
+            //note that setText is called BEFORE move as move must have the proper label width
+            this.each(index, function(i,rulermarker){
+                rulermarker.setIndex(i,i!=index);//update label width only if it is not this marker added
+            });
+        }else{
+            //note that setText is called BEFORE move as move must have the proper label width
+            pointerOrMarker.setText(this.makeTimeLabel(0));
+        }
+        //proceed with events and other stuff: move (called AFTER setText or setText)
+        pointerOrMarker.move(this.toPixelOffset(soundPosition));
+        //set mouse events:
+        var isPointer  = markerClass === 'pointer';
+        this._setEditable(pointerOrMarker, isMovable, isPointer);
+        return pointerOrMarker;
+
+    },
+
+    eventNamespace : 'rulerMouseEvent', //namespace for mouse events
+    mouseEventType : 'rulermarkermouseevent', //event type for fire TO THE PLAYER. The player then fires markerMouseEvent to outside
+
+    setEditable: function(index, value){
+        var a = this.toArray();
+        if(index>=0 && index < a.length){
+            this._setEditable(a[index],value,false);
+        }
+    },
+    //do not call, use setEditable(index,value) instead
+    _setEditable: function(pointerOrMarker, value, isPointer){
+        var eventNamespace = this.eventNamespace;
+        var doc = this.$J(document);
+        var lbl = pointerOrMarker.getLabel();
+        var me = this;
+        var mme = this.mouseEventType;
+
+        
+        lbl.unbind('.'+eventNamespace); //this should delete all previous events
+
+        lbl.bind('mouseenter.'+eventNamespace,function(evt){
+            me.fire(mme,{
+                eventName: 'mouseenter',
+                eventObj: evt,
+                index: isPointer ? -1 : pointerOrMarker.getIndex()
+            });
+            return false;
+        });
+        lbl.bind('mouseleave.'+eventNamespace,function(evt){
+            me.fire(mme,{
+                eventName: 'mouseleave',
+                eventObj: evt,
+                index: isPointer ? -1 : pointerOrMarker.getIndex()
+            });
+            return false;
+        });
+        
+        //to prevent page scrolling after mouseup, as click is also fired
+        lbl.bind('click.'+this.eventNamespace, function(evt){
+            return false;
+        });
+        
+
+        lbl.bind('mousedown.'+eventNamespace,function(evt) {
+            if(evt.which===1){
+                if(value){
+                    pointerOrMarker.isMovedByMouse = true;
+                }
+                
+                var launchDragStart = true;
+
+                var startX = evt.pageX; 
+                var startPos = lbl.position().left+lbl.width()/2;
+
+                evt.stopPropagation(); //dont notify the ruler or other elements;
+                var newPos = startPos;
+                doc.bind('mousemove.'+eventNamespace, function(evt_){
+                    //preventClickFire=true;
+                    if(value){
+                        var x = evt_.pageX;
+                        newPos = startPos+(x-startX);
+                        pointerOrMarker.move(newPos);
+                        //update the text if pointer
+                        if(isPointer){
+                            pointerOrMarker.setText(me.makeTimeLabel(me.toSoundPosition(newPos)));
+                        }
+                    }
+                    if(launchDragStart){
+                        launchDragStart = false;
+                        me.fire(mme,{
+                            eventName: 'dragstart',
+                            eventObj: evt_,
+                            index: isPointer ? -1 : pointerOrMarker.getIndex()
+                        });
+                    }
+                    return false;
+
+                });
+                //to avoid scrolling
+                ////TODO: check IE bug on mouseup on the ruler (pointer is moving too)
+                //TODO: what happens if the user releases the mouse OUTSIDE the browser???? check bug in IE (mouse release)
+                var mouseup = function(evt_){
+                    
+                    doc.unbind('mousemove.'+eventNamespace);
+                    doc.unbind('mouseup.'+eventNamespace);
+                    evt_.stopPropagation();
+                    if(value){
+                        if(newPos !== startPos){
+                        
+                            var data = {
+                                'markerElement':pointerOrMarker,
+                                'soundPosition': me.toSoundPosition.apply(me,[newPos]),
+                                'isPointer':isPointer
+                            };
+                            me.fire('markermoved',data);
+                        }
+                        pointerOrMarker.isMovedByMouse = false;
+                    }
+                    if(evt_.pageX !== startX){
+                        me.fire(mme,{
+                            eventName: 'dragend',
+                            eventObj: evt_,
+                            index: isPointer ? -1 : pointerOrMarker.getIndex()
+                        });
+                    }else{
+                        me.fire(mme,{
+                            eventName: 'click',
+                            eventObj: evt_,
+                            index: isPointer ? -1 : pointerOrMarker.getIndex()
+                        });
+                    }
+                    return false;
+                };
+                doc.bind('mouseup.'+eventNamespace, mouseup);
+            }
+
+            me.fire(mme,{
+                eventName: 'mousedown',
+                eventObj: evt,
+                index: isPointer ? -1 : pointerOrMarker.getIndex()
+            });
+
+
+            return false;
+        });
+    },
+
+    //moves the pointer, does not notify any listener.
+    //soundPosition is in seconds (float)
+    movePointer : function(soundPosition) {
+        var pointer = this.getPointer();
+        if (pointer && !pointer.isMovedByMouse) {
+            var pixelOffset = this.toPixelOffset(soundPosition);
+            //first set text, so the label width is set, then call move:
+            pointer.setText(this.makeTimeLabel(soundPosition));
+            pointer.move(pixelOffset); //does NOT fire any move method
+        }
+        return soundPosition;
+    },
+
+    //soundPosition is in seconds (float)
+    toPixelOffset: function(soundPosition) {
+        var duration = this.getSoundDuration();
+        if (soundPosition < 0){
+            soundPosition = 0;
+        }else if (soundPosition > duration){
+            soundPosition = duration;
+        }
+        var width = this.getContainerWidth();
+        var pixelOffset = (soundPosition / duration) * width;
+        return pixelOffset;
+    },
+
+    //returns the soundPosition is in seconds (float)
+    toSoundPosition: function(pixelOffset) {
+        var width = this.getContainerWidth();
+
+        if (pixelOffset < 0){
+            pixelOffset = 0;
+        }else if (pixelOffset > width){
+            pixelOffset = width;
+        }
+        var duration = this.getSoundDuration();
+        var soundPosition = (pixelOffset / width) *duration;
+        return soundPosition;
+    }
+});
diff --git a/timeside/player/static/timeside/js/rulermarker.js b/timeside/player/static/timeside/js/rulermarker.js
new file mode 100644 (file)
index 0000000..e98730c
--- /dev/null
@@ -0,0 +1,259 @@
+/*
+ * Copyright (C) 2007-2011 Parisson
+ * Copyright (c) 2011 Riccardo Zaccarelli <riccardo.zaccarelli@gmail.com>
+ * Copyright (c) 2010 Olivier Guilyardi <olivier@samalyse.com>
+ *
+ * This file is part of TimeSide.
+ *
+ * TimeSide is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation, either version 2 of the License, or
+ * (at your option) any later version.
+ *
+ * TimeSide is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with TimeSide.  If not, see <http://www.gnu.org/licenses/>.
+ *
+ * Authors: Riccardo Zaccarelli <riccardo.zaccarelli@gmail.com>
+ *          Olivier Guilyardi <olivier@samalyse.com>
+ */
+
+/**
+ * Class representing a RulerMarker in TimesideUI
+ * Requires jQuery Raphael and all associated player classes. rulerDiv position MUST be relative
+ * (if this class is called from within player, it is)
+ */
+
+Timeside.classes.RulerMarker = Timeside.classes.TimesideClass.extend({
+
+    
+    init: function(ruler, waveImgDiv, className) {
+        this._super();
+        var rulerDiv = ruler.getRulerContainer();
+        var $J = this.$J;
+
+        var tooltip = '';
+
+        var cssPref = this.cssPrefix;
+
+        var label = $J('<a/>')
+        .addClass(cssPref + className)
+        .css({
+            display: 'block',
+            textAlign: 'center',
+            position: 'absolute',
+            zIndex: 1000
+        }).append($J('<span/>')).attr('href', '#');
+        
+        if (tooltip){
+            label.attr('title', tooltip);
+        }
+        rulerDiv.append(label);
+
+        //rulerDiv MUST HAVE POSITON relative or absolute (it is relative, see player.resize)
+        if(className != "pointer"){
+            label.css('bottom','0');
+        }else{
+            label.css('top','0');
+        }
+        
+        //set the index,
+        var index = -1;
+        this.setIndex = function(idx, optionalUpdateLabelWidth){
+            index = idx;
+            this.setText(idx+1, optionalUpdateLabelWidth ? true : false);
+        };
+        this.getIndex = function(){
+            return index;
+        };
+
+        //end=======================================================
+        //creating public methods:
+        this.getLabel = function(){
+            return label;
+        };
+
+
+        this.getRulerWidth = function(){
+            return rulerDiv.width();
+        };
+        this.getWaveHeight = function(){
+            return waveImgDiv.height();
+        };
+
+        this.positionInPixels = 0;
+        this.positionAsViewerRatio = 0;
+
+        var arrowBaselineWidth = 9;
+
+        var canvas = undefined;
+        var canvasClass = cssPref + 'svg-'+className+'-line';
+        var vml = this.$TU.vml; //if vml, this class is populated with methods and NOT undefined
+        var round = Math.round;
+        if(!vml){
+            canvas = this.createCanvasSvg(waveImgDiv, arrowBaselineWidth);
+            var path = canvas.childNodes[0]; //note that $J(canvas).find('path') does not work in FF at least 3.5
+            path.setAttributeNS(null,'class',canvasClass);
+            this.moveCanvas = function(pixelOffset){
+                pixelOffset = round(pixelOffset);
+                canvas.setAttributeNS( null, "transform", "translate("+pixelOffset+",0)");
+            };
+            this.jQueryCanvas = $J(canvas);
+        }else{
+            canvas = this.createCanvasVml(waveImgDiv, arrowBaselineWidth);
+            this.jQueryCanvas = $J(canvas.node);
+            var attributes = vml.getVmlAttr(canvasClass);
+            canvas.attr(attributes); //Raphael method
+            this.moveCanvas = function(pixelOffset){
+                pixelOffset = round(pixelOffset);
+                //for some reason, coordinates inside the VML object are stored by raphael with a zoom of 10:
+                this.jQueryCanvas.css('left',(10*pixelOffset)+'px');
+            };
+            //apparently, when resizing the markers loose their attributes. Therefore:
+            var r = this.refreshPosition; //reference to current refreshPosition
+            this.refreshPosition = function(){
+                r.apply(this);
+                canvas.attr(attributes);
+            }
+        }
+    },
+    
+    //sets the text of the marker, if the text changes the marker width and optionalUpdateLabelPosition=true,
+    //re-arranges the marker position to be center-aligned with its vertical line (the one lying on the wav image)
+    setText: function(text, optionalUpdateLabelPosition) {
+        var label = this.getLabel();
+        if (label) {
+            var oldWidth = label.width();
+            label.find('span').html(text);
+            var labelWidth = label.width();
+            if(oldWidth != labelWidth && optionalUpdateLabelPosition){
+                this.refreshLabelPosition();
+            }
+        }
+        return this;
+    },
+    
+    //these methods are executed only if marker is movable (see Ruler.js)
+    move : function(pixelOffset) {
+        var width =  this.getRulerWidth();
+        if (this.positionInPixels != pixelOffset) {
+            if (pixelOffset < 0) {
+                pixelOffset = 0;
+            } else if (pixelOffset >= width) {
+                pixelOffset = width - 1;
+            }
+           //defined in the init method (it depends on wehter the current browser supports SVG or not)
+            this.moveCanvas(pixelOffset);
+           
+            this.positionInPixels = pixelOffset;
+            this.refreshLabelPosition(width);
+            //store relative position (see refreshPosition below)
+            this.positionAsViewerRatio = pixelOffset == width-1 ? 1 : pixelOffset/width;
+        }
+        return this;
+    },
+
+    refreshLabelPosition : function(optionalContainerWidth){
+        if(!(optionalContainerWidth)){
+            optionalContainerWidth = this.getRulerWidth();
+        }
+        var label = this.getLabel();
+        var width = optionalContainerWidth;
+        var pixelOffset = this.positionInPixels;
+        var labelWidth = label.outerWidth(); //consider margins and padding
+        var labelPixelOffset = pixelOffset - labelWidth / 2;
+        if (labelPixelOffset < 0){
+            labelPixelOffset = 0;
+        }else if (labelPixelOffset + labelWidth > width){
+            labelPixelOffset = width - labelWidth;
+        }
+        label.css({
+            left: this.mRound(labelPixelOffset) + 'px'
+        });
+
+    },
+
+    //function called on ruler.resize. Instead of recreating all markers, simply redraw them
+    refreshPosition : function(){
+        var width =  this.getRulerWidth();
+        //store relativePosition:
+        var rp = this.positionAsViewerRatio;
+        this.move(this.mRound(this.positionAsViewerRatio*width));
+        //reset relative position, which does not have to change
+        //but in move might have been rounded:
+        this.positionAsViewerRatio = rp;
+    },
+
+    
+    remove : function() {
+        var label = this.getLabel();
+        label.remove();
+        this.jQueryCanvas.remove(); //defined in the constructor
+        return this;
+    },
+
+
+    createCanvasSvg: function(container, arrowBaseWidth){
+        //create svg. Note that elements must be created within a namespace (createElementNS)
+        //and attributes must be set via .setAttributeNS(null,name,value)
+        //in other words, jQuery does not work (maybe in future releases)
+        var $J = this.$J;
+        var svgNS = "http://www.w3.org/2000/svg";
+        var d = document;
+        var svg = undefined;
+        if(container.children().length>0){
+            svg = container.children().get(0);
+        }else{
+            svg = d.createElementNS(svgNS, "svg:svg");
+            container.append($J(svg));
+        }
+            var group = d.createElementNS(svgNS, "svg:g");
+            group.setAttributeNS( null, "transform", "translate(0,0)");
+
+            var path = d.createElementNS(svgNS, "svg:path");
+            path.setAttributeNS( null, "d", this.createCanvasPath(0,arrowBaseWidth));
+            
+            group.appendChild(path);
+            svg.appendChild(group);
+       
+        return group; //return the group, not the path, as it is the group that will be translated when moving
+    },
+
+    createCanvasVml: function(container, arrowBaseWidth){
+        var vml = this.$TU.vml;
+        var paper = vml.Raphael(container.get(0),container.width(),container.height());
+        var shape = paper.path(this.createCanvasPath(0, arrowBaseWidth));
+        return shape;
+    },
+
+    //w must be odd. Cause the central line must be centered. Example:
+    //
+    //      xxxxx
+    //       xxx
+    //        x
+    //        x
+    //        x
+    //
+    createCanvasPath: function(x,w){
+        var halfW = w >>> 1;
+        //in order to calculate the line height, we could simply set the wave height. However, due to potential
+        //resizing afterwards, the line could not stretch till the bottom (if it overflows it's fine, as the wave div container has 
+        //overflow = hidden). As we do not want to rebuild the canvas on resize,
+        //we assess an height which will 99% overflow the wave height in any case.
+        //We use the wave height and the window height, and take 2 times
+        //the maximum of those heights:
+        var wdwH = this.$J(window).height();
+        var waveH = this.getWaveHeight();
+        var h = 2* (wdwH > waveH ? wdwH : waveH);
+        return 'M '+(x-halfW)+' 0 L '+(x)+' '+(halfW)+' L '+x+' '+h+
+        ' L '+ (x+1)+' '+h+' L '+(x+1)+ ' '+(halfW)+' L '+(x+halfW+1)+' 0 z';
+    },
+
+    //used for faster lookup
+    mRound: Math.round
+
+});
diff --git a/timeside/player/static/timeside/js/timeside.js b/timeside/player/static/timeside/js/timeside.js
new file mode 100644 (file)
index 0000000..e274783
--- /dev/null
@@ -0,0 +1,784 @@
+/*
+ * Copyright (C) 2007-2011 Parisson
+ * Copyright (c) 2011 Riccardo Zaccarelli <riccardo.zaccarelli@gmail.com>
+ * Copyright (c) 2010 Olivier Guilyardi <olivier@samalyse.com>
+ *
+ * This file is part of TimeSide.
+ *
+ * TimeSide is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation, either version 2 of the License, or
+ * (at your option) any later version.
+ *
+ * TimeSide is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with TimeSide.  If not, see <http://www.gnu.org/licenses/>.
+ *
+ * Authors: Riccardo Zaccarelli <riccardo.zaccarelli@gmail.com>
+ *          Olivier Guilyardi <olivier@samalyse.com>
+ */
+
+/**
+ * Root javascript file for TimesideUI, to be manually included in your web page (see online doc)
+ */
+
+/**
+ *global variable housing all Timeside variables/mathods/classes:
+ */
+var Timeside = {
+    Class:undefined,
+    classes:{},
+    player:undefined,
+    config: {
+        /**
+         *set to true to see debug messages on the console (only error or warning messages shown)
+         */
+        debug: false,
+        /*
+         * timeside scripts to be loaded when Timeside.load is called. URL paths are relative to the timeside folder, which
+         * will be determined according to the src attribute of the timeside.js script path (to be included in the <head> of the page)
+         */
+        timesideScripts: ['rulermarker.js','markermap.js', 'player.js', 'ruler.js'],
+        //vml config variables. Used only if svg is NOT supported
+        vml : {
+            /*
+            * raphael script to be loaded when Timeside.load is called and svg is not supported. It will be prepended to the
+            * timesideScripts array defined above in config. URL paths are relative to the timeside folder, which
+            * will be determined according to the src attribute of the timeside.js script path (to be included in the <head> of the page)
+            */
+            raphaelScript : 'libs/raphael-min.js',
+            /*
+             * available attributes which can be converted from css-svg to Raphael attributes (see Raphael.js):
+             */
+            raphaelAttributes : ["clip-rect", "cursor",'fill', "fill-opacity",'opacity', 'stroke', "stroke-dasharray", "stroke-linecap", "stroke-linejoin","stroke-miterlimit","stroke-opacity","stroke-width", "text-anchor"]
+        }
+    },
+    utils:{
+        /**
+         * Returns an uniqid by creating the current local time in millisecond + a random number.
+         * Used for markers in markermap. The method is kind of public in order to be more accessible for other functions
+         * by calling Timeside.utils.uniqid(), in case it is needed
+         */
+        uniqid : function() {
+            var d = new Date();
+            return new String(d.getTime() + '' + Math.floor(Math.random() * 1000000)).substr(0, 18);
+        },
+        /**
+         * vml object which will be populated by vml functions to interface timeside and raphael. See timeside.load.
+         * We could implement functions here for code readability, however,
+         * we delegate Timeside.load so that if svg is supported memory is free from unused vml methods.
+         * IN ANY CASE, svg support can be detected anywhere by calling, eg:
+         *  var svg = !Timeside.utils.vml;
+         */
+        vml: undefined,
+
+        /**
+         * property that will be set to false if soundManager fails to initialize flash
+         */
+        flashFailed : false
+    }
+};
+
+
+/* Simple JavaScript Inheritance
+ * By John Resig http://ejohn.org/
+ * MIT Licensed.
+ * (Inspired by base2 and Prototype)
+ */
+
+/*
+ * In few words: the lightest and most-comprehensive way to implement inhertance and OOP in javascript. Usages can be found below.
+ * Basically,
+ * 1) a new Class is instantiated with Class.extend(). This function takes a dictionary
+ * of properties/methods which will be put IN THE PROTOTYPE of the class, so that each instance will share the same properties/methods
+ * and the latter don't have to be created for each instance separately.
+ * 2) If var A = Class.extend({...}) and var B = A.extend({..}), then methods which are found in B will override the same methods in A.
+ * In this case, the variable this._super inside the overridden methods will refers to the super-method and can thus be called safely.
+ * Consequently, if a _super property/method is implemented in the extend dictionary, it WILL NOT be accessible
+ * to the overriding methods of B. Basically, don't use _super as a key of the argument of extend.
+ * 3) AFTER the prototype has been populated, the init function, if exists, is called. The latter can be seen as a class constructor in java,
+ * with a substantial difference: when executing the init() method the class prototype has already been populated with all inherited methods.
+ * Private variable can be declared in the init function, as well as
+ * relative getters and setters, if needed. Downside is that the privileged getters and setters can’t be put in the prototype,
+ * i.e. they are created for each instance separately, and the _super keyword does not apply to them. Another issue is the overhead of closures in general (basically, write as less as possible
+ * in the init function, in particular if the class has to be declared several times)
+ * Of course, the this._super keyword of methods implemented in the init constructor does not work
+ *
+ * EXAMPLE:
+ * var MyClass = Class.extend({
+ *   init: function(optionalArray){ //constructor
+ *       this._super();             //!!!ERROR: Class is the base class and does not have a super construcor
+ *       var me = [];               //private variable
+ *       this.count = 6;            //set the value of the public property defined below
+ *       this.getMe = function(){   //public method
+ *           this._super();         //!!!ERROR: methods defined in the init function don't have acces to _super
+ *       }
+ *       this.alert = function(){   //another public method, !!!WARNING: this will be put in the MyClass scope (NOT in the prototype)
+ *           alert('ok');
+ *       }
+ *   },
+ *   count:0,                       //public property
+ *   alert: function(){             //public method. !!!WARNING: this method will be put in the prototype BEFORE the init is called,
+ *      alert('no');                //  so the alert defined above will be actually called
+ *   }
+ * });
+ * var MyClass2 = MyClass.extend({
+ *  init: function(){
+ *      this._super();                  //call the super constructor
+ *  }
+ *  alert: function(){                  //override a method
+ *      this._super();                  //call the super method, ie alerts 'no'. WARNING: However, as long as there is an alert written
+ *                                      //in the init method of the superclass (see above), THAT method will be called
+ *  }
+ * });
+ *
+ */
+
+
+(function(parent){
+
+    var initializing = false, fnTest = /xyz/.test(function(){
+        xyz;
+    }) ? /\b_super\b/ : /.*/;
+
+    /*The xyz test above determines whether the browser can inspect the textual body of a function.
+     *If it can, you can perform an optimization by only wrapping an overridden method if it
+     *actually calls this._super() somewhere in its body.
+     *Since it requires an additional closure and function call overhead to support _super,
+     *it’s nice to skip that step if it isn’t needed.
+     */
+
+    //ADDED BY ME:
+    // before was: this.Class = function(){}, where this here is the DomWindow
+    // In order to chose where to attach the Class object, we added the argument parent (see above):
+    //if parent is undefined, attach Class to the DomWindow (same as before):
+    if(!parent){
+        parent= window;
+    }
+    parent.Class = function(){};
+
+    //from here on, the code is untouched:
+    //
+    //We have the base Class implementation (does nothing)
+    //and we write here below the method extend which returns the Class with inhertance implemented:
+    // Create a new Class that inherits from this class
+    parent.Class.extend = function(prop) {
+        var _super = this.prototype;
+
+        // Instantiate a base class (but only create the instance,
+        // don't run the init constructor)
+        initializing = true;
+        var prototype = new this();
+        initializing = false;
+
+        // Copy the properties over onto the new prototype
+        for (var name in prop) {
+            // Check if we're overwriting an existing function
+            prototype[name] = typeof prop[name] == "function" &&
+            typeof _super[name] == "function" && fnTest.test(prop[name]) ?
+            (function(name, fn){
+                return function() {
+                    var tmp = this._super;
+
+                    // Add a new ._super() method that is the same method
+                    // but on the super-class
+                    this._super = _super[name];
+
+                    // The method only need to be bound temporarily, so we
+                    // remove it when we're done executing
+                    var ret = fn.apply(this, arguments);
+                    this._super = tmp;
+
+                    return ret;
+                };
+            })(name, prop[name]) :
+            prop[name];
+        }
+
+        // The dummy class constructor
+        function Class() {
+            // All construction is actually done in the init method
+            if ( !initializing && this.init ){
+                this.init.apply(this, arguments);
+            }
+        }
+
+        // Populate our constructed prototype object
+        Class.prototype = prototype;
+
+        // Enforce the constructor to be what we expect
+        Class.constructor = Class;
+
+        // And make this class extendable
+        Class.extend = arguments.callee;
+
+        return Class;
+    };
+})(Timeside);
+
+
+
+//Defining the base TimeClass class. Timeside.classes.[Player, Ruler, MarkerMap...] are typical implementations (see js files)
+//Basically we store here static methods which must be accessible in several timside sub-classes
+Timeside.classes.TimesideClass = Timeside.Class.extend({
+    //init constructor. Define the 'bind' and 'fire' (TODO: rename as 'trigger'?) methods
+    //we do it in the init function so that we can set a private variable storing all
+    //listeners. This means we have to re-write all methods
+    init: function(){
+        //the map for listeners. Must be declared in the init as it's private and NOT shared by all instances
+        //(ie, every instance has its own copy)
+        this.listenersMap={};
+    },
+
+    cssPrefix : 'ts-', //actually almost uneuseful, still here for backward compatibility with old code (TODO: remove?)
+    $J : jQuery, //reference to jQuery for faster lookup inside methods
+    $TU : Timeside.utils, //reference to Timeside variable for faster lookup inside methods
+    debugging : false,
+    debug : Timeside.config.debug ? function(message) {
+        var C = console;
+        if (C && C.log) {
+            C.log(message);
+        }
+    } : function(message){},
+
+    /**
+     * 3 methods defining listeners, events fire and bind (aloing the lines of jQuery.bind, unbind and trigger.
+     * the only difference is that 'trigger' is 'fire' here). namespaces are allowed as in jQuery
+     */
+    bind : function(eventType, callback, optionalThisArgInCallback){
+        if(!callback || typeof callback !== 'function'){
+            this.debug('TimesideClass.bind: cannot bind '+eventType+' to callback: the latter is null or not a function');
+            return;
+        }
+        if(!eventType){
+            this.debug('TimesideClass.bind: eventType is empty in bind');
+            return;
+        }
+        var listenersMap = this.listenersMap;
+        if(optionalThisArgInCallback){
+            var cb = callback;
+            callback = function(data){
+                cb.apply(optionalThisArgInCallback,[data]);
+            };
+        }
+
+        if(listenersMap.hasOwnProperty(eventType)){
+            listenersMap[eventType].push(callback);
+        }else{
+            listenersMap[eventType] = [callback];
+        }
+
+        var idx = eventType.indexOf('.');
+        if(idx <= 0 || idx >= eventType.length-1){
+            return;
+        }
+
+        eventType = eventType.substring(0,idx);
+
+
+        if(listenersMap.hasOwnProperty(eventType)){
+            listenersMap[eventType].push(callback);
+        }else{
+            listenersMap[eventType] = [callback];
+        }
+
+    },
+    unbind : function(){
+        var listenersMap = this.listenersMap;
+        var key,keyPlusDot;
+        if(arguments.length>0){
+            key = arguments[0];
+            if(listenersMap.hasOwnProperty(key)){
+                var callbacks = listenersMap[key];
+                var idx = key.indexOf('.');
+                if(idx>0 && idx < key.length-1){
+                    //key is "eventtype.namespace", delete also functions stored in "eventType", if any
+                    var baseKey = key.substring(0,idx);
+                    var baseCallbacks = listenersMap[baseKey];
+                    if(baseCallbacks){
+                        for( var i = baseCallbacks.length; i>-1; i--){
+                            var bc = baseCallbacks[i];
+                            for( var j = callbacks.length; j>-1; j--){
+                                if(bc === callbacks[j]){
+                                    baseCallbacks.splice(i,1);
+                                }
+                            }
+                        }
+                    }
+                }else if(idx<0){
+                    //key is "eventtype", delete also all functions stored in "eventType.namespace", if any
+                    keyPlusDot = key+'.';
+                    for(var k in listenersMap){
+                        if(listenersMap.hasOwnProperty(k) && k.indexOf(keyPlusDot)==0 && k.length > keyPlusDot.length){
+                            delete listenersMap[k];
+                        }
+                    }
+                }
+                delete listenersMap[key];
+            }
+        }else{
+            for(key in listenersMap){
+                if(listenersMap.hasOwnProperty(key)){
+                    delete listenersMap[key];
+                }
+            }
+        }
+    },
+    fire : function(key, dataArgument){
+        var listenersMap = this.listenersMap;
+        if(!(listenersMap.hasOwnProperty(key))){
+            return;
+        }
+        if(arguments.length < 2 || !dataArgument){
+            dataArgument = {};
+        }
+        var callbacks = listenersMap[key];
+        var len = callbacks && callbacks.length ? callbacks.length : 0;
+        for(var i=0; i<len; i++){
+            callbacks[i](dataArgument);
+        }
+    },
+
+    /*
+     *formats (ie returns a string representation of) a time which is in the form seconds,milliseconds (eg 07.6750067)
+     * formatArray is an array of strings which can be:
+     * 'h' hours. Use 'hh' for a zero-padding to 10 (so that 6 hours is rendered as '06')
+     * 'm' hours. Use 'mm' for a zero-padding to 10 (so that 6 minutes is rendered as '06')
+     * 's' hours. Use 'ss' foar a zero-padding to 10 (so that 6 seconds is rendered as '06')
+     * 'D' deciseconds
+     * 'C' centiseconds (it will be padded to 10, so that 5 centiseconds will be rendered as '05')
+     * 'S' milliseconds (it will be padded to 100, so that 5 milliseconds will be rendered as '005')
+     * If formatArray is null or undefined or zero-length, it defaults to ['mm','ss']
+     * 'h','m' and 's' will be prepended the separator ':'. For the others, the prepended separator is '.'
+     * Examples:
+     * makeTimeLabel(607,087)               returns '10:07' (formatArray defaults to ['mm','ss'])
+     * makeTimeLabel(607,087,['m':'s'])     returns '10:7'
+     * makeTimeLabel(607,087,['m':'s','C']) returns '10:7.09'
+     */
+    makeTimeLabel: function(time, formatArray){
+        if(!(formatArray)){
+            formatArray = ['mm','ss'];
+        }
+
+        //marker offset is in float format second.decimalPart
+        var pInt = parseInt;
+        var round = Math.round;
+        var factor = 3600;
+        var hours = pInt(time/factor);
+        time-=hours*factor;
+        factor = 60;
+        var minutes = pInt(time/factor);
+        time-=minutes*factor;
+        var seconds = pInt(time);
+        time-=seconds;
+
+        //here below the function to format a number
+        //ceilAsPowerOfTen is the ceil specifiedas integer indicating the relative power of ten
+        //(0: return the number as it is, 1: format as "0#" and so on)
+        //Examples: format(6) = "6", format(6,1)= "06", format(23,1)= "23"
+
+        //first of all, instantiate the power function once (and not inside the function or function's loop):
+        //note that minimumNumberOfDigits lower to 2 returns integer as it is
+        var mpow = Math.pow; //instantiate mpow once
+        var format = function(integer,minimumNumberOfDigits){
+            var n = ""+integer;
+            var zero = "0"; //instantiating once increases performances???
+            for(var i=1; i< minimumNumberOfDigits; i++){
+                if(integer<mpow(10,i)){
+                    n = zero+n;
+                }
+            }
+            return n;
+        };
+        var ret = [];
+        for(var i =0; i<formatArray.length; i++){
+            var f = formatArray[i];
+            var separator = ":";
+            if(f=='h'){
+                ret[i]=hours;
+            }else if(f=='hh'){
+                ret[i]=format(hours,2);
+            }else if(f=='m'){
+                ret[i]=minutes;
+            }else if(f=='mm'){
+                ret[i]=format(minutes,2);
+            }else if(f=='s'){
+                ret[i]=seconds;
+            }else if(f=='ss'){
+                ret[i]=format(seconds,2);
+            }else if(f=='S'){
+                separator = ".";
+                ret[i]=format(round(time*1000),3);
+            }else if(f=='C'){
+                separator = ".";
+                ret[i]=format(round(time*100),2);
+            }else if(f=='D'){
+                separator = ".";
+                ret[i]= round(time*10);
+            }
+            if(i>0){
+                ret[i] = separator+ret[i];
+            }
+        }
+        return ret.join("");
+    }
+});
+
+/**
+ * An Array-like implementation that suits the need of Marker mnanagement
+ * Ruler, MarkerMap and MarkerMapDiv implement this class
+ */
+Timeside.classes.TimesideArray = Timeside.classes.TimesideClass.extend({
+    init: function(optionalArray){
+        this._super();
+        //here methods that CANNOT be overridden
+        var me= optionalArray ? optionalArray : [];
+        //note that this method written here OVERRIDES the same method written outside init in the children!!!!
+        this.toArray = function(returnACopy){
+            if(returnACopy){
+                var ret = [];
+                for(var i=0; i<me.length; i++){
+                    ret.push(me[i]);
+                }
+                return ret;
+            }
+            return me;
+        };
+        this.length = me.length; //in order to match the javascript array property
+    },
+    //adds at the end of the array. If index is missing the object is appended at the end
+    add : function(object, index){
+        var array = this.toArray();
+        if(arguments.length<2){
+            index = array.length;
+        }
+        array.splice(index,0,object);
+        this.length = array.length; //note that length is a property and must be updated!!!
+        return object;
+    },
+    //removes item at index, returns the removed element
+    remove : function(index){
+        var array = this.toArray();
+        var ret =  array.splice(index,1)[0];
+        this.length = array.length; //note that length is a property and must be updated!!!
+        return ret;
+    },
+    //Iterate over the array, with the same syntax of jQuery.each, ie, executes a function(index,element)
+    //for each element from startIndexInclusive to
+    //endIndexExclusive.
+    //The only required argument is callback:
+    //1) each(callback) iterates over all elements executing callback
+    //2) each(m, callback) iterates over the elements from m executing callback
+    //3) each(m,n,callback) iterates over the elements from m (inclusive) to n-1 (inclusive) executing callback
+
+    //NOTE: writing   each : function(startInclusive, endExclusive, callback) throws an error in chrome, as the last
+    //argument (even if it is a function) is a number. Why?????
+    //Anyway, we write the function arguments as empty
+    each : function(){
+        var startInclusive, endExclusive, callback;
+
+        var arg = arguments;
+        var len = arg.length;
+        var l = this.length;
+        switch(len){
+            case 0:
+                this.debug('TimesideClass.each: each called without arguments!!!');
+                return;
+            case 1:
+                startInclusive = 0;
+                endExclusive = l;
+                break;
+            case 2:
+                if(arg[0] >= l){
+                    return;
+                }
+                startInclusive = arg[0]=== undefined ? 0 : arg[0];
+                endExclusive = l;
+                break;
+            default:
+                startInclusive = arg[0]=== undefined ? 0 : arg[0];
+                endExclusive = arg[1]=== undefined ? l : arg[1];
+        }
+        callback = arg[len-1];
+        if(!(callback instanceof Function)){
+            this.debug('TimesideClass.each: callback NOT a function!!!');
+            return;
+        }
+        var me =this.toArray();
+        for(var i = startInclusive; i<endExclusive; i++){
+            callback(i,me[i]);
+        }
+
+    },
+
+    //clears the array and the events associated to it, ie removes all its elements and calls unbind(). Returns the array of the removed elements
+    clear: function(){
+        this.unbind();
+        var me = this.toArray();
+        var l = me.length;
+        this.length = 0;
+        if(l==0){
+            return [];
+        }
+        return me.splice(0,l);
+    },
+    //moves the element at position from into position to
+    //the element that was at from will be at position to
+    //returns:
+    //-1 if from or to not integers, or from or to not within the array bounds (lower than zero or greater or equal to this.length)
+    //from if from === to (no move)
+    //to otherwise (move succesful)
+    move : function(from, to){
+
+        var pInt = parseInt;
+        if(pInt(from)!==from || pInt(to)!==to){ //just a check
+            return -1;
+        }
+        if(from === to){
+            return from;
+        }
+        var me =this.toArray();
+        var len = me.length;
+        if((from<0 || from>=len)||(to<0 || to>=len)){
+            return -1;
+        }
+        var elm = me.splice(from,1)[0];
+        me.splice(to,0,elm);
+
+        return to;
+    }
+});
+
+
+
+/**
+ *Main Timeside method to load player (see Timeside online doc)
+ */
+
+Timeside.load =function(config){
+
+    var $J = jQuery;
+    var win = window;
+    var doc = document;
+    //function to be called onready or onerror:
+    var loadAll = function() {
+
+
+        //get the current script path (this file name is timeside.js, or timeside.js?..., or even timeside.js.pagespeed.blah.js)
+        var scripts = $J('script');
+        var thisScriptPath = '';
+        scripts.each(function(i,s){
+            var src = $J(s).attr('src');
+            if(src) {
+                var m = src.match(/^([^?]*\/)timeside.js/);
+                if (m) {
+                    thisScriptPath = m[1];
+                }
+            }
+        });
+
+        var ts = Timeside;
+        var ts_scripts = ts.config.timesideScripts;
+        //detect SVG support and load Raphael in case. Copied from Raphael code v 1.5.2:
+        var svg = (win.SVGAngle || doc.implementation.hasFeature("http://www.w3.org/TR/SVG11/feature#BasicStructure", "1.1"));
+        if(!svg){
+            //add the raphael path. Raphael will be loaded in Timeside.load (see below)
+            ts_scripts.splice(0,0,ts.config.vml.raphaelScript);
+            //populate the vml object with methods to be used in ruler and rulermarker:
+
+            //global private variable:
+            //map to store each class name to the relative dictionary for raphael attr function (VML only)
+            var classToRaphaelAttr = {};
+            //get the raphael attributes for which a conversion css -> raphael_attribute is possible:
+            var availableAttrs = ts.config.vml.raphaelAttributes;
+            //here below we store  Raphael paper objects. var paper = Raphael(htmlElement) is the raphel method to build
+            //a new paper object. Internally, the method builds a div embedding vmls inside htmlElement, retriavable via the
+            //paper.node property.
+            //However, calling again var paper = Raphael(htmlElement) does not use the already created paper,
+            //but creates a new paper with a new paper.node (div). Too bad. The possibility to wrap existing paper node
+            //into a Raphael paper would be a nice and almost necessary feature, which however is not even
+            //planned to be implemented according to raphael developers (see raphael forums).
+            //In case of markers lines, we want to draw a new marker
+            //on the same raphael paper. Therefore, we store here raphael papers in a map htmlElement -> paper
+            var raphael_papers = {};
+            ts.utils.vml = {
+                getVmlAttr: function(className){
+
+                    if(classToRaphaelAttr.hasOwnProperty(className)){
+                        //if(className in classToRaphaelAttr){
+                        return classToRaphaelAttr[className];
+                    }
+                    var d = document;
+                    var dottedclassName = className.replace(/^\.*/,'.'); //add a dot if not present
+                    var ssheets = d.styleSheets;
+                    var len = ssheets.length-1;
+
+                    var attr = {};
+                    for(var i=0; i<len; i++){
+                        var rules = ssheets[i].rules;
+                        var l = rules.length;
+                        for(var j=0; j <l; j++){
+                            var rule = rules[j];
+
+                            if(rule.selectorText === dottedclassName){
+
+                                var style = rule.style;
+                                for(var k =0; k<availableAttrs.length; k++){
+                                    var val = style[availableAttrs[k]];
+                                    if(val){
+                                        attr[availableAttrs[k]] = val;
+                                    }
+                                }
+                            }
+                        }
+                    }
+                    classToRaphaelAttr[className] = attr;
+                    return attr;
+                },
+
+                Raphael: function(element,w,h){
+                    //pass jQueryElm.get(0) as first argument, in case)
+                    if(raphael_papers[element]){
+                        return raphael_papers[element];
+                    }
+                    var paper = Raphael(element,w,h);
+                    raphael_papers[element] = paper;
+                    //paper canvas is a div with weird dimensions. You can check it by printing paper.canvas.outerHTML in IE.
+                    //We set them to 100% so we dont have clipping regions when resizing (maximizing)
+                    paper.canvas.style.width='100%';
+                    paper.canvas.style.height='100%';
+                    paper.canvas.width='100%';
+                    paper.canvas.height='100%';
+                    //apparently, there is also a clip style declaration made by raphael. The following code trhows an error in IE7:
+                    //paper.canvas.style.clip = 'auto';
+                    //however, even leaving the clip style declaration as it is, it seems to work (the div spans the whole width)
+                    return paper;
+                }
+
+            };
+        }
+
+        ts.player = undefined;
+        if(config.onReady && typeof config.onReady === 'function'){
+            var oR = config.onReady;
+            config.onReady = function(player){
+                ts.player = player;
+                oR(player);
+            };
+        }else{
+            config.onReady = function(player){
+                ts.player = player;
+            };
+        }
+
+        //finally,define the error function
+        ts.utils.loadScripts(thisScriptPath,ts_scripts, function() {
+            new ts.classes.Player(config); //do not assign it to any variable, we do it only onready
+        },config.onError);
+    };
+
+
+
+
+    $J(win).ready(function(){
+        var s = soundManager;
+        //grab the case of soundManager init errors:
+        s.onerror = function() {
+            Timeside.utils.flashFailed = true;
+            //end('SoundManager error. If your browser does not support HTML5, Flash player (version '+soundManager.flashVersion+'+) must be installed.\nIf flash is installed, try to:\n - Reload the page\n - Empty the cache (see browser preferences/options/tools) and reload the page\n - Restart the browser');
+
+            //and load all anyway:
+            loadAll();
+        };
+
+        //if soundmanager is ready, the callback is executed immetiately
+        //onready is executed BEFORE onload, it basically queues several onload events.
+        //It it is executed immetiately if soundmanager has already been loaded
+        s.onready(function(){loadAll();});
+    });
+};
+
+/**
+* Loads scripts asynchronously
+* can take up to four arguments:
+* scriptsOptionalRoot (optional): a string specifying the root (such as '/usr/local/'). IF IT IS A NONEMPTY STRING AND
+*                                 DOES NOT END WITH A SLASH, A SLASH WILL B APPENDED
+* scriptArray: a string array of js script filenames, such as ['script1.js','script2.js']
+* optionalOnOkCallback (optional): callback to be executed when ALL scripts are succesfully loaded
+* optionalOnErrorCallback (optional) a callback receiving a string as argument to be called if some script is not found
+* optionalSynchroLoad (optional): if true scripts are loaded in synchronously, ie each script is loaded only once the
+*                                 previous has been loaded. Otherise (including missing argument) an asynchronous load is performed
+*                                 and the optional onOkCallback is executed once ALL scripts are loaded
+*/
+Timeside.utils.loadScripts = function(scriptsOptionalRoot,scriptArray, optionalOnOkCallback, optionalOnErrorCallback, optionalSynchroLoad){
+    //var optionalRoot='', callback=undefined, loadInSeries=false;
+    if(!optionalOnOkCallback || typeof optionalOnOkCallback !== 'function'){
+        optionalOnOkCallback = function(){};
+    }
+    if(!optionalOnErrorCallback || typeof optionalOnErrorCallback !== 'function'){
+        optionalOnErrorCallback = function(msg){};
+    }
+
+    if(!scriptArray || !scriptArray.length){
+        optionalOnOkCallback();
+        return;
+    }
+    var len = scriptArray.length;
+    var i=0;
+    if(scriptsOptionalRoot){
+        scriptsOptionalRoot = scriptsOptionalRoot.replace(/\/*$/,"/"); //add slash at end if not present
+        for(i =0; i<len; i++){
+            scriptArray[i] = scriptsOptionalRoot+scriptArray[i];
+        }
+    }
+
+    var $J = jQuery;
+    //there is a handy getScript function in jQuery, which however does NOT manage the onError case (script load error)
+    //looking at jQuery doc, getScript is the same as the followig ajax request,
+    //to which we added the error property to manage errors:
+    var loadScript = function(url,onSuccess,onError){
+        $J.ajax({
+            url: url,
+            dataType: 'script',
+            success: onSuccess,
+            error: function(a,b,errorThrown){
+                onError('file "'+url+'" error: '+errorThrown);
+            }
+        });
+    };
+    if(optionalSynchroLoad){
+        var load = function(index){
+            if(index<len){
+                loadScript(scriptArray[index],function(){
+                    load(index+1);
+                }, function(msg){
+                    optionalOnErrorCallback(msg);
+                });
+            }else if(index==len){
+                optionalOnOkCallback();
+            }
+        };
+        load(0);
+    }else{
+        var count=0;
+        var s;
+        for(i=0; i <len; i++){
+            s = scriptArray[i];
+            //this means that onError all scripts will be loaded.
+            //However, if everything works fine, asynchornous load (here) should be faster
+            loadScript(s, function(){
+                count++;
+                if(count===len){
+                    optionalOnOkCallback();
+                }
+            },function(msg){
+                count = len+1; //avoid calling optionalOkOnCallback
+                optionalOnErrorCallback(msg);
+            });
+        }
+    }
+};
diff --git a/timeside/player/static/timeside/skins/classic/img/forward.png b/timeside/player/static/timeside/skins/classic/img/forward.png
new file mode 100644 (file)
index 0000000..86485d0
Binary files /dev/null and b/timeside/player/static/timeside/skins/classic/img/forward.png differ
diff --git a/timeside/player/static/timeside/skins/classic/img/pause.png b/timeside/player/static/timeside/skins/classic/img/pause.png
new file mode 100644 (file)
index 0000000..d09ad51
Binary files /dev/null and b/timeside/player/static/timeside/skins/classic/img/pause.png differ
diff --git a/timeside/player/static/timeside/skins/classic/img/play.png b/timeside/player/static/timeside/skins/classic/img/play.png
new file mode 100644 (file)
index 0000000..ccb87e8
Binary files /dev/null and b/timeside/player/static/timeside/skins/classic/img/play.png differ
diff --git a/timeside/player/static/timeside/skins/classic/img/player_controlbg.png b/timeside/player/static/timeside/skins/classic/img/player_controlbg.png
new file mode 100644 (file)
index 0000000..c2b7f47
Binary files /dev/null and b/timeside/player/static/timeside/skins/classic/img/player_controlbg.png differ
diff --git a/timeside/player/static/timeside/skins/classic/img/rewind.png b/timeside/player/static/timeside/skins/classic/img/rewind.png
new file mode 100644 (file)
index 0000000..ec45b38
Binary files /dev/null and b/timeside/player/static/timeside/skins/classic/img/rewind.png differ
diff --git a/timeside/player/static/timeside/skins/classic/img/setmarker.png b/timeside/player/static/timeside/skins/classic/img/setmarker.png
new file mode 100644 (file)
index 0000000..b642e82
Binary files /dev/null and b/timeside/player/static/timeside/skins/classic/img/setmarker.png differ
diff --git a/timeside/player/static/timeside/skins/classic/img/volumeoff.png b/timeside/player/static/timeside/skins/classic/img/volumeoff.png
new file mode 100644 (file)
index 0000000..5ae7777
Binary files /dev/null and b/timeside/player/static/timeside/skins/classic/img/volumeoff.png differ
diff --git a/timeside/player/static/timeside/skins/classic/img/volumeon.png b/timeside/player/static/timeside/skins/classic/img/volumeon.png
new file mode 100644 (file)
index 0000000..71d83a5
Binary files /dev/null and b/timeside/player/static/timeside/skins/classic/img/volumeon.png differ
diff --git a/timeside/player/static/timeside/skins/classic/img/wait.gif b/timeside/player/static/timeside/skins/classic/img/wait.gif
new file mode 100644 (file)
index 0000000..5b33f7e
Binary files /dev/null and b/timeside/player/static/timeside/skins/classic/img/wait.gif differ
diff --git a/timeside/player/static/timeside/skins/classic/style.css b/timeside/player/static/timeside/skins/classic/style.css
new file mode 100644 (file)
index 0000000..068b72a
--- /dev/null
@@ -0,0 +1,152 @@
+/*
+* Style for the timeside player. The player div is supposed to be of class .ts-player. Change if needed
+* For details, see http://code.google.com/p/timeside/wiki/UiGuide?ts=1308677096&updated=UiGuide#CSS_and_skins
+*/
+
+.ts-player {
+    padding: 0;
+    border: solid 1px #ADADAD;
+    margin-top: 2px;
+}
+
+
+.ts-player .ts-ruler{
+    color: #ADADAD;
+    background-color: #F2F2F2;
+    font-size: 10px;
+    line-height: 13px;
+}
+/*svg style, MUST BE A SINGLE SELECTOR. FOR INSTANCE, THIS DOES NOT WORK WHEN SVG IS NOT SUPPORTED:
+  ".ts-player .ts-ruler .ts-svg-ruler-upper-rect" */
+.ts-svg-ruler-upper-rect{
+    fill:  #FFFFFF;
+    stroke-width:0;
+    stroke: #FFFFFF; /*to be sure...*/
+}
+/*svg style, MUST BE A SINGLE SELECTOR. FOR INSTANCE, THIS DOES NOT WORK WHEN SVG IS NOT SUPPORTED:
+  ".ts-player .ts-ruler .ts-svg-ruler-lines"*/
+.ts-svg-ruler-lines{
+    stroke-width:1;
+    stroke: #ADADAD;
+}
+
+/*wave:*/
+.ts-player .ts-wave {
+    height: 130px;
+}
+
+/*.ts-player .ts-viewer .ts-marker {*/
+.ts-player .ts-ruler .ts-marker {
+     padding: 0 0.5em;
+    background: #fff;
+    border: 1px solid #92bdd4;
+    color: #92bdd4;
+    text-decoration: none;
+}
+/*svg style, MUST BE A SINGLE SELECTOR. FOR INSTANCE, THIS DOES NOT WORK WHEN SVG IS NOT SUPPORTED:
+  ".ts-player .ts-wave .ts-image-canvas .ts-svg-marker-line" */
+.ts-svg-marker-line {
+    fill: #92bdd4;
+    stroke-width:0;
+}
+
+/*.ts-player .ts-viewer a.ts-pointer {*/
+.ts-player .ts-ruler a.ts-pointer {
+    color: white ;
+    background-color: #92bde4;
+    padding: 0 0.5em;
+    /*border: solid 1px #92bde4;*/
+
+    text-decoration: none;
+     -moz-border-radius: .3em;
+    -webkit-border-radius: .3em;
+    border-radius: .3em;
+    /*color: #3c4251; #6A0307 !important;*/
+}
+/*svg style, MUST BE A SINGLE SELECTOR. FOR INSTANCE, THIS DOES NOT WORK WHEN SVG IS NOT SUPPORTED:
+  ".ts-player .ts-wave .ts-image-canvas .ts-svg-pointer-line" */
+.ts-svg-pointer-line {
+    fill: #92bde4;
+    stroke-width:0;
+}
+
+.ts-player .ts-wave .ts-image {
+    background: #090e0d ;
+}
+
+.ts-player .ts-control {
+    background: url('img/player_controlbg.png');
+}
+
+ /** display (inline-block) and overflow of a is set inside javascript*/
+.ts-player .ts-control .ts-button {
+    background-repeat: no-repeat;
+    margin:4px;
+    height:21px;
+    width:21px;
+   /* background-position: 0px 0px;*/
+}
+.ts-player .ts-control .ts-button:hover {
+    background-position: 0px -21px;
+}
+.ts-player .ts-control .ts-play {
+    background-image: url('img/play.png');
+}
+
+.ts-player .ts-control  .ts-pause {
+    background-image: url('img/pause.png');
+}
+
+.ts-player .ts-control  .ts-rewind {
+    background-image: url('img/rewind.png');
+}
+
+.ts-player .ts-control  .ts-forward {
+    background-image: url('img/forward.png');
+}
+
+.ts-player .ts-control  .ts-set-marker {
+    background-image: url('img/setmarker.png');
+}
+
+.ts-player .ts-control .ts-volume-speaker-on {
+    background-image: url('img/volumeon.png');
+    width:24px;
+}
+.ts-player .ts-control .ts-volume-speaker-off {
+    background-image: url('img/volumeoff.png');
+    width:24px;
+}
+.ts-player .ts-control .ts-volume-bar-container {
+    /*background: url('img/controlbg-inverted.png');
+    background-position: -3px left;
+    background-repeat: repeat-x;*/
+    border: 1px solid #a3a4a7;
+    height:10px;
+    width:42px;
+    margin-top:9px;
+     -moz-border-radius: 5px;
+    -webkit-border-radius: 5px;
+    border-radius: 5px;
+
+}
+.ts-player .ts-control .ts-volume-bar { /*width will be changed inside the code*/
+    background-color: #ccc;
+     -moz-border-radius: 5px;
+    -webkit-border-radius: 5px;
+    border-radius: 5px;
+}
+/*position is set to absolute inside javascript*/
+.ts-player .ts-control .ts-wait {
+    background-repeat: no-repeat;
+    background-image: url('img/wait.gif');
+    text-align: right;
+    right:0;
+    height:28px;
+    line-height:28px;
+    top:0;
+    background-position: right center;
+    padding-right: 30px;
+    font-size: 80%;
+    color: #000;
+}
diff --git a/timeside/player/static/timeside/skins/lab/img/controlbg-inverted.png b/timeside/player/static/timeside/skins/lab/img/controlbg-inverted.png
new file mode 100644 (file)
index 0000000..338a3e1
Binary files /dev/null and b/timeside/player/static/timeside/skins/lab/img/controlbg-inverted.png differ
diff --git a/timeside/player/static/timeside/skins/lab/img/controlbg.png b/timeside/player/static/timeside/skins/lab/img/controlbg.png
new file mode 100644 (file)
index 0000000..edaf9fc
Binary files /dev/null and b/timeside/player/static/timeside/skins/lab/img/controlbg.png differ
diff --git a/timeside/player/static/timeside/skins/lab/img/empty.png b/timeside/player/static/timeside/skins/lab/img/empty.png
new file mode 100644 (file)
index 0000000..120bea9
Binary files /dev/null and b/timeside/player/static/timeside/skins/lab/img/empty.png differ
diff --git a/timeside/player/static/timeside/skins/lab/img/forward.png b/timeside/player/static/timeside/skins/lab/img/forward.png
new file mode 100644 (file)
index 0000000..f42a3e0
Binary files /dev/null and b/timeside/player/static/timeside/skins/lab/img/forward.png differ
diff --git a/timeside/player/static/timeside/skins/lab/img/pause.png b/timeside/player/static/timeside/skins/lab/img/pause.png
new file mode 100644 (file)
index 0000000..ca2fbc4
Binary files /dev/null and b/timeside/player/static/timeside/skins/lab/img/pause.png differ
diff --git a/timeside/player/static/timeside/skins/lab/img/play.png b/timeside/player/static/timeside/skins/lab/img/play.png
new file mode 100644 (file)
index 0000000..957e628
Binary files /dev/null and b/timeside/player/static/timeside/skins/lab/img/play.png differ
diff --git a/timeside/player/static/timeside/skins/lab/img/rewind.png b/timeside/player/static/timeside/skins/lab/img/rewind.png
new file mode 100644 (file)
index 0000000..4058546
Binary files /dev/null and b/timeside/player/static/timeside/skins/lab/img/rewind.png differ
diff --git a/timeside/player/static/timeside/skins/lab/img/setmarker.png b/timeside/player/static/timeside/skins/lab/img/setmarker.png
new file mode 100644 (file)
index 0000000..badcce7
Binary files /dev/null and b/timeside/player/static/timeside/skins/lab/img/setmarker.png differ
diff --git a/timeside/player/static/timeside/skins/lab/img/volume.png b/timeside/player/static/timeside/skins/lab/img/volume.png
new file mode 100644 (file)
index 0000000..d741e55
Binary files /dev/null and b/timeside/player/static/timeside/skins/lab/img/volume.png differ
diff --git a/timeside/player/static/timeside/skins/lab/img/volumeoff.png b/timeside/player/static/timeside/skins/lab/img/volumeoff.png
new file mode 100644 (file)
index 0000000..dc8cc21
Binary files /dev/null and b/timeside/player/static/timeside/skins/lab/img/volumeoff.png differ
diff --git a/timeside/player/static/timeside/skins/lab/img/volumeon.png b/timeside/player/static/timeside/skins/lab/img/volumeon.png
new file mode 100644 (file)
index 0000000..93830f5
Binary files /dev/null and b/timeside/player/static/timeside/skins/lab/img/volumeon.png differ
diff --git a/timeside/player/static/timeside/skins/lab/img/wait.gif b/timeside/player/static/timeside/skins/lab/img/wait.gif
new file mode 100644 (file)
index 0000000..155c8a5
Binary files /dev/null and b/timeside/player/static/timeside/skins/lab/img/wait.gif differ
diff --git a/timeside/player/static/timeside/skins/lab/img/wait2.gif b/timeside/player/static/timeside/skins/lab/img/wait2.gif
new file mode 100644 (file)
index 0000000..f2d7273
Binary files /dev/null and b/timeside/player/static/timeside/skins/lab/img/wait2.gif differ
diff --git a/timeside/player/static/timeside/skins/lab/img/wait3.gif b/timeside/player/static/timeside/skins/lab/img/wait3.gif
new file mode 100644 (file)
index 0000000..bb2f003
Binary files /dev/null and b/timeside/player/static/timeside/skins/lab/img/wait3.gif differ
diff --git a/timeside/player/static/timeside/skins/lab/style.css b/timeside/player/static/timeside/skins/lab/style.css
new file mode 100644 (file)
index 0000000..578b4dc
--- /dev/null
@@ -0,0 +1,146 @@
+/*
+* Style for the timeside player. The player div is supposed to be of class .ts-player. Change if needed
+* For details, see http://code.google.com/p/timeside/wiki/UiGuide?ts=1308677096&updated=UiGuide#CSS_and_skins
+*/
+
+.ts-player {
+    padding: 0;
+    border: solid 1px #ADADAD;
+    margin-top: 2px;
+}
+
+
+.ts-player .ts-ruler{
+    color: white;
+    background-color: #2E2E2E;
+    font-size: 10px;
+    line-height: 13px;
+}
+/*svg style, MUST BE A SINGLE SELECTOR. FOR INSTANCE, THIS DOES NOT WORK WHEN SVG IS NOT SUPPORTED:
+  ".ts-player .ts-ruler .ts-svg-ruler-upper-rect" */
+.ts-svg-ruler-upper-rect{
+    fill:  #595959;
+    stroke-width:0;
+    stroke: #595959; /*to be sure...*/
+}
+/*svg style, MUST BE A SINGLE SELECTOR. FOR INSTANCE, THIS DOES NOT WORK WHEN SVG IS NOT SUPPORTED:
+  ".ts-player .ts-ruler .ts-svg-ruler-lines"*/
+.ts-svg-ruler-lines{
+    stroke-width:1;
+    stroke: #ADADAD;
+}
+
+/*wave:*/
+.ts-player .ts-wave {
+    height: 130px;
+}
+
+/*.ts-player .ts-viewer .ts-marker {*/
+.ts-player .ts-ruler .ts-marker {
+     padding: 0 0.5em;
+    background: #e65911;
+    color: #FFF;
+    text-decoration: none;
+}
+/*svg style, MUST BE A SINGLE SELECTOR. FOR INSTANCE, THIS DOES NOT WORK WHEN SVG IS NOT SUPPORTED:
+  ".ts-player .ts-wave .ts-image-canvas .ts-svg-marker-line" */
+.ts-svg-marker-line {
+    fill: #e65911;
+    stroke-width:0;
+}
+
+/*.ts-player .ts-viewer a.ts-pointer {*/
+.ts-player .ts-ruler a.ts-pointer {
+    color: #BB0000;
+    background-color: white;
+    padding: 0 0.5em;
+    border: solid 1px #BB0000;
+
+    text-decoration: none;
+     -moz-border-radius: .3em;
+    -webkit-border-radius: .3em;
+    border-radius: .3em;
+    /*color: #3c4251; #6A0307 !important;*/
+}
+/*svg style, MUST BE A SINGLE SELECTOR. FOR INSTANCE, THIS DOES NOT WORK WHEN SVG IS NOT SUPPORTED:
+  ".ts-player .ts-wave .ts-image-canvas .ts-svg-pointer-line" */
+.ts-svg-pointer-line {
+    fill: #BB0000;
+    stroke-width:0;
+}
+
+.ts-player .ts-wave .ts-image {
+    background: #090e0d ;
+}
+
+.ts-player .ts-control {
+    background: url('img/controlbg.png');
+    font-size: 90%;
+}
+
+ /** display (inline-block) and overflow of a is set inside javascript*/
+.ts-player .ts-control .ts-button {
+    background-repeat: no-repeat;
+    height:28px;
+    width:28px;
+}
+.ts-player .ts-control .ts-play {
+    background-image: url('img/play.png');
+}
+
+.ts-player .ts-control  .ts-pause {
+    background-image: url('img/pause.png');
+}
+
+.ts-player .ts-control  .ts-rewind {
+    background-image: url('img/rewind.png');
+}
+
+.ts-player .ts-control  .ts-forward {
+    background-image: url('img/forward.png');
+}
+
+.ts-player .ts-control  .ts-set-marker {
+    background-image: url('img/setmarker.png');
+}
+
+.ts-player .ts-control .ts-volume-speaker-on {
+    background-image: url('img/volumeon.png');
+    width:24px;
+}
+.ts-player .ts-control .ts-volume-speaker-off {
+    background-image: url('img/volumeoff.png');
+    width:24px;
+}
+.ts-player .ts-control .ts-volume-bar-container { 
+    background: url('img/controlbg-inverted.png');
+    background-position: -3px left;
+    background-repeat: repeat-x;
+    height:10px;
+    width:42px;
+    margin-top:9px;
+     -moz-border-radius: 5px;
+    -webkit-border-radius: 5px;
+    border-radius: 5px;
+    
+}
+.ts-player .ts-control .ts-volume-bar { /*width will be changed inside the code*/
+    background-color: #e4eaf1;
+     -moz-border-radius: 5px;
+    -webkit-border-radius: 5px;
+    border-radius: 5px;
+}
+/*position is set to absolute inside javascript*/
+.ts-player .ts-control .ts-wait {
+    background-repeat: no-repeat;
+    background-image: url('img/wait3.gif');
+    text-align: right;
+    right:0;
+    height:28px;
+    line-height:28px;
+    top:0;
+    background-position: right center;
+    padding-right: 60px;
+    font-size: 80%;
+    color:white;
+}
\ No newline at end of file
diff --git a/timeside/player/static/timeside/swf/soundmanager2.swf b/timeside/player/static/timeside/swf/soundmanager2.swf
new file mode 100644 (file)
index 0000000..c835734
Binary files /dev/null and b/timeside/player/static/timeside/swf/soundmanager2.swf differ
diff --git a/timeside/player/static/timeside/swf/soundmanager2_debug.swf b/timeside/player/static/timeside/swf/soundmanager2_debug.swf
new file mode 100644 (file)
index 0000000..8f7ae84
Binary files /dev/null and b/timeside/player/static/timeside/swf/soundmanager2_debug.swf differ
diff --git a/timeside/player/static/timeside/swf/soundmanager2_flash9.swf b/timeside/player/static/timeside/swf/soundmanager2_flash9.swf
new file mode 100644 (file)
index 0000000..3099659
Binary files /dev/null and b/timeside/player/static/timeside/swf/soundmanager2_flash9.swf differ
diff --git a/timeside/player/static/timeside/swf/soundmanager2_flash9_debug.swf b/timeside/player/static/timeside/swf/soundmanager2_flash9_debug.swf
new file mode 100644 (file)
index 0000000..4e9bf2f
Binary files /dev/null and b/timeside/player/static/timeside/swf/soundmanager2_flash9_debug.swf differ
diff --git a/timeside/player/static/timeside/swf/soundmanager2_flash_xdomain.zip b/timeside/player/static/timeside/swf/soundmanager2_flash_xdomain.zip
new file mode 100644 (file)
index 0000000..b745e64
Binary files /dev/null and b/timeside/player/static/timeside/swf/soundmanager2_flash_xdomain.zip differ
diff --git a/timeside/serializers.py b/timeside/serializers.py
deleted file mode 100644 (file)
index a1447d1..0000000
+++ /dev/null
@@ -1,61 +0,0 @@
-from timeside.models import *
-from rest_framework import serializers
-import django.db.models
-from django.contrib.auth.models import User
-
-
-class SelectionSerializer(serializers.ModelSerializer):
-
-    class Meta:
-        model = Selection
-        fields = ('id', 'items', 'selections', 'author')
-
-
-class ItemSerializer(serializers.ModelSerializer):
-
-    class Meta:
-        model = Item
-        fields = ('id', 'title', 'file', 'mime_type', 'author')
-
-
-class ExperienceSerializer(serializers.ModelSerializer):
-
-    class Meta:
-        model = Experience
-        fields = ('id', 'presets', 'experiences', 'is_public', 'author')
-
-
-class ProcessorSerializer(serializers.ModelSerializer):
-
-    class Meta:
-        model = Processor
-        fields = ('id', 'pid', 'version')
-
-
-class ResultSerializer(serializers.ModelSerializer):
-
-    class Meta:
-        model = Result
-        fields = ('id', 'item', 'preset', 'status', 'hdf5', 'file')
-
-
-class PresetSerializer(serializers.ModelSerializer):
-
-    class Meta:
-        model = Preset
-        fields = ('id', 'processor', 'parameters', 'is_public')
-
-
-class TaskSerializer(serializers.ModelSerializer):
-
-    class Meta:
-        model = Task
-        fields = ('id', 'experience', 'selection', 'status', 'author')
-
-
-class UserSerializer(serializers.ModelSerializer):
-
-    class Meta:
-        model = User
-
-
diff --git a/timeside/server/__init__.py b/timeside/server/__init__.py
new file mode 100644 (file)
index 0000000..e69de29
diff --git a/timeside/server/admin.py b/timeside/server/admin.py
new file mode 100644 (file)
index 0000000..2112f64
--- /dev/null
@@ -0,0 +1,12 @@
+
+from django.contrib import admin
+from timeside.server.models import *
+
+admin.site.register(Selection)
+admin.site.register(Item)
+admin.site.register(Experience)
+admin.site.register(Processor)
+admin.site.register(Preset)
+admin.site.register(Result)
+admin.site.register(Task)
+
diff --git a/timeside/server/migrations/0001_initial.py b/timeside/server/migrations/0001_initial.py
new file mode 100644 (file)
index 0000000..bba562c
--- /dev/null
@@ -0,0 +1,284 @@
+# -*- coding: utf-8 -*-
+from south.utils import datetime_utils as datetime
+from south.db import db
+from south.v2 import SchemaMigration
+from django.db import models
+
+
+class Migration(SchemaMigration):
+
+    def forwards(self, orm):
+        # Adding model 'Selection'
+        db.create_table('timeside_selections', (
+            ('id', self.gf('django.db.models.fields.AutoField')(primary_key=True)),
+            ('date_added', self.gf('django.db.models.fields.DateTimeField')(auto_now_add=True, blank=True)),
+            ('date_modified', self.gf('django.db.models.fields.DateTimeField')(auto_now=True, null=True, blank=True)),
+            ('uuid', self.gf('django.db.models.fields.CharField')(unique=True, max_length=512, blank=True)),
+            ('title', self.gf('django.db.models.fields.CharField')(max_length=512, blank=True)),
+            ('description', self.gf('django.db.models.fields.TextField')(blank=True)),
+            ('author', self.gf('django.db.models.fields.related.ForeignKey')(blank=True, related_name='selections', null=True, on_delete=models.SET_NULL, to=orm['auth.User'])),
+        ))
+        db.send_create_signal('timeside', ['Selection'])
+
+        # Adding M2M table for field items on 'Selection'
+        m2m_table_name = db.shorten_name('timeside_selections_items')
+        db.create_table(m2m_table_name, (
+            ('id', models.AutoField(verbose_name='ID', primary_key=True, auto_created=True)),
+            ('selection', models.ForeignKey(orm['timeside.selection'], null=False)),
+            ('item', models.ForeignKey(orm['timeside.item'], null=False))
+        ))
+        db.create_unique(m2m_table_name, ['selection_id', 'item_id'])
+
+        # Adding M2M table for field selections on 'Selection'
+        m2m_table_name = db.shorten_name('timeside_selections_selections')
+        db.create_table(m2m_table_name, (
+            ('id', models.AutoField(verbose_name='ID', primary_key=True, auto_created=True)),
+            ('from_selection', models.ForeignKey(orm['timeside.selection'], null=False)),
+            ('to_selection', models.ForeignKey(orm['timeside.selection'], null=False))
+        ))
+        db.create_unique(m2m_table_name, ['from_selection_id', 'to_selection_id'])
+
+        # Adding model 'Item'
+        db.create_table('timeside_items', (
+            ('id', self.gf('django.db.models.fields.AutoField')(primary_key=True)),
+            ('date_added', self.gf('django.db.models.fields.DateTimeField')(auto_now_add=True, blank=True)),
+            ('date_modified', self.gf('django.db.models.fields.DateTimeField')(auto_now=True, null=True, blank=True)),
+            ('uuid', self.gf('django.db.models.fields.CharField')(unique=True, max_length=512, blank=True)),
+            ('title', self.gf('django.db.models.fields.CharField')(max_length=512, blank=True)),
+            ('description', self.gf('django.db.models.fields.TextField')(blank=True)),
+            ('file', self.gf('django.db.models.fields.files.FileField')(max_length=1024, blank=True)),
+            ('url', self.gf('django.db.models.fields.URLField')(max_length=1024, blank=True)),
+            ('sha1', self.gf('django.db.models.fields.CharField')(max_length=512, blank=True)),
+            ('mime_type', self.gf('django.db.models.fields.CharField')(max_length=256, blank=True)),
+            ('hdf5', self.gf('django.db.models.fields.files.FileField')(max_length=1024, blank=True)),
+            ('lock', self.gf('django.db.models.fields.BooleanField')(default=False)),
+            ('author', self.gf('django.db.models.fields.related.ForeignKey')(blank=True, related_name='items', null=True, on_delete=models.SET_NULL, to=orm['auth.User'])),
+        ))
+        db.send_create_signal('timeside', ['Item'])
+
+        # Adding model 'Experience'
+        db.create_table('timeside_experiences', (
+            ('id', self.gf('django.db.models.fields.AutoField')(primary_key=True)),
+            ('date_added', self.gf('django.db.models.fields.DateTimeField')(auto_now_add=True, blank=True)),
+            ('date_modified', self.gf('django.db.models.fields.DateTimeField')(auto_now=True, null=True, blank=True)),
+            ('uuid', self.gf('django.db.models.fields.CharField')(unique=True, max_length=512, blank=True)),
+            ('title', self.gf('django.db.models.fields.CharField')(max_length=512, blank=True)),
+            ('description', self.gf('django.db.models.fields.TextField')(blank=True)),
+            ('author', self.gf('django.db.models.fields.related.ForeignKey')(blank=True, related_name='experiences', null=True, on_delete=models.SET_NULL, to=orm['auth.User'])),
+            ('is_preset', self.gf('django.db.models.fields.BooleanField')(default=False)),
+        ))
+        db.send_create_signal('timeside', ['Experience'])
+
+        # Adding M2M table for field processors on 'Experience'
+        m2m_table_name = db.shorten_name('timeside_experiences_processors')
+        db.create_table(m2m_table_name, (
+            ('id', models.AutoField(verbose_name='ID', primary_key=True, auto_created=True)),
+            ('experience', models.ForeignKey(orm['timeside.experience'], null=False)),
+            ('processor', models.ForeignKey(orm['timeside.processor'], null=False))
+        ))
+        db.create_unique(m2m_table_name, ['experience_id', 'processor_id'])
+
+        # Adding M2M table for field experiences on 'Experience'
+        m2m_table_name = db.shorten_name('timeside_experiences_experiences')
+        db.create_table(m2m_table_name, (
+            ('id', models.AutoField(verbose_name='ID', primary_key=True, auto_created=True)),
+            ('from_experience', models.ForeignKey(orm['timeside.experience'], null=False)),
+            ('to_experience', models.ForeignKey(orm['timeside.experience'], null=False))
+        ))
+        db.create_unique(m2m_table_name, ['from_experience_id', 'to_experience_id'])
+
+        # Adding model 'Processor'
+        db.create_table('timeside_processors', (
+            ('id', self.gf('django.db.models.fields.AutoField')(primary_key=True)),
+            ('pid', self.gf('django.db.models.fields.CharField')(max_length=256)),
+            ('type', self.gf('django.db.models.fields.CharField')(default='none', max_length=64)),
+            ('version', self.gf('django.db.models.fields.CharField')(max_length=64, blank=True)),
+        ))
+        db.send_create_signal('timeside', ['Processor'])
+
+        # Adding model 'Result'
+        db.create_table('timeside_results', (
+            ('id', self.gf('django.db.models.fields.AutoField')(primary_key=True)),
+            ('date_added', self.gf('django.db.models.fields.DateTimeField')(auto_now_add=True, blank=True)),
+            ('date_modified', self.gf('django.db.models.fields.DateTimeField')(auto_now=True, null=True, blank=True)),
+            ('uuid', self.gf('django.db.models.fields.CharField')(unique=True, max_length=512, blank=True)),
+            ('item', self.gf('django.db.models.fields.related.ForeignKey')(blank=True, related_name='results', null=True, on_delete=models.SET_NULL, to=orm['timeside.Item'])),
+            ('processor', self.gf('django.db.models.fields.related.ForeignKey')(blank=True, related_name='results', null=True, on_delete=models.SET_NULL, to=orm['timeside.Processor'])),
+            ('hdf5', self.gf('django.db.models.fields.files.FileField')(max_length=1024, blank=True)),
+            ('output', self.gf('django.db.models.fields.files.FileField')(max_length=1024, blank=True)),
+            ('output_mime_type', self.gf('django.db.models.fields.CharField')(max_length=256, blank=True)),
+            ('status', self.gf('django.db.models.fields.IntegerField')(default=1)),
+        ))
+        db.send_create_signal('timeside', ['Result'])
+
+        # Adding model 'Parameters'
+        db.create_table('timeside_parameters', (
+            ('id', self.gf('django.db.models.fields.AutoField')(primary_key=True)),
+            ('processor', self.gf('django.db.models.fields.related.ForeignKey')(blank=True, related_name='parameters', null=True, to=orm['timeside.Experience'])),
+            ('parameters', self.gf('django.db.models.fields.TextField')(blank=True)),
+            ('is_preset', self.gf('django.db.models.fields.BooleanField')(default=False)),
+        ))
+        db.send_create_signal('timeside', ['Parameters'])
+
+        # Adding model 'Task'
+        db.create_table('timeside_tasks', (
+            ('id', self.gf('django.db.models.fields.AutoField')(primary_key=True)),
+            ('experience', self.gf('django.db.models.fields.related.ForeignKey')(blank=True, related_name='task', null=True, to=orm['timeside.Experience'])),
+            ('selection', self.gf('django.db.models.fields.related.ForeignKey')(blank=True, related_name='task', null=True, to=orm['timeside.Selection'])),
+            ('status', self.gf('django.db.models.fields.IntegerField')(default=1)),
+            ('author', self.gf('django.db.models.fields.related.ForeignKey')(blank=True, related_name='tasks', null=True, on_delete=models.SET_NULL, to=orm['auth.User'])),
+        ))
+        db.send_create_signal('timeside', ['Task'])
+
+
+    def backwards(self, orm):
+        # Deleting model 'Selection'
+        db.delete_table('timeside_selections')
+
+        # Removing M2M table for field items on 'Selection'
+        db.delete_table(db.shorten_name('timeside_selections_items'))
+
+        # Removing M2M table for field selections on 'Selection'
+        db.delete_table(db.shorten_name('timeside_selections_selections'))
+
+        # Deleting model 'Item'
+        db.delete_table('timeside_items')
+
+        # Deleting model 'Experience'
+        db.delete_table('timeside_experiences')
+
+        # Removing M2M table for field processors on 'Experience'
+        db.delete_table(db.shorten_name('timeside_experiences_processors'))
+
+        # Removing M2M table for field experiences on 'Experience'
+        db.delete_table(db.shorten_name('timeside_experiences_experiences'))
+
+        # Deleting model 'Processor'
+        db.delete_table('timeside_processors')
+
+        # Deleting model 'Result'
+        db.delete_table('timeside_results')
+
+        # Deleting model 'Parameters'
+        db.delete_table('timeside_parameters')
+
+        # Deleting model 'Task'
+        db.delete_table('timeside_tasks')
+
+
+    models = {
+        'auth.group': {
+            'Meta': {'object_name': 'Group'},
+            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
+            'name': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '80'}),
+            'permissions': ('django.db.models.fields.related.ManyToManyField', [], {'to': "orm['auth.Permission']", 'symmetrical': 'False', 'blank': 'True'})
+        },
+        'auth.permission': {
+            'Meta': {'ordering': "('content_type__app_label', 'content_type__model', 'codename')", 'unique_together': "(('content_type', 'codename'),)", 'object_name': 'Permission'},
+            'codename': ('django.db.models.fields.CharField', [], {'max_length': '100'}),
+            'content_type': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['contenttypes.ContentType']"}),
+            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
+            'name': ('django.db.models.fields.CharField', [], {'max_length': '50'})
+        },
+        'auth.user': {
+            'Meta': {'object_name': 'User'},
+            'date_joined': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime.now'}),
+            'email': ('django.db.models.fields.EmailField', [], {'max_length': '75', 'blank': 'True'}),
+            'first_name': ('django.db.models.fields.CharField', [], {'max_length': '30', 'blank': 'True'}),
+            'groups': ('django.db.models.fields.related.ManyToManyField', [], {'to': "orm['auth.Group']", 'symmetrical': 'False', 'blank': 'True'}),
+            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
+            'is_active': ('django.db.models.fields.BooleanField', [], {'default': 'True'}),
+            'is_staff': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
+            'is_superuser': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
+            'last_login': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime.now'}),
+            'last_name': ('django.db.models.fields.CharField', [], {'max_length': '30', 'blank': 'True'}),
+            'password': ('django.db.models.fields.CharField', [], {'max_length': '128'}),
+            'user_permissions': ('django.db.models.fields.related.ManyToManyField', [], {'to': "orm['auth.Permission']", 'symmetrical': 'False', 'blank': 'True'}),
+            'username': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '30'})
+        },
+        'contenttypes.contenttype': {
+            'Meta': {'ordering': "('name',)", 'unique_together': "(('app_label', 'model'),)", 'object_name': 'ContentType', 'db_table': "'django_content_type'"},
+            'app_label': ('django.db.models.fields.CharField', [], {'max_length': '100'}),
+            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
+            'model': ('django.db.models.fields.CharField', [], {'max_length': '100'}),
+            'name': ('django.db.models.fields.CharField', [], {'max_length': '100'})
+        },
+        'timeside.experience': {
+            'Meta': {'object_name': 'Experience', 'db_table': "'timeside_experiences'"},
+            'author': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'experiences'", 'null': 'True', 'on_delete': 'models.SET_NULL', 'to': "orm['auth.User']"}),
+            'date_added': ('django.db.models.fields.DateTimeField', [], {'auto_now_add': 'True', 'blank': 'True'}),
+            'date_modified': ('django.db.models.fields.DateTimeField', [], {'auto_now': 'True', 'null': 'True', 'blank': 'True'}),
+            'description': ('django.db.models.fields.TextField', [], {'blank': 'True'}),
+            'experiences': ('django.db.models.fields.related.ManyToManyField', [], {'blank': 'True', 'related_name': "'other_experiences'", 'null': 'True', 'symmetrical': 'False', 'to': "orm['timeside.Experience']"}),
+            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
+            'is_preset': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
+            'processors': ('django.db.models.fields.related.ManyToManyField', [], {'blank': 'True', 'related_name': "'experiences'", 'null': 'True', 'symmetrical': 'False', 'to': "orm['timeside.Processor']"}),
+            'title': ('django.db.models.fields.CharField', [], {'max_length': '512', 'blank': 'True'}),
+            'uuid': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '512', 'blank': 'True'})
+        },
+        'timeside.item': {
+            'Meta': {'ordering': "['title']", 'object_name': 'Item', 'db_table': "'timeside_items'"},
+            'author': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'items'", 'null': 'True', 'on_delete': 'models.SET_NULL', 'to': "orm['auth.User']"}),
+            'date_added': ('django.db.models.fields.DateTimeField', [], {'auto_now_add': 'True', 'blank': 'True'}),
+            'date_modified': ('django.db.models.fields.DateTimeField', [], {'auto_now': 'True', 'null': 'True', 'blank': 'True'}),
+            'description': ('django.db.models.fields.TextField', [], {'blank': 'True'}),
+            'file': ('django.db.models.fields.files.FileField', [], {'max_length': '1024', 'blank': 'True'}),
+            'hdf5': ('django.db.models.fields.files.FileField', [], {'max_length': '1024', 'blank': 'True'}),
+            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
+            'lock': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
+            'mime_type': ('django.db.models.fields.CharField', [], {'max_length': '256', 'blank': 'True'}),
+            'sha1': ('django.db.models.fields.CharField', [], {'max_length': '512', 'blank': 'True'}),
+            'title': ('django.db.models.fields.CharField', [], {'max_length': '512', 'blank': 'True'}),
+            'url': ('django.db.models.fields.URLField', [], {'max_length': '1024', 'blank': 'True'}),
+            'uuid': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '512', 'blank': 'True'})
+        },
+        'timeside.parameters': {
+            'Meta': {'object_name': 'Parameters'},
+            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
+            'is_preset': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
+            'parameters': ('django.db.models.fields.TextField', [], {'blank': 'True'}),
+            'processor': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'parameters'", 'null': 'True', 'to': "orm['timeside.Experience']"})
+        },
+        'timeside.processor': {
+            'Meta': {'object_name': 'Processor', 'db_table': "'timeside_processors'"},
+            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
+            'pid': ('django.db.models.fields.CharField', [], {'max_length': '256'}),
+            'type': ('django.db.models.fields.CharField', [], {'default': "'none'", 'max_length': '64'}),
+            'version': ('django.db.models.fields.CharField', [], {'max_length': '64', 'blank': 'True'})
+        },
+        'timeside.result': {
+            'Meta': {'object_name': 'Result', 'db_table': "'timeside_results'"},
+            'date_added': ('django.db.models.fields.DateTimeField', [], {'auto_now_add': 'True', 'blank': 'True'}),
+            'date_modified': ('django.db.models.fields.DateTimeField', [], {'auto_now': 'True', 'null': 'True', 'blank': 'True'}),
+            'hdf5': ('django.db.models.fields.files.FileField', [], {'max_length': '1024', 'blank': 'True'}),
+            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
+            'item': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'results'", 'null': 'True', 'on_delete': 'models.SET_NULL', 'to': "orm['timeside.Item']"}),
+            'output': ('django.db.models.fields.files.FileField', [], {'max_length': '1024', 'blank': 'True'}),
+            'output_mime_type': ('django.db.models.fields.CharField', [], {'max_length': '256', 'blank': 'True'}),
+            'processor': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'results'", 'null': 'True', 'on_delete': 'models.SET_NULL', 'to': "orm['timeside.Processor']"}),
+            'status': ('django.db.models.fields.IntegerField', [], {'default': '1'}),
+            'uuid': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '512', 'blank': 'True'})
+        },
+        'timeside.selection': {
+            'Meta': {'object_name': 'Selection', 'db_table': "'timeside_selections'"},
+            'author': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'selections'", 'null': 'True', 'on_delete': 'models.SET_NULL', 'to': "orm['auth.User']"}),
+            'date_added': ('django.db.models.fields.DateTimeField', [], {'auto_now_add': 'True', 'blank': 'True'}),
+            'date_modified': ('django.db.models.fields.DateTimeField', [], {'auto_now': 'True', 'null': 'True', 'blank': 'True'}),
+            'description': ('django.db.models.fields.TextField', [], {'blank': 'True'}),
+            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
+            'items': ('django.db.models.fields.related.ManyToManyField', [], {'blank': 'True', 'related_name': "'selections'", 'null': 'True', 'symmetrical': 'False', 'to': "orm['timeside.Item']"}),
+            'selections': ('django.db.models.fields.related.ManyToManyField', [], {'blank': 'True', 'related_name': "'other_selections'", 'null': 'True', 'symmetrical': 'False', 'to': "orm['timeside.Selection']"}),
+            'title': ('django.db.models.fields.CharField', [], {'max_length': '512', 'blank': 'True'}),
+            'uuid': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '512', 'blank': 'True'})
+        },
+        'timeside.task': {
+            'Meta': {'object_name': 'Task', 'db_table': "'timeside_tasks'"},
+            'author': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'tasks'", 'null': 'True', 'on_delete': 'models.SET_NULL', 'to': "orm['auth.User']"}),
+            'experience': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'task'", 'null': 'True', 'to': "orm['timeside.Experience']"}),
+            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
+            'selection': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'task'", 'null': 'True', 'to': "orm['timeside.Selection']"}),
+            'status': ('django.db.models.fields.IntegerField', [], {'default': '1'})
+        }
+    }
+
+    complete_apps = ['timeside']
\ No newline at end of file
diff --git a/timeside/server/migrations/0002_auto__chg_field_parameters_processor.py b/timeside/server/migrations/0002_auto__chg_field_parameters_processor.py
new file mode 100644 (file)
index 0000000..aea7f91
--- /dev/null
@@ -0,0 +1,135 @@
+# -*- coding: utf-8 -*-
+from south.utils import datetime_utils as datetime
+from south.db import db
+from south.v2 import SchemaMigration
+from django.db import models
+
+
+class Migration(SchemaMigration):
+
+    def forwards(self, orm):
+
+        # Changing field 'Parameters.processor'
+        db.alter_column('timeside_parameters', 'processor_id', self.gf('django.db.models.fields.related.ForeignKey')(null=True, to=orm['timeside.Processor']))
+
+    def backwards(self, orm):
+
+        # Changing field 'Parameters.processor'
+        db.alter_column('timeside_parameters', 'processor_id', self.gf('django.db.models.fields.related.ForeignKey')(null=True, to=orm['timeside.Experience']))
+
+    models = {
+        'auth.group': {
+            'Meta': {'object_name': 'Group'},
+            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
+            'name': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '80'}),
+            'permissions': ('django.db.models.fields.related.ManyToManyField', [], {'to': "orm['auth.Permission']", 'symmetrical': 'False', 'blank': 'True'})
+        },
+        'auth.permission': {
+            'Meta': {'ordering': "('content_type__app_label', 'content_type__model', 'codename')", 'unique_together': "(('content_type', 'codename'),)", 'object_name': 'Permission'},
+            'codename': ('django.db.models.fields.CharField', [], {'max_length': '100'}),
+            'content_type': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['contenttypes.ContentType']"}),
+            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
+            'name': ('django.db.models.fields.CharField', [], {'max_length': '50'})
+        },
+        'auth.user': {
+            'Meta': {'object_name': 'User'},
+            'date_joined': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime.now'}),
+            'email': ('django.db.models.fields.EmailField', [], {'max_length': '75', 'blank': 'True'}),
+            'first_name': ('django.db.models.fields.CharField', [], {'max_length': '30', 'blank': 'True'}),
+            'groups': ('django.db.models.fields.related.ManyToManyField', [], {'to': "orm['auth.Group']", 'symmetrical': 'False', 'blank': 'True'}),
+            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
+            'is_active': ('django.db.models.fields.BooleanField', [], {'default': 'True'}),
+            'is_staff': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
+            'is_superuser': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
+            'last_login': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime.now'}),
+            'last_name': ('django.db.models.fields.CharField', [], {'max_length': '30', 'blank': 'True'}),
+            'password': ('django.db.models.fields.CharField', [], {'max_length': '128'}),
+            'user_permissions': ('django.db.models.fields.related.ManyToManyField', [], {'to': "orm['auth.Permission']", 'symmetrical': 'False', 'blank': 'True'}),
+            'username': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '30'})
+        },
+        'contenttypes.contenttype': {
+            'Meta': {'ordering': "('name',)", 'unique_together': "(('app_label', 'model'),)", 'object_name': 'ContentType', 'db_table': "'django_content_type'"},
+            'app_label': ('django.db.models.fields.CharField', [], {'max_length': '100'}),
+            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
+            'model': ('django.db.models.fields.CharField', [], {'max_length': '100'}),
+            'name': ('django.db.models.fields.CharField', [], {'max_length': '100'})
+        },
+        'timeside.experience': {
+            'Meta': {'object_name': 'Experience', 'db_table': "'timeside_experiences'"},
+            'author': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'experiences'", 'null': 'True', 'on_delete': 'models.SET_NULL', 'to': "orm['auth.User']"}),
+            'date_added': ('django.db.models.fields.DateTimeField', [], {'auto_now_add': 'True', 'blank': 'True'}),
+            'date_modified': ('django.db.models.fields.DateTimeField', [], {'auto_now': 'True', 'null': 'True', 'blank': 'True'}),
+            'description': ('django.db.models.fields.TextField', [], {'blank': 'True'}),
+            'experiences': ('django.db.models.fields.related.ManyToManyField', [], {'blank': 'True', 'related_name': "'other_experiences'", 'null': 'True', 'symmetrical': 'False', 'to': "orm['timeside.Experience']"}),
+            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
+            'is_preset': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
+            'processors': ('django.db.models.fields.related.ManyToManyField', [], {'blank': 'True', 'related_name': "'experiences'", 'null': 'True', 'symmetrical': 'False', 'to': "orm['timeside.Processor']"}),
+            'title': ('django.db.models.fields.CharField', [], {'max_length': '512', 'blank': 'True'}),
+            'uuid': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '512', 'blank': 'True'})
+        },
+        'timeside.item': {
+            'Meta': {'ordering': "['title']", 'object_name': 'Item', 'db_table': "'timeside_items'"},
+            'author': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'items'", 'null': 'True', 'on_delete': 'models.SET_NULL', 'to': "orm['auth.User']"}),
+            'date_added': ('django.db.models.fields.DateTimeField', [], {'auto_now_add': 'True', 'blank': 'True'}),
+            'date_modified': ('django.db.models.fields.DateTimeField', [], {'auto_now': 'True', 'null': 'True', 'blank': 'True'}),
+            'description': ('django.db.models.fields.TextField', [], {'blank': 'True'}),
+            'file': ('django.db.models.fields.files.FileField', [], {'max_length': '1024', 'blank': 'True'}),
+            'hdf5': ('django.db.models.fields.files.FileField', [], {'max_length': '1024', 'blank': 'True'}),
+            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
+            'lock': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
+            'mime_type': ('django.db.models.fields.CharField', [], {'max_length': '256', 'blank': 'True'}),
+            'sha1': ('django.db.models.fields.CharField', [], {'max_length': '512', 'blank': 'True'}),
+            'title': ('django.db.models.fields.CharField', [], {'max_length': '512', 'blank': 'True'}),
+            'url': ('django.db.models.fields.URLField', [], {'max_length': '1024', 'blank': 'True'}),
+            'uuid': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '512', 'blank': 'True'})
+        },
+        'timeside.parameters': {
+            'Meta': {'object_name': 'Parameters'},
+            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
+            'is_preset': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
+            'parameters': ('django.db.models.fields.TextField', [], {'blank': 'True'}),
+            'processor': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'parameters'", 'null': 'True', 'to': "orm['timeside.Processor']"})
+        },
+        'timeside.processor': {
+            'Meta': {'object_name': 'Processor', 'db_table': "'timeside_processors'"},
+            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
+            'pid': ('django.db.models.fields.CharField', [], {'max_length': '256'}),
+            'type': ('django.db.models.fields.CharField', [], {'default': "'none'", 'max_length': '64'}),
+            'version': ('django.db.models.fields.CharField', [], {'max_length': '64', 'blank': 'True'})
+        },
+        'timeside.result': {
+            'Meta': {'object_name': 'Result', 'db_table': "'timeside_results'"},
+            'date_added': ('django.db.models.fields.DateTimeField', [], {'auto_now_add': 'True', 'blank': 'True'}),
+            'date_modified': ('django.db.models.fields.DateTimeField', [], {'auto_now': 'True', 'null': 'True', 'blank': 'True'}),
+            'hdf5': ('django.db.models.fields.files.FileField', [], {'max_length': '1024', 'blank': 'True'}),
+            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
+            'item': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'results'", 'null': 'True', 'on_delete': 'models.SET_NULL', 'to': "orm['timeside.Item']"}),
+            'output': ('django.db.models.fields.files.FileField', [], {'max_length': '1024', 'blank': 'True'}),
+            'output_mime_type': ('django.db.models.fields.CharField', [], {'max_length': '256', 'blank': 'True'}),
+            'processor': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'results'", 'null': 'True', 'on_delete': 'models.SET_NULL', 'to': "orm['timeside.Processor']"}),
+            'status': ('django.db.models.fields.IntegerField', [], {'default': '1'}),
+            'uuid': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '512', 'blank': 'True'})
+        },
+        'timeside.selection': {
+            'Meta': {'object_name': 'Selection', 'db_table': "'timeside_selections'"},
+            'author': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'selections'", 'null': 'True', 'on_delete': 'models.SET_NULL', 'to': "orm['auth.User']"}),
+            'date_added': ('django.db.models.fields.DateTimeField', [], {'auto_now_add': 'True', 'blank': 'True'}),
+            'date_modified': ('django.db.models.fields.DateTimeField', [], {'auto_now': 'True', 'null': 'True', 'blank': 'True'}),
+            'description': ('django.db.models.fields.TextField', [], {'blank': 'True'}),
+            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
+            'items': ('django.db.models.fields.related.ManyToManyField', [], {'blank': 'True', 'related_name': "'selections'", 'null': 'True', 'symmetrical': 'False', 'to': "orm['timeside.Item']"}),
+            'selections': ('django.db.models.fields.related.ManyToManyField', [], {'blank': 'True', 'related_name': "'other_selections'", 'null': 'True', 'symmetrical': 'False', 'to': "orm['timeside.Selection']"}),
+            'title': ('django.db.models.fields.CharField', [], {'max_length': '512', 'blank': 'True'}),
+            'uuid': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '512', 'blank': 'True'})
+        },
+        'timeside.task': {
+            'Meta': {'object_name': 'Task', 'db_table': "'timeside_tasks'"},
+            'author': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'tasks'", 'null': 'True', 'on_delete': 'models.SET_NULL', 'to': "orm['auth.User']"}),
+            'experience': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'task'", 'null': 'True', 'to': "orm['timeside.Experience']"}),
+            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
+            'selection': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'task'", 'null': 'True', 'to': "orm['timeside.Selection']"}),
+            'status': ('django.db.models.fields.IntegerField', [], {'default': '1'})
+        }
+    }
+
+    complete_apps = ['timeside']
\ No newline at end of file
diff --git a/timeside/server/migrations/0003_auto__del_field_processor_type.py b/timeside/server/migrations/0003_auto__del_field_processor_type.py
new file mode 100644 (file)
index 0000000..1c5c6a2
--- /dev/null
@@ -0,0 +1,136 @@
+# -*- coding: utf-8 -*-
+from south.utils import datetime_utils as datetime
+from south.db import db
+from south.v2 import SchemaMigration
+from django.db import models
+
+
+class Migration(SchemaMigration):
+
+    def forwards(self, orm):
+        # Deleting field 'Processor.type'
+        db.delete_column('timeside_processors', 'type')
+
+
+    def backwards(self, orm):
+        # Adding field 'Processor.type'
+        db.add_column('timeside_processors', 'type',
+                      self.gf('django.db.models.fields.CharField')(default='none', max_length=64),
+                      keep_default=False)
+
+
+    models = {
+        'auth.group': {
+            'Meta': {'object_name': 'Group'},
+            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
+            'name': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '80'}),
+            'permissions': ('django.db.models.fields.related.ManyToManyField', [], {'to': "orm['auth.Permission']", 'symmetrical': 'False', 'blank': 'True'})
+        },
+        'auth.permission': {
+            'Meta': {'ordering': "('content_type__app_label', 'content_type__model', 'codename')", 'unique_together': "(('content_type', 'codename'),)", 'object_name': 'Permission'},
+            'codename': ('django.db.models.fields.CharField', [], {'max_length': '100'}),
+            'content_type': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['contenttypes.ContentType']"}),
+            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
+            'name': ('django.db.models.fields.CharField', [], {'max_length': '50'})
+        },
+        'auth.user': {
+            'Meta': {'object_name': 'User'},
+            'date_joined': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime.now'}),
+            'email': ('django.db.models.fields.EmailField', [], {'max_length': '75', 'blank': 'True'}),
+            'first_name': ('django.db.models.fields.CharField', [], {'max_length': '30', 'blank': 'True'}),
+            'groups': ('django.db.models.fields.related.ManyToManyField', [], {'to': "orm['auth.Group']", 'symmetrical': 'False', 'blank': 'True'}),
+            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
+            'is_active': ('django.db.models.fields.BooleanField', [], {'default': 'True'}),
+            'is_staff': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
+            'is_superuser': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
+            'last_login': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime.now'}),
+            'last_name': ('django.db.models.fields.CharField', [], {'max_length': '30', 'blank': 'True'}),
+            'password': ('django.db.models.fields.CharField', [], {'max_length': '128'}),
+            'user_permissions': ('django.db.models.fields.related.ManyToManyField', [], {'to': "orm['auth.Permission']", 'symmetrical': 'False', 'blank': 'True'}),
+            'username': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '30'})
+        },
+        'contenttypes.contenttype': {
+            'Meta': {'ordering': "('name',)", 'unique_together': "(('app_label', 'model'),)", 'object_name': 'ContentType', 'db_table': "'django_content_type'"},
+            'app_label': ('django.db.models.fields.CharField', [], {'max_length': '100'}),
+            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
+            'model': ('django.db.models.fields.CharField', [], {'max_length': '100'}),
+            'name': ('django.db.models.fields.CharField', [], {'max_length': '100'})
+        },
+        'timeside.experience': {
+            'Meta': {'object_name': 'Experience', 'db_table': "'timeside_experiences'"},
+            'author': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'experiences'", 'null': 'True', 'on_delete': 'models.SET_NULL', 'to': "orm['auth.User']"}),
+            'date_added': ('django.db.models.fields.DateTimeField', [], {'auto_now_add': 'True', 'blank': 'True'}),
+            'date_modified': ('django.db.models.fields.DateTimeField', [], {'auto_now': 'True', 'null': 'True', 'blank': 'True'}),
+            'description': ('django.db.models.fields.TextField', [], {'blank': 'True'}),
+            'experiences': ('django.db.models.fields.related.ManyToManyField', [], {'blank': 'True', 'related_name': "'other_experiences'", 'null': 'True', 'symmetrical': 'False', 'to': "orm['timeside.Experience']"}),
+            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
+            'is_preset': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
+            'processors': ('django.db.models.fields.related.ManyToManyField', [], {'blank': 'True', 'related_name': "'experiences'", 'null': 'True', 'symmetrical': 'False', 'to': "orm['timeside.Processor']"}),
+            'title': ('django.db.models.fields.CharField', [], {'max_length': '512', 'blank': 'True'}),
+            'uuid': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '512', 'blank': 'True'})
+        },
+        'timeside.item': {
+            'Meta': {'ordering': "['title']", 'object_name': 'Item', 'db_table': "'timeside_items'"},
+            'author': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'items'", 'null': 'True', 'on_delete': 'models.SET_NULL', 'to': "orm['auth.User']"}),
+            'date_added': ('django.db.models.fields.DateTimeField', [], {'auto_now_add': 'True', 'blank': 'True'}),
+            'date_modified': ('django.db.models.fields.DateTimeField', [], {'auto_now': 'True', 'null': 'True', 'blank': 'True'}),
+            'description': ('django.db.models.fields.TextField', [], {'blank': 'True'}),
+            'file': ('django.db.models.fields.files.FileField', [], {'max_length': '1024', 'blank': 'True'}),
+            'hdf5': ('django.db.models.fields.files.FileField', [], {'max_length': '1024', 'blank': 'True'}),
+            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
+            'lock': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
+            'mime_type': ('django.db.models.fields.CharField', [], {'max_length': '256', 'blank': 'True'}),
+            'sha1': ('django.db.models.fields.CharField', [], {'max_length': '512', 'blank': 'True'}),
+            'title': ('django.db.models.fields.CharField', [], {'max_length': '512', 'blank': 'True'}),
+            'url': ('django.db.models.fields.URLField', [], {'max_length': '1024', 'blank': 'True'}),
+            'uuid': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '512', 'blank': 'True'})
+        },
+        'timeside.parameters': {
+            'Meta': {'object_name': 'Parameters'},
+            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
+            'is_preset': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
+            'parameters': ('django.db.models.fields.TextField', [], {'blank': 'True'}),
+            'processor': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'parameters'", 'null': 'True', 'to': "orm['timeside.Processor']"})
+        },
+        'timeside.processor': {
+            'Meta': {'object_name': 'Processor', 'db_table': "'timeside_processors'"},
+            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
+            'pid': ('django.db.models.fields.CharField', [], {'max_length': '256'}),
+            'version': ('django.db.models.fields.CharField', [], {'max_length': '64', 'blank': 'True'})
+        },
+        'timeside.result': {
+            'Meta': {'object_name': 'Result', 'db_table': "'timeside_results'"},
+            'date_added': ('django.db.models.fields.DateTimeField', [], {'auto_now_add': 'True', 'blank': 'True'}),
+            'date_modified': ('django.db.models.fields.DateTimeField', [], {'auto_now': 'True', 'null': 'True', 'blank': 'True'}),
+            'hdf5': ('django.db.models.fields.files.FileField', [], {'max_length': '1024', 'blank': 'True'}),
+            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
+            'item': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'results'", 'null': 'True', 'on_delete': 'models.SET_NULL', 'to': "orm['timeside.Item']"}),
+            'output': ('django.db.models.fields.files.FileField', [], {'max_length': '1024', 'blank': 'True'}),
+            'output_mime_type': ('django.db.models.fields.CharField', [], {'max_length': '256', 'blank': 'True'}),
+            'processor': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'results'", 'null': 'True', 'on_delete': 'models.SET_NULL', 'to': "orm['timeside.Processor']"}),
+            'status': ('django.db.models.fields.IntegerField', [], {'default': '1'}),
+            'uuid': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '512', 'blank': 'True'})
+        },
+        'timeside.selection': {
+            'Meta': {'object_name': 'Selection', 'db_table': "'timeside_selections'"},
+            'author': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'selections'", 'null': 'True', 'on_delete': 'models.SET_NULL', 'to': "orm['auth.User']"}),
+            'date_added': ('django.db.models.fields.DateTimeField', [], {'auto_now_add': 'True', 'blank': 'True'}),
+            'date_modified': ('django.db.models.fields.DateTimeField', [], {'auto_now': 'True', 'null': 'True', 'blank': 'True'}),
+            'description': ('django.db.models.fields.TextField', [], {'blank': 'True'}),
+            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
+            'items': ('django.db.models.fields.related.ManyToManyField', [], {'blank': 'True', 'related_name': "'selections'", 'null': 'True', 'symmetrical': 'False', 'to': "orm['timeside.Item']"}),
+            'selections': ('django.db.models.fields.related.ManyToManyField', [], {'blank': 'True', 'related_name': "'other_selections'", 'null': 'True', 'symmetrical': 'False', 'to': "orm['timeside.Selection']"}),
+            'title': ('django.db.models.fields.CharField', [], {'max_length': '512', 'blank': 'True'}),
+            'uuid': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '512', 'blank': 'True'})
+        },
+        'timeside.task': {
+            'Meta': {'object_name': 'Task', 'db_table': "'timeside_tasks'"},
+            'author': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'tasks'", 'null': 'True', 'on_delete': 'models.SET_NULL', 'to': "orm['auth.User']"}),
+            'experience': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'task'", 'null': 'True', 'to': "orm['timeside.Experience']"}),
+            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
+            'selection': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'task'", 'null': 'True', 'to': "orm['timeside.Selection']"}),
+            'status': ('django.db.models.fields.IntegerField', [], {'default': '1'})
+        }
+    }
+
+    complete_apps = ['timeside']
\ No newline at end of file
diff --git a/timeside/server/migrations/0004_auto__del_field_result_processor__add_field_result_parameters.py b/timeside/server/migrations/0004_auto__del_field_result_processor__add_field_result_parameters.py
new file mode 100644 (file)
index 0000000..6b03bcf
--- /dev/null
@@ -0,0 +1,144 @@
+# -*- coding: utf-8 -*-
+from south.utils import datetime_utils as datetime
+from south.db import db
+from south.v2 import SchemaMigration
+from django.db import models
+
+
+class Migration(SchemaMigration):
+
+    def forwards(self, orm):
+        # Deleting field 'Result.processor'
+        db.delete_column('timeside_results', 'processor_id')
+
+        # Adding field 'Result.parameters'
+        db.add_column('timeside_results', 'parameters',
+                      self.gf('django.db.models.fields.related.ForeignKey')(blank=True, related_name='results', null=True, on_delete=models.SET_NULL, to=orm['timeside.Parameters']),
+                      keep_default=False)
+
+
+    def backwards(self, orm):
+        # Adding field 'Result.processor'
+        db.add_column('timeside_results', 'processor',
+                      self.gf('django.db.models.fields.related.ForeignKey')(related_name='results', null=True, to=orm['timeside.Processor'], on_delete=models.SET_NULL, blank=True),
+                      keep_default=False)
+
+        # Deleting field 'Result.parameters'
+        db.delete_column('timeside_results', 'parameters_id')
+
+
+    models = {
+        'auth.group': {
+            'Meta': {'object_name': 'Group'},
+            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
+            'name': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '80'}),
+            'permissions': ('django.db.models.fields.related.ManyToManyField', [], {'to': "orm['auth.Permission']", 'symmetrical': 'False', 'blank': 'True'})
+        },
+        'auth.permission': {
+            'Meta': {'ordering': "('content_type__app_label', 'content_type__model', 'codename')", 'unique_together': "(('content_type', 'codename'),)", 'object_name': 'Permission'},
+            'codename': ('django.db.models.fields.CharField', [], {'max_length': '100'}),
+            'content_type': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['contenttypes.ContentType']"}),
+            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
+            'name': ('django.db.models.fields.CharField', [], {'max_length': '50'})
+        },
+        'auth.user': {
+            'Meta': {'object_name': 'User'},
+            'date_joined': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime.now'}),
+            'email': ('django.db.models.fields.EmailField', [], {'max_length': '75', 'blank': 'True'}),
+            'first_name': ('django.db.models.fields.CharField', [], {'max_length': '30', 'blank': 'True'}),
+            'groups': ('django.db.models.fields.related.ManyToManyField', [], {'to': "orm['auth.Group']", 'symmetrical': 'False', 'blank': 'True'}),
+            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
+            'is_active': ('django.db.models.fields.BooleanField', [], {'default': 'True'}),
+            'is_staff': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
+            'is_superuser': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
+            'last_login': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime.now'}),
+            'last_name': ('django.db.models.fields.CharField', [], {'max_length': '30', 'blank': 'True'}),
+            'password': ('django.db.models.fields.CharField', [], {'max_length': '128'}),
+            'user_permissions': ('django.db.models.fields.related.ManyToManyField', [], {'to': "orm['auth.Permission']", 'symmetrical': 'False', 'blank': 'True'}),
+            'username': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '30'})
+        },
+        'contenttypes.contenttype': {
+            'Meta': {'ordering': "('name',)", 'unique_together': "(('app_label', 'model'),)", 'object_name': 'ContentType', 'db_table': "'django_content_type'"},
+            'app_label': ('django.db.models.fields.CharField', [], {'max_length': '100'}),
+            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
+            'model': ('django.db.models.fields.CharField', [], {'max_length': '100'}),
+            'name': ('django.db.models.fields.CharField', [], {'max_length': '100'})
+        },
+        'timeside.experience': {
+            'Meta': {'object_name': 'Experience', 'db_table': "'timeside_experiences'"},
+            'author': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'experiences'", 'null': 'True', 'on_delete': 'models.SET_NULL', 'to': "orm['auth.User']"}),
+            'date_added': ('django.db.models.fields.DateTimeField', [], {'auto_now_add': 'True', 'blank': 'True'}),
+            'date_modified': ('django.db.models.fields.DateTimeField', [], {'auto_now': 'True', 'null': 'True', 'blank': 'True'}),
+            'description': ('django.db.models.fields.TextField', [], {'blank': 'True'}),
+            'experiences': ('django.db.models.fields.related.ManyToManyField', [], {'blank': 'True', 'related_name': "'other_experiences'", 'null': 'True', 'symmetrical': 'False', 'to': "orm['timeside.Experience']"}),
+            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
+            'is_preset': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
+            'processors': ('django.db.models.fields.related.ManyToManyField', [], {'blank': 'True', 'related_name': "'experiences'", 'null': 'True', 'symmetrical': 'False', 'to': "orm['timeside.Processor']"}),
+            'title': ('django.db.models.fields.CharField', [], {'max_length': '512', 'blank': 'True'}),
+            'uuid': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '512', 'blank': 'True'})
+        },
+        'timeside.item': {
+            'Meta': {'ordering': "['title']", 'object_name': 'Item', 'db_table': "'timeside_items'"},
+            'author': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'items'", 'null': 'True', 'on_delete': 'models.SET_NULL', 'to': "orm['auth.User']"}),
+            'date_added': ('django.db.models.fields.DateTimeField', [], {'auto_now_add': 'True', 'blank': 'True'}),
+            'date_modified': ('django.db.models.fields.DateTimeField', [], {'auto_now': 'True', 'null': 'True', 'blank': 'True'}),
+            'description': ('django.db.models.fields.TextField', [], {'blank': 'True'}),
+            'file': ('django.db.models.fields.files.FileField', [], {'max_length': '1024', 'blank': 'True'}),
+            'hdf5': ('django.db.models.fields.files.FileField', [], {'max_length': '1024', 'blank': 'True'}),
+            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
+            'lock': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
+            'mime_type': ('django.db.models.fields.CharField', [], {'max_length': '256', 'blank': 'True'}),
+            'sha1': ('django.db.models.fields.CharField', [], {'max_length': '512', 'blank': 'True'}),
+            'title': ('django.db.models.fields.CharField', [], {'max_length': '512', 'blank': 'True'}),
+            'url': ('django.db.models.fields.URLField', [], {'max_length': '1024', 'blank': 'True'}),
+            'uuid': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '512', 'blank': 'True'})
+        },
+        'timeside.parameters': {
+            'Meta': {'object_name': 'Parameters'},
+            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
+            'is_preset': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
+            'parameters': ('django.db.models.fields.TextField', [], {'blank': 'True'}),
+            'processor': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'parameters'", 'null': 'True', 'to': "orm['timeside.Processor']"})
+        },
+        'timeside.processor': {
+            'Meta': {'object_name': 'Processor', 'db_table': "'timeside_processors'"},
+            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
+            'pid': ('django.db.models.fields.CharField', [], {'max_length': '256'}),
+            'version': ('django.db.models.fields.CharField', [], {'max_length': '64', 'blank': 'True'})
+        },
+        'timeside.result': {
+            'Meta': {'object_name': 'Result', 'db_table': "'timeside_results'"},
+            'date_added': ('django.db.models.fields.DateTimeField', [], {'auto_now_add': 'True', 'blank': 'True'}),
+            'date_modified': ('django.db.models.fields.DateTimeField', [], {'auto_now': 'True', 'null': 'True', 'blank': 'True'}),
+            'hdf5': ('django.db.models.fields.files.FileField', [], {'max_length': '1024', 'blank': 'True'}),
+            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
+            'item': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'results'", 'null': 'True', 'on_delete': 'models.SET_NULL', 'to': "orm['timeside.Item']"}),
+            'output': ('django.db.models.fields.files.FileField', [], {'max_length': '1024', 'blank': 'True'}),
+            'output_mime_type': ('django.db.models.fields.CharField', [], {'max_length': '256', 'blank': 'True'}),
+            'parameters': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'results'", 'null': 'True', 'on_delete': 'models.SET_NULL', 'to': "orm['timeside.Parameters']"}),
+            'status': ('django.db.models.fields.IntegerField', [], {'default': '1'}),
+            'uuid': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '512', 'blank': 'True'})
+        },
+        'timeside.selection': {
+            'Meta': {'object_name': 'Selection', 'db_table': "'timeside_selections'"},
+            'author': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'selections'", 'null': 'True', 'on_delete': 'models.SET_NULL', 'to': "orm['auth.User']"}),
+            'date_added': ('django.db.models.fields.DateTimeField', [], {'auto_now_add': 'True', 'blank': 'True'}),
+            'date_modified': ('django.db.models.fields.DateTimeField', [], {'auto_now': 'True', 'null': 'True', 'blank': 'True'}),
+            'description': ('django.db.models.fields.TextField', [], {'blank': 'True'}),
+            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
+            'items': ('django.db.models.fields.related.ManyToManyField', [], {'blank': 'True', 'related_name': "'selections'", 'null': 'True', 'symmetrical': 'False', 'to': "orm['timeside.Item']"}),
+            'selections': ('django.db.models.fields.related.ManyToManyField', [], {'blank': 'True', 'related_name': "'other_selections'", 'null': 'True', 'symmetrical': 'False', 'to': "orm['timeside.Selection']"}),
+            'title': ('django.db.models.fields.CharField', [], {'max_length': '512', 'blank': 'True'}),
+            'uuid': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '512', 'blank': 'True'})
+        },
+        'timeside.task': {
+            'Meta': {'object_name': 'Task', 'db_table': "'timeside_tasks'"},
+            'author': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'tasks'", 'null': 'True', 'on_delete': 'models.SET_NULL', 'to': "orm['auth.User']"}),
+            'experience': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'task'", 'null': 'True', 'to': "orm['timeside.Experience']"}),
+            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
+            'selection': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'task'", 'null': 'True', 'to': "orm['timeside.Selection']"}),
+            'status': ('django.db.models.fields.IntegerField', [], {'default': '1'})
+        }
+    }
+
+    complete_apps = ['timeside']
\ No newline at end of file
diff --git a/timeside/server/migrations/0005_auto__del_field_result_output_mime_type__del_field_result_output__add_.py b/timeside/server/migrations/0005_auto__del_field_result_output_mime_type__del_field_result_output__add_.py
new file mode 100644 (file)
index 0000000..64dd868
--- /dev/null
@@ -0,0 +1,166 @@
+# -*- coding: utf-8 -*-
+from south.utils import datetime_utils as datetime
+from south.db import db
+from south.v2 import SchemaMigration
+from django.db import models
+
+
+class Migration(SchemaMigration):
+
+    def forwards(self, orm):
+        # Deleting field 'Result.output_mime_type'
+        db.delete_column('timeside_results', 'output_mime_type')
+
+        # Deleting field 'Result.output'
+        db.delete_column('timeside_results', 'output')
+
+        # Adding field 'Result.file'
+        db.add_column('timeside_results', 'file',
+                      self.gf('django.db.models.fields.files.FileField')(max_length=1024, null=True, blank=True),
+                      keep_default=False)
+
+        # Adding field 'Result.mime_type'
+        db.add_column('timeside_results', 'mime_type',
+                      self.gf('django.db.models.fields.CharField')(default='', max_length=256, blank=True),
+                      keep_default=False)
+
+
+        # Changing field 'Result.hdf5'
+        db.alter_column('timeside_results', 'hdf5', self.gf('django.db.models.fields.files.FileField')(max_length=1024, null=True))
+
+    def backwards(self, orm):
+        # Adding field 'Result.output_mime_type'
+        db.add_column('timeside_results', 'output_mime_type',
+                      self.gf('django.db.models.fields.CharField')(default='', max_length=256, blank=True),
+                      keep_default=False)
+
+        # Adding field 'Result.output'
+        db.add_column('timeside_results', 'output',
+                      self.gf('django.db.models.fields.files.FileField')(default='foo.bar', max_length=1024, blank=True),
+                      keep_default=False)
+
+        # Deleting field 'Result.file'
+        db.delete_column('timeside_results', 'file')
+
+        # Deleting field 'Result.mime_type'
+        db.delete_column('timeside_results', 'mime_type')
+
+
+        # Changing field 'Result.hdf5'
+        db.alter_column('timeside_results', 'hdf5', self.gf('django.db.models.fields.files.FileField')(default='foo.bar', max_length=1024))
+
+    models = {
+        'auth.group': {
+            'Meta': {'object_name': 'Group'},
+            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
+            'name': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '80'}),
+            'permissions': ('django.db.models.fields.related.ManyToManyField', [], {'to': "orm['auth.Permission']", 'symmetrical': 'False', 'blank': 'True'})
+        },
+        'auth.permission': {
+            'Meta': {'ordering': "('content_type__app_label', 'content_type__model', 'codename')", 'unique_together': "(('content_type', 'codename'),)", 'object_name': 'Permission'},
+            'codename': ('django.db.models.fields.CharField', [], {'max_length': '100'}),
+            'content_type': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['contenttypes.ContentType']"}),
+            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
+            'name': ('django.db.models.fields.CharField', [], {'max_length': '50'})
+        },
+        'auth.user': {
+            'Meta': {'object_name': 'User'},
+            'date_joined': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime.now'}),
+            'email': ('django.db.models.fields.EmailField', [], {'max_length': '75', 'blank': 'True'}),
+            'first_name': ('django.db.models.fields.CharField', [], {'max_length': '30', 'blank': 'True'}),
+            'groups': ('django.db.models.fields.related.ManyToManyField', [], {'to': "orm['auth.Group']", 'symmetrical': 'False', 'blank': 'True'}),
+            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
+            'is_active': ('django.db.models.fields.BooleanField', [], {'default': 'True'}),
+            'is_staff': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
+            'is_superuser': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
+            'last_login': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime.now'}),
+            'last_name': ('django.db.models.fields.CharField', [], {'max_length': '30', 'blank': 'True'}),
+            'password': ('django.db.models.fields.CharField', [], {'max_length': '128'}),
+            'user_permissions': ('django.db.models.fields.related.ManyToManyField', [], {'to': "orm['auth.Permission']", 'symmetrical': 'False', 'blank': 'True'}),
+            'username': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '30'})
+        },
+        'contenttypes.contenttype': {
+            'Meta': {'ordering': "('name',)", 'unique_together': "(('app_label', 'model'),)", 'object_name': 'ContentType', 'db_table': "'django_content_type'"},
+            'app_label': ('django.db.models.fields.CharField', [], {'max_length': '100'}),
+            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
+            'model': ('django.db.models.fields.CharField', [], {'max_length': '100'}),
+            'name': ('django.db.models.fields.CharField', [], {'max_length': '100'})
+        },
+        'timeside.experience': {
+            'Meta': {'object_name': 'Experience', 'db_table': "'timeside_experiences'"},
+            'author': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'experiences'", 'null': 'True', 'on_delete': 'models.SET_NULL', 'to': "orm['auth.User']"}),
+            'date_added': ('django.db.models.fields.DateTimeField', [], {'auto_now_add': 'True', 'blank': 'True'}),
+            'date_modified': ('django.db.models.fields.DateTimeField', [], {'auto_now': 'True', 'null': 'True', 'blank': 'True'}),
+            'description': ('django.db.models.fields.TextField', [], {'blank': 'True'}),
+            'experiences': ('django.db.models.fields.related.ManyToManyField', [], {'blank': 'True', 'related_name': "'other_experiences'", 'null': 'True', 'symmetrical': 'False', 'to': "orm['timeside.Experience']"}),
+            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
+            'is_preset': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
+            'processors': ('django.db.models.fields.related.ManyToManyField', [], {'blank': 'True', 'related_name': "'experiences'", 'null': 'True', 'symmetrical': 'False', 'to': "orm['timeside.Processor']"}),
+            'title': ('django.db.models.fields.CharField', [], {'max_length': '512', 'blank': 'True'}),
+            'uuid': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '512', 'blank': 'True'})
+        },
+        'timeside.item': {
+            'Meta': {'ordering': "['title']", 'object_name': 'Item', 'db_table': "'timeside_items'"},
+            'author': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'items'", 'null': 'True', 'on_delete': 'models.SET_NULL', 'to': "orm['auth.User']"}),
+            'date_added': ('django.db.models.fields.DateTimeField', [], {'auto_now_add': 'True', 'blank': 'True'}),
+            'date_modified': ('django.db.models.fields.DateTimeField', [], {'auto_now': 'True', 'null': 'True', 'blank': 'True'}),
+            'description': ('django.db.models.fields.TextField', [], {'blank': 'True'}),
+            'file': ('django.db.models.fields.files.FileField', [], {'max_length': '1024', 'blank': 'True'}),
+            'hdf5': ('django.db.models.fields.files.FileField', [], {'max_length': '1024', 'blank': 'True'}),
+            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
+            'lock': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
+            'mime_type': ('django.db.models.fields.CharField', [], {'max_length': '256', 'blank': 'True'}),
+            'sha1': ('django.db.models.fields.CharField', [], {'max_length': '512', 'blank': 'True'}),
+            'title': ('django.db.models.fields.CharField', [], {'max_length': '512', 'blank': 'True'}),
+            'url': ('django.db.models.fields.URLField', [], {'max_length': '1024', 'blank': 'True'}),
+            'uuid': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '512', 'blank': 'True'})
+        },
+        'timeside.parameters': {
+            'Meta': {'object_name': 'Parameters'},
+            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
+            'is_preset': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
+            'parameters': ('django.db.models.fields.TextField', [], {'blank': 'True'}),
+            'processor': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'parameters'", 'null': 'True', 'to': "orm['timeside.Processor']"})
+        },
+        'timeside.processor': {
+            'Meta': {'object_name': 'Processor', 'db_table': "'timeside_processors'"},
+            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
+            'pid': ('django.db.models.fields.CharField', [], {'max_length': '256'}),
+            'version': ('django.db.models.fields.CharField', [], {'max_length': '64', 'blank': 'True'})
+        },
+        'timeside.result': {
+            'Meta': {'object_name': 'Result', 'db_table': "'timeside_results'"},
+            'date_added': ('django.db.models.fields.DateTimeField', [], {'auto_now_add': 'True', 'blank': 'True'}),
+            'date_modified': ('django.db.models.fields.DateTimeField', [], {'auto_now': 'True', 'null': 'True', 'blank': 'True'}),
+            'file': ('django.db.models.fields.files.FileField', [], {'max_length': '1024', 'null': 'True', 'blank': 'True'}),
+            'hdf5': ('django.db.models.fields.files.FileField', [], {'max_length': '1024', 'null': 'True', 'blank': 'True'}),
+            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
+            'item': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'results'", 'null': 'True', 'on_delete': 'models.SET_NULL', 'to': "orm['timeside.Item']"}),
+            'mime_type': ('django.db.models.fields.CharField', [], {'max_length': '256', 'blank': 'True'}),
+            'parameters': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'results'", 'null': 'True', 'on_delete': 'models.SET_NULL', 'to': "orm['timeside.Parameters']"}),
+            'status': ('django.db.models.fields.IntegerField', [], {'default': '1'}),
+            'uuid': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '512', 'blank': 'True'})
+        },
+        'timeside.selection': {
+            'Meta': {'object_name': 'Selection', 'db_table': "'timeside_selections'"},
+            'author': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'selections'", 'null': 'True', 'on_delete': 'models.SET_NULL', 'to': "orm['auth.User']"}),
+            'date_added': ('django.db.models.fields.DateTimeField', [], {'auto_now_add': 'True', 'blank': 'True'}),
+            'date_modified': ('django.db.models.fields.DateTimeField', [], {'auto_now': 'True', 'null': 'True', 'blank': 'True'}),
+            'description': ('django.db.models.fields.TextField', [], {'blank': 'True'}),
+            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
+            'items': ('django.db.models.fields.related.ManyToManyField', [], {'blank': 'True', 'related_name': "'selections'", 'null': 'True', 'symmetrical': 'False', 'to': "orm['timeside.Item']"}),
+            'selections': ('django.db.models.fields.related.ManyToManyField', [], {'blank': 'True', 'related_name': "'other_selections'", 'null': 'True', 'symmetrical': 'False', 'to': "orm['timeside.Selection']"}),
+            'title': ('django.db.models.fields.CharField', [], {'max_length': '512', 'blank': 'True'}),
+            'uuid': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '512', 'blank': 'True'})
+        },
+        'timeside.task': {
+            'Meta': {'object_name': 'Task', 'db_table': "'timeside_tasks'"},
+            'author': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'tasks'", 'null': 'True', 'on_delete': 'models.SET_NULL', 'to': "orm['auth.User']"}),
+            'experience': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'task'", 'null': 'True', 'to': "orm['timeside.Experience']"}),
+            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
+            'selection': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'task'", 'null': 'True', 'to': "orm['timeside.Selection']"}),
+            'status': ('django.db.models.fields.IntegerField', [], {'default': '1'})
+        }
+    }
+
+    complete_apps = ['timeside']
\ No newline at end of file
diff --git a/timeside/server/migrations/0006_auto__del_parameters__add_preset__del_field_result_parameters__add_fie.py b/timeside/server/migrations/0006_auto__del_parameters__add_preset__del_field_result_parameters__add_fie.py
new file mode 100644 (file)
index 0000000..5f9d3fe
--- /dev/null
@@ -0,0 +1,220 @@
+# -*- coding: utf-8 -*-
+from south.utils import datetime_utils as datetime
+from south.db import db
+from south.v2 import SchemaMigration
+from django.db import models
+
+
+class Migration(SchemaMigration):
+
+    def forwards(self, orm):
+        # Deleting model 'Parameters'
+        db.delete_table('timeside_parameters')
+
+        # Adding model 'Preset'
+        db.create_table('timeside_presets', (
+            ('id', self.gf('django.db.models.fields.AutoField')(primary_key=True)),
+            ('processor', self.gf('django.db.models.fields.related.ForeignKey')(blank=True, related_name='preset', null=True, to=orm['timeside.Processor'])),
+            ('parameters', self.gf('django.db.models.fields.TextField')(blank=True)),
+            ('is_public', self.gf('django.db.models.fields.BooleanField')(default=False)),
+        ))
+        db.send_create_signal('timeside', ['Preset'])
+
+        # Deleting field 'Result.parameters'
+        db.delete_column('timeside_results', 'parameters_id')
+
+        # Adding field 'Result.preset'
+        db.add_column('timeside_results', 'preset',
+                      self.gf('django.db.models.fields.related.ForeignKey')(blank=True, related_name='results', null=True, on_delete=models.SET_NULL, to=orm['timeside.Preset']),
+                      keep_default=False)
+
+
+        # Changing field 'Result.hdf5'
+        db.alter_column('timeside_results', 'hdf5', self.gf('django.db.models.fields.files.FileField')(default=0, max_length=1024))
+
+        # Changing field 'Result.file'
+        db.alter_column('timeside_results', 'file', self.gf('django.db.models.fields.files.FileField')(default=0, max_length=1024))
+        # Deleting field 'Experience.is_preset'
+        db.delete_column('timeside_experiences', 'is_preset')
+
+        # Adding field 'Experience.is_public'
+        db.add_column('timeside_experiences', 'is_public',
+                      self.gf('django.db.models.fields.BooleanField')(default=False),
+                      keep_default=False)
+
+        # Removing M2M table for field processors on 'Experience'
+        db.delete_table(db.shorten_name('timeside_experiences_processors'))
+
+        # Adding M2M table for field presets on 'Experience'
+        m2m_table_name = db.shorten_name('timeside_experiences_presets')
+        db.create_table(m2m_table_name, (
+            ('id', models.AutoField(verbose_name='ID', primary_key=True, auto_created=True)),
+            ('experience', models.ForeignKey(orm['timeside.experience'], null=False)),
+            ('preset', models.ForeignKey(orm['timeside.preset'], null=False))
+        ))
+        db.create_unique(m2m_table_name, ['experience_id', 'preset_id'])
+
+
+    def backwards(self, orm):
+        # Adding model 'Parameters'
+        db.create_table('timeside_parameters', (
+            ('parameters', self.gf('django.db.models.fields.TextField')(blank=True)),
+            ('id', self.gf('django.db.models.fields.AutoField')(primary_key=True)),
+            ('is_preset', self.gf('django.db.models.fields.BooleanField')(default=False)),
+            ('processor', self.gf('django.db.models.fields.related.ForeignKey')(related_name='parameters', null=True, to=orm['timeside.Processor'], blank=True)),
+        ))
+        db.send_create_signal('timeside', ['Parameters'])
+
+        # Deleting model 'Preset'
+        db.delete_table('timeside_presets')
+
+        # Adding field 'Result.parameters'
+        db.add_column('timeside_results', 'parameters',
+                      self.gf('django.db.models.fields.related.ForeignKey')(related_name='results', null=True, to=orm['timeside.Parameters'], on_delete=models.SET_NULL, blank=True),
+                      keep_default=False)
+
+        # Deleting field 'Result.preset'
+        db.delete_column('timeside_results', 'preset_id')
+
+
+        # Changing field 'Result.hdf5'
+        db.alter_column('timeside_results', 'hdf5', self.gf('django.db.models.fields.files.FileField')(max_length=1024, null=True))
+
+        # Changing field 'Result.file'
+        db.alter_column('timeside_results', 'file', self.gf('django.db.models.fields.files.FileField')(max_length=1024, null=True))
+        # Adding field 'Experience.is_preset'
+        db.add_column('timeside_experiences', 'is_preset',
+                      self.gf('django.db.models.fields.BooleanField')(default=False),
+                      keep_default=False)
+
+        # Deleting field 'Experience.is_public'
+        db.delete_column('timeside_experiences', 'is_public')
+
+        # Adding M2M table for field processors on 'Experience'
+        m2m_table_name = db.shorten_name('timeside_experiences_processors')
+        db.create_table(m2m_table_name, (
+            ('id', models.AutoField(verbose_name='ID', primary_key=True, auto_created=True)),
+            ('experience', models.ForeignKey(orm['timeside.experience'], null=False)),
+            ('processor', models.ForeignKey(orm['timeside.processor'], null=False))
+        ))
+        db.create_unique(m2m_table_name, ['experience_id', 'processor_id'])
+
+        # Removing M2M table for field presets on 'Experience'
+        db.delete_table(db.shorten_name('timeside_experiences_presets'))
+
+
+    models = {
+        'auth.group': {
+            'Meta': {'object_name': 'Group'},
+            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
+            'name': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '80'}),
+            'permissions': ('django.db.models.fields.related.ManyToManyField', [], {'to': "orm['auth.Permission']", 'symmetrical': 'False', 'blank': 'True'})
+        },
+        'auth.permission': {
+            'Meta': {'ordering': "('content_type__app_label', 'content_type__model', 'codename')", 'unique_together': "(('content_type', 'codename'),)", 'object_name': 'Permission'},
+            'codename': ('django.db.models.fields.CharField', [], {'max_length': '100'}),
+            'content_type': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['contenttypes.ContentType']"}),
+            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
+            'name': ('django.db.models.fields.CharField', [], {'max_length': '50'})
+        },
+        'auth.user': {
+            'Meta': {'object_name': 'User'},
+            'date_joined': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime.now'}),
+            'email': ('django.db.models.fields.EmailField', [], {'max_length': '75', 'blank': 'True'}),
+            'first_name': ('django.db.models.fields.CharField', [], {'max_length': '30', 'blank': 'True'}),
+            'groups': ('django.db.models.fields.related.ManyToManyField', [], {'to': "orm['auth.Group']", 'symmetrical': 'False', 'blank': 'True'}),
+            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
+            'is_active': ('django.db.models.fields.BooleanField', [], {'default': 'True'}),
+            'is_staff': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
+            'is_superuser': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
+            'last_login': ('django.db.models.fields.DateTimeField', [], {'default': 'datetime.datetime.now'}),
+            'last_name': ('django.db.models.fields.CharField', [], {'max_length': '30', 'blank': 'True'}),
+            'password': ('django.db.models.fields.CharField', [], {'max_length': '128'}),
+            'user_permissions': ('django.db.models.fields.related.ManyToManyField', [], {'to': "orm['auth.Permission']", 'symmetrical': 'False', 'blank': 'True'}),
+            'username': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '30'})
+        },
+        'contenttypes.contenttype': {
+            'Meta': {'ordering': "('name',)", 'unique_together': "(('app_label', 'model'),)", 'object_name': 'ContentType', 'db_table': "'django_content_type'"},
+            'app_label': ('django.db.models.fields.CharField', [], {'max_length': '100'}),
+            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
+            'model': ('django.db.models.fields.CharField', [], {'max_length': '100'}),
+            'name': ('django.db.models.fields.CharField', [], {'max_length': '100'})
+        },
+        'timeside.experience': {
+            'Meta': {'object_name': 'Experience', 'db_table': "'timeside_experiences'"},
+            'author': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'experiences'", 'null': 'True', 'on_delete': 'models.SET_NULL', 'to': "orm['auth.User']"}),
+            'date_added': ('django.db.models.fields.DateTimeField', [], {'auto_now_add': 'True', 'blank': 'True'}),
+            'date_modified': ('django.db.models.fields.DateTimeField', [], {'auto_now': 'True', 'null': 'True', 'blank': 'True'}),
+            'description': ('django.db.models.fields.TextField', [], {'blank': 'True'}),
+            'experiences': ('django.db.models.fields.related.ManyToManyField', [], {'blank': 'True', 'related_name': "'other_experiences'", 'null': 'True', 'symmetrical': 'False', 'to': "orm['timeside.Experience']"}),
+            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
+            'is_public': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
+            'presets': ('django.db.models.fields.related.ManyToManyField', [], {'blank': 'True', 'related_name': "'experiences'", 'null': 'True', 'symmetrical': 'False', 'to': "orm['timeside.Preset']"}),
+            'title': ('django.db.models.fields.CharField', [], {'max_length': '512', 'blank': 'True'}),
+            'uuid': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '512', 'blank': 'True'})
+        },
+        'timeside.item': {
+            'Meta': {'ordering': "['title']", 'object_name': 'Item', 'db_table': "'timeside_items'"},
+            'author': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'items'", 'null': 'True', 'on_delete': 'models.SET_NULL', 'to': "orm['auth.User']"}),
+            'date_added': ('django.db.models.fields.DateTimeField', [], {'auto_now_add': 'True', 'blank': 'True'}),
+            'date_modified': ('django.db.models.fields.DateTimeField', [], {'auto_now': 'True', 'null': 'True', 'blank': 'True'}),
+            'description': ('django.db.models.fields.TextField', [], {'blank': 'True'}),
+            'file': ('django.db.models.fields.files.FileField', [], {'max_length': '1024', 'blank': 'True'}),
+            'hdf5': ('django.db.models.fields.files.FileField', [], {'max_length': '1024', 'blank': 'True'}),
+            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
+            'lock': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
+            'mime_type': ('django.db.models.fields.CharField', [], {'max_length': '256', 'blank': 'True'}),
+            'sha1': ('django.db.models.fields.CharField', [], {'max_length': '512', 'blank': 'True'}),
+            'title': ('django.db.models.fields.CharField', [], {'max_length': '512', 'blank': 'True'}),
+            'url': ('django.db.models.fields.URLField', [], {'max_length': '1024', 'blank': 'True'}),
+            'uuid': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '512', 'blank': 'True'})
+        },
+        'timeside.preset': {
+            'Meta': {'object_name': 'Preset', 'db_table': "'timeside_presets'"},
+            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
+            'is_public': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
+            'parameters': ('django.db.models.fields.TextField', [], {'blank': 'True'}),
+            'processor': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'preset'", 'null': 'True', 'to': "orm['timeside.Processor']"})
+        },
+        'timeside.processor': {
+            'Meta': {'object_name': 'Processor', 'db_table': "'timeside_processors'"},
+            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
+            'pid': ('django.db.models.fields.CharField', [], {'max_length': '256'}),
+            'version': ('django.db.models.fields.CharField', [], {'max_length': '64', 'blank': 'True'})
+        },
+        'timeside.result': {
+            'Meta': {'object_name': 'Result', 'db_table': "'timeside_results'"},
+            'date_added': ('django.db.models.fields.DateTimeField', [], {'auto_now_add': 'True', 'blank': 'True'}),
+            'date_modified': ('django.db.models.fields.DateTimeField', [], {'auto_now': 'True', 'null': 'True', 'blank': 'True'}),
+            'file': ('django.db.models.fields.files.FileField', [], {'max_length': '1024', 'blank': 'True'}),
+            'hdf5': ('django.db.models.fields.files.FileField', [], {'max_length': '1024', 'blank': 'True'}),
+            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
+            'item': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'results'", 'null': 'True', 'on_delete': 'models.SET_NULL', 'to': "orm['timeside.Item']"}),
+            'mime_type': ('django.db.models.fields.CharField', [], {'max_length': '256', 'blank': 'True'}),
+            'preset': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'results'", 'null': 'True', 'on_delete': 'models.SET_NULL', 'to': "orm['timeside.Preset']"}),
+            'status': ('django.db.models.fields.IntegerField', [], {'default': '1'}),
+            'uuid': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '512', 'blank': 'True'})
+        },
+        'timeside.selection': {
+            'Meta': {'object_name': 'Selection', 'db_table': "'timeside_selections'"},
+            'author': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'selections'", 'null': 'True', 'on_delete': 'models.SET_NULL', 'to': "orm['auth.User']"}),
+            'date_added': ('django.db.models.fields.DateTimeField', [], {'auto_now_add': 'True', 'blank': 'True'}),
+            'date_modified': ('django.db.models.fields.DateTimeField', [], {'auto_now': 'True', 'null': 'True', 'blank': 'True'}),
+            'description': ('django.db.models.fields.TextField', [], {'blank': 'True'}),
+            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
+            'items': ('django.db.models.fields.related.ManyToManyField', [], {'blank': 'True', 'related_name': "'selections'", 'null': 'True', 'symmetrical': 'False', 'to': "orm['timeside.Item']"}),
+            'selections': ('django.db.models.fields.related.ManyToManyField', [], {'blank': 'True', 'related_name': "'other_selections'", 'null': 'True', 'symmetrical': 'False', 'to': "orm['timeside.Selection']"}),
+            'title': ('django.db.models.fields.CharField', [], {'max_length': '512', 'blank': 'True'}),
+            'uuid': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '512', 'blank': 'True'})
+        },
+        'timeside.task': {
+            'Meta': {'object_name': 'Task', 'db_table': "'timeside_tasks'"},
+            'author': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'tasks'", 'null': 'True', 'on_delete': 'models.SET_NULL', 'to': "orm['auth.User']"}),
+            'experience': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'task'", 'null': 'True', 'to': "orm['timeside.Experience']"}),
+            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
+            'selection': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'task'", 'null': 'True', 'to': "orm['timeside.Selection']"}),
+            'status': ('django.db.models.fields.IntegerField', [], {'default': '1'})
+        }
+    }
+
+    complete_apps = ['timeside']
\ No newline at end of file
diff --git a/timeside/server/migrations/__init__.py b/timeside/server/migrations/__init__.py
new file mode 100644 (file)
index 0000000..e69de29
diff --git a/timeside/server/models.py b/timeside/server/models.py
new file mode 100644 (file)
index 0000000..65ae129
--- /dev/null
@@ -0,0 +1,262 @@
+# -*- coding: utf-8 -*-
+
+import timeside, os, uuid, time, hashlib, mimetypes
+
+from timeside.analyzer.core import AnalyzerResultContainer, AnalyzerResult
+from timeside.decoder.utils import sha1sum_file
+
+from django.db import models
+from django.utils.translation import ugettext_lazy as _
+from django.contrib.auth.models import User
+from django.db.models.signals import post_save
+from django.conf import settings
+
+app = 'timeside'
+
+processors = timeside.core.processors(timeside.api.IProcessor)
+
+PROCESSOR_PIDS = [(processor.id(), processor.id())  for processor in processors]
+
+STATUS = ((0, _('failed')), (1, _('pending')), (2, _('running')),
+                         (3, _('done')), (4, _('ready')))
+
+def get_mime_type(path):
+    return mimetypes.guess_type(path)[0]
+
+def get_processor(pid):
+    for proc in processors:
+        if proc.id() == pid:
+            return proc()
+    raise ValueError('Processor %s does not exists' % pid) 
+
+def set_mimetype(sender, **kwargs):
+    instance = kwargs['instance']
+    if instance.file:
+        if not instance.mime_type:
+            instance.mime_type = get_mime_type(instance.file.path)
+
+def set_hash(sender, **kwargs):
+    instance = kwargs['instance']
+    if instance.file:
+        if not instance.sha1:
+            instance.sha1 = sha1sum_file(instance.file.path)
+
+class MetaCore:
+
+    app_label = app
+
+
+class BaseResource(models.Model):
+
+    date_added = models.DateTimeField(_('date added'), auto_now_add=True)
+    date_modified = models.DateTimeField(_('date modified'), auto_now=True, null=True)
+    uuid = models.CharField(_('uuid'), unique=True, blank=True, max_length=512, editable=False)
+
+    class Meta(MetaCore):
+        abstract = True
+    
+    def save(self, **kwargs):
+        if not self.uuid:
+            self.uuid = uuid.uuid4()
+        super(BaseResource, self).save(**kwargs)
+
+
+class DocBaseResource(BaseResource):
+
+    title = models.CharField(_('title'), blank=True, max_length=512)
+    description = models.TextField(_('description'), blank=True)
+
+    def __unicode__(self):
+        return self.title    
+    
+    class Meta(MetaCore):
+        abstract = True
+    
+
+class Selection(DocBaseResource):
+
+    items = models.ManyToManyField('Item', related_name="selections", verbose_name=_('items'), blank=True, null=True)
+    author = models.ForeignKey(User, related_name="selections", verbose_name=_('author'), blank=True, null=True, on_delete=models.SET_NULL)
+    selections = models.ManyToManyField('Selection', related_name="other_selections", verbose_name=_('other selections'), blank=True, null=True)
+
+    class Meta(MetaCore):
+        db_table = app + '_selections'
+        verbose_name = _('selection')
+
+
+class Item(DocBaseResource):
+
+    file = models.FileField(_('file'), upload_to='items/%Y/%m/%d', blank=True, max_length=1024)
+    url = models.URLField(_('URL'), blank=True, max_length=1024)
+    sha1 = models.CharField(_('sha1'), blank=True, max_length=512)
+    mime_type = models.CharField(_('mime type'), blank=True, max_length=256)
+    hdf5 = models.FileField(_('HDF5 result file'), upload_to='results/%Y/%m/%d', blank=True, max_length=1024)
+    lock = models.BooleanField(default=False)
+    author = models.ForeignKey(User, related_name="items", verbose_name=_('author'), blank=True, null=True, on_delete=models.SET_NULL)
+
+    class Meta(MetaCore):
+        db_table = app + '_items'
+        ordering = ['title']
+        verbose_name = _('item')
+
+    def results(self):
+        return [result for result in self.results.all()]
+
+    def lock_setter(self, lock):
+        self.lock = lock
+        self.save()
+
+
+class Experience(DocBaseResource):
+
+    presets = models.ManyToManyField('Preset', related_name="experiences", verbose_name=_('presets'), blank=True, null=True)
+    author = models.ForeignKey(User, related_name="experiences", verbose_name=_('author'), blank=True, null=True, on_delete=models.SET_NULL)
+    experiences = models.ManyToManyField('Experience', related_name="other_experiences", verbose_name=_('other experiences'), blank=True, null=True)
+    is_public = models.BooleanField(default=False)
+
+    class Meta(MetaCore):
+        db_table = app + '_experiences'
+        verbose_name = _('Experience')
+
+
+class Processor(models.Model):
+    
+    pid = models.CharField(_('pid'), choices=PROCESSOR_PIDS, max_length=256)
+    version = models.CharField(_('version'), max_length=64, blank=True)
+
+    class Meta(MetaCore):
+        db_table = app + '_processors'
+        verbose_name = _('processor')
+
+    def __unicode__(self):
+        return '_'.join([self.pid, str(self.id)])
+    
+    def save(self, **kwargs):
+        if not self.version:
+            self.version = timeside.__version__
+        super(Processor, self).save(**kwargs)
+        
+
+class Preset(models.Model):
+
+    processor = models.ForeignKey('Processor', related_name="presets", verbose_name=_('processor'), blank=True, null=True)
+    parameters = models.TextField(_('Parameters'), blank=True)
+    is_public = models.BooleanField(default=False)
+
+    class Meta(MetaCore):
+        db_table = app + '_presets'
+        verbose_name = _('Preset')
+        verbose_name_plural = _('Presets')
+
+    def __unicode__(self):
+        return '_'.join([unicode(self.processor), str(self.id)])
+
+    
+class Result(BaseResource):
+
+    item = models.ForeignKey('Item', related_name="results", verbose_name=_('item'), blank=True, null=True, on_delete=models.SET_NULL)
+    preset = models.ForeignKey('Preset', related_name="results", verbose_name=_('preset'), blank=True, null=True, on_delete=models.SET_NULL)
+    hdf5 = models.FileField(_('HDF5 result file'), upload_to='results/%Y/%m/%d', blank=True, max_length=1024)
+    file = models.FileField(_('Output file'), upload_to='results/%Y/%m/%d', blank=True, max_length=1024)
+    mime_type = models.CharField(_('Output file MIME type'), blank=True, max_length=256)
+    status = models.IntegerField(_('status'), choices=STATUS, default=1)
+    
+    class Meta(MetaCore):
+        db_table = app + '_results'
+        verbose_name = _('Result')
+        verbose_name_plural = _('Results')
+
+    def status_setter(self, status):
+        self.status = status
+        self.save()
+
+    def __unicode__(self):
+        return '_'.join([self.item.title, unicode(self.parameters.processor)])
+
+
+class Task(models.Model):
+
+    experience = models.ForeignKey('Experience', related_name="task", verbose_name=_('experience'), blank=True, null=True)
+    selection = models.ForeignKey('Selection', related_name="task", verbose_name=_('selection'), blank=True, null=True)
+    status = models.IntegerField(_('status'), choices=STATUS, default=1)
+    author = models.ForeignKey(User, related_name="tasks", verbose_name=_('author'), blank=True, null=True, on_delete=models.SET_NULL)    
+
+    class Meta(MetaCore):
+        db_table = app + '_tasks'
+        verbose_name = _('Task')
+        verbose_name_plural = _('Tasks')
+
+    def __unicode__(self):
+        return '_'.join([unicode(self.experience), unicode(self.id)])
+
+    def status_setter(self, status):
+        self.status = status
+        self.save()
+
+    def run(self):
+        results_root = 'results'
+        if not os.path.exists(settings.MEDIA_ROOT + results_root):
+            os.makedirs(settings.MEDIA_ROOT + results_root)
+
+        self.status_setter(2)
+
+        for item in self.selection.items.all():
+            path = results_root + os.sep + item.uuid + os.sep
+            if not os.path.exists(settings.MEDIA_ROOT + os.sep + path):
+                os.makedirs(settings.MEDIA_ROOT + os.sep + path)
+            
+            # pipe = timeside.decoder.FileDecoder(item.file.path, sha1=item.sha1)
+            pipe = timeside.decoder.FileDecoder(item.file.path)
+            
+            proc_dict = {}
+
+            for preset in self.experience.presets.all():
+                proc = get_processor(preset.processor.pid)
+                proc_dict[preset.processor] = proc
+                #proc.set_parameters(preset.parameters)
+                pipe = pipe | proc
+
+            # while item.lock:
+            #     time.sleep(30)
+            
+            if not item.hdf5:
+                item.hdf5 =  path + item.uuid + '.hdf5'
+                item.save()
+
+            pipe.run()
+            item.lock_setter(True)
+            pipe.results.to_hdf5(item.hdf5.path)
+            item.lock_setter(False)
+            
+            for processor in proc_dict.keys():
+                proc = proc_dict[processor]
+
+                for processor_id in proc.results.keys():
+                    parameters = proc.results[processor_id].parameters
+                    preset, c = Preset.objects.get_or_create(processor=processor, parameters=unicode(parameters))
+                    result, c = Result.objects.get_or_create(preset=preset, item=item)
+                
+                    if proc.type == 'analyzer':
+                        result.hdf5 = path + item.uuid + '_' + str(proc.UUID) + '.hdf5'
+                        proc.results.to_hdf5(result.hdf5.path)
+                        
+                    if proc.type == 'grapher':
+                        result.file = path + item.uuid + '_' + str(proc.UUID) + '.png'
+                        proc.render(output=result.file)
+                    
+                    result.save()
+            
+            # except:
+            #     self.status_setter(0)
+            #     item.lock_setter(False)
+            #     break
+        
+        self.status_setter(3)
+        del proc
+        del pipe
+
+
+post_save.connect(set_mimetype, sender=Item)
+post_save.connect(set_hash, sender=Item)
+post_save.connect(set_mimetype, sender=Result)
+
diff --git a/timeside/server/sandbox/__init__.py b/timeside/server/sandbox/__init__.py
new file mode 100644 (file)
index 0000000..e69de29
diff --git a/timeside/server/sandbox/diag.sh b/timeside/server/sandbox/diag.sh
new file mode 100755 (executable)
index 0000000..a76eca4
--- /dev/null
@@ -0,0 +1,19 @@
+#!/bin/sh
+
+app="timeside"
+dir="diagram"
+
+if [ ! -d $dir ]; then
+       mkdir $dir
+fi
+
+./manage.py graph_models  -a > $dir/$app-all.dot
+./manage.py graph_models $app > $dir/$app.dot
+
+sed -i '/#\ /d' $dir/$app-all.dot
+sed -i '/#\ /d' $dir/$app.dot
+
+dot $dir/$app-all.dot -Tpdf -o $dir/$app-all.pdf
+dot $dir/$app.dot -Tpdf -o $dir/$app.pdf
+
+rsync -a $dir/ doc.parisson.com:/var/www/files/doc/$app/diagram/
diff --git a/timeside/server/sandbox/diagram/timeside.dot b/timeside/server/sandbox/diagram/timeside.dot
new file mode 100644 (file)
index 0000000..2f04481
--- /dev/null
@@ -0,0 +1,541 @@
+digraph model_graph {
+
+  fontname = "Helvetica"
+  fontsize = 8
+  splines  = true
+
+  node [
+    fontname = "Helvetica"
+    fontsize = 8
+    shape = "plaintext"
+  ]
+
+  edge [
+    fontname = "Helvetica"
+    fontsize = 8
+  ]
+
+
+
+  timeside_models_DocBaseResource [label=<
+    <TABLE BGCOLOR="palegoldenrod" BORDER="0" CELLBORDER="0" CELLSPACING="0">
+    <TR><TD COLSPAN="2" CELLPADDING="4" ALIGN="CENTER" BGCOLOR="olivedrab4">
+    <FONT FACE="Helvetica Bold" COLOR="white">
+    DocBaseResource<BR/>&lt;<FONT FACE="Helvetica Italic">BaseResource</FONT>&gt;
+    </FONT></TD></TR>
+  
+    <TR><TD ALIGN="LEFT" BORDER="0">
+    <FONT COLOR="#7B7B7B" FACE="Helvetica Italic">date_added</FONT>
+    </TD><TD ALIGN="LEFT">
+    <FONT COLOR="#7B7B7B" FACE="Helvetica Italic">DateTimeField</FONT>
+    </TD></TR>
+  
+    <TR><TD ALIGN="LEFT" BORDER="0">
+    <FONT COLOR="#7B7B7B" FACE="Helvetica Italic">date_modified</FONT>
+    </TD><TD ALIGN="LEFT">
+    <FONT COLOR="#7B7B7B" FACE="Helvetica Italic">DateTimeField</FONT>
+    </TD></TR>
+  
+    <TR><TD ALIGN="LEFT" BORDER="0">
+    <FONT COLOR="#7B7B7B" FACE="Helvetica ">description</FONT>
+    </TD><TD ALIGN="LEFT">
+    <FONT COLOR="#7B7B7B" FACE="Helvetica ">TextField</FONT>
+    </TD></TR>
+  
+    <TR><TD ALIGN="LEFT" BORDER="0">
+    <FONT COLOR="#7B7B7B" FACE="Helvetica ">title</FONT>
+    </TD><TD ALIGN="LEFT">
+    <FONT COLOR="#7B7B7B" FACE="Helvetica ">CharField</FONT>
+    </TD></TR>
+  
+    <TR><TD ALIGN="LEFT" BORDER="0">
+    <FONT COLOR="#7B7B7B" FACE="Helvetica Italic">uuid</FONT>
+    </TD><TD ALIGN="LEFT">
+    <FONT COLOR="#7B7B7B" FACE="Helvetica Italic">CharField</FONT>
+    </TD></TR>
+  
+    </TABLE>
+    >]
+
+  timeside_models_BaseResource [label=<
+    <TABLE BGCOLOR="palegoldenrod" BORDER="0" CELLBORDER="0" CELLSPACING="0">
+    <TR><TD COLSPAN="2" CELLPADDING="4" ALIGN="CENTER" BGCOLOR="olivedrab4">
+    <FONT FACE="Helvetica Bold" COLOR="white">
+    BaseResource
+    </FONT></TD></TR>
+  
+    <TR><TD ALIGN="LEFT" BORDER="0">
+    <FONT COLOR="#7B7B7B" FACE="Helvetica ">date_added</FONT>
+    </TD><TD ALIGN="LEFT">
+    <FONT COLOR="#7B7B7B" FACE="Helvetica ">DateTimeField</FONT>
+    </TD></TR>
+  
+    <TR><TD ALIGN="LEFT" BORDER="0">
+    <FONT COLOR="#7B7B7B" FACE="Helvetica ">date_modified</FONT>
+    </TD><TD ALIGN="LEFT">
+    <FONT COLOR="#7B7B7B" FACE="Helvetica ">DateTimeField</FONT>
+    </TD></TR>
+  
+    <TR><TD ALIGN="LEFT" BORDER="0">
+    <FONT COLOR="#7B7B7B" FACE="Helvetica ">uuid</FONT>
+    </TD><TD ALIGN="LEFT">
+    <FONT COLOR="#7B7B7B" FACE="Helvetica ">CharField</FONT>
+    </TD></TR>
+  
+    </TABLE>
+    >]
+
+  timeside_models_Selection [label=<
+    <TABLE BGCOLOR="palegoldenrod" BORDER="0" CELLBORDER="0" CELLSPACING="0">
+    <TR><TD COLSPAN="2" CELLPADDING="4" ALIGN="CENTER" BGCOLOR="olivedrab4">
+    <FONT FACE="Helvetica Bold" COLOR="white">
+    Selection<BR/>&lt;<FONT FACE="Helvetica Italic">DocBaseResource</FONT>&gt;
+    </FONT></TD></TR>
+  
+    <TR><TD ALIGN="LEFT" BORDER="0">
+    <FONT FACE="Helvetica Bold">id</FONT>
+    </TD><TD ALIGN="LEFT">
+    <FONT FACE="Helvetica Bold">AutoField</FONT>
+    </TD></TR>
+  
+    <TR><TD ALIGN="LEFT" BORDER="0">
+    <FONT COLOR="#7B7B7B" FACE="Helvetica Bold">author</FONT>
+    </TD><TD ALIGN="LEFT">
+    <FONT COLOR="#7B7B7B" FACE="Helvetica Bold">ForeignKey (id)</FONT>
+    </TD></TR>
+  
+    <TR><TD ALIGN="LEFT" BORDER="0">
+    <FONT COLOR="#7B7B7B" FACE="Helvetica Italic">date_added</FONT>
+    </TD><TD ALIGN="LEFT">
+    <FONT COLOR="#7B7B7B" FACE="Helvetica Italic">DateTimeField</FONT>
+    </TD></TR>
+  
+    <TR><TD ALIGN="LEFT" BORDER="0">
+    <FONT COLOR="#7B7B7B" FACE="Helvetica Italic">date_modified</FONT>
+    </TD><TD ALIGN="LEFT">
+    <FONT COLOR="#7B7B7B" FACE="Helvetica Italic">DateTimeField</FONT>
+    </TD></TR>
+  
+    <TR><TD ALIGN="LEFT" BORDER="0">
+    <FONT COLOR="#7B7B7B" FACE="Helvetica Italic">description</FONT>
+    </TD><TD ALIGN="LEFT">
+    <FONT COLOR="#7B7B7B" FACE="Helvetica Italic">TextField</FONT>
+    </TD></TR>
+  
+    <TR><TD ALIGN="LEFT" BORDER="0">
+    <FONT COLOR="#7B7B7B" FACE="Helvetica Italic">title</FONT>
+    </TD><TD ALIGN="LEFT">
+    <FONT COLOR="#7B7B7B" FACE="Helvetica Italic">CharField</FONT>
+    </TD></TR>
+  
+    <TR><TD ALIGN="LEFT" BORDER="0">
+    <FONT COLOR="#7B7B7B" FACE="Helvetica Italic">uuid</FONT>
+    </TD><TD ALIGN="LEFT">
+    <FONT COLOR="#7B7B7B" FACE="Helvetica Italic">CharField</FONT>
+    </TD></TR>
+  
+    </TABLE>
+    >]
+
+  timeside_models_Item [label=<
+    <TABLE BGCOLOR="palegoldenrod" BORDER="0" CELLBORDER="0" CELLSPACING="0">
+    <TR><TD COLSPAN="2" CELLPADDING="4" ALIGN="CENTER" BGCOLOR="olivedrab4">
+    <FONT FACE="Helvetica Bold" COLOR="white">
+    Item<BR/>&lt;<FONT FACE="Helvetica Italic">DocBaseResource</FONT>&gt;
+    </FONT></TD></TR>
+  
+    <TR><TD ALIGN="LEFT" BORDER="0">
+    <FONT FACE="Helvetica Bold">id</FONT>
+    </TD><TD ALIGN="LEFT">
+    <FONT FACE="Helvetica Bold">AutoField</FONT>
+    </TD></TR>
+  
+    <TR><TD ALIGN="LEFT" BORDER="0">
+    <FONT COLOR="#7B7B7B" FACE="Helvetica Bold">author</FONT>
+    </TD><TD ALIGN="LEFT">
+    <FONT COLOR="#7B7B7B" FACE="Helvetica Bold">ForeignKey (id)</FONT>
+    </TD></TR>
+  
+    <TR><TD ALIGN="LEFT" BORDER="0">
+    <FONT COLOR="#7B7B7B" FACE="Helvetica Italic">date_added</FONT>
+    </TD><TD ALIGN="LEFT">
+    <FONT COLOR="#7B7B7B" FACE="Helvetica Italic">DateTimeField</FONT>
+    </TD></TR>
+  
+    <TR><TD ALIGN="LEFT" BORDER="0">
+    <FONT COLOR="#7B7B7B" FACE="Helvetica Italic">date_modified</FONT>
+    </TD><TD ALIGN="LEFT">
+    <FONT COLOR="#7B7B7B" FACE="Helvetica Italic">DateTimeField</FONT>
+    </TD></TR>
+  
+    <TR><TD ALIGN="LEFT" BORDER="0">
+    <FONT COLOR="#7B7B7B" FACE="Helvetica Italic">description</FONT>
+    </TD><TD ALIGN="LEFT">
+    <FONT COLOR="#7B7B7B" FACE="Helvetica Italic">TextField</FONT>
+    </TD></TR>
+  
+    <TR><TD ALIGN="LEFT" BORDER="0">
+    <FONT COLOR="#7B7B7B" FACE="Helvetica ">file</FONT>
+    </TD><TD ALIGN="LEFT">
+    <FONT COLOR="#7B7B7B" FACE="Helvetica ">FileField</FONT>
+    </TD></TR>
+  
+    <TR><TD ALIGN="LEFT" BORDER="0">
+    <FONT COLOR="#7B7B7B" FACE="Helvetica ">hdf5</FONT>
+    </TD><TD ALIGN="LEFT">
+    <FONT COLOR="#7B7B7B" FACE="Helvetica ">FileField</FONT>
+    </TD></TR>
+  
+    <TR><TD ALIGN="LEFT" BORDER="0">
+    <FONT COLOR="#7B7B7B" FACE="Helvetica ">lock</FONT>
+    </TD><TD ALIGN="LEFT">
+    <FONT COLOR="#7B7B7B" FACE="Helvetica ">BooleanField</FONT>
+    </TD></TR>
+  
+    <TR><TD ALIGN="LEFT" BORDER="0">
+    <FONT COLOR="#7B7B7B" FACE="Helvetica ">mime_type</FONT>
+    </TD><TD ALIGN="LEFT">
+    <FONT COLOR="#7B7B7B" FACE="Helvetica ">CharField</FONT>
+    </TD></TR>
+  
+    <TR><TD ALIGN="LEFT" BORDER="0">
+    <FONT COLOR="#7B7B7B" FACE="Helvetica ">sha1</FONT>
+    </TD><TD ALIGN="LEFT">
+    <FONT COLOR="#7B7B7B" FACE="Helvetica ">CharField</FONT>
+    </TD></TR>
+  
+    <TR><TD ALIGN="LEFT" BORDER="0">
+    <FONT COLOR="#7B7B7B" FACE="Helvetica Italic">title</FONT>
+    </TD><TD ALIGN="LEFT">
+    <FONT COLOR="#7B7B7B" FACE="Helvetica Italic">CharField</FONT>
+    </TD></TR>
+  
+    <TR><TD ALIGN="LEFT" BORDER="0">
+    <FONT COLOR="#7B7B7B" FACE="Helvetica ">url</FONT>
+    </TD><TD ALIGN="LEFT">
+    <FONT COLOR="#7B7B7B" FACE="Helvetica ">URLField</FONT>
+    </TD></TR>
+  
+    <TR><TD ALIGN="LEFT" BORDER="0">
+    <FONT COLOR="#7B7B7B" FACE="Helvetica Italic">uuid</FONT>
+    </TD><TD ALIGN="LEFT">
+    <FONT COLOR="#7B7B7B" FACE="Helvetica Italic">CharField</FONT>
+    </TD></TR>
+  
+    </TABLE>
+    >]
+
+  timeside_models_Experience [label=<
+    <TABLE BGCOLOR="palegoldenrod" BORDER="0" CELLBORDER="0" CELLSPACING="0">
+    <TR><TD COLSPAN="2" CELLPADDING="4" ALIGN="CENTER" BGCOLOR="olivedrab4">
+    <FONT FACE="Helvetica Bold" COLOR="white">
+    Experience<BR/>&lt;<FONT FACE="Helvetica Italic">DocBaseResource</FONT>&gt;
+    </FONT></TD></TR>
+  
+    <TR><TD ALIGN="LEFT" BORDER="0">
+    <FONT FACE="Helvetica Bold">id</FONT>
+    </TD><TD ALIGN="LEFT">
+    <FONT FACE="Helvetica Bold">AutoField</FONT>
+    </TD></TR>
+  
+    <TR><TD ALIGN="LEFT" BORDER="0">
+    <FONT COLOR="#7B7B7B" FACE="Helvetica Bold">author</FONT>
+    </TD><TD ALIGN="LEFT">
+    <FONT COLOR="#7B7B7B" FACE="Helvetica Bold">ForeignKey (id)</FONT>
+    </TD></TR>
+  
+    <TR><TD ALIGN="LEFT" BORDER="0">
+    <FONT COLOR="#7B7B7B" FACE="Helvetica Italic">date_added</FONT>
+    </TD><TD ALIGN="LEFT">
+    <FONT COLOR="#7B7B7B" FACE="Helvetica Italic">DateTimeField</FONT>
+    </TD></TR>
+  
+    <TR><TD ALIGN="LEFT" BORDER="0">
+    <FONT COLOR="#7B7B7B" FACE="Helvetica Italic">date_modified</FONT>
+    </TD><TD ALIGN="LEFT">
+    <FONT COLOR="#7B7B7B" FACE="Helvetica Italic">DateTimeField</FONT>
+    </TD></TR>
+  
+    <TR><TD ALIGN="LEFT" BORDER="0">
+    <FONT COLOR="#7B7B7B" FACE="Helvetica Italic">description</FONT>
+    </TD><TD ALIGN="LEFT">
+    <FONT COLOR="#7B7B7B" FACE="Helvetica Italic">TextField</FONT>
+    </TD></TR>
+  
+    <TR><TD ALIGN="LEFT" BORDER="0">
+    <FONT COLOR="#7B7B7B" FACE="Helvetica ">is_public</FONT>
+    </TD><TD ALIGN="LEFT">
+    <FONT COLOR="#7B7B7B" FACE="Helvetica ">BooleanField</FONT>
+    </TD></TR>
+  
+    <TR><TD ALIGN="LEFT" BORDER="0">
+    <FONT COLOR="#7B7B7B" FACE="Helvetica Italic">title</FONT>
+    </TD><TD ALIGN="LEFT">
+    <FONT COLOR="#7B7B7B" FACE="Helvetica Italic">CharField</FONT>
+    </TD></TR>
+  
+    <TR><TD ALIGN="LEFT" BORDER="0">
+    <FONT COLOR="#7B7B7B" FACE="Helvetica Italic">uuid</FONT>
+    </TD><TD ALIGN="LEFT">
+    <FONT COLOR="#7B7B7B" FACE="Helvetica Italic">CharField</FONT>
+    </TD></TR>
+  
+    </TABLE>
+    >]
+
+  timeside_models_Processor [label=<
+    <TABLE BGCOLOR="palegoldenrod" BORDER="0" CELLBORDER="0" CELLSPACING="0">
+    <TR><TD COLSPAN="2" CELLPADDING="4" ALIGN="CENTER" BGCOLOR="olivedrab4">
+    <FONT FACE="Helvetica Bold" COLOR="white">
+    Processor
+    </FONT></TD></TR>
+  
+    <TR><TD ALIGN="LEFT" BORDER="0">
+    <FONT FACE="Helvetica Bold">id</FONT>
+    </TD><TD ALIGN="LEFT">
+    <FONT FACE="Helvetica Bold">AutoField</FONT>
+    </TD></TR>
+  
+    <TR><TD ALIGN="LEFT" BORDER="0">
+    <FONT FACE="Helvetica ">pid</FONT>
+    </TD><TD ALIGN="LEFT">
+    <FONT FACE="Helvetica ">CharField</FONT>
+    </TD></TR>
+  
+    <TR><TD ALIGN="LEFT" BORDER="0">
+    <FONT COLOR="#7B7B7B" FACE="Helvetica ">version</FONT>
+    </TD><TD ALIGN="LEFT">
+    <FONT COLOR="#7B7B7B" FACE="Helvetica ">CharField</FONT>
+    </TD></TR>
+  
+    </TABLE>
+    >]
+
+  timeside_models_Preset [label=<
+    <TABLE BGCOLOR="palegoldenrod" BORDER="0" CELLBORDER="0" CELLSPACING="0">
+    <TR><TD COLSPAN="2" CELLPADDING="4" ALIGN="CENTER" BGCOLOR="olivedrab4">
+    <FONT FACE="Helvetica Bold" COLOR="white">
+    Preset
+    </FONT></TD></TR>
+  
+    <TR><TD ALIGN="LEFT" BORDER="0">
+    <FONT FACE="Helvetica Bold">id</FONT>
+    </TD><TD ALIGN="LEFT">
+    <FONT FACE="Helvetica Bold">AutoField</FONT>
+    </TD></TR>
+  
+    <TR><TD ALIGN="LEFT" BORDER="0">
+    <FONT COLOR="#7B7B7B" FACE="Helvetica Bold">processor</FONT>
+    </TD><TD ALIGN="LEFT">
+    <FONT COLOR="#7B7B7B" FACE="Helvetica Bold">ForeignKey (id)</FONT>
+    </TD></TR>
+  
+    <TR><TD ALIGN="LEFT" BORDER="0">
+    <FONT COLOR="#7B7B7B" FACE="Helvetica ">is_public</FONT>
+    </TD><TD ALIGN="LEFT">
+    <FONT COLOR="#7B7B7B" FACE="Helvetica ">BooleanField</FONT>
+    </TD></TR>
+  
+    <TR><TD ALIGN="LEFT" BORDER="0">
+    <FONT COLOR="#7B7B7B" FACE="Helvetica ">parameters</FONT>
+    </TD><TD ALIGN="LEFT">
+    <FONT COLOR="#7B7B7B" FACE="Helvetica ">TextField</FONT>
+    </TD></TR>
+  
+    </TABLE>
+    >]
+
+  timeside_models_Result [label=<
+    <TABLE BGCOLOR="palegoldenrod" BORDER="0" CELLBORDER="0" CELLSPACING="0">
+    <TR><TD COLSPAN="2" CELLPADDING="4" ALIGN="CENTER" BGCOLOR="olivedrab4">
+    <FONT FACE="Helvetica Bold" COLOR="white">
+    Result<BR/>&lt;<FONT FACE="Helvetica Italic">BaseResource</FONT>&gt;
+    </FONT></TD></TR>
+  
+    <TR><TD ALIGN="LEFT" BORDER="0">
+    <FONT FACE="Helvetica Bold">id</FONT>
+    </TD><TD ALIGN="LEFT">
+    <FONT FACE="Helvetica Bold">AutoField</FONT>
+    </TD></TR>
+  
+    <TR><TD ALIGN="LEFT" BORDER="0">
+    <FONT COLOR="#7B7B7B" FACE="Helvetica Bold">item</FONT>
+    </TD><TD ALIGN="LEFT">
+    <FONT COLOR="#7B7B7B" FACE="Helvetica Bold">ForeignKey (id)</FONT>
+    </TD></TR>
+  
+    <TR><TD ALIGN="LEFT" BORDER="0">
+    <FONT COLOR="#7B7B7B" FACE="Helvetica Bold">preset</FONT>
+    </TD><TD ALIGN="LEFT">
+    <FONT COLOR="#7B7B7B" FACE="Helvetica Bold">ForeignKey (id)</FONT>
+    </TD></TR>
+  
+    <TR><TD ALIGN="LEFT" BORDER="0">
+    <FONT COLOR="#7B7B7B" FACE="Helvetica Italic">date_added</FONT>
+    </TD><TD ALIGN="LEFT">
+    <FONT COLOR="#7B7B7B" FACE="Helvetica Italic">DateTimeField</FONT>
+    </TD></TR>
+  
+    <TR><TD ALIGN="LEFT" BORDER="0">
+    <FONT COLOR="#7B7B7B" FACE="Helvetica Italic">date_modified</FONT>
+    </TD><TD ALIGN="LEFT">
+    <FONT COLOR="#7B7B7B" FACE="Helvetica Italic">DateTimeField</FONT>
+    </TD></TR>
+  
+    <TR><TD ALIGN="LEFT" BORDER="0">
+    <FONT COLOR="#7B7B7B" FACE="Helvetica ">file</FONT>
+    </TD><TD ALIGN="LEFT">
+    <FONT COLOR="#7B7B7B" FACE="Helvetica ">FileField</FONT>
+    </TD></TR>
+  
+    <TR><TD ALIGN="LEFT" BORDER="0">
+    <FONT COLOR="#7B7B7B" FACE="Helvetica ">hdf5</FONT>
+    </TD><TD ALIGN="LEFT">
+    <FONT COLOR="#7B7B7B" FACE="Helvetica ">FileField</FONT>
+    </TD></TR>
+  
+    <TR><TD ALIGN="LEFT" BORDER="0">
+    <FONT COLOR="#7B7B7B" FACE="Helvetica ">mime_type</FONT>
+    </TD><TD ALIGN="LEFT">
+    <FONT COLOR="#7B7B7B" FACE="Helvetica ">CharField</FONT>
+    </TD></TR>
+  
+    <TR><TD ALIGN="LEFT" BORDER="0">
+    <FONT FACE="Helvetica ">status</FONT>
+    </TD><TD ALIGN="LEFT">
+    <FONT FACE="Helvetica ">IntegerField</FONT>
+    </TD></TR>
+  
+    <TR><TD ALIGN="LEFT" BORDER="0">
+    <FONT COLOR="#7B7B7B" FACE="Helvetica Italic">uuid</FONT>
+    </TD><TD ALIGN="LEFT">
+    <FONT COLOR="#7B7B7B" FACE="Helvetica Italic">CharField</FONT>
+    </TD></TR>
+  
+    </TABLE>
+    >]
+
+  timeside_models_Task [label=<
+    <TABLE BGCOLOR="palegoldenrod" BORDER="0" CELLBORDER="0" CELLSPACING="0">
+    <TR><TD COLSPAN="2" CELLPADDING="4" ALIGN="CENTER" BGCOLOR="olivedrab4">
+    <FONT FACE="Helvetica Bold" COLOR="white">
+    Task
+    </FONT></TD></TR>
+  
+    <TR><TD ALIGN="LEFT" BORDER="0">
+    <FONT FACE="Helvetica Bold">id</FONT>
+    </TD><TD ALIGN="LEFT">
+    <FONT FACE="Helvetica Bold">AutoField</FONT>
+    </TD></TR>
+  
+    <TR><TD ALIGN="LEFT" BORDER="0">
+    <FONT COLOR="#7B7B7B" FACE="Helvetica Bold">author</FONT>
+    </TD><TD ALIGN="LEFT">
+    <FONT COLOR="#7B7B7B" FACE="Helvetica Bold">ForeignKey (id)</FONT>
+    </TD></TR>
+  
+    <TR><TD ALIGN="LEFT" BORDER="0">
+    <FONT COLOR="#7B7B7B" FACE="Helvetica Bold">experience</FONT>
+    </TD><TD ALIGN="LEFT">
+    <FONT COLOR="#7B7B7B" FACE="Helvetica Bold">ForeignKey (id)</FONT>
+    </TD></TR>
+  
+    <TR><TD ALIGN="LEFT" BORDER="0">
+    <FONT COLOR="#7B7B7B" FACE="Helvetica Bold">selection</FONT>
+    </TD><TD ALIGN="LEFT">
+    <FONT COLOR="#7B7B7B" FACE="Helvetica Bold">ForeignKey (id)</FONT>
+    </TD></TR>
+  
+    <TR><TD ALIGN="LEFT" BORDER="0">
+    <FONT FACE="Helvetica ">status</FONT>
+    </TD><TD ALIGN="LEFT">
+    <FONT FACE="Helvetica ">IntegerField</FONT>
+    </TD></TR>
+  
+    </TABLE>
+    >]
+
+
+
+
+
+  timeside_models_DocBaseResource -> timeside_models_BaseResource
+  [label="abstract\ninheritance"] [arrowhead=empty, arrowtail=none, dir=both];
+  django_contrib_auth_models_User [label=<
+  <TABLE BGCOLOR="palegoldenrod" BORDER="0" CELLBORDER="0" CELLSPACING="0">
+  <TR><TD COLSPAN="2" CELLPADDING="4" ALIGN="CENTER" BGCOLOR="olivedrab4">
+  <FONT FACE="Helvetica Bold" COLOR="white">User</FONT>
+  </TD></TR>
+  </TABLE>
+  >]
+  timeside_models_Selection -> django_contrib_auth_models_User
+  [label="author (selections)"] [arrowhead=none, arrowtail=dot, dir=both];
+
+  timeside_models_Selection -> timeside_models_Item
+  [label="items (selections)"] [arrowhead=dot arrowtail=dot, dir=both];
+
+  timeside_models_Selection -> timeside_models_Selection
+  [label="selections (other_selections)"] [arrowhead=dot arrowtail=dot, dir=both];
+
+  timeside_models_Selection -> timeside_models_DocBaseResource
+  [label="abstract\ninheritance"] [arrowhead=empty, arrowtail=none, dir=both];
+  django_contrib_auth_models_User [label=<
+  <TABLE BGCOLOR="palegoldenrod" BORDER="0" CELLBORDER="0" CELLSPACING="0">
+  <TR><TD COLSPAN="2" CELLPADDING="4" ALIGN="CENTER" BGCOLOR="olivedrab4">
+  <FONT FACE="Helvetica Bold" COLOR="white">User</FONT>
+  </TD></TR>
+  </TABLE>
+  >]
+  timeside_models_Item -> django_contrib_auth_models_User
+  [label="author (items)"] [arrowhead=none, arrowtail=dot, dir=both];
+
+  timeside_models_Item -> timeside_models_DocBaseResource
+  [label="abstract\ninheritance"] [arrowhead=empty, arrowtail=none, dir=both];
+  django_contrib_auth_models_User [label=<
+  <TABLE BGCOLOR="palegoldenrod" BORDER="0" CELLBORDER="0" CELLSPACING="0">
+  <TR><TD COLSPAN="2" CELLPADDING="4" ALIGN="CENTER" BGCOLOR="olivedrab4">
+  <FONT FACE="Helvetica Bold" COLOR="white">User</FONT>
+  </TD></TR>
+  </TABLE>
+  >]
+  timeside_models_Experience -> django_contrib_auth_models_User
+  [label="author (experiences)"] [arrowhead=none, arrowtail=dot, dir=both];
+
+  timeside_models_Experience -> timeside_models_Preset
+  [label="presets (experiences)"] [arrowhead=dot arrowtail=dot, dir=both];
+
+  timeside_models_Experience -> timeside_models_Experience
+  [label="experiences (other_experiences)"] [arrowhead=dot arrowtail=dot, dir=both];
+
+  timeside_models_Experience -> timeside_models_DocBaseResource
+  [label="abstract\ninheritance"] [arrowhead=empty, arrowtail=none, dir=both];
+
+  timeside_models_Preset -> timeside_models_Processor
+  [label="processor (preset)"] [arrowhead=none, arrowtail=dot, dir=both];
+
+  timeside_models_Result -> timeside_models_Item
+  [label="item (results)"] [arrowhead=none, arrowtail=dot, dir=both];
+
+  timeside_models_Result -> timeside_models_Preset
+  [label="preset (results)"] [arrowhead=none, arrowtail=dot, dir=both];
+
+  timeside_models_Result -> timeside_models_BaseResource
+  [label="abstract\ninheritance"] [arrowhead=empty, arrowtail=none, dir=both];
+
+  timeside_models_Task -> timeside_models_Experience
+  [label="experience (task)"] [arrowhead=none, arrowtail=dot, dir=both];
+
+  timeside_models_Task -> timeside_models_Selection
+  [label="selection (task)"] [arrowhead=none, arrowtail=dot, dir=both];
+  django_contrib_auth_models_User [label=<
+  <TABLE BGCOLOR="palegoldenrod" BORDER="0" CELLBORDER="0" CELLSPACING="0">
+  <TR><TD COLSPAN="2" CELLPADDING="4" ALIGN="CENTER" BGCOLOR="olivedrab4">
+  <FONT FACE="Helvetica Bold" COLOR="white">User</FONT>
+  </TD></TR>
+  </TABLE>
+  >]
+  timeside_models_Task -> django_contrib_auth_models_User
+  [label="author (tasks)"] [arrowhead=none, arrowtail=dot, dir=both];
+
+}
+
diff --git a/timeside/server/sandbox/diagram/timeside.pdf b/timeside/server/sandbox/diagram/timeside.pdf
new file mode 100644 (file)
index 0000000..9f72bae
Binary files /dev/null and b/timeside/server/sandbox/diagram/timeside.pdf differ
diff --git a/timeside/server/sandbox/manage.py b/timeside/server/sandbox/manage.py
new file mode 100755 (executable)
index 0000000..f9726f9
--- /dev/null
@@ -0,0 +1,10 @@
+#!/usr/bin/env python
+import os
+import sys
+
+if __name__ == "__main__":
+    os.environ.setdefault("DJANGO_SETTINGS_MODULE", "settings")
+
+    from django.core.management import execute_from_command_line
+
+    execute_from_command_line(sys.argv)
diff --git a/timeside/server/sandbox/settings.py b/timeside/server/sandbox/settings.py
new file mode 100644 (file)
index 0000000..2318f5f
--- /dev/null
@@ -0,0 +1,170 @@
+# Django settings for server project.
+
+DEBUG = True
+TEMPLATE_DEBUG = DEBUG
+
+import os, sys
+sys.dont_write_bytecode = True
+
+ADMINS = (
+    # ('Your Name', 'your_email@example.com'),
+)
+
+MANAGERS = ADMINS
+
+DATABASES = {
+    'default': {
+        'ENGINE': 'django.db.backends.sqlite3', # Add 'postgresql_psycopg2', 'mysql', 'sqlite3' or 'oracle'.
+        'NAME': 'timeside.sql',                      # Or path to database file if using sqlite3.
+        'USER': '',                      # Not used with sqlite3.
+        'PASSWORD': '',                  # Not used with sqlite3.
+        'HOST': '',                      # Set to empty string for localhost. Not used with sqlite3.
+        'PORT': '',                      # Set to empty string for default. Not used with sqlite3.
+    }
+}
+
+# Hosts/domain names that are valid for this site; required if DEBUG is False
+# See https://docs.djangoproject.com/en/1.4/ref/settings/#allowed-hosts
+ALLOWED_HOSTS = []
+
+# Local time zone for this installation. Choices can be found here:
+# http://en.wikipedia.org/wiki/List_of_tz_zones_by_name
+# although not all choices may be available on all operating systems.
+# In a Windows environment this must be set to your system time zone.
+TIME_ZONE = 'America/Chicago'
+
+# Language code for this installation. All choices can be found here:
+# http://www.i18nguy.com/unicode/language-identifiers.html
+LANGUAGE_CODE = 'en-us'
+
+SITE_ID = 1
+
+# If you set this to False, Django will make some optimizations so as not
+# to load the internationalization machinery.
+USE_I18N = True
+
+# If you set this to False, Django will not format dates, numbers and
+# calendars according to the current locale.
+USE_L10N = True
+
+# If you set this to False, Django will not use timezone-aware datetimes.
+USE_TZ = True
+
+# Full filesystem path to the project.
+PROJECT_ROOT = os.path.dirname(os.path.abspath(__file__))
+
+# Absolute filesystem path to the directory that will hold user-uploaded files.
+# Example: "/home/media/media.lawrence.com/media/"
+MEDIA_ROOT = PROJECT_ROOT + '/media/'
+
+# URL that handles the media served from MEDIA_ROOT. Make sure to use a
+# trailing slash.
+# Examples: "http://media.lawrence.com/media/", "http://example.com/media/"
+MEDIA_URL = ''
+
+# Absolute path to the directory static files should be collected to.
+# Don't put anything in this directory yourself; store your static files
+# in apps' "static/" subdirectories and in STATICFILES_DIRS.
+# Example: "/home/media/media.lawrence.com/static/"
+STATIC_ROOT = ''
+
+# URL prefix for static files.
+# Example: "http://media.lawrence.com/static/"
+STATIC_URL = '/static/'
+
+# Additional locations of static files
+STATICFILES_DIRS = (
+    # Put strings here, like "/home/html/static" or "C:/www/django/static".
+    # Always use forward slashes, even on Windows.
+    # Don't forget to use absolute paths, not relative paths.
+)
+
+# List of finder classes that know how to find static files in
+# various locations.
+STATICFILES_FINDERS = (
+    'django.contrib.staticfiles.finders.FileSystemFinder',
+    'django.contrib.staticfiles.finders.AppDirectoriesFinder',
+#    'django.contrib.staticfiles.finders.DefaultStorageFinder',
+)
+
+# Make this unique, and don't share it with anybody.
+SECRET_KEY = '5%z&amp;a3r@t0=xr2eaio+400qf-32$b5zp897pr*wh5i^s4(-+3('
+
+# List of callables that know how to import templates from various sources.
+TEMPLATE_LOADERS = (
+    'django.template.loaders.filesystem.Loader',
+    'django.template.loaders.app_directories.Loader',
+#    'django.template.loaders.eggs.Loader',
+)
+
+MIDDLEWARE_CLASSES = (
+    'django.middleware.common.CommonMiddleware',
+    'django.contrib.sessions.middleware.SessionMiddleware',
+    'django.middleware.csrf.CsrfViewMiddleware',
+    'django.contrib.auth.middleware.AuthenticationMiddleware',
+    'django.contrib.messages.middleware.MessageMiddleware',
+    # Uncomment the next line for simple clickjacking protection:
+    # 'django.middleware.clickjacking.XFrameOptionsMiddleware',
+)
+
+ROOT_URLCONF = 'urls'
+
+# Python dotted path to the WSGI application used by Django's runserver.
+WSGI_APPLICATION = 'wsgi.application'
+
+TEMPLATE_DIRS = (
+    # Put strings here, like "/home/html/django_templates" or "C:/www/django/templates".
+    # Always use forward slashes, even on Windows.
+    # Don't forget to use absolute paths, not relative paths.
+)
+
+INSTALLED_APPS = (
+    'django.contrib.auth',
+    'django.contrib.contenttypes',
+    'django.contrib.sessions',
+    'django.contrib.sites',
+    'django.contrib.messages',
+    'django.contrib.staticfiles',
+    # Uncomment the next line to enable the admin:
+    'django.contrib.admin',
+    # Uncomment the next line to enable admin documentation:
+    # 'django.contrib.admindocs',
+    'django_extensions',
+    'south',
+    # 'timeside',
+    'timeside.server',
+    'timeside.player',
+    'rest_framework',
+)
+
+# A sample logging configuration. The only tangible logging
+# performed by this configuration is to send an email to
+# the site admins on every HTTP 500 error when DEBUG=False.
+# See http://docs.djangoproject.com/en/dev/topics/logging for
+# more details on how to customize your logging configuration.
+LOGGING = {
+    'version': 1,
+    'disable_existing_loggers': False,
+    'filters': {
+        'require_debug_false': {
+            '()': 'django.utils.log.RequireDebugFalse'
+        }
+    },
+    'handlers': {
+        'mail_admins': {
+            'level': 'ERROR',
+            'filters': ['require_debug_false'],
+            'class': 'django.utils.log.AdminEmailHandler'
+        }
+    },
+    'loggers': {
+        'django.request': {
+            'handlers': ['mail_admins'],
+            'level': 'ERROR',
+            'propagate': True,
+        },
+    }
+}
+
+REST_FRAMEWORK = {
+}
\ No newline at end of file
diff --git a/timeside/server/sandbox/update_schema.sh b/timeside/server/sandbox/update_schema.sh
new file mode 100755 (executable)
index 0000000..82d28e9
--- /dev/null
@@ -0,0 +1,5 @@
+#!/bin/sh
+
+./manage.py schemamigration timeside --auto
+./manage.py migrate timeside
+
diff --git a/timeside/server/sandbox/urls.py b/timeside/server/sandbox/urls.py
new file mode 100644 (file)
index 0000000..2224d24
--- /dev/null
@@ -0,0 +1,20 @@
+from django.conf.urls import patterns, include, url
+
+# Uncomment the next two lines to enable the admin:
+from django.contrib import admin
+admin.autodiscover()
+
+urlpatterns = patterns('',
+
+    url(r'^', include('timeside.server.urls')),
+
+    # Examples:
+    # url(r'^$', 'server.views.home', name='home'),
+    # url(r'^server/', include('server.foo.urls')),
+
+    # Uncomment the admin/doc line below to enable admin documentation:
+    # url(r'^admin/doc/', include('django.contrib.admindocs.urls')),
+
+    # Uncomment the next line to enable the admin:
+    url(r'^admin/', include(admin.site.urls)),
+)
diff --git a/timeside/server/sandbox/wsgi.py b/timeside/server/sandbox/wsgi.py
new file mode 100644 (file)
index 0000000..c4d2c74
--- /dev/null
@@ -0,0 +1,28 @@
+"""
+WSGI config for server project.
+
+This module contains the WSGI application used by Django's development server
+and any production WSGI deployments. It should expose a module-level variable
+named ``application``. Django's ``runserver`` and ``runfcgi`` commands discover
+this application via the ``WSGI_APPLICATION`` setting.
+
+Usually you will have the standard Django WSGI application here, but it also
+might make sense to replace the whole Django WSGI application with a custom one
+that later delegates to the Django one. For example, you could introduce WSGI
+middleware here, or combine a Django application with an application of another
+framework.
+
+"""
+import os
+
+os.environ.setdefault("DJANGO_SETTINGS_MODULE", "sandbox.settings")
+
+# This application object is used by any WSGI server configured to use this
+# file. This includes Django's development server, if the WSGI_APPLICATION
+# setting points here.
+from django.core.wsgi import get_wsgi_application
+application = get_wsgi_application()
+
+# Apply WSGI middleware here.
+# from helloworld.wsgi import HelloWorldApplication
+# application = HelloWorldApplication(application)
diff --git a/timeside/server/serializers.py b/timeside/server/serializers.py
new file mode 100644 (file)
index 0000000..5814f11
--- /dev/null
@@ -0,0 +1,61 @@
+from timeside.server.models import *
+from rest_framework import serializers
+import django.db.models
+from django.contrib.auth.models import User
+
+
+class SelectionSerializer(serializers.ModelSerializer):
+
+    class Meta:
+        model = Selection
+        fields = ('id', 'items', 'selections', 'author')
+
+
+class ItemSerializer(serializers.ModelSerializer):
+
+    class Meta:
+        model = Item
+        fields = ('id', 'title', 'file', 'mime_type', 'author')
+
+
+class ExperienceSerializer(serializers.ModelSerializer):
+
+    class Meta:
+        model = Experience
+        fields = ('id', 'presets', 'experiences', 'is_public', 'author')
+
+
+class ProcessorSerializer(serializers.ModelSerializer):
+
+    class Meta:
+        model = Processor
+        fields = ('id', 'pid', 'version')
+
+
+class ResultSerializer(serializers.ModelSerializer):
+
+    class Meta:
+        model = Result
+        fields = ('id', 'item', 'preset', 'status', 'hdf5', 'file')
+
+
+class PresetSerializer(serializers.ModelSerializer):
+
+    class Meta:
+        model = Preset
+        fields = ('id', 'processor', 'parameters', 'is_public')
+
+
+class TaskSerializer(serializers.ModelSerializer):
+
+    class Meta:
+        model = Task
+        fields = ('id', 'experience', 'selection', 'status', 'author')
+
+
+class UserSerializer(serializers.ModelSerializer):
+
+    class Meta:
+        model = User
+
+
diff --git a/timeside/server/templates/timeside/base.html b/timeside/server/templates/timeside/base.html
new file mode 100644 (file)
index 0000000..372c79f
--- /dev/null
@@ -0,0 +1,40 @@
+<!DOCTYPE html>
+{% load i18n %}
+{% get_current_language as LANGUAGE_CODE %}
+{% get_available_languages as LANGUAGES %}
+<html lang="{{ LANGUAGE_CODE }}" xml:lang="{{ LANGUAGE_CODE }}" {% if LANGUAGE_BIDI %}dir="rtl"{% endif %}>
+
+<head>
+<meta http-equiv="Content-type" content="text/html;charset=UTF-8" />
+<title></title>
+
+{% block stylesheets %}
+{% endblock %}
+
+{% block extra_stylesheets %}{% endblock %}
+
+{% block javascript %}
+    <script src="{{ STATIC_URL }}timeside/js/libs/soundmanager2-nodebug-jsmin.js" type="text/javascript"></script>
+    <script src="{{ STATIC_URL }}timeside/js/timeside.js" type="text/javascript"></script>
+    <script src="{{ STATIC_URL }}telemeta/js/playerLoader.js" type="text/javascript"></script>
+    <script src="{{ STATIC_URL }}telemeta/js/divmarker.js" type="text/javascript"></script>
+{% endblock %}
+
+{% block extra_javascript %}{% endblock %}
+</head>
+
+<body>
+{% block layout %}
+<div id="layout">
+
+{% block content %}
+{% endblock content %}
+
+</div>
+{% endblock layout %}
+
+{% block analytics %}
+{% endblock analytics %}
+
+</body>
+</html>
diff --git a/timeside/server/templates/timeside/index.html b/timeside/server/templates/timeside/index.html
new file mode 100644 (file)
index 0000000..9e67fd7
--- /dev/null
@@ -0,0 +1,12 @@
+{% extends "timeside/base.html" %}
+{% load i18n %}
+
+{% block content %}
+
+<ul>
+ {% for item in object_list %}
+  <li>{{ item.title }}</li>
+ {% endfor %}
+</ul>
+
+{% endblock content %}
diff --git a/timeside/server/urls.py b/timeside/server/urls.py
new file mode 100644 (file)
index 0000000..3c10efe
--- /dev/null
@@ -0,0 +1,25 @@
+# -*- coding: utf-8 -*-
+
+from django.conf.urls import patterns, include, url
+from django.contrib import admin
+from rest_framework import routers
+from timeside.server import views
+
+admin.autodiscover()
+
+api_router = routers.DefaultRouter()
+api_router.register(r'selections', views.SelectionViewSet)
+api_router.register(r'items', views.ItemViewSet)
+api_router.register(r'experiences', views.ExperienceViewSet)
+api_router.register(r'processors', views.ProcessorViewSet)
+api_router.register(r'results', views.ResultViewSet)
+api_router.register(r'presets', views.PresetViewSet)
+api_router.register(r'tasks', views.TaskViewSet)
+api_router.register(r'users', views.UserViewSet)
+
+urlpatterns = patterns('',
+    url(r'^admin/', include(admin.site.urls)),
+    url(r'^api/', include(api_router.urls)),
+    url(r'^$', views.IndexView.as_view(), name="timeside-index"),
+    url(r'^results/(?P<pk>.*)/json/$', views.ResultAnalyzerView.as_view(), name="timeside-result-json"),
+)
diff --git a/timeside/server/views.py b/timeside/server/views.py
new file mode 100644 (file)
index 0000000..d4cd7f7
--- /dev/null
@@ -0,0 +1,82 @@
+# -*- coding: utf-8 -*-
+
+from django.views.generic import *
+from django.http import HttpResponse, HttpResponseRedirect
+
+from rest_framework import viewsets
+
+import timeside
+from timeside.server.models import *
+from timeside.server.serializers import *
+
+
+class SelectionViewSet(viewsets.ModelViewSet):
+    
+    model = Selection
+    serializer_class = SelectionSerializer
+
+
+class ItemViewSet(viewsets.ModelViewSet):
+    
+    model = Item
+    serializer_class = ItemSerializer
+
+
+class ExperienceViewSet(viewsets.ModelViewSet):
+    
+    model = Experience
+    serializer_class = ExperienceSerializer
+
+
+class ProcessorViewSet(viewsets.ModelViewSet):
+    
+    model = Processor
+    serializer_class = ProcessorSerializer
+
+
+class ResultViewSet(viewsets.ModelViewSet):
+    
+    model = Result
+    serializer_class = ResultSerializer
+
+
+class PresetViewSet(viewsets.ModelViewSet):
+    
+    model = Preset
+    serializer_class = PresetSerializer
+
+
+class TaskViewSet(viewsets.ModelViewSet):
+    
+    model = Task
+    serializer_class = TaskSerializer
+
+
+class UserViewSet(viewsets.ModelViewSet):
+    
+    model = User
+    serializer_class = UserSerializer
+
+
+class IndexView(ListView):
+
+    model = Item
+    template_name='timeside/index.html'
+
+    def get_context_data(self, **kwargs):
+        context = super(IndexView, self).get_context_data(**kwargs)
+        return context
+
+    def dispatch(self, *args, **kwargs):
+        return super(IndexView, self).dispatch(*args, **kwargs)
+
+
+class ResultAnalyzerView(View):
+    
+    model = Result
+
+    def get(self, request, *args, **kwargs):
+        result = Result.objects.get(pk=kwargs['pk'])
+        container = AnalyzerResultContainer()
+        return HttpResponse(container.from_hdf5(result.hdf5.path).to_json(), mimetype='application/json')
+    
\ No newline at end of file
diff --git a/timeside/static/timeside/README.rst b/timeside/static/timeside/README.rst
deleted file mode 100644 (file)
index 241b18b..0000000
+++ /dev/null
@@ -1,30 +0,0 @@
-===================
-TimeSide UI 
-===================
-
-Please refer to http://code.google.com/p/timeside/wiki/UiGuide for an exhaustive guide.
-
-Provides
-=========
-
-* SoundManager 2 >= 2.97 : http://www.schillmania.com/projects/soundmanager2
-* jQuery => 1.6 : http://www.jquery.com
-* Raphael (ADDED AUTOMATICALLY, DO NOT ADD YOURSELF) => 1.52 http://raphaeljs.com/
-
-
-Licensing
-=========
-
-Copyright (c) 2009-2011 Parisson SARL
-
-Copyright (c) 2008-2009 Samalyse
-
-Copyright (c) 2011 Riccardo Zaccarelli
-
-Authors:
-
- * Riccardo Zaccarelli <riccardo.zaccarelli gmail.com>
- * Olivier Guilyardi <olivier samalyse com>
-
-TimeSide is released under the terms of the GNU General Public License
-version 2. Please see the LICENSE file for details.
diff --git a/timeside/static/timeside/js/libs/jquery-1.6.min.js b/timeside/static/timeside/js/libs/jquery-1.6.min.js
deleted file mode 100644 (file)
index c72011d..0000000
+++ /dev/null
@@ -1,16 +0,0 @@
-/*!
- * jQuery JavaScript Library v1.6
- * http://jquery.com/
- *
- * Copyright 2011, John Resig
- * Dual licensed under the MIT or GPL Version 2 licenses.
- * http://jquery.org/license
- *
- * Includes Sizzle.js
- * http://sizzlejs.com/
- * Copyright 2011, The Dojo Foundation
- * Released under the MIT, BSD, and GPL Licenses.
- *
- * Date: Mon May 2 13:50:00 2011 -0400
- */
-(function(a,b){function cw(a){return f.isWindow(a)?a:a.nodeType===9?a.defaultView||a.parentWindow:!1}function ct(a){if(!ch[a]){var b=f("<"+a+">").appendTo("body"),d=b.css("display");b.remove();if(d==="none"||d===""){ci||(ci=c.createElement("iframe"),ci.frameBorder=ci.width=ci.height=0),c.body.appendChild(ci);if(!cj||!ci.createElement)cj=(ci.contentWindow||ci.contentDocument).document,cj.write("<!doctype><html><body></body></html>");b=cj.createElement(a),cj.body.appendChild(b),d=f.css(b,"display"),c.body.removeChild(ci)}ch[a]=d}return ch[a]}function cs(a,b){var c={};f.each(cn.concat.apply([],cn.slice(0,b)),function(){c[this]=a});return c}function cr(){co=b}function cq(){setTimeout(cr,0);return co=f.now()}function cg(){try{return new a.ActiveXObject("Microsoft.XMLHTTP")}catch(b){}}function cf(){try{return new a.XMLHttpRequest}catch(b){}}function b_(a,c){a.dataFilter&&(c=a.dataFilter(c,a.dataType));var d=a.dataTypes,e={},g,h,i=d.length,j,k=d[0],l,m,n,o,p;for(g=1;g<i;g++){if(g===1)for(h in a.converters)typeof h=="string"&&(e[h.toLowerCase()]=a.converters[h]);l=k,k=d[g];if(k==="*")k=l;else if(l!=="*"&&l!==k){m=l+" "+k,n=e[m]||e["* "+k];if(!n){p=b;for(o in e){j=o.split(" ");if(j[0]===l||j[0]==="*"){p=e[j[1]+" "+k];if(p){o=e[o],o===!0?n=p:p===!0&&(n=o);break}}}}!n&&!p&&f.error("No conversion from "+m.replace(" "," to ")),n!==!0&&(c=n?n(c):p(o(c)))}}return c}function b$(a,c,d){var e=a.contents,f=a.dataTypes,g=a.responseFields,h,i,j,k;for(i in g)i in d&&(c[g[i]]=d[i]);while(f[0]==="*")f.shift(),h===b&&(h=a.mimeType||c.getResponseHeader("content-type"));if(h)for(i in e)if(e[i]&&e[i].test(h)){f.unshift(i);break}if(f[0]in d)j=f[0];else{for(i in d){if(!f[0]||a.converters[i+" "+f[0]]){j=i;break}k||(k=i)}j=j||k}if(j){j!==f[0]&&f.unshift(j);return d[j]}}function bZ(a,b,c,d){if(f.isArray(b))f.each(b,function(b,e){c||bD.test(a)?d(a,e):bZ(a+"["+(typeof e=="object"||f.isArray(e)?b:"")+"]",e,c,d)});else if(!c&&b!=null&&typeof b=="object")for(var e in b)bZ(a+"["+e+"]",b[e],c,d);else d(a,b)}function bY(a,c,d,e,f,g){f=f||c.dataTypes[0],g=g||{},g[f]=!0;var h=a[f],i=0,j=h?h.length:0,k=a===bS,l;for(;i<j&&(k||!l);i++)l=h[i](c,d,e),typeof l=="string"&&(!k||g[l]?l=b:(c.dataTypes.unshift(l),l=bY(a,c,d,e,l,g)));(k||!l)&&!g["*"]&&(l=bY(a,c,d,e,"*",g));return l}function bX(a){return function(b,c){typeof b!="string"&&(c=b,b="*");if(f.isFunction(c)){var d=b.toLowerCase().split(bO),e=0,g=d.length,h,i,j;for(;e<g;e++)h=d[e],j=/^\+/.test(h),j&&(h=h.substr(1)||"*"),i=a[h]=a[h]||[],i[j?"unshift":"push"](c)}}}function bB(a,b,c){var d=b==="width"?bv:bw,e=b==="width"?a.offsetWidth:a.offsetHeight;if(c==="border")return e;f.each(d,function(){c||(e-=parseFloat(f.css(a,"padding"+this))||0),c==="margin"?e+=parseFloat(f.css(a,"margin"+this))||0:e-=parseFloat(f.css(a,"border"+this+"Width"))||0});return e}function bl(a,b){b.src?f.ajax({url:b.src,async:!1,dataType:"script"}):f.globalEval(b.text||b.textContent||b.innerHTML||""),b.parentNode&&b.parentNode.removeChild(b)}function bk(a){f.nodeName(a,"input")?bj(a):a.getElementsByTagName&&f.grep(a.getElementsByTagName("input"),bj)}function bj(a){if(a.type==="checkbox"||a.type==="radio")a.defaultChecked=a.checked}function bi(a){return"getElementsByTagName"in a?a.getElementsByTagName("*"):"querySelectorAll"in a?a.querySelectorAll("*"):[]}function bh(a,b){var c;if(b.nodeType===1){b.clearAttributes&&b.clearAttributes(),b.mergeAttributes&&b.mergeAttributes(a),c=b.nodeName.toLowerCase();if(c==="object")b.outerHTML=a.outerHTML;else if(c!=="input"||a.type!=="checkbox"&&a.type!=="radio"){if(c==="option")b.selected=a.defaultSelected;else if(c==="input"||c==="textarea")b.defaultValue=a.defaultValue}else a.checked&&(b.defaultChecked=b.checked=a.checked),b.value!==a.value&&(b.value=a.value);b.removeAttribute(f.expando)}}function bg(a,b){if(b.nodeType===1&&!!f.hasData(a)){var c=f.expando,d=f.data(a),e=f.data(b,d);if(d=d[c]){var g=d.events;e=e[c]=f.extend({},d);if(g){delete e.handle,e.events={};for(var h in g)for(var i=0,j=g[h].length;i<j;i++)f.event.add(b,h+(g[h][i].namespace?".":"")+g[h][i].namespace,g[h][i],g[h][i].data)}}}}function bf(a,b){return f.nodeName(a,"table")?a.getElementsByTagName("tbody")[0]||a.appendChild(a.ownerDocument.createElement("tbody")):a}function W(a,b,c){b=b||0;if(f.isFunction(b))return f.grep(a,function(a,d){var e=!!b.call(a,d,a);return e===c});if(b.nodeType)return f.grep(a,function(a,d){return a===b===c});if(typeof b=="string"){var d=f.grep(a,function(a){return a.nodeType===1});if(R.test(b))return f.filter(b,d,!c);b=f.filter(b,d)}return f.grep(a,function(a,d){return f.inArray(a,b)>=0===c})}function V(a){return!a||!a.parentNode||a.parentNode.nodeType===11}function N(a,b){return(a&&a!=="*"?a+".":"")+b.replace(z,"`").replace(A,"&")}function M(a){var b,c,d,e,g,h,i,j,k,l,m,n,o,p=[],q=[],r=f._data(this,"events");if(!(a.liveFired===this||!r||!r.live||a.target.disabled||a.button&&a.type==="click")){a.namespace&&(n=new RegExp("(^|\\.)"+a.namespace.split(".").join("\\.(?:.*\\.)?")+"(\\.|$)")),a.liveFired=this;var s=r.live.slice(0);for(i=0;i<s.length;i++)g=s[i],g.origType.replace(x,"")===a.type?q.push(g.selector):s.splice(i--,1);e=f(a.target).closest(q,a.currentTarget);for(j=0,k=e.length;j<k;j++){m=e[j];for(i=0;i<s.length;i++){g=s[i];if(m.selector===g.selector&&(!n||n.test(g.namespace))&&!m.elem.disabled){h=m.elem,d=null;if(g.preType==="mouseenter"||g.preType==="mouseleave")a.type=g.preType,d=f(a.relatedTarget).closest(g.selector)[0],d&&f.contains(h,d)&&(d=h);(!d||d!==h)&&p.push({elem:h,handleObj:g,level:m.level})}}}for(j=0,k=p.length;j<k;j++){e=p[j];if(c&&e.level>c)break;a.currentTarget=e.elem,a.data=e.handleObj.data,a.handleObj=e.handleObj,o=e.handleObj.origHandler.apply(e.elem,arguments);if(o===!1||a.isPropagationStopped()){c=e.level,o===!1&&(b=!1);if(a.isImmediatePropagationStopped())break}}return b}}function K(a,c,d){var e=f.extend({},d[0]);e.type=a,e.originalEvent={},e.liveFired=b,f.event.handle.call(c,e),e.isDefaultPrevented()&&d[0].preventDefault()}function E(){return!0}function D(){return!1}function m(a,c,d){var e=c+"defer",g=c+"queue",h=c+"mark",i=f.data(a,e,b,!0);i&&(d==="queue"||!f.data(a,g,b,!0))&&(d==="mark"||!f.data(a,h,b,!0))&&setTimeout(function(){!f.data(a,g,b,!0)&&!f.data(a,h,b,!0)&&(f.removeData(a,e,!0),i.resolve())},0)}function l(a){for(var b in a)if(b!=="toJSON")return!1;return!0}function k(a,c,d){if(d===b&&a.nodeType===1){name="data-"+c.replace(j,"$1-$2").toLowerCase(),d=a.getAttribute(name);if(typeof d=="string"){try{d=d==="true"?!0:d==="false"?!1:d==="null"?null:f.isNaN(d)?i.test(d)?f.parseJSON(d):d:parseFloat(d)}catch(e){}f.data(a,c,d)}else d=b}return d}var c=a.document,d=a.navigator,e=a.location,f=function(){function H(){if(!e.isReady){try{c.documentElement.doScroll("left")}catch(a){setTimeout(H,1);return}e.ready()}}var e=function(a,b){return new e.fn.init(a,b,h)},f=a.jQuery,g=a.$,h,i=/^(?:[^<]*(<[\w\W]+>)[^>]*$|#([\w\-]*)$)/,j=/\S/,k=/^\s+/,l=/\s+$/,m=/\d/,n=/^<(\w+)\s*\/?>(?:<\/\1>)?$/,o=/^[\],:{}\s]*$/,p=/\\(?:["\\\/bfnrt]|u[0-9a-fA-F]{4})/g,q=/"[^"\\\n\r]*"|true|false|null|-?\d+(?:\.\d*)?(?:[eE][+\-]?\d+)?/g,r=/(?:^|:|,)(?:\s*\[)+/g,s=/(webkit)[ \/]([\w.]+)/,t=/(opera)(?:.*version)?[ \/]([\w.]+)/,u=/(msie) ([\w.]+)/,v=/(mozilla)(?:.*? rv:([\w.]+))?/,w=d.userAgent,x,y,z,A=Object.prototype.toString,B=Object.prototype.hasOwnProperty,C=Array.prototype.push,D=Array.prototype.slice,E=String.prototype.trim,F=Array.prototype.indexOf,G={};e.fn=e.prototype={constructor:e,init:function(a,d,f){var g,h,j,k;if(!a)return this;if(a.nodeType){this.context=this[0]=a,this.length=1;return this}if(a==="body"&&!d&&c.body){this.context=c,this[0]=c.body,this.selector=a,this.length=1;return this}if(typeof a=="string"){a.charAt(0)==="<"&&a.charAt(a.length-1)===">"&&a.length>=3?g=[null,a,null]:g=i.exec(a);if(g&&(g[1]||!d)){if(g[1]){d=d instanceof e?d[0]:d,k=d?d.ownerDocument||d:c,j=n.exec(a),j?e.isPlainObject(d)?(a=[c.createElement(j[1])],e.fn.attr.call(a,d,!0)):a=[k.createElement(j[1])]:(j=e.buildFragment([g[1]],[k]),a=(j.cacheable?e.clone(j.fragment):j.fragment).childNodes);return e.merge(this,a)}h=c.getElementById(g[2]);if(h&&h.parentNode){if(h.id!==g[2])return f.find(a);this.length=1,this[0]=h}this.context=c,this.selector=a;return this}return!d||d.jquery?(d||f).find(a):this.constructor(d).find(a)}if(e.isFunction(a))return f.ready(a);a.selector!==b&&(this.selector=a.selector,this.context=a.context);return e.makeArray(a,this)},selector:"",jquery:"1.6",length:0,size:function(){return this.length},toArray:function(){return D.call(this,0)},get:function(a){return a==null?this.toArray():a<0?this[this.length+a]:this[a]},pushStack:function(a,b,c){var d=this.constructor();e.isArray(a)?C.apply(d,a):e.merge(d,a),d.prevObject=this,d.context=this.context,b==="find"?d.selector=this.selector+(this.selector?" ":"")+c:b&&(d.selector=this.selector+"."+b+"("+c+")");return d},each:function(a,b){return e.each(this,a,b)},ready:function(a){e.bindReady(),y.done(a);return this},eq:function(a){return a===-1?this.slice(a):this.slice(a,+a+1)},first:function(){return this.eq(0)},last:function(){return this.eq(-1)},slice:function(){return this.pushStack(D.apply(this,arguments),"slice",D.call(arguments).join(","))},map:function(a){return this.pushStack(e.map(this,function(b,c){return a.call(b,c,b)}))},end:function(){return this.prevObject||this.constructor(null)},push:C,sort:[].sort,splice:[].splice},e.fn.init.prototype=e.fn,e.extend=e.fn.extend=function(){var a,c,d,f,g,h,i=arguments[0]||{},j=1,k=arguments.length,l=!1;typeof i=="boolean"&&(l=i,i=arguments[1]||{},j=2),typeof i!="object"&&!e.isFunction(i)&&(i={}),k===j&&(i=this,--j);for(;j<k;j++)if((a=arguments[j])!=null)for(c in a){d=i[c],f=a[c];if(i===f)continue;l&&f&&(e.isPlainObject(f)||(g=e.isArray(f)))?(g?(g=!1,h=d&&e.isArray(d)?d:[]):h=d&&e.isPlainObject(d)?d:{},i[c]=e.extend(l,h,f)):f!==b&&(i[c]=f)}return i},e.extend({noConflict:function(b){a.$===e&&(a.$=g),b&&a.jQuery===e&&(a.jQuery=f);return e},isReady:!1,readyWait:1,holdReady:function(a){a?e.readyWait++:e.ready(!0)},ready:function(a){if(a===!0&&!--e.readyWait||a!==!0&&!e.isReady){if(!c.body)return setTimeout(e.ready,1);e.isReady=!0;if(a!==!0&&--e.readyWait>0)return;y.resolveWith(c,[e]),e.fn.trigger&&e(c).trigger("ready").unbind("ready")}},bindReady:function(){if(!y){y=e._Deferred();if(c.readyState==="complete")return setTimeout(e.ready,1);if(c.addEventListener)c.addEventListener("DOMContentLoaded",z,!1),a.addEventListener("load",e.ready,!1);else if(c.attachEvent){c.attachEvent("onreadystatechange",z),a.attachEvent("onload",e.ready);var b=!1;try{b=a.frameElement==null}catch(d){}c.documentElement.doScroll&&b&&H()}}},isFunction:function(a){return e.type(a)==="function"},isArray:Array.isArray||function(a){return e.type(a)==="array"},isWindow:function(a){return a&&typeof a=="object"&&"setInterval"in a},isNaN:function(a){return a==null||!m.test(a)||isNaN(a)},type:function(a){return a==null?String(a):G[A.call(a)]||"object"},isPlainObject:function(a){if(!a||e.type(a)!=="object"||a.nodeType||e.isWindow(a))return!1;if(a.constructor&&!B.call(a,"constructor")&&!B.call(a.constructor.prototype,"isPrototypeOf"))return!1;var c;for(c in a);return c===b||B.call(a,c)},isEmptyObject:function(a){for(var b in a)return!1;return!0},error:function(a){throw a},parseJSON:function(b){if(typeof b!="string"||!b)return null;b=e.trim(b);if(a.JSON&&a.JSON.parse)return a.JSON.parse(b);if(o.test(b.replace(p,"@").replace(q,"]").replace(r,"")))return(new Function("return "+b))();e.error("Invalid JSON: "+b)},parseXML:function(b,c,d){a.DOMParser?(d=new DOMParser,c=d.parseFromString(b,"text/xml")):(c=new ActiveXObject("Microsoft.XMLDOM"),c.async="false",c.loadXML(b)),d=c.documentElement,(!d||!d.nodeName||d.nodeName==="parsererror")&&e.error("Invalid XML: "+b);return c},noop:function(){},globalEval:function(b){b&&j.test(b)&&(a.execScript||function(b){a.eval.call(a,b)})(b)},nodeName:function(a,b){return a.nodeName&&a.nodeName.toUpperCase()===b.toUpperCase()},each:function(a,c,d){var f,g=0,h=a.length,i=h===b||e.isFunction(a);if(d){if(i){for(f in a)if(c.apply(a[f],d)===!1)break}else for(;g<h;)if(c.apply(a[g++],d)===!1)break}else if(i){for(f in a)if(c.call(a[f],f,a[f])===!1)break}else for(;g<h;)if(c.call(a[g],g,a[g++])===!1)break;return a},trim:E?function(a){return a==null?"":E.call(a)}:function(a){return a==null?"":(a+"").replace(k,"").replace(l,"")},makeArray:function(a,b){var c=b||[];if(a!=null){var d=e.type(a);a.length==null||d==="string"||d==="function"||d==="regexp"||e.isWindow(a)?C.call(c,a):e.merge(c,a)}return c},inArray:function(a,b){if(F)return F.call(b,a);for(var c=0,d=b.length;c<d;c++)if(b[c]===a)return c;return-1},merge:function(a,c){var d=a.length,e=0;if(typeof c.length=="number")for(var f=c.length;e<f;e++)a[d++]=c[e];else while(c[e]!==b)a[d++]=c[e++];a.length=d;return a},grep:function(a,b,c){var d=[],e;c=!!c;for(var f=0,g=a.length;f<g;f++)e=!!b(a[f],f),c!==e&&d.push(a[f]);return d},map:function(a,c,d){var f,g,h=[],i=0,j=a.length,k=a instanceof e||j!==b&&typeof j=="number"&&(j>0&&a[0]&&a[j-1]||j===0||e.isArray(a));if(k)for(;i<j;i++)f=c(a[i],i,d),f!=null&&(h[h.length]=f);else for(g in a)f=c(a[g],g,d),f!=null&&(h[h.length]=f);return h.concat.apply([],h)},guid:1,proxy:function(a,c){if(typeof c=="string"){var d=a[c];c=a,a=d}if(!e.isFunction(a))return b;var f=D.call(arguments,2),g=function(){return a.apply(c,f.concat(D.call(arguments)))};g.guid=a.guid=a.guid||g.guid||e.guid++;return g},access:function(a,c,d,f,g,h){var i=a.length;if(typeof c=="object"){for(var j in c)e.access(a,j,c[j],f,g,d);return a}if(d!==b){f=!h&&f&&e.isFunction(d);for(var k=0;k<i;k++)g(a[k],c,f?d.call(a[k],k,g(a[k],c)):d,h);return a}return i?g(a[0],c):b},now:function(){return(new Date).getTime()},uaMatch:function(a){a=a.toLowerCase();var b=s.exec(a)||t.exec(a)||u.exec(a)||a.indexOf("compatible")<0&&v.exec(a)||[];return{browser:b[1]||"",version:b[2]||"0"}},sub:function(){function a(b,c){return new a.fn.init(b,c)}e.extend(!0,a,this),a.superclass=this,a.fn=a.prototype=this(),a.fn.constructor=a,a.sub=this.sub,a.fn.init=function(c,d){d&&d instanceof e&&!(d instanceof a)&&(d=a(d));return e.fn.init.call(this,c,d,b)},a.fn.init.prototype=a.fn;var b=a(c);return a},browser:{}}),e.each("Boolean Number String Function Array Date RegExp Object".split(" "),function(a,b){G["[object "+b+"]"]=b.toLowerCase()}),x=e.uaMatch(w),x.browser&&(e.browser[x.browser]=!0,e.browser.version=x.version),e.browser.webkit&&(e.browser.safari=!0),j.test(" ")&&(k=/^[\s\xA0]+/,l=/[\s\xA0]+$/),h=e(c),c.addEventListener?z=function(){c.removeEventListener("DOMContentLoaded",z,!1),e.ready()}:c.attachEvent&&(z=function(){c.readyState==="complete"&&(c.detachEvent("onreadystatechange",z),e.ready())});return e}(),g="done fail isResolved isRejected promise then always pipe".split(" "),h=[].slice;f.extend({_Deferred:function(){var a=[],b,c,d,e={done:function(){if(!d){var c=arguments,g,h,i,j,k;b&&(k=b,b=0);for(g=0,h=c.length;g<h;g++)i=c[g],j=f.type(i),j==="array"?e.done.apply(e,i):j==="function"&&a.push(i);k&&e.resolveWith(k[0],k[1])}return this},resolveWith:function(e,f){if(!d&&!b&&!c){f=f||[],c=1;try{while(a[0])a.shift().apply(e,f)}finally{b=[e,f],c=0}}return this},resolve:function(){e.resolveWith(this,arguments);return this},isResolved:function(){return!!c||!!b},cancel:function(){d=1,a=[];return this}};return e},Deferred:function(a){var b=f._Deferred(),c=f._Deferred(),d;f.extend(b,{then:function(a,c){b.done(a).fail(c);return this},always:function(){return b.done.apply(b,arguments).fail.apply(this,arguments)},fail:c.done,rejectWith:c.resolveWith,reject:c.resolve,isRejected:c.isResolved,pipe:function(a,c){return f.Deferred(function(d){f.each({done:[a,"resolve"],fail:[c,"reject"]},function(a,c){var e=c[0],g=c[1],h;f.isFunction(e)?b[a](function(){h=e.apply(this,arguments),f.isFunction(h.promise)?h.promise().then(d.resolve,d.reject):d[g](h)}):b[a](d[g])})}).promise()},promise:function(a){if(a==null){if(d)return d;d=a={}}var c=g.length;while(c--)a[g[c]]=b[g[c]];return a}}),b.done(c.cancel).fail(b.cancel),delete b.cancel,a&&a.call(b,b);return b},when:function(a){function i(a){return function(c){b[a]=arguments.length>1?h.call(arguments,0):c,--e||g.resolveWith(g,h.call(b,0))}}var b=arguments,c=0,d=b.length,e=d,g=d<=1&&a&&f.isFunction(a.promise)?a:f.Deferred();if(d>1){for(;c<d;c++)b[c]&&f.isFunction(b[c].promise)?b[c].promise().then(i(c),g.reject):--e;e||g.resolveWith(g,b)}else g!==a&&g.resolveWith(g,d?[a]:[]);return g.promise()}}),f.support=function(){var a=c.createElement("div"),b,d,e,f,g,h,i,j,k,l,m,n,o,p,q;a.setAttribute("className","t"),a.innerHTML="   <link/><table></table><a href='/a' style='top:1px;float:left;opacity:.55;'>a</a><input type='checkbox'/>",b=a.getElementsByTagName("*"),d=a.getElementsByTagName("a")[0];if(!b||!b.length||!d)return{};e=c.createElement("select"),f=e.appendChild(c.createElement("option")),g=a.getElementsByTagName("input")[0],i={leadingWhitespace:a.firstChild.nodeType===3,tbody:!a.getElementsByTagName("tbody").length,htmlSerialize:!!a.getElementsByTagName("link").length,style:/top/.test(d.getAttribute("style")),hrefNormalized:d.getAttribute("href")==="/a",opacity:/^0.55$/.test(d.style.opacity),cssFloat:!!d.style.cssFloat,checkOn:g.value==="on",optSelected:f.selected,getSetAttribute:a.className!=="t",submitBubbles:!0,changeBubbles:!0,focusinBubbles:!1,deleteExpando:!0,noCloneEvent:!0,inlineBlockNeedsLayout:!1,shrinkWrapBlocks:!1,reliableMarginRight:!0},g.checked=!0,i.noCloneChecked=g.cloneNode(!0).checked,e.disabled=!0,i.optDisabled=!f.disabled;try{delete a.test}catch(r){i.deleteExpando=!1}!a.addEventListener&&a.attachEvent&&a.fireEvent&&(a.attachEvent("onclick",function click(){i.noCloneEvent=!1,a.detachEvent("onclick",click)}),a.cloneNode(!0).fireEvent("onclick")),g=c.createElement("input"),g.value="t",g.setAttribute("type","radio"),i.radioValue=g.value==="t",g.setAttribute("checked","checked"),a.appendChild(g),j=c.createDocumentFragment(),j.appendChild(a.firstChild),i.checkClone=j.cloneNode(!0).cloneNode(!0).lastChild.checked,a.innerHTML="",a.style.width=a.style.paddingLeft="1px",k=c.createElement("body"),l={visibility:"hidden",width:0,height:0,border:0,margin:0,background:"none"};for(p in l)k.style[p]=l[p];k.appendChild(a),c.documentElement.appendChild(k),i.appendChecked=g.checked,i.boxModel=a.offsetWidth===2,"zoom"in a.style&&(a.style.display="inline",a.style.zoom=1,i.inlineBlockNeedsLayout=a.offsetWidth===2,a.style.display="",a.innerHTML="<div style='width:4px;'></div>",i.shrinkWrapBlocks=a.offsetWidth!==2),a.innerHTML="<table><tr><td style='padding:0;border:0;display:none'></td><td>t</td></tr></table>",m=a.getElementsByTagName("td"),q=m[0].offsetHeight===0,m[0].style.display="",m[1].style.display="none",i.reliableHiddenOffsets=q&&m[0].offsetHeight===0,a.innerHTML="",c.defaultView&&c.defaultView.getComputedStyle&&(h=c.createElement("div"),h.style.width="0",h.style.marginRight="0",a.appendChild(h),i.reliableMarginRight=(parseInt(c.defaultView.getComputedStyle(h,null).marginRight,10)||0)===0),k.innerHTML="",c.documentElement.removeChild(k);if(a.attachEvent)for(p in{submit:1,change:1,focusin:1})o="on"+p,q=o in a,q||(a.setAttribute(o,"return;"),q=typeof a[o]=="function"),i[p+"Bubbles"]=q;return i}(),f.boxModel=f.support.boxModel;var i=/^(?:\{.*\}|\[.*\])$/,j=/([a-z])([A-Z])/g;f.extend({cache:{},uuid:0,expando:"jQuery"+(f.fn.jquery+Math.random()).replace(/\D/g,""),noData:{embed:!0,object:"clsid:D27CDB6E-AE6D-11cf-96B8-444553540000",applet:!0},hasData:function(a){a=a.nodeType?f.cache[a[f.expando]]:a[f.expando];return!!a&&!l(a)},data:function(a,c,d,e){if(!!f.acceptData(a)){var g=f.expando,h=typeof c=="string",i,j=a.nodeType,k=j?f.cache:a,l=j?a[f.expando]:a[f.expando]&&f.expando;if((!l||e&&l&&!k[l][g])&&h&&d===b)return;l||(j?a[f.expando]=l=++f.uuid:l=f.expando),k[l]||(k[l]={},j||(k[l].toJSON=f.noop));if(typeof c=="object"||typeof c=="function")e?k[l][g]=f.extend(k[l][g],c):k[l]=f.extend(k[l],c);i=k[l],e&&(i[g]||(i[g]={}),i=i[g]),d!==b&&(i[c]=d);if(c==="events"&&!i[c])return i[g]&&i[g].events;return h?i[c]:i}},removeData:function(b,c,d){if(!!f.acceptData(b)){var e=f.expando,g=b.nodeType,h=g?f.cache:b,i=g?b[f.expando]:f.expando;if(!h[i])return;if(c){var j=d?h[i][e]:h[i];if(j){delete j[c];if(!l(j))return}}if(d){delete h[i][e];if(!l(h[i]))return}var k=h[i][e];f.support.deleteExpando||h!=a?delete h[i]:h[i]=null,k?(h[i]={},g||(h[i].toJSON=f.noop),h[i][e]=k):g&&(f.support.deleteExpando?delete b[f.expando]:b.removeAttribute?b.removeAttribute(f.expando):b[f.expando]=null)}},_data:function(a,b,c){return f.data(a,b,c,!0)},acceptData:function(a){if(a.nodeName){var b=f.noData[a.nodeName.toLowerCase()];if(b)return b!==!0&&a.getAttribute("classid")===b}return!0}}),f.fn.extend({data:function(a,c){var d=null;if(typeof a=="undefined"){if(this.length){d=f.data(this[0]);if(this[0].nodeType===1){var e=this[0].attributes,g;for(var h=0,i=e.length;h<i;h++)g=e[h].name,g.indexOf("data-")===0&&(g=f.camelCase(g.substring(5)),k(this[0],g,d[g]))}}return d}if(typeof a=="object")return this.each(function(){f.data(this,a)});var j=a.split(".");j[1]=j[1]?"."+j[1]:"";if(c===b){d=this.triggerHandler("getData"+j[1]+"!",[j[0]]),d===b&&this.length&&(d=f.data(this[0],a),d=k(this[0],a,d));return d===b&&j[1]?this.data(j[0]):d}return this.each(function(){var b=f(this),d=[j[0],c];b.triggerHandler("setData"+j[1]+"!",d),f.data(this,a,c),b.triggerHandler("changeData"+j[1]+"!",d)})},removeData:function(a){return this.each(function(){f.removeData(this,a)})}}),f.extend({_mark:function(a,c){a&&(c=(c||"fx")+"mark",f.data(a,c,(f.data(a,c,b,!0)||0)+1,!0))},_unmark:function(a,c,d){a!==!0&&(d=c,c=a,a=!1);if(c){d=d||"fx";var e=d+"mark",g=a?0:(f.data(c,e,b,!0)||1)-1;g?f.data(c,e,g,!0):(f.removeData(c,e,!0),m(c,d,"mark"))}},queue:function(a,c,d){if(a){c=(c||"fx")+"queue";var e=f.data(a,c,b,!0);d&&(!e||f.isArray(d)?e=f.data(a,c,f.makeArray(d),!0):e.push(d));return e||[]}},dequeue:function(a,b){b=b||"fx";var c=f.queue(a,b),d=c.shift(),e;d==="inprogress"&&(d=c.shift()),d&&(b==="fx"&&c.unshift("inprogress"),d.call(a,function(){f.dequeue(a,b)})),c.length||(f.removeData(a,b+"queue",!0),m(a,b,"queue"))}}),f.fn.extend({queue:function(a,c){typeof a!="string"&&(c=a,a="fx");if(c===b)return f.queue(this[0],a);return this.each(function(){var b=f.queue(this,a,c);a==="fx"&&b[0]!=="inprogress"&&f.dequeue(this,a)})},dequeue:function(a){return this.each(function(){f.dequeue(this,a)})},delay:function(a,b){a=f.fx?f.fx.speeds[a]||a:a,b=b||"fx";return this.queue(b,function(){var c=this;setTimeout(function(){f.dequeue(c,b)},a)})},clearQueue:function(a){return this.queue(a||"fx",[])},promise:function(a,c){function l(){--h||d.resolveWith(e,[e])}typeof a!="string"&&(c=a,a=b),a=a||"fx";var d=f.Deferred(),e=this,g=e.length,h=1,i=a+"defer",j=a+"queue",k=a+"mark";while(g--)if(tmp=f.data(e[g],i,b,!0)||(f.data(e[g],j,b,!0)||f.data(e[g],k,b,!0))&&f.data(e[g],i,f._Deferred(),!0))h++,tmp.done(l);l();return d.promise()}});var n=/[\n\t\r]/g,o=/\s+/,p=/\r/g,q=/^(?:button|input)$/i,r=/^(?:button|input|object|select|textarea)$/i,s=/^a(?:rea)?$/i,t=/^(?:data-|aria-)/,u=/\:/,v;f.fn.extend({attr:function(a,b){return f.access(this,a,b,!0,f.attr)},removeAttr:function(a){return this.each(function(){f.removeAttr(this,a)})},prop:function(a,b){return f.access(this,a,b,!0,f.prop)},removeProp:function(a){return this.each(function(){try{this[a]=b,delete this[a]}catch(c){}})},addClass:function(a){if(f.isFunction(a))return this.each(function(b){var c=f(this);c.addClass(a.call(this,b,c.attr("class")||""))});if(a&&typeof a=="string"){var b=(a||"").split(o);for(var c=0,d=this.length;c<d;c++){var e=this[c];if(e.nodeType===1)if(!e.className)e.className=a;else{var g=" "+e.className+" ",h=e.className;for(var i=0,j=b.length;i<j;i++)g.indexOf(" "+b[i]+" ")<0&&(h+=" "+b[i]);e.className=f.trim(h)}}}return this},removeClass:function(a){if(f.isFunction(a))return this.each(function(b){var c=f(this);c.removeClass(a.call(this,b,c.attr("class")))});if(a&&typeof a=="string"||a===b){var c=(a||"").split(o);for(var d=0,e=this.length;d<e;d++){var g=this[d];if(g.nodeType===1&&g.className)if(a){var h=(" "+g.className+" ").replace(n," ");for(var i=0,j=c.length;i<j;i++)h=h.replace(" "+c[i]+" "," ");g.className=f.trim(h)}else g.className=""}}return this},toggleClass:function(a,b){var c=typeof a,d=typeof b=="boolean";if(f.isFunction(a))return this.each(function(c){var d=f(this);d.toggleClass(a.call(this,c,d.attr("class"),b),b)});return this.each(function(){if(c==="string"){var e,g=0,h=f(this),i=b,j=a.split(o);while(e=j[g++])i=d?i:!h.hasClass(e),h[i?"addClass":"removeClass"](e)}else if(c==="undefined"||c==="boolean")this.className&&f._data(this,"__className__",this.className),this.className=this.className||a===!1?"":f._data(this,"__className__")||""})},hasClass:function(a){var b=" "+a+" ";for(var c=0,d=this.length;c<d;c++)if((" "+this[c].className+" ").replace(n," ").indexOf(b)>-1)return!0;return!1},val:function(a){var c,d,e=this[0];if(!arguments.length){if(e){c=f.valHooks[e.nodeName.toLowerCase()]||f.valHooks[e.type];if(c&&"get"in c&&(d=c.get(e,"value"))!==b)return d;return(e.value||"").replace(p,"")}return b}var g=f.isFunction(a);return this.each(function(d){var e=f(this),h;if(this.nodeType===1){g?h=a.call(this,d,e.val()):h=a,h==null?h="":typeof h=="number"?h+="":f.isArray(h)&&(h=f.map(h,function(a){return a==null?"":a+""})),c=f.valHooks[this.nodeName.toLowerCase()]||f.valHooks[this.type];if(!c||"set"in c&&c.set(this,h,"value")===b)this.value=h}})}}),f.extend({valHooks:{option:{get:function(a){var b=a.attributes.value;return!b||b.specified?a.value:a.text}},select:{get:function(a){var b=a.selectedIndex,c=[],d=a.options,e=a.type==="select-one";if(b<0)return null;for(var g=e?b:0,h=e?b+1:d.length;g<h;g++){var i=d[g];if(i.selected&&(f.support.optDisabled?!i.disabled:i.getAttribute("disabled")===null)&&(!i.parentNode.disabled||!f.nodeName(i.parentNode,"optgroup"))){value=f(i).val();if(e)return value;c.push(value)}}if(e&&!c.length&&d.length)return f(d[b]).val();return c},set:function(a,b){var c=f.makeArray(b);f(a).find("option").each(function(){this.selected=f.inArray(f(this).val(),c)>=0}),c.length||(a.selectedIndex=-1);return c}}},attrFn:{val:!0,css:!0,html:!0,text:!0,data:!0,width:!0,height:!0,offset:!0},attrFix:{tabindex:"tabIndex",readonly:"readOnly"},attr:function(a,c,d,e){var g=a.nodeType;if(!a||g===3||g===8||g===2)return b;if(e&&c in f.attrFn)return f(a)[c](d);var h,i,j=g!==1||!f.isXMLDoc(a);c=j&&f.attrFix[c]||c,i=f.attrHooks[c]||(v&&(f.nodeName(a,"form")||u.test(c))?v:b);if(d!==b){if(d===null||d===!1&&!t.test(c)){f.removeAttr(a,c);return b}if(i&&"set"in i&&j&&(h=i.set(a,d,c))!==b)return h;d===!0&&!t.test(c)&&(d=c),a.setAttribute(c,""+d);return d}if(i&&"get"in i&&j)return i.get(a,c);h=a.getAttribute(c);return h===null?b:h},removeAttr:function(a,b){a.nodeType===1&&(b=f.attrFix[b]||b,f.support.getSetAttribute?a.removeAttribute(b):(f.attr(a,b,""),a.removeAttributeNode(a.getAttributeNode(b))))},attrHooks:{type:{set:function(a,b){if(q.test(a.nodeName)&&a.parentNode)f.error("type property can't be changed");else if(!f.support.radioValue&&b==="radio"&&f.nodeName(a,"input")){var c=a.getAttribute("value");a.setAttribute("type",b),c&&(a.value=c);return b}}},tabIndex:{get:function(a){var c=a.getAttributeNode("tabIndex");return c&&c.specified?parseInt(c.value,10):r.test(a.nodeName)||s.test(a.nodeName)&&a.href?0:b}}},propFix:{},prop:function(a,c,d){var e=a.nodeType;if(!a||e===3||e===8||e===2)return b;var g,h,i=e!==1||!f.isXMLDoc(a);c=i&&f.propFix[c]||c,h=f.propHooks[c];return d!==b?h&&"set"in h&&(g=h.set(a,d,c))!==b?g:a[c]=d:h&&"get"in h&&(g=h.get(a,c))!==b?g:a[c]},propHooks:{}}),f.support.getSetAttribute||(f.attrFix=f.extend(f.attrFix,{"for":"htmlFor","class":"className",maxlength:"maxLength",cellspacing:"cellSpacing",cellpadding:"cellPadding",rowspan:"rowSpan",colspan:"colSpan",usemap:"useMap",frameborder:"frameBorder"}),v=f.attrHooks.name=f.attrHooks.value=f.valHooks.button={get:function(a,c){var d;if(c==="value"&&!f.nodeName(a,"button"))return a.getAttribute(c);d=a.getAttributeNode(c);return d&&d.specified?d.nodeValue:b},set:function(a,b,c){var d=a.getAttributeNode(c);if(d){d.nodeValue=b;return b}}},f.each(["width","height"],function(a,b){f.attrHooks[b]=f.extend(f.attrHooks[b],{set:function(a,c){if(c===""){a.setAttribute(b,"auto");return c}}})})),f.support.hrefNormalized||f.each(["href","src","width","height"],function(a,c){f.attrHooks[c]=f.extend(f.attrHooks[c],{get:function(a){var d=a.getAttribute(c,2);return d===null?b:d}})}),f.support.style||(f.attrHooks.style={get:function(a){return a.style.cssText.toLowerCase()||b},set:function(a,b){return a.style.cssText=""+b}}),f.support.optSelected||(f.propHooks.selected=f.extend(f.propHooks.selected,{get:function(a){var b=a.parentNode;b&&(b.selectedIndex,b.parentNode&&b.parentNode.selectedIndex)}})),f.support.checkOn||f.each(["radio","checkbox"],function(){f.valHooks[this]={get:function(a){return a.getAttribute("value")===null?"on":a.value}}}),f.each(["radio","checkbox"],function(){f.valHooks[this]=f.extend(f.valHooks[this],{set:function(a,b){if(f.isArray(b))return a.checked=f.inArray(f(a).val(),b)>=0}})});var w=Object.prototype.hasOwnProperty,x=/\.(.*)$/,y=/^(?:textarea|input|select)$/i,z=/\./g,A=/ /g,B=/[^\w\s.|`]/g,C=function(a){return a.replace(B,"\\$&")};f.event={add:function(a,c,d,e){if(a.nodeType!==3&&a.nodeType!==8){if(d===!1)d=D;else if(!d)return;var g,h;d.handler&&(g=d,d=g.handler),d.guid||(d.guid=f.guid++);var i=f._data(a);if(!i)return;var j=i.events,k=i.handle;j||(i.events=j={}),k||(i.handle=k=function(a){return typeof f!="undefined"&&(!a||f.event.triggered!==a.type)?f.event.handle.apply(k.elem,arguments):b}),k.elem=a,c=c.split(" ");var l,m=0,n;while(l=c[m++]){h=g?f.extend({},g):{handler:d,data:e},l.indexOf(".")>-1?(n=l.split("."),l=n.shift(),h.namespace=n.slice(0).sort().join(".")):(n=[],h.namespace=""),h.type=l,h.guid||(h.guid=d.guid);var o=j[l],p=f.event.special[l]||{};if(!o){o=j[l]=[];if(!p.setup||p.setup.call(a,e,n,k)===!1)a.addEventListener?a.addEventListener(l,k,!1):a.attachEvent&&a.attachEvent("on"+l,k)}p.add&&(p.add.call(a,h),h.handler.guid||(h.handler.guid=d.guid)),o.push(h),f.event.global[l]=!0}a=null}},global:{},remove:function(a,c,d,e){if(a.nodeType!==3&&a.nodeType!==8){d===!1&&(d=D);var g,h,i,j,k=0,l,m,n,o,p,q,r,s=f.hasData(a)&&f._data(a),t=s&&s.events;if(!s||!t)return;c&&c.type&&(d=c.handler,c=c.type);if(!c||typeof c=="string"&&c.charAt(0)==="."){c=c||"";for(h in t)f.event.remove(a,h+c);return}c=c.split(" ");while(h=c[k++]){r=h,q=null,l=h.indexOf(".")<0,m=[],l||(m=h.split("."),h=m.shift(),n=new RegExp("(^|\\.)"+f.map(m.slice(0).sort(),C).join("\\.(?:.*\\.)?")+"(\\.|$)")),p=t[h];if(!p)continue;if(!d){for(j=0;j<p.length;j++){q=p[j];if(l||n.test(q.namespace))f.event.remove(a,r,q.handler,j),p.splice(j--,1)}continue}o=f.event.special[h]||{};for(j=e||0;j<p.length;j++){q=p[j];if(d.guid===q.guid){if(l||n.test(q.namespace))e==null&&p.splice(j--,1),o.remove&&o.remove.call(a,q);if(e!=null)break}}if(p.length===0||e!=null&&p.length===1)(!o.teardown||o.teardown.call(a,m)===!1)&&f.removeEvent(a,h,s.handle),g=null,delete t[h]}if(f.isEmptyObject(t)){var u=s.handle;u&&(u.elem=null),delete s.events,delete s.handle,f.isEmptyObject(s)&&f.removeData(a,b,!0)}}},customEvent:{getData:!0,setData:!0,changeData:!0},trigger:function(c,d,e,g){var h=c.type||c,i=[],j;h.indexOf("!")>=0&&(h=h.slice(0,-1),j=!0),h.indexOf(".")>=0&&(i=h.split("."),h=i.shift(),i.sort());if(!!e&&!f.event.customEvent[h]||!!f.event.global[h]){c=typeof c=="object"?c[f.expando]?c:new f.Event(h,c):new f.Event(h),c.type=h,c.exclusive=j,c.namespace=i.join("."),c.namespace_re=new RegExp("(^|\\.)"+i.join("\\.(?:.*\\.)?")+"(\\.|$)");if(g||!e)c.preventDefault(),c.stopPropagation();if(!e){f.each(f.cache,function(){var a=f.expando,b=this[a];b&&b.events&&b.events[h]&&f.event.trigger(c,d,b.handle.elem)});return}if(e.nodeType===3||e.nodeType===8)return;c.result=b,c.target=e,d=d?f.makeArray(d):[],d.unshift(c);var k=e,l=h.indexOf(":")<0?"on"+h:"";do{var m=f._data(k,"handle");c.currentTarget=k,m&&m.apply(k,d),l&&f.acceptData(k)&&k[l]&&k[l].apply(k,d)===!1&&(c.result=!1,c.preventDefault()),k=k.parentNode||k.ownerDocument||k===c.target.ownerDocument&&a}while(k&&!c.isPropagationStopped());if(!c.isDefaultPrevented()){var n,o=f.event.special[h]||{};if((!o._default||o._default.call(e.ownerDocument,c)===!1)&&(h!=="click"||!f.nodeName(e,"a"))&&f.acceptData(e)){try{l&&e[h]&&(n=e[l],n&&(e[l]=null),f.event.triggered=h,e[h]())}catch(p){}n&&(e[l]=n),f.event.triggered=b}}return c.result}},handle:function(c){c=f.event.fix(c||a.event);var d=((f._data(this,"events")||{})[c.type]||[]).slice(0),e=!c.exclusive&&!c.namespace,g=Array.prototype.slice.call(arguments,0);g[0]=c,c.currentTarget=this;for(var h=0,i=d.length;h<i;h++){var j=d[h];if(e||c.namespace_re.test(j.namespace)){c.handler=j.handler,c.data=j.data,c.handleObj=j;var k=j.handler.apply(this,g);k!==b&&(c.result=k,k===!1&&(c.preventDefault(),c.stopPropagation()));if(c.isImmediatePropagationStopped())break}}return c.result},props:"altKey attrChange attrName bubbles button cancelable charCode clientX clientY ctrlKey currentTarget data detail eventPhase fromElement handler keyCode layerX layerY metaKey newValue offsetX offsetY pageX pageY prevValue relatedNode relatedTarget screenX screenY shiftKey srcElement target toElement view wheelDelta which".split(" "),fix:function(a){if(a[f.expando])return a;var d=a;a=f.Event(d);for(var e=this.props.length,g;e;)g=this.props[--e],a[g]=d[g];a.target||(a.target=a.srcElement||c),a.target.nodeType===3&&(a.target=a.target.parentNode),!a.relatedTarget&&a.fromElement&&(a.relatedTarget=a.fromElement===a.target?a.toElement:a.fromElement);if(a.pageX==null&&a.clientX!=null){var h=a.target.ownerDocument||c,i=h.documentElement,j=h.body;a.pageX=a.clientX+(i&&i.scrollLeft||j&&j.scrollLeft||0)-(i&&i.clientLeft||j&&j.clientLeft||0),a.pageY=a.clientY+(i&&i.scrollTop||j&&j.scrollTop||0)-(i&&i.clientTop||j&&j.clientTop||0)}a.which==null&&(a.charCode!=null||a.keyCode!=null)&&(a.which=a.charCode!=null?a.charCode:a.keyCode),!a.metaKey&&a.ctrlKey&&(a.metaKey=a.ctrlKey),!a.which&&a.button!==b&&(a.which=a.button&1?1:a.button&2?3:a.button&4?2:0);return a},guid:1e8,proxy:f.proxy,special:{ready:{setup:f.bindReady,teardown:f.noop},live:{add:function(a){f.event.add(this,N(a.origType,a.selector),f.extend({},a,{handler:M,guid:a.handler.guid}))},remove:function(a){f.event.remove(this,N(a.origType,a.selector),a)}},beforeunload:{setup:function(a,b,c){f.isWindow(this)&&(this.onbeforeunload=c)},teardown:function(a,b){this.onbeforeunload===b&&(this.onbeforeunload=null)}}}},f.removeEvent=c.removeEventListener?function(a,b,c){a.removeEventListener&&a.removeEventListener(b,c,!1)}:function(a,b,c){a.detachEvent&&a.detachEvent("on"+b,c)},f.Event=function(a,b){if(!this.preventDefault)return new f.Event(a,b);a&&a.type?(this.originalEvent=a,this.type=a.type,this.isDefaultPrevented=a.defaultPrevented||a.returnValue===!1||a.getPreventDefault&&a.getPreventDefault()?E:D):this.type=a,b&&f.extend(this,b),this.timeStamp=f.now(),this[f.expando]=!0},f.Event.prototype={preventDefault:function(){this.isDefaultPrevented=E;var a=this.originalEvent;!a||(a.preventDefault?a.preventDefault():a.returnValue=!1)},stopPropagation:function(){this.isPropagationStopped=E;var a=this.originalEvent;!a||(a.stopPropagation&&a.stopPropagation(),a.cancelBubble=!0)},stopImmediatePropagation:function(){this.isImmediatePropagationStopped=E,this.stopPropagation()},isDefaultPrevented:D,isPropagationStopped:D,isImmediatePropagationStopped:D};var F=function(a){var b=a.relatedTarget;try{if(b&&b!==c&&!b.parentNode)return;while(b&&b!==this)b=b.parentNode;b!==this&&(a.type=a.data,f.event.handle.apply(this,arguments))}catch(d){}},G=function(a){a.type=a.data,f.event.handle.apply(this,arguments)};f.each({mouseenter:"mouseover",mouseleave:"mouseout"},function(a,b){f.event.special[a]={setup:function(c){f.event.add(this,b,c&&c.selector?G:F,a)},teardown:function(a){f.event.remove(this,b,a&&a.selector?G:F)}}}),f.support.submitBubbles||(f.event.special.submit={setup:function(a,b){if(!f.nodeName(this,"form"))f.event.add(this,"click.specialSubmit",function(a){var b=a.target,c=b.type;(c==="submit"||c==="image")&&f(b).closest("form").length&&K("submit",this,arguments)}),f.event.add(this,"keypress.specialSubmit",function(a){var b=a.target,c=b.type;(c==="text"||c==="password")&&f(b).closest("form").length&&a.keyCode===13&&K("submit",this,arguments)});else return!1},teardown:function(a){f.event.remove(this,".specialSubmit")}});if(!f.support.changeBubbles){var H,I=function(a){var b=a.type,c=a.value;b==="radio"||b==="checkbox"?c=a.checked:b==="select-multiple"?c=a.selectedIndex>-1?f.map(a.options,function(a){return a.selected}).join("-"):"":f.nodeName(a,"select")&&(c=a.selectedIndex);return c},J=function J(a){var c=a.target,d,e;if(!!y.test(c.nodeName)&&!c.readOnly){d=f._data(c,"_change_data"),e=I(c),(a.type!=="focusout"||c.type!=="radio")&&f._data(c,"_change_data",e);if(d===b||e===d)return;if(d!=null||e)a.type="change",a.liveFired=b,f.event.trigger(a,arguments[1],c)}};f.event.special.change={filters:{focusout:J,beforedeactivate:J,click:function(a){var b=a.target,c=f.nodeName(b,"input")?b.type:"";(c==="radio"||c==="checkbox"||f.nodeName(b,"select"))&&J.call(this,a)},keydown:function(a){var b=a.target,c=f.nodeName(b,"input")?b.type:"";(a.keyCode===13&&!f.nodeName(b,"textarea")||a.keyCode===32&&(c==="checkbox"||c==="radio")||c==="select-multiple")&&J.call(this,a)},beforeactivate:function(a){var b=a.target;f._data(b,"_change_data",I(b))}},setup:function(a,b){if(this.type==="file")return!1;for(var c in H)f.event.add(this,c+".specialChange",H[c]);return y.test(this.nodeName)},teardown:function(a){f.event.remove(this,".specialChange");return y.test(this.nodeName)}},H=f.event.special.change.filters,H.focus=H.beforeactivate}f.support.focusinBubbles||f.each({focus:"focusin",blur:"focusout"},function(a,b){function e(a){var c=f.event.fix(a);c.type=b,c.originalEvent={},f.event.trigger(c,null,c.target),c.isDefaultPrevented()&&a.preventDefault()}var d=0;f.event.special[b]={setup:function(){d++===0&&c.addEventListener(a,e,!0)},teardown:function(){--d===0&&c.removeEventListener(a,e,!0)}}}),f.each(["bind","one"],function(a,c){f.fn[c]=function(a,d,e){var g;if(typeof a=="object"){for(var h in a)this[c](h,d,a[h],e);return this}if(arguments.length===2||d===!1)e=d,d=b;c==="one"?(g=function(a){f(this).unbind(a,g);return e.apply(this,arguments)},g.guid=e.guid||f.guid++):g=e;if(a==="unload"&&c!=="one")this.one(a,d,e);else for(var i=0,j=this.length;i<j;i++)f.event.add(this[i],a,g,d);return this}}),f.fn.extend({unbind:function(a,b){if(typeof a=="object"&&!a.preventDefault)for(var c in a)this.unbind(c,a[c]);else for(var d=0,e=this.length;d<e;d++)f.event.remove(this[d],a,b);return this},delegate:function(a,b,c,d){return this.live(b,c,d,a)},undelegate:function(a,b,c){return arguments.length===0?this.unbind("live"):this.die(b,null,c,a)},trigger:function(a,b){return this.each(function(){f.event.trigger(a,b,this)})},triggerHandler:function(a,b){if(this[0])return f.event.trigger(a,b,this[0],!0)},toggle:function(a){var b=arguments,c=a.guid||f.guid++,d=0,e=function(c){var e=(f.data(this,"lastToggle"+a.guid)||0)%d;f.data(this,"lastToggle"+a.guid,e+1),c.preventDefault();return b[e].apply(this,arguments)||!1};e.guid=c;while(d<b.length)b[d++].guid=c;return this.click(e)},hover:function(a,b){return this.mouseenter(a).mouseleave(b||a)}});var L={focus:"focusin",blur:"focusout",mouseenter:"mouseover",mouseleave:"mouseout"};f.each(["live","die"],function(a,c){f.fn[c]=function(a,d,e,g){var h,i=0,j,k,l,m=g||this.selector,n=g?this:f(this.context);if(typeof a=="object"&&!a.preventDefault){for(var o in a)n[c](o,d,a[o],m);return this}if(c==="die"&&!a&&g&&g.charAt(0)==="."){n.unbind(g);return this}if(d===!1||f.isFunction(d))e=d||D,d=b;a=(a||"").split(" ");while((h=a[i++])!=null){j=x.exec(h),k="",j&&(k=j[0],h=h.replace(x,""));if(h==="hover"){a.push("mouseenter"+k,"mouseleave"+k);continue}l=h,L[h]?(a.push(L[h]+k),h=h+k):h=(L[h]||h)+k;if(c==="live")for(var p=0,q=n.length;p<q;p++)f.event.add(n[p],"live."+N(h,m),{data:d,selector:m,handler:e,origType:h,origHandler:e,preType:l});else n.unbind("live."+N(h,m),e)}return this}}),f.each("blur focus focusin focusout load resize scroll unload click dblclick mousedown mouseup mousemove mouseover mouseout mouseenter mouseleave change select submit keydown keypress keyup error".split(" "),function(a,b){f.fn[b]=function(a,c){c==null&&(c=a,a=null);return arguments.length>0?this.bind(b,a,c):this.trigger(b)},f.attrFn&&(f.attrFn[b]=!0)}),function(){function u(a,b,c,d,e,f){for(var g=0,h=d.length;g<h;g++){var i=d[g];if(i){var j=!1;i=i[a];while(i){if(i.sizcache===c){j=d[i.sizset];break}if(i.nodeType===1){f||(i.sizcache=c,i.sizset=g);if(typeof b!="string"){if(i===b){j=!0;break}}else if(k.filter(b,[i]).length>0){j=i;break}}i=i[a]}d[g]=j}}}function t(a,b,c,d,e,f){for(var g=0,h=d.length;g<h;g++){var i=d[g];if(i){var j=!1;i=i[a];while(i){if(i.sizcache===c){j=d[i.sizset];break}i.nodeType===1&&!f&&(i.sizcache=c,i.sizset=g);if(i.nodeName.toLowerCase()===b){j=i;break}i=i[a]}d[g]=j}}}var a=/((?:\((?:\([^()]+\)|[^()]+)+\)|\[(?:\[[^\[\]]*\]|['"][^'"]*['"]|[^\[\]'"]+)+\]|\\.|[^ >+~,(\[\\]+)+|[>+~])(\s*,\s*)?((?:.|\r|\n)*)/g,d=0,e=Object.prototype.toString,g=!1,h=!0,i=/\\/g,j=/\W/;[0,0].sort(function(){h=!1;return 0});var k=function(b,d,f,g){f=f||[],d=d||c;var h=d;if(d.nodeType!==1&&d.nodeType!==9)return[];if(!b||typeof b!="string")return f;var i,j,n,o,q,r,s,t,u=!0,w=k.isXML(d),x=[],y=b;do{a.exec(""),i=a.exec(y);if(i){y=i[3],x.push(i[1]);if(i[2]){o=i[3];break}}}while(i);if(x.length>1&&m.exec(b))if(x.length===2&&l.relative[x[0]])j=v(x[0]+x[1],d);else{j=l.relative[x[0]]?[d]:k(x.shift(),d);while(x.length)b=x.shift(),l.relative[b]&&(b+=x.shift()),j=v(b,j)}else{!g&&x.length>1&&d.nodeType===9&&!w&&l.match.ID.test(x[0])&&!l.match.ID.test(x[x.length-1])&&(q=k.find(x.shift(),d,w),d=q.expr?k.filter(q.expr,q.set)[0]:q.set[0]);if(d){q=g?{expr:x.pop(),set:p(g)}:k.find(x.pop(),x.length===1&&(x[0]==="~"||x[0]==="+")&&d.parentNode?d.parentNode:d,w),j=q.expr?k.filter(q.expr,q.set):q.set,x.length>0?n=p(j):u=!1;while(x.length)r=x.pop(),s=r,l.relative[r]?s=x.pop():r="",s==null&&(s=d),l.relative[r](n,s,w)}else n=x=[]}n||(n=j),n||k.error(r||b);if(e.call(n)==="[object Array]")if(!u)f.push.apply(f,n);else if(d&&d.nodeType===1)for(t=0;n[t]!=null;t++)n[t]&&(n[t]===!0||n[t].nodeType===1&&k.contains(d,n[t]))&&f.push(j[t]);else for(t=0;n[t]!=null;t++)n[t]&&n[t].nodeType===1&&f.push(j[t]);else p(n,f);o&&(k(o,h,f,g),k.uniqueSort(f));return f};k.uniqueSort=function(a){if(r){g=h,a.sort(r);if(g)for(var b=1;b<a.length;b++)a[b]===a[b-1]&&a.splice(b--,1)}return a},k.matches=function(a,b){return k(a,null,null,b)},k.matchesSelector=function(a,b){return k(b,null,null,[a]).length>0},k.find=function(a,b,c){var d;if(!a)return[];for(var e=0,f=l.order.length;e<f;e++){var g,h=l.order[e];if(g=l.leftMatch[h].exec(a)){var j=g[1];g.splice(1,1);if(j.substr(j.length-1)!=="\\"){g[1]=(g[1]||"").replace(i,""),d=l.find[h](g,b,c);if(d!=null){a=a.replace(l.match[h],"");break}}}}d||(d=typeof b.getElementsByTagName!="undefined"?b.getElementsByTagName("*"):[]);return{set:d,expr:a}},k.filter=function(a,c,d,e){var f,g,h=a,i=[],j=c,m=c&&c[0]&&k.isXML(c[0]);while(a&&c.length){for(var n in l.filter)if((f=l.leftMatch[n].exec(a))!=null&&f[2]){var o,p,q=l.filter[n],r=f[1];g=!1,f.splice(1,1);if(r.substr(r.length-1)==="\\")continue;j===i&&(i=[]);if(l.preFilter[n]){f=l.preFilter[n](f,j,d,i,e,m);if(!f)g=o=!0;else if(f===!0)continue}if(f)for(var s=0;(p=j[s])!=null;s++)if(p){o=q(p,f,s,j);var t=e^!!o;d&&o!=null?t?g=!0:j[s]=!1:t&&(i.push(p),g=!0)}if(o!==b){d||(j=i),a=a.replace(l.match[n],"");if(!g)return[];break}}if(a===h)if(g==null)k.error(a);else break;h=a}return j},k.error=function(a){throw"Syntax error, unrecognized expression: "+a};var l=k.selectors={order:["ID","NAME","TAG"],match:{ID:/#((?:[\w\u00c0-\uFFFF\-]|\\.)+)/,CLASS:/\.((?:[\w\u00c0-\uFFFF\-]|\\.)+)/,NAME:/\[name=['"]*((?:[\w\u00c0-\uFFFF\-]|\\.)+)['"]*\]/,ATTR:/\[\s*((?:[\w\u00c0-\uFFFF\-]|\\.)+)\s*(?:(\S?=)\s*(?:(['"])(.*?)\3|(#?(?:[\w\u00c0-\uFFFF\-]|\\.)*)|)|)\s*\]/,TAG:/^((?:[\w\u00c0-\uFFFF\*\-]|\\.)+)/,CHILD:/:(only|nth|last|first)-child(?:\(\s*(even|odd|(?:[+\-]?\d+|(?:[+\-]?\d*)?n\s*(?:[+\-]\s*\d+)?))\s*\))?/,POS:/:(nth|eq|gt|lt|first|last|even|odd)(?:\((\d*)\))?(?=[^\-]|$)/,PSEUDO:/:((?:[\w\u00c0-\uFFFF\-]|\\.)+)(?:\((['"]?)((?:\([^\)]+\)|[^\(\)]*)+)\2\))?/},leftMatch:{},attrMap:{"class":"className","for":"htmlFor"},attrHandle:{href:function(a){return a.getAttribute("href")},type:function(a){return a.getAttribute("type")}},relative:{"+":function(a,b){var c=typeof b=="string",d=c&&!j.test(b),e=c&&!d;d&&(b=b.toLowerCase());for(var f=0,g=a.length,h;f<g;f++)if(h=a[f]){while((h=h.previousSibling)&&h.nodeType!==1);a[f]=e||h&&h.nodeName.toLowerCase()===b?h||!1:h===b}e&&k.filter(b,a,!0)},">":function(a,b){var c,d=typeof b=="string",e=0,f=a.length;if(d&&!j.test(b)){b=b.toLowerCase();for(;e<f;e++){c=a[e];if(c){var g=c.parentNode;a[e]=g.nodeName.toLowerCase()===b?g:!1}}}else{for(;e<f;e++)c=a[e],c&&(a[e]=d?c.parentNode:c.parentNode===b);d&&k.filter(b,a,!0)}},"":function(a,b,c){var e,f=d++,g=u;typeof b=="string"&&!j.test(b)&&(b=b.toLowerCase(),e=b,g=t),g("parentNode",b,f,a,e,c)},"~":function(a,b,c){var e,f=d++,g=u;typeof b=="string"&&!j.test(b)&&(b=b.toLowerCase(),e=b,g=t),g("previousSibling",b,f,a,e,c)}},find:{ID:function(a,b,c){if(typeof b.getElementById!="undefined"&&!c){var d=b.getElementById(a[1]);return d&&d.parentNode?[d]:[]}},NAME:function(a,b){if(typeof b.getElementsByName!="undefined"){var c=[],d=b.getElementsByName(a[1]);for(var e=0,f=d.length;e<f;e++)d[e].getAttribute("name")===a[1]&&c.push(d[e]);return c.length===0?null:c}},TAG:function(a,b){if(typeof b.getElementsByTagName!="undefined")return b.getElementsByTagName(a[1])}},preFilter:{CLASS:function(a,b,c,d,e,f){a=" "+a[1].replace(i,"")+" ";if(f)return a;for(var g=0,h;(h=b[g])!=null;g++)h&&(e^(h.className&&(" "+h.className+" ").replace(/[\t\n\r]/g," ").indexOf(a)>=0)?c||d.push(h):c&&(b[g]=!1));return!1},ID:function(a){return a[1].replace(i,"")},TAG:function(a,b){return a[1].replace(i,"").toLowerCase()},CHILD:function(a){if(a[1]==="nth"){a[2]||k.error(a[0]),a[2]=a[2].replace(/^\+|\s*/g,"");var b=/(-?)(\d*)(?:n([+\-]?\d*))?/.exec(a[2]==="even"&&"2n"||a[2]==="odd"&&"2n+1"||!/\D/.test(a[2])&&"0n+"+a[2]||a[2]);a[2]=b[1]+(b[2]||1)-0,a[3]=b[3]-0}else a[2]&&k.error(a[0]);a[0]=d++;return a},ATTR:function(a,b,c,d,e,f){var g=a[1]=a[1].replace(i,"");!f&&l.attrMap[g]&&(a[1]=l.attrMap[g]),a[4]=(a[4]||a[5]||"").replace(i,""),a[2]==="~="&&(a[4]=" "+a[4]+" ");return a},PSEUDO:function(b,c,d,e,f){if(b[1]==="not")if((a.exec(b[3])||"").length>1||/^\w/.test(b[3]))b[3]=k(b[3],null,null,c);else{var g=k.filter(b[3],c,d,!0^f);d||e.push.apply(e,g);return!1}else if(l.match.POS.test(b[0])||l.match.CHILD.test(b[0]))return!0;return b},POS:function(a){a.unshift(!0);return a}},filters:{enabled:function(a){return a.disabled===!1&&a.type!=="hidden"},disabled:function(a){return a.disabled===!0},checked:function(a){return a.checked===!0},selected:function(a){a.parentNode&&a.parentNode.selectedIndex;return a.selected===!0},parent:function(a){return!!a.firstChild},empty:function(a){return!a.firstChild},has:function(a,b,c){return!!k(c[3],a).length},header:function(a){return/h\d/i.test(a.nodeName)},text:function(a){var b=a.getAttribute("type"),c=a.type;return a.nodeName.toLowerCase()==="input"&&"text"===c&&(b===c||b===null)},radio:function(a){return a.nodeName.toLowerCase()==="input"&&"radio"===a.type},checkbox:function(a){return a.nodeName.toLowerCase()==="input"&&"checkbox"===a.type},file:function(a){return a.nodeName.toLowerCase()==="input"&&"file"===a.type},password:function(a){return a.nodeName.toLowerCase()==="input"&&"password"===a.type},submit:function(a){var b=a.nodeName.toLowerCase();return(b==="input"||b==="button")&&"submit"===a.type},image:function(a){return a.nodeName.toLowerCase()==="input"&&"image"===a.type},reset:function(a){return a.nodeName.toLowerCase()==="input"&&"reset"===a.type},button:function(a){var b=a.nodeName.toLowerCase();return b==="input"&&"button"===a.type||b==="button"},input:function(a){return/input|select|textarea|button/i.test(a.nodeName)},focus:function(a){return a===a.ownerDocument.activeElement}},setFilters:{first:function(a,b){return b===0},last:function(a,b,c,d){return b===d.length-1},even:function(a,b){return b%2===0},odd:function(a,b){return b%2===1},lt:function(a,b,c){return b<c[3]-0},gt:function(a,b,c){return b>c[3]-0},nth:function(a,b,c){return c[3]-0===b},eq:function(a,b,c){return c[3]-0===b}},filter:{PSEUDO:function(a,b,c,d){var e=b[1],f=l.filters[e];if(f)return f(a,c,b,d);if(e==="contains")return(a.textContent||a.innerText||k.getText([a])||"").indexOf(b[3])>=0;if(e==="not"){var g=b[3];for(var h=0,i=g.length;h<i;h++)if(g[h]===a)return!1;return!0}k.error(e)},CHILD:function(a,b){var c=b[1],d=a;switch(c){case"only":case"first":while(d=d.previousSibling)if(d.nodeType===1)return!1;if(c==="first")return!0;d=a;case"last":while(d=d.nextSibling)if(d.nodeType===1)return!1;return!0;case"nth":var e=b[2],f=b[3];if(e===1&&f===0)return!0;var g=b[0],h=a.parentNode;if(h&&(h.sizcache!==g||!a.nodeIndex)){var i=0;for(d=h.firstChild;d;d=d.nextSibling)d.nodeType===1&&(d.nodeIndex=++i);h.sizcache=g}var j=a.nodeIndex-f;return e===0?j===0:j%e===0&&j/e>=0}},ID:function(a,b){return a.nodeType===1&&a.getAttribute("id")===b},TAG:function(a,b){return b==="*"&&a.nodeType===1||a.nodeName.toLowerCase()===b},CLASS:function(a,b){return(" "+(a.className||a.getAttribute("class"))+" ").indexOf(b)>-1},ATTR:function(a,b){var c=b[1],d=l.attrHandle[c]?l.attrHandle[c](a):a[c]!=null?a[c]:a.getAttribute(c),e=d+"",f=b[2],g=b[4];return d==null?f==="!=":f==="="?e===g:f==="*="?e.indexOf(g)>=0:f==="~="?(" "+e+" ").indexOf(g)>=0:g?f==="!="?e!==g:f==="^="?e.indexOf(g)===0:f==="$="?e.substr(e.length-g.length)===g:f==="|="?e===g||e.substr(0,g.length+1)===g+"-":!1:e&&d!==!1},POS:function(a,b,c,d){var e=b[2],f=l.setFilters[e];if(f)return f(a,c,b,d)}}},m=l.match.POS,n=function(a,b){return"\\"+(b-0+1)};for(var o in l.match)l.match[o]=new RegExp(l.match[o].source+/(?![^\[]*\])(?![^\(]*\))/.source),l.leftMatch[o]=new RegExp(/(^(?:.|\r|\n)*?)/.source+l.match[o].source.replace(/\\(\d+)/g,n));var p=function(a,b){a=Array.prototype.slice.call(a,0);if(b){b.push.apply(b,a);return b}return a};try{Array.prototype.slice.call(c.documentElement.childNodes,0)[0].nodeType}catch(q){p=function(a,b){var c=0,d=b||[];if(e.call(a)==="[object Array]")Array.prototype.push.apply(d,a);else if(typeof a.length=="number")for(var f=a.length;c<f;c++)d.push(a[c]);else for(;a[c];c++)d.push(a[c]);return d}}var r,s;c.documentElement.compareDocumentPosition?r=function(a,b){if(a===b){g=!0;return 0}if(!a.compareDocumentPosition||!b.compareDocumentPosition)return a.compareDocumentPosition?-1:1;return a.compareDocumentPosition(b)&4?-1:1}:(r=function(a,b){var c,d,e=[],f=[],h=a.parentNode,i=b.parentNode,j=h;if(a===b){g=!0;return 0}if(h===i)return s(a,b);if(!h)return-1;if(!i)return 1;while(j)e.unshift(j),j=j.parentNode;j=i;while(j)f.unshift(j),j=j.parentNode;c=e.length,d=f.length;for(var k=0;k<c&&k<d;k++)if(e[k]!==f[k])return s(e[k],f[k]);return k===c?s(a,f[k],-1):s(e[k],b,1)},s=function(a,b,c){if(a===b)return c;var d=a.nextSibling;while(d){if(d===b)return-1;d=d.nextSibling}return 1}),k.getText=function(a){var b="",c;for(var d=0;a[d];d++)c=a[d],c.nodeType===3||c.nodeType===4?b+=c.nodeValue:c.nodeType!==8&&(b+=k.getText(c.childNodes));return b},function(){var a=c.createElement("div"),d="script"+(new Date).getTime(),e=c.documentElement;a.innerHTML="<a name='"+d+"'/>",e.insertBefore(a,e.firstChild),c.getElementById(d)&&(l.find.ID=function(a,c,d){if(typeof c.getElementById!="undefined"&&!d){var e=c.getElementById(a[1]);return e?e.id===a[1]||typeof e.getAttributeNode!="undefined"&&e.getAttributeNode("id").nodeValue===a[1]?[e]:b:[]}},l.filter.ID=function(a,b){var c=typeof a.getAttributeNode!="undefined"&&a.getAttributeNode("id");return a.nodeType===1&&c&&c.nodeValue===b}),e.removeChild(a),e=a=null}(),function(){var a=c.createElement("div");a.appendChild(c.createComment("")),a.getElementsByTagName("*").length>0&&(l.find.TAG=function(a,b){var c=b.getElementsByTagName(a[1]);if(a[1]==="*"){var d=[];for(var e=0;c[e];e++)c[e].nodeType===1&&d.push(c[e]);c=d}return c}),a.innerHTML="<a href='#'></a>",a.firstChild&&typeof a.firstChild.getAttribute!="undefined"&&a.firstChild.getAttribute("href")!=="#"&&(l.attrHandle.href=function(a){return a.getAttribute("href",2)}),a=null}(),c.querySelectorAll&&function(){var a=k,b=c.createElement("div"),d="__sizzle__";b.innerHTML="<p class='TEST'></p>";if(!b.querySelectorAll||b.querySelectorAll(".TEST").length!==0){k=function(b,e,f,g){e=e||c;if(!g&&!k.isXML(e)){var h=/^(\w+$)|^\.([\w\-]+$)|^#([\w\-]+$)/.exec(b);if(h&&(e.nodeType===1||e.nodeType===9)){if(h[1])return p(e.getElementsByTagName(b),f);if(h[2]&&l.find.CLASS&&e.getElementsByClassName)return p(e.getElementsByClassName(h[2]),f)}if(e.nodeType===9){if(b==="body"&&e.body)return p([e.body],f);if(h&&h[3]){var i=e.getElementById(h[3]);if(!i||!i.parentNode)return p([],f);if(i.id===h[3])return p([i],f)}try{return p(e.querySelectorAll(b),f)}catch(j){}}else if(e.nodeType===1&&e.nodeName.toLowerCase()!=="object"){var m=e,n=e.getAttribute("id"),o=n||d,q=e.parentNode,r=/^\s*[+~]/.test(b);n?o=o.replace(/'/g,"\\$&"):e.setAttribute("id",o),r&&q&&(e=e.parentNode);try{if(!r||q)return p(e.querySelectorAll("[id='"+o+"'] "+b),f)}catch(s){}finally{n||m.removeAttribute("id")}}}return a(b,e,f,g)};for(var e in a)k[e]=a[e];b=null}}(),function(){var a=c.documentElement,b=a.matchesSelector||a.mozMatchesSelector||a.webkitMatchesSelector||a.msMatchesSelector;if(b){var d=!b.call(c.createElement("div"),"div"),e=!1;try{b.call(c.documentElement,"[test!='']:sizzle")}catch(f){e=!0}k.matchesSelector=function(a,c){c=c.replace(/\=\s*([^'"\]]*)\s*\]/g,"='$1']");if(!k.isXML(a))try{if(e||!l.match.PSEUDO.test(c)&&!/!=/.test(c)){var f=b.call(a,c);if(f||!d||a.document&&a.document.nodeType!==11)return f}}catch(g){}return k(c,null,null,[a]).length>0}}}(),function(){var a=c.createElement("div");a.innerHTML="<div class='test e'></div><div class='test'></div>";if(!!a.getElementsByClassName&&a.getElementsByClassName("e").length!==0){a.lastChild.className="e";if(a.getElementsByClassName("e").length===1)return;l.order.splice(1,0,"CLASS"),l.find.CLASS=function(a,b,c){if(typeof b.getElementsByClassName!="undefined"&&!c)return b.getElementsByClassName(a[1])},a=null}}(),c.documentElement.contains?k.contains=function(a,b){return a!==b&&(a.contains?a.contains(b):!0)}:c.documentElement.compareDocumentPosition?k.contains=function(a,b){return!!(a.compareDocumentPosition(b)&16)}:k.contains=function(){return!1},k.isXML=function(a){var b=(a?a.ownerDocument||a:0).documentElement;return b?b.nodeName!=="HTML":!1};var v=function(a,b){var c,d=[],e="",f=b.nodeType?[b]:b;while(c=l.match.PSEUDO.exec(a))e+=c[0],a=a.replace(l.match.PSEUDO,"");a=l.relative[a]?a+"*":a;for(var g=0,h=f.length;g<h;g++)k(a,f[g],d);return k.filter(e,d)};f.find=k,f.expr=k.selectors,f.expr[":"]=f.expr.filters,f.unique=k.uniqueSort,f.text=k.getText,f.isXMLDoc=k.isXML,f.contains=k.contains}();var O=/Until$/,P=/^(?:parents|prevUntil|prevAll)/,Q=/,/,R=/^.[^:#\[\.,]*$/,S=Array.prototype.slice,T=f.expr.match.POS,U={children:!0,contents:!0,next:!0,prev:!0};f.fn.extend({find:function(a){var b=this,c,d;if(typeof a!="string")return f(a).filter(function(){for(c=0,d=b.length;c<d;c++)if(f.contains(b[c],this))return!0});var e=this.pushStack("","find",a),g,h,i;for(c=0,d=this.length;c<d;c++){g=e.length,f.find(a,this[c],e);if(c>0)for(h=g;h<e.length;h++)for(i=0;i<g;i++)if(e[i]===e[h]){e.splice(h--,1);break}}return e},has:function(a){var b=f(a);return this.filter(function(){for(var a=0,c=b.length;a<c;a++)if(f.contains(this,b[a]))return!0})},not:function(a){return this.pushStack(W(this,a,!1),"not",a)},filter:function(a){return this.pushStack(W(this,a,!0),"filter",a)},is:function(a){return!!a&&(typeof a=="string"?f.filter(a,this).length>0:this.filter(a).length>0)},closest:function(a,b){var c=[],d,e,g=this[0];if(f.isArray(a)){var h,i,j={},k=1;if(g&&a.length){for(d=0,e=a.length;d<e;d++)i=a[d],j[i]||(j[i]=T.test(i)?f(i,b||this.context):i);while(g&&g.ownerDocument&&g!==b){for(i in j)h=j[i],(h.jquery?h.index(g)>-1:f(g).is(h))&&c.push({selector:i,elem:g,level:k});g=g.parentNode,k++}}return c}var l=T.test(a)||typeof a!="string"?f(a,b||this.context):0;for(d=0,e=this.length;d<e;d++){g=this[d];while(g){if(l?l.index(g)>-1:f.find.matchesSelector(g,a)){c.push(g);break}g=g.parentNode;if(!g||!g.ownerDocument||g===b||g.nodeType===11)break}}c=c.length>1?f.unique(c):c;return this.pushStack(c,"closest",a)},index:function(a){if(!a||typeof a=="string")return f.inArray(this[0],a?f(a):this.parent().children());return f.inArray(a.jquery?a[0]:a,this)},add:function(a,b){var c=typeof a=="string"?f(a,b):f.makeArray(a&&a.nodeType?[a]:a),d=f.merge(this.get(),c);return this.pushStack(V(c[0])||V(d[0])?d:f.unique(d))},andSelf:function(){return this.add(this.prevObject)}}),f.each({parent:function(a){var b=a.parentNode;return b&&b.nodeType!==11?b:null},parents:function(a){return f.dir(a,"parentNode")},parentsUntil:function(a,b,c){return f.dir(a,"parentNode",c)},next:function(a){return f.nth(a,2,"nextSibling")},prev:function(a){return f.nth(a,2,"previousSibling")},nextAll:function(a){return f.dir(a,"nextSibling")},prevAll:function(a){return f.dir(a,"previousSibling")},nextUntil:function(a,b,c){return f.dir(a,"nextSibling",c)},prevUntil:function(a,b,c){return f.dir(a,"previousSibling",c)},siblings:function(a){return f.sibling(a.parentNode.firstChild,a)},children:function(a){return f.sibling(a.firstChild)},contents:function(a){return f.nodeName(a,"iframe")?a.contentDocument||a.contentWindow.document:f.makeArray(a.childNodes)}},function(a,b){f.fn[a]=function(c,d){var e=f.map(this,b,c),g=S.call(arguments);O.test(a)||(d=c),d&&typeof d=="string"&&(e=f.filter(d,e)),e=this.length>1&&!U[a]?f.unique(e):e,(this.length>1||Q.test(d))&&P.test(a)&&(e=e.reverse());return this.pushStack(e,a,g.join(","))}}),f.extend({filter:function(a,b,c){c&&(a=":not("+a+")");return b.length===1?f.find.matchesSelector(b[0],a)?[b[0]]:[]:f.find.matches(a,b)},dir:function(a,c,d){var e=[],g=a[c];while(g&&g.nodeType!==9&&(d===b||g.nodeType!==1||!f(g).is(d)))g.nodeType===1&&e.push(g),g=g[c];return e},nth:function(a,b,c,d){b=b||1;var e=0;for(;a;a=a[c])if(a.nodeType===1&&++e===b)break;return a},sibling:function(a,b){var c=[];for(;a;a=a.nextSibling)a.nodeType===1&&a!==b&&c.push(a);return c}});var X=/ jQuery\d+="(?:\d+|null)"/g,Y=/^\s+/,Z=/<(?!area|br|col|embed|hr|img|input|link|meta|param)(([\w:]+)[^>]*)\/>/ig,$=/<([\w:]+)/,_=/<tbody/i,ba=/<|&#?\w+;/,bb=/<(?:script|object|embed|option|style)/i,bc=/checked\s*(?:[^=]|=\s*.checked.)/i,bd=/\/(java|ecma)script/i,be={option:[1,"<select multiple='multiple'>","</select>"],legend:[1,"<fieldset>","</fieldset>"],thead:[1,"<table>","</table>"],tr:[2,"<table><tbody>","</tbody></table>"],td:[3,"<table><tbody><tr>","</tr></tbody></table>"],col:[2,"<table><tbody></tbody><colgroup>","</colgroup></table>"],area:[1,"<map>","</map>"],_default:[0,"",""]};be.optgroup=be.option,be.tbody=be.tfoot=be.colgroup=be.caption=be.thead,be.th=be.td,f.support.htmlSerialize||(be._default=[1,"div<div>","</div>"]),f.fn.extend({text:function(a){if(f.isFunction(a))return this.each(function(b){var c=f(this);c.text(a.call(this,b,c.text()))});if(typeof a!="object"&&a!==b)return this.empty().append((this[0]&&this[0].ownerDocument||c).createTextNode(a));return f.text(this)},wrapAll:function(a){if(f.isFunction(a))return this.each(function(b){f(this).wrapAll(a.call(this,b))});if(this[0]){var b=f(a,this[0].ownerDocument).eq(0).clone(!0);this[0].parentNode&&b.insertBefore(this[0]),b.map(function(){var a=this;while(a.firstChild&&a.firstChild.nodeType===1)a=a.firstChild;return a}).append(this)}return this},wrapInner:function(a){if(f.isFunction(a))return this.each(function(b){f(this).wrapInner(a.call(this,b))});return this.each(function(){var b=f(this),c=b.contents();c.length?c.wrapAll(a):b.append(a)})},wrap:function(a){return this.each(function(){f(this).wrapAll(a)})},unwrap:function(){return this.parent().each(function(){f.nodeName(this,"body")||f(this).replaceWith(this.childNodes)}).end()},append:function(){return this.domManip(arguments,!0,function(a){this.nodeType===1&&this.appendChild(a)})},prepend:function(){return this.domManip(arguments,!0,function(a){this.nodeType===1&&this.insertBefore(a,this.firstChild)})},before:function(){if(this[0]&&this[0].parentNode)return this.domManip(arguments,!1,function(a){this.parentNode.insertBefore(a,this)});if(arguments.length){var a=f(arguments[0]);a.push.apply(a,this.toArray());return this.pushStack(a,"before",arguments)}},after:function(){if(this[0]&&this[0].parentNode)return this.domManip(arguments,!1,function(a){this.parentNode.insertBefore(a,this.nextSibling)});if(arguments.length){var a=this.pushStack(this,"after",arguments);a.push.apply(a,f(arguments[0]).toArray());return a}},remove:function(a,b){for(var c=0,d;(d=this[c])!=null;c++)if(!a||f.filter(a,[d]).length)!b&&d.nodeType===1&&(f.cleanData(d.getElementsByTagName("*")),f.cleanData([d])),d.parentNode&&d.parentNode.removeChild(d);return this},empty:function(){for(var a=0,b;(b=this[a])!=null;a++){b.nodeType===1&&f.cleanData(b.getElementsByTagName("*"));while(b.firstChild)b.removeChild(b.firstChild)}return this},clone:function(a,b){a=a==null?!1:a,b=b==null?a:b;return this.map(function(){return f.clone(this,a,b)})},html:function(a){if(a===b)return this[0]&&this[0].nodeType===1?this[0].innerHTML.replace(X,""):null;if(typeof a=="string"&&!bb.test(a)&&(f.support.leadingWhitespace||!Y.test(a))&&!be[($.exec(a)||["",""])[1].toLowerCase()]){a=a.replace(Z,"<$1></$2>");try{for(var c=0,d=this.length;c<d;c++)this[c].nodeType===1&&(f.cleanData(this[c].getElementsByTagName("*")),this[c].innerHTML=a)}catch(e){this.empty().append(a)}}else f.isFunction(a)?this.each(function(b){var c=f(this);c.html(a.call(this,b,c.html()))}):this.empty().append(a);return this},replaceWith:function(a){if(this[0]&&this[0].parentNode){if(f.isFunction(a))return this.each(function(b){var c=f(this),d=c.html();c.replaceWith(a.call(this,b,d))});typeof a!="string"&&(a=f(a).detach());return this.each(function(){var b=this.nextSibling,c=this.parentNode;f(this).remove(),b?f(b).before(a):f(c).append(a)})}return this.length?this.pushStack(f(f.isFunction(a)?a():a),"replaceWith",a):this},detach:function(a){return this.remove(a,!0)},domManip:function(a,c,d){var e,g,h,i,j=a[0],k=[];if(!f.support.checkClone&&arguments.length===3&&typeof j=="string"&&bc.test(j))return this.each(function(){f(this).domManip(a,c,d,!0)});if(f.isFunction(j))return this.each(function(e){var g=f(this);a[0]=j.call(this,e,c?g.html():b),g.domManip(a,c,d)});if(this[0]){i=j&&j.parentNode,f.support.parentNode&&i&&i.nodeType===11&&i.childNodes.length===this.length?e={fragment:i}:e=f.buildFragment(a,this,k),h=e.fragment,h.childNodes.length===1?g=h=h.firstChild:g=h.firstChild;if(g){c=c&&f.nodeName(g,"tr");for(var l=0,m=this.length,n=m-1;l<m;l++)d.call(c?bf(this[l],g):this[l],e.cacheable||m>1&&l<n?f.clone(h,!0,!0):h)}k.length&&f.each(k,bl)}return this}}),f.buildFragment=function(a,b,d){var e,g,h,i=b&&b[0]?b[0].ownerDocument||b[0]:c;a.length===1&&typeof a[0]=="string"&&a[0].length<512&&i===c&&a[0].charAt(0)==="<"&&!bb.test(a[0])&&(f.support.checkClone||!bc.test(a[0]))&&(g=!0,h=f.fragments[a[0]],h&&h!==1&&(e=h)),e||(e=i.createDocumentFragment(),f.clean(a,i,e,d)),g&&(f.fragments[a[0]]=h?e:1);return{fragment:e,cacheable:g}},f.fragments={},f.each({appendTo:"append",prependTo:"prepend",insertBefore:"before",insertAfter:"after",replaceAll:"replaceWith"},function(a,b){f.fn[a]=function(c){var d=[],e=f(c),g=this.length===1&&this[0].parentNode;if(g&&g.nodeType===11&&g.childNodes.length===1&&e.length===1){e[b](this[0]);return this}for(var h=0,i=e.length;h<i;h++){var j=(h>0?this.clone(!0):this).get();f(e[h])[b](j),d=d.concat(j)}return this.pushStack(d,a,e.selector)}}),f.extend({clone:function(a,b,c){var d=a.cloneNode(!0),e,g,h;if((!f.support.noCloneEvent||!f.support.noCloneChecked)&&(a.nodeType===1||a.nodeType===11)&&!f.isXMLDoc(a)){bh(a,d),e=bi(a),g=bi(d);for(h=0;e[h];++h)bh(e[h],g[h])}if(b){bg(a,d);if(c){e=bi(a),g=bi(d);for(h=0;e[h];++h)bg(e[h],g[h])}}return d},clean:function(a,b,d,e){var g;b=b||c,typeof b.createElement=="undefined"&&(b=b.ownerDocument||b[0]&&b[0].ownerDocument||c);var h=[];for(var i=0,j;(j=a[i])!=null;i++){typeof j=="number"&&(j+="");if(!j)continue;if(typeof j=="string")if(!ba.test(j))j=b.createTextNode(j);else{j=j.replace(Z,"<$1></$2>");var k=($.exec(j)||["",""])[1].toLowerCase(),l=be[k]||be._default,m=l[0],n=b.createElement("div");n.innerHTML=l[1]+j+l[2];while(m--)n=n.lastChild;if(!f.support.tbody){var o=_.test(j),p=k==="table"&&!o?n.firstChild&&n.firstChild.childNodes:l[1]==="<table>"&&!o?n.childNodes:[];for(var q=p.length-1;q>=0;--q)f.nodeName(p[q],"tbody")&&!p[q].childNodes.length&&p[q].parentNode.removeChild(p[q])}!f.support.leadingWhitespace&&Y.test(j)&&n.insertBefore(b.createTextNode(Y.exec(j)[0]),n.firstChild),j=n.childNodes}var r;if(!f.support.appendChecked)if(j[0]&&typeof (r=j.length)=="number")for(i=0;i<r;i++)bk(j[i]);else bk(j);j.nodeType?h.push(j):h=f.merge(h,j)}if(d){g=function(a){return!a.type||bd.test(a.type)};for(i=0;h[i];i++)if(e&&f.nodeName(h[i],"script")&&(!h[i].type||h[i].type.toLowerCase()==="text/javascript"))e.push(h[i].parentNode?h[i].parentNode.removeChild(h[i]):h[i]);else{if(h[i].nodeType===1){var s=f.grep(h[i].getElementsByTagName("script"),g);h.splice.apply(h,[i+1,0].concat(s))}d.appendChild(h[i])}}return h},cleanData:function(a){var b,c,d=f.cache,e=f.expando,g=f.event.special,h=f.support.deleteExpando;for(var i=0,j;(j=a[i])!=null;i++){if(j.nodeName&&f.noData[j.nodeName.toLowerCase()])continue;c=j[f.expando];if(c){b=d[c]&&d[c][e];if(b&&b.events){for(var k in b.events)g[k]?f.event.remove(j,k):f.removeEvent(j,k,b.handle);b.handle&&(b.handle.elem=null)}h?delete j[f.expando]:j.removeAttribute&&j.removeAttribute(f.expando),delete d[c]}}}});var bm=/alpha\([^)]*\)/i,bn=/opacity=([^)]*)/,bo=/-([a-z])/ig,bp=/([A-Z]|^ms)/g,bq=/^-?\d+(?:px)?$/i,br=/^-?\d/,bs=/^[+\-]=/,bt=/[^+\-\.\de]+/g,bu={position:"absolute",visibility:"hidden",display:"block"},bv=["Left","Right"],bw=["Top","Bottom"],bx,by,bz,bA=function(a,b){return b.toUpperCase()};f.fn.css=function(a,c){if(arguments.length===2&&c===b)return this;return f.access(this,a,c,!0,function(a,c,d){return d!==b?f.style(a,c,d):f.css(a,c)})},f.extend({cssHooks:{opacity:{get:function(a,b){if(b){var c=bx(a,"opacity","opacity");return c===""?"1":c}return a.style.opacity}}},cssNumber:{zIndex:!0,fontWeight:!0,opacity:!0,zoom:!0,lineHeight:!0,widows:!0,orphans:!0},cssProps:{"float":f.support.cssFloat?"cssFloat":"styleFloat"},style:function(a,c,d,e){if(!!a&&a.nodeType!==3&&a.nodeType!==8&&!!a.style){var g,h,i=f.camelCase(c),j=a.style,k=f.cssHooks[i];c=f.cssProps[i]||i;if(d===b){if(k&&"get"in k&&(g=k.get(a,!1,e))!==b)return g;return j[c]}h=typeof d;if(h==="number"&&isNaN(d)||d==null)return;h==="string"&&bs.test(d)&&(d=+d.replace(bt,"")+parseFloat(f.css(a,c))),h==="number"&&!f.cssNumber[i]&&(d+="px");if(!k||!("set"in k)||(d=k.set(a,d))!==b)try{j[c]=d}catch(l){}}},css:function(a,c,d){var e,g;c=f.camelCase(c),g=f.cssHooks[c],c=f.cssProps[c]||c,c==="cssFloat"&&(c="float");if(g&&"get"in g&&(e=g.get(a,!0,d))!==b)return e;if(bx)return bx(a,c)},swap:function(a,b,c){var d={};for(var e in b)d[e]=a.style[e],a.style[e]=b[e];c.call(a);for(e in b)a.style[e]=d[e]},camelCase:function(a){return a.replace(bo,bA)}}),f.curCSS=f.css,f.each(["height","width"],function(a,b){f.cssHooks[b]={get:function(a,c,d){var e;if(c){a.offsetWidth!==0?e=bB(a,b,d):f.swap(a,bu,function(){e=bB(a,b,d)});if(e<=0){e=bx(a,b,b),e==="0px"&&bz&&(e=bz(a,b,b));if(e!=null)return e===""||e==="auto"?"0px":e}if(e<0||e==null){e=a.style[b];return e===""||e==="auto"?"0px":e}return typeof e=="string"?e:e+"px"}},set:function(a,b){if(!bq.test(b))return b;b=parseFloat(b);if(b>=0)return b+"px"}}}),f.support.opacity||(f.cssHooks.opacity={get:function(a,b){return bn.test((b&&a.currentStyle?a.currentStyle.filter:a.style.filter)||"")?parseFloat(RegExp.$1)/100+"":b?"1":""},set:function(a,b){var c=a.style,d=a.currentStyle;c.zoom=1;var e=f.isNaN(b)?"":"alpha(opacity="+b*100+")",g=d&&d.filter||c.filter||"";c.filter=bm.test(g)?g.replace(bm,e):g+" "+e}}),f(function(){f.support.reliableMarginRight||(f.cssHooks.marginRight={get:function(a,b){var c;f.swap(a,{display:"inline-block"},function(){b?c=bx(a,"margin-right","marginRight"):c=a.style.marginRight});return c}})}),c.defaultView&&c.defaultView.getComputedStyle&&(by=function(a,c){var d,e,g;c=c.replace(bp,"-$1").toLowerCase();if(!(e=a.ownerDocument.defaultView))return b;if(g=e.getComputedStyle(a,null))d=g.getPropertyValue(c),d===""&&!f.contains(a.ownerDocument.documentElement,a)&&(d=f.style(a,c));return d}),c.documentElement.currentStyle&&(bz=function(a,b){var c,d=a.currentStyle&&a.currentStyle[b],e=a.runtimeStyle&&a.runtimeStyle[b],f=a.style;!bq.test(d)&&br.test(d)&&(c=f.left,e&&(a.runtimeStyle.left=a.currentStyle.left),f.left=b==="fontSize"?"1em":d||0,d=f.pixelLeft+"px",f.left=c,e&&(a.runtimeStyle.left=e));return d===""?"auto":d}),bx=by||bz,f.expr&&f.expr.filters&&(f.expr.filters.hidden=function(a){var b=a.offsetWidth,c=a.offsetHeight;return b===0&&c===0||!f.support.reliableHiddenOffsets&&(a.style.display||f.css(a,"display"))==="none"},f.expr.filters.visible=function(a){return!f.expr.filters.hidden(a)});var bC=/%20/g,bD=/\[\]$/,bE=/\r?\n/g,bF=/#.*$/,bG=/^(.*?):[ \t]*([^\r\n]*)\r?$/mg,bH=/^(?:color|date|datetime|email|hidden|month|number|password|range|search|tel|text|time|url|week)$/i,bI=/^(?:about|app|app\-storage|.+\-extension|file|widget):$/,bJ=/^(?:GET|HEAD)$/,bK=/^\/\//,bL=/\?/,bM=/<script\b[^<]*(?:(?!<\/script>)<[^<]*)*<\/script>/gi,bN=/^(?:select|textarea)/i,bO=/\s+/,bP=/([?&])_=[^&]*/,bQ=/^([\w\+\.\-]+:)(?:\/\/([^\/?#:]*)(?::(\d+))?)?/,bR=f.fn.load,bS={},bT={},bU,bV;try{bU=e.href}catch(bW){bU=c.createElement("a"),bU.href="",bU=bU.href}bV=bQ.exec(bU.toLowerCase())||[],f.fn.extend({load:function(a,c,d){if(typeof a!="string"&&bR)return bR.apply(this,arguments);if(!this.length)return this;var e=a.indexOf(" ");if(e>=0){var g=a.slice(e,a.length);a=a.slice(0,e)}var h="GET";c&&(f.isFunction(c)?(d=c,c=b):typeof c=="object"&&(c=f.param(c,f.ajaxSettings.traditional),h="POST"));var i=this;f.ajax({url:a,type:h,dataType:"html",data:c,complete:function(a,b,c){c=a.responseText,a.isResolved()&&(a.done(function(a){c=a}),i.html(g?f("<div>").append(c.replace(bM,"")).find(g):c)),d&&i.each(d,[c,b,a])}});return this},serialize:function(){return f.param(this.serializeArray())},serializeArray:function(){return this.map(function(){return this.elements?f.makeArray(this.elements):this}).filter(function(){return this.name&&!this.disabled&&(this.checked||bN.test(this.nodeName)||bH.test(this.type))}).map(function(a,b){var c=f(this).val();return c==null?null:f.isArray(c)?f.map(c,function(a,c){return{name:b.name,value:a.replace(bE,"\r\n")}}):{name:b.name,value:c.replace(bE,"\r\n")}}).get()}}),f.each("ajaxStart ajaxStop ajaxComplete ajaxError ajaxSuccess ajaxSend".split(" "),function(a,b){f.fn[b]=function(a){return this.bind(b,a)}}),f.each(["get","post"],function(a,c){f[c]=function(a,d,e,g){f.isFunction(d)&&(g=g||e,e=d,d=b);return f.ajax({type:c,url:a,data:d,success:e,dataType:g})}}),f.extend({getScript:function(a,c){return f.get(a,b,c,"script")},getJSON:function(a,b,c){return f.get(a,b,c,"json")},ajaxSetup:function(a,b){b?f.extend(!0,a,f.ajaxSettings,b):(b=a,a=f.extend(!0,f.ajaxSettings,b));for(var c in{context:1,url:1})c in b?a[c]=b[c]:c in f.ajaxSettings&&(a[c]=f.ajaxSettings[c]);return a},ajaxSettings:{url:bU,isLocal:bI.test(bV[1]),global:!0,type:"GET",contentType:"application/x-www-form-urlencoded",processData:!0,async:!0,accepts:{xml:"application/xml, text/xml",html:"text/html",text:"text/plain",json:"application/json, text/javascript","*":"*/*"},contents:{xml:/xml/,html:/html/,json:/json/},responseFields:{xml:"responseXML",text:"responseText"},converters:{"* text":a.String,"text html":!0,"text json":f.parseJSON,"text xml":f.parseXML}},ajaxPrefilter:bX(bS),ajaxTransport:bX(bT),ajax:function(a,c){function w(a,c,l,m){if(s!==2){s=2,q&&clearTimeout(q),p=b,n=m||"",v.readyState=a?4:0;var o,r,u,w=l?b$(d,v,l):b,x,y;if(a>=200&&a<300||a===304){if(d.ifModified){if(x=v.getResponseHeader("Last-Modified"))f.lastModified[k]=x;if(y=v.getResponseHeader("Etag"))f.etag[k]=y}if(a===304)c="notmodified",o=!0;else try{r=b_(d,w),c="success",o=!0}catch(z){c="parsererror",u=z}}else{u=c;if(!c||a)c="error",a<0&&(a=0)}v.status=a,v.statusText=c,o?h.resolveWith(e,[r,c,v]):h.rejectWith(e,[v,c,u]),v.statusCode(j),j=b,t&&g.trigger("ajax"+(o?"Success":"Error"),[v,d,o?r:u]),i.resolveWith(e,[v,c]),t&&(g.trigger("ajaxComplete",[v,d]),--f.active||f.event.trigger("ajaxStop"))}}typeof a=="object"&&(c=a,a=b),c=c||{};var d=f.ajaxSetup({},c),e=d.context||d,g=e!==d&&(e.nodeType||e instanceof f)?f(e):f.event,h=f.Deferred(),i=f._Deferred(),j=d.statusCode||{},k,l={},m={},n,o,p,q,r,s=0,t,u,v={readyState:0,setRequestHeader:function(a,b){if(!s){var c=a.toLowerCase();a=m[c]=m[c]||a,l[a]=b}return this},getAllResponseHeaders:function(){return s===2?n:null},getResponseHeader:function(a){var c;if(s===2){if(!o){o={};while(c=bG.exec(n))o[c[1].toLowerCase()]=c[2]}c=o[a.toLowerCase()]}return c===b?null:c},overrideMimeType:function(a){s||(d.mimeType=a);return this},abort:function(a){a=a||"abort",p&&p.abort(a),w(0,a);return this}};h.promise(v),v.success=v.done,v.error=v.fail,v.complete=i.done,v.statusCode=function(a){if(a){var b;if(s<2)for(b in a)j[b]=[j[b],a[b]];else b=a[v.status],v.then(b,b)}return this},d.url=((a||d.url)+"").replace(bF,"").replace(bK,bV[1]+"//"),d.dataTypes=f.trim(d.dataType||"*").toLowerCase().split(bO),d.crossDomain==null&&(r=bQ.exec(d.url.toLowerCase()),d.crossDomain=!(!r||r[1]==bV[1]&&r[2]==bV[2]&&(r[3]||(r[1]==="http:"?80:443))==(bV[3]||(bV[1]==="http:"?80:443)))),d.data&&d.processData&&typeof d.data!="string"&&(d.data=f.param(d.data,d.traditional)),bY(bS,d,c,v);if(s===2)return!1;t=d.global,d.type=d.type.toUpperCase(),d.hasContent=!bJ.test(d.type),t&&f.active++===0&&f.event.trigger("ajaxStart");if(!d.hasContent){d.data&&(d.url+=(bL.test(d.url)?"&":"?")+d.data),k=d.url;if(d.cache===!1){var x=f.now(),y=d.url.replace(bP,"$1_="+x);d.url=y+(y===d.url?(bL.test(d.url)?"&":"?")+"_="+x:"")}}(d.data&&d.hasContent&&d.contentType!==!1||c.contentType)&&v.setRequestHeader("Content-Type",d.contentType),d.ifModified&&(k=k||d.url,f.lastModified[k]&&v.setRequestHeader("If-Modified-Since",f.lastModified[k]),f.etag[k]&&v.setRequestHeader("If-None-Match",f.etag[k])),v.setRequestHeader("Accept",d.dataTypes[0]&&d.accepts[d.dataTypes[0]]?d.accepts[d.dataTypes[0]]+(d.dataTypes[0]!=="*"?", */*; q=0.01":""):d.accepts["*"]);for(u in d.headers)v.setRequestHeader(u,d.headers[u]);if(d.beforeSend&&(d.beforeSend.call(e,v,d)===!1||s===2)){v.abort();return!1}for(u in{success:1,error:1,complete:1})v[u](d[u]);p=bY(bT,d,c,v);if(!p)w(-1,"No Transport");else{v.readyState=1,t&&g.trigger("ajaxSend",[v,d]),d.async&&d.timeout>0&&(q=setTimeout(function(){v.abort("timeout")},d.timeout));try{s=1,p.send(l,w)}catch(z){status<2?w(-1,z):f.error(z)}}return v},param:function(a,c){var d=[],e=function(a,b){b=f.isFunction(b)?b():b,d[d.length]=encodeURIComponent(a)+"="+encodeURIComponent(b)};c===b&&(c=f.ajaxSettings.traditional);if(f.isArray(a)||a.jquery&&!f.isPlainObject(a))f.each(a,function(){e(this.name,this.value)});else for(var g in a)bZ(g,a[g],c,e);return d.join("&").replace(bC,"+")}}),f.extend({active:0,lastModified:{},etag:{}});var ca=f.now(),cb=/(\=)\?(&|$)|\?\?/i;f.ajaxSetup({jsonp:"callback",jsonpCallback:function(){return f.expando+"_"+ca++}}),f.ajaxPrefilter("json jsonp",function(b,c,d){var e=b.contentType==="application/x-www-form-urlencoded"&&typeof b.data=="string";if(b.dataTypes[0]==="jsonp"||b.jsonp!==!1&&(cb.test(b.url)||e&&cb.test(b.data))){var g,h=b.jsonpCallback=f.isFunction(b.jsonpCallback)?b.jsonpCallback():b.jsonpCallback,i=a[h],j=b.url,k=b.data,l="$1"+h+"$2";b.jsonp!==!1&&(j=j.replace(cb,l),b.url===j&&(e&&(k=k.replace(cb,l)),b.data===k&&(j+=(/\?/.test(j)?"&":"?")+b.jsonp+"="+h))),b.url=j,b.data=k,a[h]=function(a){g=[a]},d.always(function(){a[h]=i,g&&f.isFunction(i)&&a[h](g[0])}),b.converters["script json"]=function(){g||f.error(h+" was not called");return g[0]},b.dataTypes[0]="json";return"script"}}),f.ajaxSetup({accepts:{script:"text/javascript, application/javascript, application/ecmascript, application/x-ecmascript"},contents:{script:/javascript|ecmascript/},converters:{"text script":function(a){f.globalEval(a);return a}}}),f.ajaxPrefilter("script",function(a){a.cache===b&&(a.cache=!1),a.crossDomain&&(a.type="GET",a.global=!1)}),f.ajaxTransport("script",function(a){if(a.crossDomain){var d,e=c.head||c.getElementsByTagName("head")[0]||c.documentElement;return{send:function(f,g){d=c.createElement("script"),d.async="async",a.scriptCharset&&(d.charset=a.scriptCharset),d.src=a.url,d.onload=d.onreadystatechange=function(a,c){if(c||!d.readyState||/loaded|complete/.test(d.readyState))d.onload=d.onreadystatechange=null,e&&d.parentNode&&e.removeChild(d),d=b,c||g(200,"success")},e.insertBefore(d,e.firstChild)},abort:function(){d&&d.onload(0,1)}}}});var cc=a.ActiveXObject?function(){for(var a in ce)ce[a](0,1)}:!1,cd=0,ce;f.ajaxSettings.xhr=a.ActiveXObject?function(){return!this.isLocal&&cf()||cg()}:cf,function(a){f.extend(f.support,{ajax:!!a,cors:!!a&&"withCredentials"in a})}(f.ajaxSettings.xhr()),f.support.ajax&&f.ajaxTransport(function(c){if(!c.crossDomain||f.support.cors){var d;return{send:function(e,g){var h=c.xhr(),i,j;c.username?h.open(c.type,c.url,c.async,c.username,c.password):h.open(c.type,c.url,c.async);if(c.xhrFields)for(j in c.xhrFields)h[j]=c.xhrFields[j];c.mimeType&&h.overrideMimeType&&h.overrideMimeType(c.mimeType),!c.crossDomain&&!e["X-Requested-With"]&&(e["X-Requested-With"]="XMLHttpRequest");try{for(j in e)h.setRequestHeader(j,e[j])}catch(k){}h.send(c.hasContent&&c.data||null),d=function(a,e){var j,k,l,m,n;try{if(d&&(e||h.readyState===4)){d=b,i&&(h.onreadystatechange=f.noop,cc&&delete ce[i]);if(e)h.readyState!==4&&h.abort();else{j=h.status,l=h.getAllResponseHeaders(),m={},n=h.responseXML,n&&n.documentElement&&(m.xml=n),m.text=h.responseText;try{k=h.statusText}catch(o){k=""}!j&&c.isLocal&&!c.crossDomain?j=m.text?200:404:j===1223&&(j=204)}}}catch(p){e||g(-1,p)}m&&g(j,k,m,l)},!c.async||h.readyState===4?d():(i=++cd,cc&&(ce||(ce={},f(a).unload(cc)),ce[i]=d),h.onreadystatechange=d)},abort:function(){d&&d(0,1)}}}});var ch={},ci,cj,ck=/^(?:toggle|show|hide)$/,cl=/^([+\-]=)?([\d+.\-]+)([a-z%]*)$/i,cm,cn=[["height","marginTop","marginBottom","paddingTop","paddingBottom"],["width","marginLeft","marginRight","paddingLeft","paddingRight"],["opacity"]],co,cp=a.webkitRequestAnimationFrame||a.mozRequestAnimationFrame||a.oRequestAnimationFrame;f.fn.extend({show:function(a,b,c){var d,e;if(a||a===0)return this.animate(cs("show",3),a,b,c);for(var g=0,h=this.length;g<h;g++)d=this[g],d.style&&(e=d.style.display,!f._data(d,"olddisplay")&&e==="none"&&(e=d.style.display=""),e===""&&f.css(d,"display")==="none"&&f._data(d,"olddisplay",ct(d.nodeName)));for(g=0;g<h;g++){d=this[g];if(d.style){e=d.style.display;if(e===""||e==="none")d.style.display=f._data(d,"olddisplay")||""}}return this},hide:function(a,b,c){if(a||a===0)return this.animate(cs("hide",3),a,b,c);for(var d=0,e=this.length;d<e;d++)if(this[d].style){var g=f.css(this[d],"display");g!=="none"&&!f._data(this[d],"olddisplay")&&f._data(this[d],"olddisplay",g)}for(d=0;d<e;d++)this[d].style&&(this[d].style.display="none");return this},_toggle:f.fn.toggle,toggle:function(a,b,c){var d=typeof a=="boolean";f.isFunction(a)&&f.isFunction(b)?this._toggle.apply(this,arguments):a==null||d?this.each(function(){var b=d?a:f(this).is(":hidden");f(this)[b?"show":"hide"]()}):this.animate(cs("toggle",3),a,b,c);return this},fadeTo:function(a,b,c,d){return this.filter(":hidden").css("opacity",0).show().end().animate({opacity:b},a,c,d)},animate:function(a,b,c,d){var e=f.speed(b,c,d);if(f.isEmptyObject(a))return this.each(e.complete,[!1]);return this[e.queue===!1?"each":"queue"](function(){e.queue===!1&&f._mark(this);var b=f.extend({},e),c=this.nodeType===1,d=c&&f(this).is(":hidden"),g,h,i,j,k,l,m,n,o;b.animatedProperties={};for(i in a){g=f.camelCase(i),i!==g&&(a[g]=a[i],delete a[i]),h=a[g];if(h==="hide"&&d||h==="show"&&!d)return b.complete.call(this);c&&(g==="height"||g==="width")&&(b.overflow=[this.style.overflow,this.style.overflowX,this.style.overflowY],f.css(this,"display")==="inline"&&f.css(this,"float")==="none"&&(f.support.inlineBlockNeedsLayout?(j=ct(this.nodeName),j==="inline"?this.style.display="inline-block":(this.style.display="inline",this.style.zoom=1)):this.style.display="inline-block")),b.animatedProperties[g]=f.isArray(h)?h[1]:b.specialEasing&&b.specialEasing[g]||b.easing||"swing"}b.overflow!=null&&(this.style.overflow="hidden");for(i in a)k=new f.fx(this,b,i),h=a[i],ck.test(h)?k[h==="toggle"?d?"show":"hide":h]():(l=cl.exec(h),m=k.cur(),l?(n=parseFloat(l[2]),o=l[3]||(f.cssNumber[g]?"":"px"),o!=="px"&&(f.style(this,i,(n||1)+o),m=(n||1)/k.cur()*m,f.style(this,i,m+o)),l[1]&&(n=(l[1]==="-="?-1:1)*n+m),k.custom(m,n,o)):k.custom(m,h,""));return!0})},stop:function(a,b){a&&this.queue([]),this.each(function(){var a=f.timers,c=a.length;b||f._unmark(!0,this);while(c--)a[c].elem===this&&(b&&a[c](!0),a.splice(c,1))}),b||this.dequeue();return this}}),f.each({slideDown:cs("show",1),slideUp:cs("hide",1),slideToggle:cs("toggle",1),fadeIn:{opacity:"show"},fadeOut:{opacity:"hide"},fadeToggle:{opacity:"toggle"}},function(a,b){f.fn[a]=function(a,c,d){return this.animate(b,a,c,d)}}),f.extend({speed:function(a,b,c){var d=a&&typeof a=="object"?f.extend({},a):{complete:c||!c&&b||f.isFunction(a)&&a,duration:a,easing:c&&b||b&&!f.isFunction(b)&&b};d.duration=f.fx.off?0:typeof d.duration=="number"?d.duration:d.duration in f.fx.speeds?f.fx.speeds[d.duration]:f.fx.speeds._default,d.old=d.complete,d.complete=function(a){d.queue!==!1?f.dequeue(this):a!==!1&&f._unmark(this),f.isFunction(d.old)&&d.old.call(this)};return d},easing:{linear:function(a,b,c,d){return c+d*a},swing:function(a,b,c,d){return(-Math.cos(a*Math.PI)/2+.5)*d+c}},timers:[],fx:function(a,b,c){this.options=b,this.elem=a,this.prop=c,b.orig=b.orig||{}}}),f.fx.prototype={update:function(){this.options.step&&this.options.step.call(this.elem,this.now,this),(f.fx.step[this.prop]||f.fx.step._default)(this)},cur:function(){if(this.elem[this.prop]!=null&&(!this.elem.style||this.elem.style[this.prop]==null))return this.elem[this.prop];var a,b=f.css(this.elem,this.prop);return isNaN(a=parseFloat(b))?!b||b==="auto"?0:b:a},custom:function(a,b,c){function h(a){return d.step(a)}var d=this,e=f.fx,g;this.startTime=co||cq(),this.start=a,this.end=b,this.unit=c||this.unit||(f.cssNumber[this.prop]?"":"px"),this.now=this.start,this.pos=this.state=0,h.elem=this.elem,h()&&f.timers.push(h)&&!cm&&(cp?(cm=1,g=function(){cm&&(cp(g),e.tick())},cp(g)):cm=setInterval(e.tick,e.interval))},show:function(){this.options.orig[this.prop]=f.style(this.elem,this.prop),this.options.show=!0,this.custom(this.prop==="width"||this.prop==="height"?1:0,this.cur()),f(this.elem).show()},hide:function(){this.options.orig[this.prop]=f.style(this.elem,this.prop),this.options.hide=!0,this.custom(this.cur(),0)},step:function(a){var b=co||cq(),c=!0,d=this.elem,e=this.options,g,h;if(a||b>=e.duration+this.startTime){this.now=this.end,this.pos=this.state=1,this.update(),e.animatedProperties[this.prop]=!0;for(g in e.animatedProperties)e.animatedProperties[g]!==!0&&(c=!1);if(c){e.overflow!=null&&!f.support.shrinkWrapBlocks&&f.each(["","X","Y"],function(a,b){d.style["overflow"+b]=e.overflow[a]}),e.hide&&f(d).hide();if(e.hide||e.show)for(var i in e.animatedProperties)f.style(d,i,e.orig[i]);e.complete.call(d)}return!1}e.duration==Infinity?this.now=b:(h=b-this.startTime,this.state=h/e.duration,this.pos=f.easing[e.animatedProperties[this.prop]](this.state,h,0,1,e.duration),this.now=this.start+(this.end-this.start)*this.pos),this.update();return!0}},f.extend(f.fx,{tick:function(){var a=f.timers,b=a.length;while(b--)a[b]()||a.splice(b,1);a.length||f.fx.stop()},interval:13,stop:function(){clearInterval(cm),cm=null},speeds:{slow:600,fast:200,_default:400},step:{opacity:function(a){f.style(a.elem,"opacity",a.now)},_default:function(a){a.elem.style&&a.elem.style[a.prop]!=null?a.elem.style[a.prop]=(a.prop==="width"||a.prop==="height"?Math.max(0,a.now):a.now)+a.unit:a.elem[a.prop]=a.now}}}),f.expr&&f.expr.filters&&(f.expr.filters.animated=function(a){return f.grep(f.timers,function(b){return a===b.elem}).length});var cu=/^t(?:able|d|h)$/i,cv=/^(?:body|html)$/i;"getBoundingClientRect"in c.documentElement?f.fn.offset=function(a){var b=this[0],c;if(a)return this.each(function(b){f.offset.setOffset(this,a,b)});if(!b||!b.ownerDocument)return null;if(b===b.ownerDocument.body)return f.offset.bodyOffset(b);try{c=b.getBoundingClientRect()}catch(d){}var e=b.ownerDocument,g=e.documentElement;if(!c||!f.contains(g,b))return c?{top:c.top,left:c.left}:{top:0,left:0};var h=e.body,i=cw(e),j=g.clientTop||h.clientTop||0,k=g.clientLeft||h.clientLeft||0,l=i.pageYOffset||f.support.boxModel&&g.scrollTop||h.scrollTop,m=i.pageXOffset||f.support.boxModel&&g.scrollLeft||h.scrollLeft,n=c.top+l-j,o=c.left+m-k;return{top:n,left:o}}:f.fn.offset=function(a){var b=this[0];if(a)return this.each(function(b){f.offset.setOffset(this,a,b)});if(!b||!b.ownerDocument)return null;if(b===b.ownerDocument.body)return f.offset.bodyOffset(b);f.offset.initialize();var c,d=b.offsetParent,e=b,g=b.ownerDocument,h=g.documentElement,i=g.body,j=g.defaultView,k=j?j.getComputedStyle(b,null):b.currentStyle,l=b.offsetTop,m=b.offsetLeft;while((b=b.parentNode)&&b!==i&&b!==h){if(f.offset.supportsFixedPosition&&k.position==="fixed")break;c=j?j.getComputedStyle(b,null):b.currentStyle,l-=b.scrollTop,m-=b.scrollLeft,b===d&&(l+=b.offsetTop,m+=b.offsetLeft,f.offset.doesNotAddBorder&&(!f.offset.doesAddBorderForTableAndCells||!cu.test(b.nodeName))&&(l+=parseFloat(c.borderTopWidth)||0,m+=parseFloat(c.borderLeftWidth)||0),e=d,d=b.offsetParent),f.offset.subtractsBorderForOverflowNotVisible&&c.overflow!=="visible"&&(l+=parseFloat(c.borderTopWidth)||0,m+=parseFloat(c.borderLeftWidth)||0),k=c}if(k.position==="relative"||k.position==="static")l+=i.offsetTop,m+=i.offsetLeft;f.offset.supportsFixedPosition&&k.position==="fixed"&&(l+=Math.max(h.scrollTop,i.scrollTop),m+=Math.max(h.scrollLeft,i.scrollLeft));return{top:l,left:m}},f.offset={initialize:function(){var a=c.body,b=c.createElement("div"),d,e,g,h,i=parseFloat(f.css(a,"marginTop"))||0,j="<div style='position:absolute;top:0;left:0;margin:0;border:5px solid #000;padding:0;width:1px;height:1px;'><div></div></div><table style='position:absolute;top:0;left:0;margin:0;border:5px solid #000;padding:0;width:1px;height:1px;' cellpadding='0' cellspacing='0'><tr><td></td></tr></table>";f.extend(b.style,{position:"absolute",top:0,left:0,margin:0,border:0,width:"1px",height:"1px",visibility:"hidden"}),b.innerHTML=j,a.insertBefore(b,a.firstChild),d=b.firstChild,e=d.firstChild,h=d.nextSibling.firstChild.firstChild,this.doesNotAddBorder=e.offsetTop!==5,this.doesAddBorderForTableAndCells=h.offsetTop===5,e.style.position="fixed",e.style.top="20px",this.supportsFixedPosition=e.offsetTop===20||e.offsetTop===15,e.style.position=e.style.top="",d.style.overflow="hidden",d.style.position="relative",this.subtractsBorderForOverflowNotVisible=e.offsetTop===-5,this.doesNotIncludeMarginInBodyOffset=a.offsetTop!==i,a.removeChild(b),f.offset.initialize=f.noop},bodyOffset:function(a){var b=a.offsetTop,c=a.offsetLeft;f.offset.initialize(),f.offset.doesNotIncludeMarginInBodyOffset&&(b+=parseFloat(f.css(a,"marginTop"))||0,c+=parseFloat(f.css(a,"marginLeft"))||0);return{top:b,left:c}},setOffset:function(a,b,c){var d=f.css(a,"position");d==="static"&&(a.style.position="relative");var e=f(a),g=e.offset(),h=f.css(a,"top"),i=f.css(a,"left"),j=(d==="absolute"||d==="fixed")&&f.inArray("auto",[h,i])>-1,k={},l={},m,n;j?(l=e.position(),m=l.top,n=l.left):(m=parseFloat(h)||0,n=parseFloat(i)||0),f.isFunction(b)&&(b=b.call(a,c,g)),b.top!=null&&(k.top=b.top-g.top+m),b.left!=null&&(k.left=b.left-g.left+n),"using"in b?b.using.call(a,k):e.css(k)}},f.fn.extend({position:function(){if(!this[0])return null;var a=this[0],b=this.offsetParent(),c=this.offset(),d=cv.test(b[0].nodeName)?{top:0,left:0}:b.offset();c.top-=parseFloat(f.css(a,"marginTop"))||0,c.left-=parseFloat(f.css(a,"marginLeft"))||0,d.top+=parseFloat(f.css(b[0],"borderTopWidth"))||0,d.left+=parseFloat(f.css(b[0],"borderLeftWidth"))||0;return{top:c.top-d.top,left:c.left-d.left}},offsetParent:function(){return this.map(function(){var a=this.offsetParent||c.body;while(a&&!cv.test(a.nodeName)&&f.css(a,"position")==="static")a=a.offsetParent;return a})}}),f.each(["Left","Top"],function(a,c){var d="scroll"+c;f.fn[d]=function(c){var e,g;if(c===b){e=this[0];if(!e)return null;g=cw(e);return g?"pageXOffset"in g?g[a?"pageYOffset":"pageXOffset"]:f.support.boxModel&&g.document.documentElement[d]||g.document.body[d]:e[d]}return this.each(function(){g=cw(this),g?g.scrollTo(a?f(g).scrollLeft():c,a?c:f(g).scrollTop()):this[d]=c})}}),f.each(["Height","Width"],function(a,c){var d=c.toLowerCase();f.fn["inner"+c]=function(){return this[0]?parseFloat(f.css(this[0],d,"padding")):null},f.fn["outer"+c]=function(a){return this[0]?parseFloat(f.css(this[0],d,a?"margin":"border")):null},f.fn[d]=function(a){var e=this[0];if(!e)return a==null?null:this;if(f.isFunction(a))return this.each(function(b){var c=f(this);c[d](a.call(this,b,c[d]()))});if(f.isWindow(e)){var g=e.document.documentElement["client"+c];return e.document.compatMode==="CSS1Compat"&&g||e.document.body["client"+c]||g}if(e.nodeType===9)return Math.max(e.documentElement["client"+c],e.body["scroll"+c],e.documentElement["scroll"+c],e.body["offset"+c],e.documentElement["offset"+c]);if(a===b){var h=f.css(e,d),i=parseFloat(h);return f.isNaN(i)?h:i}return this.css(d,typeof a=="string"?a:a+"px")}}),a.jQuery=a.$=f})(window);
\ No newline at end of file
diff --git a/timeside/static/timeside/js/libs/raphael-min.js b/timeside/static/timeside/js/libs/raphael-min.js
deleted file mode 100644 (file)
index e5e7126..0000000
+++ /dev/null
@@ -1,7 +0,0 @@
-/*
- * Raphael 1.5.2 - JavaScript Vector Library
- *
- * Copyright (c) 2010 Dmitry Baranovskiy (http://raphaeljs.com)
- * Licensed under the MIT (http://raphaeljs.com/license.html) license.
- */
-(function(){function a(){if(a.is(arguments[0],G)){var b=arguments[0],d=bV[m](a,b.splice(0,3+a.is(b[0],E))),e=d.set();for(var g=0,h=b[w];g<h;g++){var i=b[g]||{};c[f](i.type)&&e[L](d[i.type]().attr(i))}return e}return bV[m](a,arguments)}a.version="1.5.2";var b=/[, ]+/,c={circle:1,rect:1,path:1,ellipse:1,text:1,image:1},d=/\{(\d+)\}/g,e="prototype",f="hasOwnProperty",g=document,h=window,i={was:Object[e][f].call(h,"Raphael"),is:h.Raphael},j=function(){this.customAttributes={}},k,l="appendChild",m="apply",n="concat",o="createTouch"in g,p="",q=" ",r=String,s="split",t="click dblclick mousedown mousemove mouseout mouseover mouseup touchstart touchmove touchend orientationchange touchcancel gesturestart gesturechange gestureend"[s](q),u={mousedown:"touchstart",mousemove:"touchmove",mouseup:"touchend"},v="join",w="length",x=r[e].toLowerCase,y=Math,z=y.max,A=y.min,B=y.abs,C=y.pow,D=y.PI,E="number",F="string",G="array",H="toString",I="fill",J=Object[e][H],K={},L="push",M=/^url\(['"]?([^\)]+?)['"]?\)$/i,N=/^\s*((#[a-f\d]{6})|(#[a-f\d]{3})|rgba?\(\s*([\d\.]+%?\s*,\s*[\d\.]+%?\s*,\s*[\d\.]+(?:%?\s*,\s*[\d\.]+)?)%?\s*\)|hsba?\(\s*([\d\.]+(?:deg|\xb0|%)?\s*,\s*[\d\.]+%?\s*,\s*[\d\.]+(?:%?\s*,\s*[\d\.]+)?)%?\s*\)|hsla?\(\s*([\d\.]+(?:deg|\xb0|%)?\s*,\s*[\d\.]+%?\s*,\s*[\d\.]+(?:%?\s*,\s*[\d\.]+)?)%?\s*\))\s*$/i,O={"NaN":1,Infinity:1,"-Infinity":1},P=/^(?:cubic-)?bezier\(([^,]+),([^,]+),([^,]+),([^\)]+)\)/,Q=y.round,R="setAttribute",S=parseFloat,T=parseInt,U=" progid:DXImageTransform.Microsoft",V=r[e].toUpperCase,W={blur:0,"clip-rect":"0 0 1e9 1e9",cursor:"default",cx:0,cy:0,fill:"#fff","fill-opacity":1,font:"10px \"Arial\"","font-family":"\"Arial\"","font-size":"10","font-style":"normal","font-weight":400,gradient:0,height:0,href:"http://raphaeljs.com/",opacity:1,path:"M0,0",r:0,rotation:0,rx:0,ry:0,scale:"1 1",src:"",stroke:"#000","stroke-dasharray":"","stroke-linecap":"butt","stroke-linejoin":"butt","stroke-miterlimit":0,"stroke-opacity":1,"stroke-width":1,target:"_blank","text-anchor":"middle",title:"Raphael",translation:"0 0",width:0,x:0,y:0},X={along:"along",blur:E,"clip-rect":"csv",cx:E,cy:E,fill:"colour","fill-opacity":E,"font-size":E,height:E,opacity:E,path:"path",r:E,rotation:"csv",rx:E,ry:E,scale:"csv",stroke:"colour","stroke-opacity":E,"stroke-width":E,translation:"csv",width:E,x:E,y:E},Y="replace",Z=/^(from|to|\d+%?)$/,$=/\s*,\s*/,_={hs:1,rg:1},ba=/,?([achlmqrstvxz]),?/gi,bb=/([achlmqstvz])[\s,]*((-?\d*\.?\d*(?:e[-+]?\d+)?\s*,?\s*)+)/ig,bc=/(-?\d*\.?\d*(?:e[-+]?\d+)?)\s*,?\s*/ig,bd=/^r(?:\(([^,]+?)\s*,\s*([^\)]+?)\))?/,be=function(a,b){return a.key-b.key};a.type=h.SVGAngle||g.implementation.hasFeature("http://www.w3.org/TR/SVG11/feature#BasicStructure","1.1")?"SVG":"VML";if(a.type=="VML"){var bf=g.createElement("div"),bg;bf.innerHTML="<v:shape adj=\"1\"/>";bg=bf.firstChild;bg.style.behavior="url(#default#VML)";if(!(bg&&typeof bg.adj=="object"))return a.type=null;bf=null}a.svg=!(a.vml=a.type=="VML");j[e]=a[e];k=j[e];a._id=0;a._oid=0;a.fn={};a.is=function(a,b){b=x.call(b);if(b=="finite")return!O[f](+a);return b=="null"&&a===null||b==typeof a||b=="object"&&a===Object(a)||b=="array"&&Array.isArray&&Array.isArray(a)||J.call(a).slice(8,-1).toLowerCase()==b};a.angle=function(b,c,d,e,f,g){{if(f==null){var h=b-d,i=c-e;if(!h&&!i)return 0;return((h<0)*180+y.atan(-i/-h)*180/D+360)%360}return a.angle(b,c,f,g)-a.angle(d,e,f,g)}};a.rad=function(a){return a%360*D/180};a.deg=function(a){return a*180/D%360};a.snapTo=function(b,c,d){d=a.is(d,"finite")?d:10;if(a.is(b,G)){var e=b.length;while(e--)if(B(b[e]-c)<=d)return b[e]}else{b=+b;var f=c%b;if(f<d)return c-f;if(f>b-d)return c-f+b}return c};function bh(){var a=[],b=0;for(;b<32;b++)a[b]=(~(~(y.random()*16)))[H](16);a[12]=4;a[16]=(a[16]&3|8)[H](16);return"r-"+a[v]("")}a.setWindow=function(a){h=a;g=h.document};var bi=function(b){if(a.vml){var c=/^\s+|\s+$/g,d;try{var e=new ActiveXObject("htmlfile");e.write("<body>");e.close();d=e.body}catch(a){d=createPopup().document.body}var f=d.createTextRange();bi=bm(function(a){try{d.style.color=r(a)[Y](c,p);var b=f.queryCommandValue("ForeColor");b=(b&255)<<16|b&65280|(b&16711680)>>>16;return"#"+("000000"+b[H](16)).slice(-6)}catch(a){return"none"}})}else{var h=g.createElement("i");h.title="Raphaël Colour Picker";h.style.display="none";g.body[l](h);bi=bm(function(a){h.style.color=a;return g.defaultView.getComputedStyle(h,p).getPropertyValue("color")})}return bi(b)},bj=function(){return"hsb("+[this.h,this.s,this.b]+")"},bk=function(){return"hsl("+[this.h,this.s,this.l]+")"},bl=function(){return this.hex};a.hsb2rgb=function(b,c,d,e){if(a.is(b,"object")&&"h"in b&&"s"in b&&"b"in b){d=b.b;c=b.s;b=b.h;e=b.o}return a.hsl2rgb(b,c,d/2,e)};a.hsl2rgb=function(b,c,d,e){if(a.is(b,"object")&&"h"in b&&"s"in b&&"l"in b){d=b.l;c=b.s;b=b.h}if(b>1||c>1||d>1){b/=360;c/=100;d/=100}var f={},g=["r","g","b"],h,i,j,k,l,m;if(c){d<0.5?h=d*(1+c):h=d+c-d*c;i=2*d-h;for(var n=0;n<3;n++){j=b+1/3*-(n-1);j<0&&j++;j>1&&j--;j*6<1?f[g[n]]=i+(h-i)*6*j:j*2<1?f[g[n]]=h:j*3<2?f[g[n]]=i+(h-i)*(2/3-j)*6:f[g[n]]=i}}else f={r:d,g:d,b:d};f.r*=255;f.g*=255;f.b*=255;f.hex="#"+(16777216|f.b|f.g<<8|f.r<<16).toString(16).slice(1);a.is(e,"finite")&&(f.opacity=e);f.toString=bl;return f};a.rgb2hsb=function(b,c,d){if(c==null&&a.is(b,"object")&&"r"in b&&"g"in b&&"b"in b){d=b.b;c=b.g;b=b.r}if(c==null&&a.is(b,F)){var e=a.getRGB(b);b=e.r;c=e.g;d=e.b}if(b>1||c>1||d>1){b/=255;c/=255;d/=255}var f=z(b,c,d),g=A(b,c,d),h,i,j=f;{if(g==f)return{h:0,s:0,b:f,toString:bj};var k=f-g;i=k/f;b==f?h=(c-d)/k:c==f?h=2+(d-b)/k:h=4+(b-c)/k;h/=6;h<0&&h++;h>1&&h--}return{h:h,s:i,b:j,toString:bj}};a.rgb2hsl=function(b,c,d){if(c==null&&a.is(b,"object")&&"r"in b&&"g"in b&&"b"in b){d=b.b;c=b.g;b=b.r}if(c==null&&a.is(b,F)){var e=a.getRGB(b);b=e.r;c=e.g;d=e.b}if(b>1||c>1||d>1){b/=255;c/=255;d/=255}var f=z(b,c,d),g=A(b,c,d),h,i,j=(f+g)/2,k;if(g==f)k={h:0,s:0,l:j};else{var l=f-g;i=j<0.5?l/(f+g):l/(2-f-g);b==f?h=(c-d)/l:c==f?h=2+(d-b)/l:h=4+(b-c)/l;h/=6;h<0&&h++;h>1&&h--;k={h:h,s:i,l:j}}k.toString=bk;return k};a._path2string=function(){return this.join(",")[Y](ba,"$1")};function bm(a,b,c){function d(){var g=Array[e].slice.call(arguments,0),h=g[v]("►"),i=d.cache=d.cache||{},j=d.count=d.count||[];if(i[f](h))return c?c(i[h]):i[h];j[w]>=1000&&delete i[j.shift()];j[L](h);i[h]=a[m](b,g);return c?c(i[h]):i[h]}return d}a.getRGB=bm(function(b){if(!b||!(!((b=r(b)).indexOf("-")+1)))return{r:-1,g:-1,b:-1,hex:"none",error:1};if(b=="none")return{r:-1,g:-1,b:-1,hex:"none"};!(_[f](b.toLowerCase().substring(0,2))||b.charAt()=="#")&&(b=bi(b));var c,d,e,g,h,i,j,k=b.match(N);if(k){if(k[2]){g=T(k[2].substring(5),16);e=T(k[2].substring(3,5),16);d=T(k[2].substring(1,3),16)}if(k[3]){g=T((i=k[3].charAt(3))+i,16);e=T((i=k[3].charAt(2))+i,16);d=T((i=k[3].charAt(1))+i,16)}if(k[4]){j=k[4][s]($);d=S(j[0]);j[0].slice(-1)=="%"&&(d*=2.55);e=S(j[1]);j[1].slice(-1)=="%"&&(e*=2.55);g=S(j[2]);j[2].slice(-1)=="%"&&(g*=2.55);k[1].toLowerCase().slice(0,4)=="rgba"&&(h=S(j[3]));j[3]&&j[3].slice(-1)=="%"&&(h/=100)}if(k[5]){j=k[5][s]($);d=S(j[0]);j[0].slice(-1)=="%"&&(d*=2.55);e=S(j[1]);j[1].slice(-1)=="%"&&(e*=2.55);g=S(j[2]);j[2].slice(-1)=="%"&&(g*=2.55);(j[0].slice(-3)=="deg"||j[0].slice(-1)=="°")&&(d/=360);k[1].toLowerCase().slice(0,4)=="hsba"&&(h=S(j[3]));j[3]&&j[3].slice(-1)=="%"&&(h/=100);return a.hsb2rgb(d,e,g,h)}if(k[6]){j=k[6][s]($);d=S(j[0]);j[0].slice(-1)=="%"&&(d*=2.55);e=S(j[1]);j[1].slice(-1)=="%"&&(e*=2.55);g=S(j[2]);j[2].slice(-1)=="%"&&(g*=2.55);(j[0].slice(-3)=="deg"||j[0].slice(-1)=="°")&&(d/=360);k[1].toLowerCase().slice(0,4)=="hsla"&&(h=S(j[3]));j[3]&&j[3].slice(-1)=="%"&&(h/=100);return a.hsl2rgb(d,e,g,h)}k={r:d,g:e,b:g};k.hex="#"+(16777216|g|e<<8|d<<16).toString(16).slice(1);a.is(h,"finite")&&(k.opacity=h);return k}return{r:-1,g:-1,b:-1,hex:"none",error:1}},a);a.getColor=function(a){var b=this.getColor.start=this.getColor.start||{h:0,s:1,b:a||0.75},c=this.hsb2rgb(b.h,b.s,b.b);b.h+=0.075;if(b.h>1){b.h=0;b.s-=0.2;b.s<=0&&(this.getColor.start={h:0,s:1,b:b.b})}return c.hex};a.getColor.reset=function(){delete this.start};a.parsePathString=bm(function(b){if(!b)return null;var c={a:7,c:6,h:1,l:2,m:2,q:4,s:4,t:2,v:1,z:0},d=[];a.is(b,G)&&a.is(b[0],G)&&(d=bo(b));d[w]||r(b)[Y](bb,function(a,b,e){var f=[],g=x.call(b);e[Y](bc,function(a,b){b&&f[L](+b)});if(g=="m"&&f[w]>2){d[L]([b][n](f.splice(0,2)));g="l";b=b=="m"?"l":"L"}while(f[w]>=c[g]){d[L]([b][n](f.splice(0,c[g])));if(!c[g])break}});d[H]=a._path2string;return d});a.findDotsAtSegment=function(a,b,c,d,e,f,g,h,i){var j=1-i,k=C(j,3)*a+C(j,2)*3*i*c+j*3*i*i*e+C(i,3)*g,l=C(j,3)*b+C(j,2)*3*i*d+j*3*i*i*f+C(i,3)*h,m=a+2*i*(c-a)+i*i*(e-2*c+a),n=b+2*i*(d-b)+i*i*(f-2*d+b),o=c+2*i*(e-c)+i*i*(g-2*e+c),p=d+2*i*(f-d)+i*i*(h-2*f+d),q=(1-i)*a+i*c,r=(1-i)*b+i*d,s=(1-i)*e+i*g,t=(1-i)*f+i*h,u=90-y.atan((m-o)/(n-p))*180/D;(m>o||n<p)&&(u+=180);return{x:k,y:l,m:{x:m,y:n},n:{x:o,y:p},start:{x:q,y:r},end:{x:s,y:t},alpha:u}};var bn=bm(function(a){if(!a)return{x:0,y:0,width:0,height:0};a=bw(a);var b=0,c=0,d=[],e=[],f;for(var g=0,h=a[w];g<h;g++){f=a[g];if(f[0]=="M"){b=f[1];c=f[2];d[L](b);e[L](c)}else{var i=bv(b,c,f[1],f[2],f[3],f[4],f[5],f[6]);d=d[n](i.min.x,i.max.x);e=e[n](i.min.y,i.max.y);b=f[5];c=f[6]}}var j=A[m](0,d),k=A[m](0,e);return{x:j,y:k,width:z[m](0,d)-j,height:z[m](0,e)-k}}),bo=function(b){var c=[];if(!a.is(b,G)||!a.is(b&&b[0],G))b=a.parsePathString(b);for(var d=0,e=b[w];d<e;d++){c[d]=[];for(var f=0,g=b[d][w];f<g;f++)c[d][f]=b[d][f]}c[H]=a._path2string;return c},bp=bm(function(b){if(!a.is(b,G)||!a.is(b&&b[0],G))b=a.parsePathString(b);var c=[],d=0,e=0,f=0,g=0,h=0;if(b[0][0]=="M"){d=b[0][1];e=b[0][2];f=d;g=e;h++;c[L](["M",d,e])}for(var i=h,j=b[w];i<j;i++){var k=c[i]=[],l=b[i];if(l[0]!=x.call(l[0])){k[0]=x.call(l[0]);switch(k[0]){case"a":k[1]=l[1];k[2]=l[2];k[3]=l[3];k[4]=l[4];k[5]=l[5];k[6]=+(l[6]-d).toFixed(3);k[7]=+(l[7]-e).toFixed(3);break;case"v":k[1]=+(l[1]-e).toFixed(3);break;case"m":f=l[1];g=l[2];default:for(var m=1,n=l[w];m<n;m++)k[m]=+(l[m]-(m%2?d:e)).toFixed(3)}}else{k=c[i]=[];if(l[0]=="m"){f=l[1]+d;g=l[2]+e}for(var o=0,p=l[w];o<p;o++)c[i][o]=l[o]}var q=c[i][w];switch(c[i][0]){case"z":d=f;e=g;break;case"h":d+=+c[i][q-1];break;case"v":e+=+c[i][q-1];break;default:d+=+c[i][q-2];e+=+c[i][q-1]}}c[H]=a._path2string;return c},0,bo),bq=bm(function(b){if(!a.is(b,G)||!a.is(b&&b[0],G))b=a.parsePathString(b);var c=[],d=0,e=0,f=0,g=0,h=0;if(b[0][0]=="M"){d=+b[0][1];e=+b[0][2];f=d;g=e;h++;c[0]=["M",d,e]}for(var i=h,j=b[w];i<j;i++){var k=c[i]=[],l=b[i];if(l[0]!=V.call(l[0])){k[0]=V.call(l[0]);switch(k[0]){case"A":k[1]=l[1];k[2]=l[2];k[3]=l[3];k[4]=l[4];k[5]=l[5];k[6]=+(l[6]+d);k[7]=+(l[7]+e);break;case"V":k[1]=+l[1]+e;break;case"H":k[1]=+l[1]+d;break;case"M":f=+l[1]+d;g=+l[2]+e;default:for(var m=1,n=l[w];m<n;m++)k[m]=+l[m]+(m%2?d:e)}}else for(var o=0,p=l[w];o<p;o++)c[i][o]=l[o];switch(k[0]){case"Z":d=f;e=g;break;case"H":d=k[1];break;case"V":e=k[1];break;case"M":f=c[i][c[i][w]-2];g=c[i][c[i][w]-1];default:d=c[i][c[i][w]-2];e=c[i][c[i][w]-1]}}c[H]=a._path2string;return c},null,bo),br=function(a,b,c,d){return[a,b,c,d,c,d]},bs=function(a,b,c,d,e,f){var g=1/3,h=2/3;return[g*a+h*c,g*b+h*d,g*e+h*c,g*f+h*d,e,f]},bt=function(a,b,c,d,e,f,g,h,i,j){var k=D*120/180,l=D/180*(+e||0),m=[],o,p=bm(function(a,b,c){var d=a*y.cos(c)-b*y.sin(c),e=a*y.sin(c)+b*y.cos(c);return{x:d,y:e}});if(j){G=j[0];H=j[1];E=j[2];F=j[3]}else{o=p(a,b,-l);a=o.x;b=o.y;o=p(h,i,-l);h=o.x;i=o.y;var q=y.cos(D/180*e),r=y.sin(D/180*e),t=(a-h)/2,u=(b-i)/2,x=t*t/(c*c)+u*u/(d*d);if(x>1){x=y.sqrt(x);c=x*c;d=x*d}var z=c*c,A=d*d,C=(f==g?-1:1)*y.sqrt(B((z*A-z*u*u-A*t*t)/(z*u*u+A*t*t))),E=C*c*u/d+(a+h)/2,F=C*-d*t/c+(b+i)/2,G=y.asin(((b-F)/d).toFixed(9)),H=y.asin(((i-F)/d).toFixed(9));G=a<E?D-G:G;H=h<E?D-H:H;G<0&&(G=D*2+G);H<0&&(H=D*2+H);g&&G>H&&(G=G-D*2);!g&&H>G&&(H=H-D*2)}var I=H-G;if(B(I)>k){var J=H,K=h,L=i;H=G+k*(g&&H>G?1:-1);h=E+c*y.cos(H);i=F+d*y.sin(H);m=bt(h,i,c,d,e,0,g,K,L,[H,J,E,F])}I=H-G;var M=y.cos(G),N=y.sin(G),O=y.cos(H),P=y.sin(H),Q=y.tan(I/4),R=4/3*c*Q,S=4/3*d*Q,T=[a,b],U=[a+R*N,b-S*M],V=[h+R*P,i-S*O],W=[h,i];U[0]=2*T[0]-U[0];U[1]=2*T[1]-U[1];{if(j)return[U,V,W][n](m);m=[U,V,W][n](m)[v]()[s](",");var X=[];for(var Y=0,Z=m[w];Y<Z;Y++)X[Y]=Y%2?p(m[Y-1],m[Y],l).y:p(m[Y],m[Y+1],l).x;return X}},bu=function(a,b,c,d,e,f,g,h,i){var j=1-i;return{x:C(j,3)*a+C(j,2)*3*i*c+j*3*i*i*e+C(i,3)*g,y:C(j,3)*b+C(j,2)*3*i*d+j*3*i*i*f+C(i,3)*h}},bv=bm(function(a,b,c,d,e,f,g,h){var i=e-2*c+a-(g-2*e+c),j=2*(c-a)-2*(e-c),k=a-c,l=(-j+y.sqrt(j*j-4*i*k))/2/i,n=(-j-y.sqrt(j*j-4*i*k))/2/i,o=[b,h],p=[a,g],q;B(l)>"1e12"&&(l=0.5);B(n)>"1e12"&&(n=0.5);if(l>0&&l<1){q=bu(a,b,c,d,e,f,g,h,l);p[L](q.x);o[L](q.y)}if(n>0&&n<1){q=bu(a,b,c,d,e,f,g,h,n);p[L](q.x);o[L](q.y)}i=f-2*d+b-(h-2*f+d);j=2*(d-b)-2*(f-d);k=b-d;l=(-j+y.sqrt(j*j-4*i*k))/2/i;n=(-j-y.sqrt(j*j-4*i*k))/2/i;B(l)>"1e12"&&(l=0.5);B(n)>"1e12"&&(n=0.5);if(l>0&&l<1){q=bu(a,b,c,d,e,f,g,h,l);p[L](q.x);o[L](q.y)}if(n>0&&n<1){q=bu(a,b,c,d,e,f,g,h,n);p[L](q.x);o[L](q.y)}return{min:{x:A[m](0,p),y:A[m](0,o)},max:{x:z[m](0,p),y:z[m](0,o)}}}),bw=bm(function(a,b){var c=bq(a),d=b&&bq(b),e={x:0,y:0,bx:0,by:0,X:0,Y:0,qx:null,qy:null},f={x:0,y:0,bx:0,by:0,X:0,Y:0,qx:null,qy:null},g=function(a,b){var c,d;if(!a)return["C",b.x,b.y,b.x,b.y,b.x,b.y];!(a[0]in{T:1,Q:1})&&(b.qx=b.qy=null);switch(a[0]){case"M":b.X=a[1];b.Y=a[2];break;case"A":a=["C"][n](bt[m](0,[b.x,b.y][n](a.slice(1))));break;case"S":c=b.x+(b.x-(b.bx||b.x));d=b.y+(b.y-(b.by||b.y));a=["C",c,d][n](a.slice(1));break;case"T":b.qx=b.x+(b.x-(b.qx||b.x));b.qy=b.y+(b.y-(b.qy||b.y));a=["C"][n](bs(b.x,b.y,b.qx,b.qy,a[1],a[2]));break;case"Q":b.qx=a[1];b.qy=a[2];a=["C"][n](bs(b.x,b.y,a[1],a[2],a[3],a[4]));break;case"L":a=["C"][n](br(b.x,b.y,a[1],a[2]));break;case"H":a=["C"][n](br(b.x,b.y,a[1],b.y));break;case"V":a=["C"][n](br(b.x,b.y,b.x,a[1]));break;case"Z":a=["C"][n](br(b.x,b.y,b.X,b.Y));break}return a},h=function(a,b){if(a[b][w]>7){a[b].shift();var e=a[b];while(e[w])a.splice(b++,0,["C"][n](e.splice(0,6)));a.splice(b,1);k=z(c[w],d&&d[w]||0)}},i=function(a,b,e,f,g){if(a&&b&&a[g][0]=="M"&&b[g][0]!="M"){b.splice(g,0,["M",f.x,f.y]);e.bx=0;e.by=0;e.x=a[g][1];e.y=a[g][2];k=z(c[w],d&&d[w]||0)}};for(var j=0,k=z(c[w],d&&d[w]||0);j<k;j++){c[j]=g(c[j],e);h(c,j);d&&(d[j]=g(d[j],f));d&&h(d,j);i(c,d,e,f,j);i(d,c,f,e,j);var l=c[j],o=d&&d[j],p=l[w],q=d&&o[w];e.x=l[p-2];e.y=l[p-1];e.bx=S(l[p-4])||e.x;e.by=S(l[p-3])||e.y;f.bx=d&&(S(o[q-4])||f.x);f.by=d&&(S(o[q-3])||f.y);f.x=d&&o[q-2];f.y=d&&o[q-1]}return d?[c,d]:c},null,bo),bx=bm(function(b){var c=[];for(var d=0,e=b[w];d<e;d++){var f={},g=b[d].match(/^([^:]*):?([\d\.]*)/);f.color=a.getRGB(g[1]);if(f.color.error)return null;f.color=f.color.hex;g[2]&&(f.offset=g[2]+"%");c[L](f)}for(d=1,e=c[w]-1;d<e;d++){if(!c[d].offset){var h=S(c[d-1].offset||0),i=0;for(var j=d+1;j<e;j++){if(c[j].offset){i=c[j].offset;break}}if(!i){i=100;j=e}i=S(i);var k=(i-h)/(j-d+1);for(;d<j;d++){h+=k;c[d].offset=h+"%"}}}return c}),by=function(b,c,d,e){var f;if(a.is(b,F)||a.is(b,"object")){f=a.is(b,F)?g.getElementById(b):b;if(f.tagName)return c==null?{container:f,width:f.style.pixelWidth||f.offsetWidth,height:f.style.pixelHeight||f.offsetHeight}:{container:f,width:c,height:d}}else return{container:1,x:b,y:c,width:d,height:e}},bz=function(a,b){var c=this;for(var d in b){if(b[f](d)&&!(d in a))switch(typeof b[d]){case"function":(function(b){a[d]=a===c?b:function(){return b[m](c,arguments)}})(b[d]);break;case"object":a[d]=a[d]||{};bz.call(this,a[d],b[d]);break;default:a[d]=b[d];break}}},bA=function(a,b){a==b.top&&(b.top=a.prev);a==b.bottom&&(b.bottom=a.next);a.next&&(a.next.prev=a.prev);a.prev&&(a.prev.next=a.next)},bB=function(a,b){if(b.top===a)return;bA(a,b);a.next=null;a.prev=b.top;b.top.next=a;b.top=a},bC=function(a,b){if(b.bottom===a)return;bA(a,b);a.next=b.bottom;a.prev=null;b.bottom.prev=a;b.bottom=a},bD=function(a,b,c){bA(a,c);b==c.top&&(c.top=a);b.next&&(b.next.prev=a);a.next=b.next;a.prev=b;b.next=a},bE=function(a,b,c){bA(a,c);b==c.bottom&&(c.bottom=a);b.prev&&(b.prev.next=a);a.prev=b.prev;b.prev=a;a.next=b},bF=function(a){return function(){throw new Error("Raphaël: you are calling to method “"+a+"” of removed object")}};a.pathToRelative=bp;if(a.svg){k.svgns="http://www.w3.org/2000/svg";k.xlink="http://www.w3.org/1999/xlink";Q=function(a){return+a+(~(~a)===a)*0.5};var bG=function(a,b){if(b)for(var c in b)b[f](c)&&a[R](c,r(b[c]));else{a=g.createElementNS(k.svgns,a);a.style.webkitTapHighlightColor="rgba(0,0,0,0)";return a}};a[H]=function(){return"Your browser supports SVG.\nYou are running Raphaël "+this.version};var bH=function(a,b){var c=bG("path");b.canvas&&b.canvas[l](c);var d=new bN(c,b);d.type="path";bK(d,{fill:"none",stroke:"#000",path:a});return d},bI=function(a,b,c){var d="linear",e=0.5,f=0.5,h=a.style;b=r(b)[Y](bd,function(a,b,c){d="radial";if(b&&c){e=S(b);f=S(c);var g=(f>0.5)*2-1;C(e-0.5,2)+C(f-0.5,2)>0.25&&(f=y.sqrt(0.25-C(e-0.5,2))*g+0.5)&&f!=0.5&&(f=f.toFixed(5)-0.00001*g)}return p});b=b[s](/\s*\-\s*/);if(d=="linear"){var i=b.shift();i=-S(i);if(isNaN(i))return null;var j=[0,0,y.cos(i*D/180),y.sin(i*D/180)],k=1/(z(B(j[2]),B(j[3]))||1);j[2]*=k;j[3]*=k;if(j[2]<0){j[0]=-j[2];j[2]=0}if(j[3]<0){j[1]=-j[3];j[3]=0}}var m=bx(b);if(!m)return null;var n=a.getAttribute(I);n=n.match(/^url\(#(.*)\)$/);n&&c.defs.removeChild(g.getElementById(n[1]));var o=bG(d+"Gradient");o.id=bh();bG(o,d=="radial"?{fx:e,fy:f}:{x1:j[0],y1:j[1],x2:j[2],y2:j[3]});c.defs[l](o);for(var q=0,t=m[w];q<t;q++){var u=bG("stop");bG(u,{offset:m[q].offset?m[q].offset:q?"100%":"0%","stop-color":m[q].color||"#fff"});o[l](u)}bG(a,{fill:"url(#"+o.id+")",opacity:1,"fill-opacity":1});h.fill=p;h.opacity=1;h.fillOpacity=1;return 1},bJ=function(b){var c=b.getBBox();bG(b.pattern,{patternTransform:a.format("translate({0},{1})",c.x,c.y)})},bK=function(c,d){var e={"":[0],none:[0],"-":[3,1],".":[1,1],"-.":[3,1,1,1],"-..":[3,1,1,1,1,1],". ":[1,3],"- ":[4,3],"--":[8,3],"- .":[4,3,1,3],"--.":[8,3,1,3],"--..":[8,3,1,3,1,3]},h=c.node,i=c.attrs,j=c.rotate(),k=function(a,b){b=e[x.call(b)];if(b){var c=a.attrs["stroke-width"]||"1",f=({round:c,square:c,butt:0})[a.attrs["stroke-linecap"]||d["stroke-linecap"]]||0,g=[],i=b[w];while(i--)g[i]=b[i]*c+(i%2?1:-1)*f;bG(h,{"stroke-dasharray":g[v](",")})}};d[f]("rotation")&&(j=d.rotation);var m=r(j)[s](b);if(m.length-1){m[1]=+m[1];m[2]=+m[2]}else m=null;S(j)&&c.rotate(0,true);for(var n in d){if(d[f](n)){if(!W[f](n))continue;var o=d[n];i[n]=o;switch(n){case"blur":c.blur(o);break;case"rotation":c.rotate(o,true);break;case"href":case"title":case"target":var t=h.parentNode;if(x.call(t.tagName)!="a"){var u=bG("a");t.insertBefore(u,h);u[l](h);t=u}n=="target"&&o=="blank"?t.setAttributeNS(c.paper.xlink,"show","new"):t.setAttributeNS(c.paper.xlink,n,o);break;case"cursor":h.style.cursor=o;break;case"clip-rect":var y=r(o)[s](b);if(y[w]==4){c.clip&&c.clip.parentNode.parentNode.removeChild(c.clip.parentNode);var z=bG("clipPath"),A=bG("rect");z.id=bh();bG(A,{x:y[0],y:y[1],width:y[2],height:y[3]});z[l](A);c.paper.defs[l](z);bG(h,{"clip-path":"url(#"+z.id+")"});c.clip=A}if(!o){var B=g.getElementById(h.getAttribute("clip-path")[Y](/(^url\(#|\)$)/g,p));B&&B.parentNode.removeChild(B);bG(h,{"clip-path":p});delete c.clip}break;case"path":c.type=="path"&&bG(h,{d:o?i.path=bq(o):"M0,0"});break;case"width":h[R](n,o);if(i.fx){n="x";o=i.x}else break;case"x":i.fx&&(o=-i.x-(i.width||0));case"rx":if(n=="rx"&&c.type=="rect")break;case"cx":m&&(n=="x"||n=="cx")&&(m[1]+=o-i[n]);h[R](n,o);c.pattern&&bJ(c);break;case"height":h[R](n,o);if(i.fy){n="y";o=i.y}else break;case"y":i.fy&&(o=-i.y-(i.height||0));case"ry":if(n=="ry"&&c.type=="rect")break;case"cy":m&&(n=="y"||n=="cy")&&(m[2]+=o-i[n]);h[R](n,o);c.pattern&&bJ(c);break;case"r":c.type=="rect"?bG(h,{rx:o,ry:o}):h[R](n,o);break;case"src":c.type=="image"&&h.setAttributeNS(c.paper.xlink,"href",o);break;case"stroke-width":h.style.strokeWidth=o;h[R](n,o);i["stroke-dasharray"]&&k(c,i["stroke-dasharray"]);break;case"stroke-dasharray":k(c,o);break;case"translation":var C=r(o)[s](b);C[0]=+C[0]||0;C[1]=+C[1]||0;if(m){m[1]+=C[0];m[2]+=C[1]}cz.call(c,C[0],C[1]);break;case"scale":C=r(o)[s](b);c.scale(+C[0]||1,+C[1]||+C[0]||1,isNaN(S(C[2]))?null:+C[2],isNaN(S(C[3]))?null:+C[3]);break;case I:var D=r(o).match(M);if(D){z=bG("pattern");var E=bG("image");z.id=bh();bG(z,{x:0,y:0,patternUnits:"userSpaceOnUse",height:1,width:1});bG(E,{x:0,y:0});E.setAttributeNS(c.paper.xlink,"href",D[1]);z[l](E);var F=g.createElement("img");F.style.cssText="position:absolute;left:-9999em;top-9999em";F.onload=function(){bG(z,{width:this.offsetWidth,height:this.offsetHeight});bG(E,{width:this.offsetWidth,height:this.offsetHeight});g.body.removeChild(this);c.paper.safari()};g.body[l](F);F.src=D[1];c.paper.defs[l](z);h.style.fill="url(#"+z.id+")";bG(h,{fill:"url(#"+z.id+")"});c.pattern=z;c.pattern&&bJ(c);break}var G=a.getRGB(o);if(G.error)if((({circle:1,ellipse:1})[f](c.type)||r(o).charAt()!="r")&&bI(h,o,c.paper)){i.gradient=o;i.fill="none";break}else{delete d.gradient;delete i.gradient;!a.is(i.opacity,"undefined")&&a.is(d.opacity,"undefined")&&bG(h,{opacity:i.opacity});!a.is(i["fill-opacity"],"undefined")&&a.is(d["fill-opacity"],"undefined")&&bG(h,{"fill-opacity":i["fill-opacity"]})}G[f]("opacity")&&bG(h,{"fill-opacity":G.opacity>1?G.opacity/100:G.opacity});case"stroke":G=a.getRGB(o);h[R](n,G.hex);n=="stroke"&&G[f]("opacity")&&bG(h,{"stroke-opacity":G.opacity>1?G.opacity/100:G.opacity});break;case"gradient":(({circle:1,ellipse:1})[f](c.type)||r(o).charAt()!="r")&&bI(h,o,c.paper);break;case"opacity":i.gradient&&!i[f]("stroke-opacity")&&bG(h,{"stroke-opacity":o>1?o/100:o});case"fill-opacity":if(i.gradient){var H=g.getElementById(h.getAttribute(I)[Y](/^url\(#|\)$/g,p));if(H){var J=H.getElementsByTagName("stop");J[J[w]-1][R]("stop-opacity",o)}break}default:n=="font-size"&&(o=T(o,10)+"px");var K=n[Y](/(\-.)/g,function(a){return V.call(a.substring(1))});h.style[K]=o;h[R](n,o);break}}}bM(c,d);m?c.rotate(m.join(q)):S(j)&&c.rotate(j,true)},bL=1.2,bM=function(b,c){if(b.type!="text"||!(c[f]("text")||c[f]("font")||c[f]("font-size")||c[f]("x")||c[f]("y")))return;var d=b.attrs,e=b.node,h=e.firstChild?T(g.defaultView.getComputedStyle(e.firstChild,p).getPropertyValue("font-size"),10):10;if(c[f]("text")){d.text=c.text;while(e.firstChild)e.removeChild(e.firstChild);var i=r(c.text)[s]("\n");for(var j=0,k=i[w];j<k;j++)if(i[j]){var m=bG("tspan");j&&bG(m,{dy:h*bL,x:d.x});m[l](g.createTextNode(i[j]));e[l](m)}}else{i=e.getElementsByTagName("tspan");for(j=0,k=i[w];j<k;j++)j&&bG(i[j],{dy:h*bL,x:d.x})}bG(e,{y:d.y});var n=b.getBBox(),o=d.y-(n.y+n.height/2);o&&a.is(o,"finite")&&bG(e,{y:d.y+o})},bN=function(b,c){var d=0,e=0;this[0]=b;this.id=a._oid++;this.node=b;b.raphael=this;this.paper=c;this.attrs=this.attrs||{};this.transformations=[];this._={tx:0,ty:0,rt:{deg:0,cx:0,cy:0},sx:1,sy:1};!c.bottom&&(c.bottom=this);this.prev=c.top;c.top&&(c.top.next=this);c.top=this;this.next=null},bO=bN[e];bN[e].rotate=function(c,d,e){if(this.removed)return this;if(c==null){if(this._.rt.cx)return[this._.rt.deg,this._.rt.cx,this._.rt.cy][v](q);return this._.rt.deg}var f=this.getBBox();c=r(c)[s](b);if(c[w]-1){d=S(c[1]);e=S(c[2])}c=S(c[0]);d!=null&&d!==false?this._.rt.deg=c:this._.rt.deg+=c;e==null&&(d=null);this._.rt.cx=d;this._.rt.cy=e;d=d==null?f.x+f.width/2:d;e=e==null?f.y+f.height/2:e;if(this._.rt.deg){this.transformations[0]=a.format("rotate({0} {1} {2})",this._.rt.deg,d,e);this.clip&&bG(this.clip,{transform:a.format("rotate({0} {1} {2})",-this._.rt.deg,d,e)})}else{this.transformations[0]=p;this.clip&&bG(this.clip,{transform:p})}bG(this.node,{transform:this.transformations[v](q)});return this};bN[e].hide=function(){!this.removed&&(this.node.style.display="none");return this};bN[e].show=function(){!this.removed&&(this.node.style.display="");return this};bN[e].remove=function(){if(this.removed)return;bA(this,this.paper);this.node.parentNode.removeChild(this.node);for(var a in this)delete this[a];this.removed=true};bN[e].getBBox=function(){if(this.removed)return this;if(this.type=="path")return bn(this.attrs.path);if(this.node.style.display=="none"){this.show();var a=true}var b={};try{b=this.node.getBBox()}catch(a){}finally{b=b||{}}if(this.type=="text"){b={x:b.x,y:Infinity,width:0,height:0};for(var c=0,d=this.node.getNumberOfChars();c<d;c++){var e=this.node.getExtentOfChar(c);e.y<b.y&&(b.y=e.y);e.y+e.height-b.y>b.height&&(b.height=e.y+e.height-b.y);e.x+e.width-b.x>b.width&&(b.width=e.x+e.width-b.x)}}a&&this.hide();return b};bN[e].attr=function(b,c){if(this.removed)return this;if(b==null){var d={};for(var e in this.attrs)this.attrs[f](e)&&(d[e]=this.attrs[e]);this._.rt.deg&&(d.rotation=this.rotate());(this._.sx!=1||this._.sy!=1)&&(d.scale=this.scale());d.gradient&&d.fill=="none"&&(d.fill=d.gradient)&&delete d.gradient;return d}if(c==null&&a.is(b,F)){if(b=="translation")return cz.call(this);if(b=="rotation")return this.rotate();if(b=="scale")return this.scale();if(b==I&&this.attrs.fill=="none"&&this.attrs.gradient)return this.attrs.gradient;return this.attrs[b]}if(c==null&&a.is(b,G)){var g={};for(var h=0,i=b.length;h<i;h++)g[b[h]]=this.attr(b[h]);return g}if(c!=null){var j={};j[b]=c}else b!=null&&a.is(b,"object")&&(j=b);for(var k in this.paper.customAttributes)if(this.paper.customAttributes[f](k)&&j[f](k)&&a.is(this.paper.customAttributes[k],"function")){var l=this.paper.customAttributes[k].apply(this,[][n](j[k]));this.attrs[k]=j[k];for(var m in l)l[f](m)&&(j[m]=l[m])}bK(this,j);return this};bN[e].toFront=function(){if(this.removed)return this;this.node.parentNode[l](this.node);var a=this.paper;a.top!=this&&bB(this,a);return this};bN[e].toBack=function(){if(this.removed)return this;if(this.node.parentNode.firstChild!=this.node){this.node.parentNode.insertBefore(this.node,this.node.parentNode.firstChild);bC(this,this.paper);var a=this.paper}return this};bN[e].insertAfter=function(a){if(this.removed)return this;var b=a.node||a[a.length-1].node;b.nextSibling?b.parentNode.insertBefore(this.node,b.nextSibling):b.parentNode[l](this.node);bD(this,a,this.paper);return this};bN[e].insertBefore=function(a){if(this.removed)return this;var b=a.node||a[0].node;b.parentNode.insertBefore(this.node,b);bE(this,a,this.paper);return this};bN[e].blur=function(a){var b=this;if(+a!==0){var c=bG("filter"),d=bG("feGaussianBlur");b.attrs.blur=a;c.id=bh();bG(d,{stdDeviation:+a||1.5});c.appendChild(d);b.paper.defs.appendChild(c);b._blur=c;bG(b.node,{filter:"url(#"+c.id+")"})}else{if(b._blur){b._blur.parentNode.removeChild(b._blur);delete b._blur;delete b.attrs.blur}b.node.removeAttribute("filter")}};var bP=function(a,b,c,d){var e=bG("circle");a.canvas&&a.canvas[l](e);var f=new bN(e,a);f.attrs={cx:b,cy:c,r:d,fill:"none",stroke:"#000"};f.type="circle";bG(e,f.attrs);return f},bQ=function(a,b,c,d,e,f){var g=bG("rect");a.canvas&&a.canvas[l](g);var h=new bN(g,a);h.attrs={x:b,y:c,width:d,height:e,r:f||0,rx:f||0,ry:f||0,fill:"none",stroke:"#000"};h.type="rect";bG(g,h.attrs);return h},bR=function(a,b,c,d,e){var f=bG("ellipse");a.canvas&&a.canvas[l](f);var g=new bN(f,a);g.attrs={cx:b,cy:c,rx:d,ry:e,fill:"none",stroke:"#000"};g.type="ellipse";bG(f,g.attrs);return g},bS=function(a,b,c,d,e,f){var g=bG("image");bG(g,{x:c,y:d,width:e,height:f,preserveAspectRatio:"none"});g.setAttributeNS(a.xlink,"href",b);a.canvas&&a.canvas[l](g);var h=new bN(g,a);h.attrs={x:c,y:d,width:e,height:f,src:b};h.type="image";return h},bT=function(a,b,c,d){var e=bG("text");bG(e,{x:b,y:c,"text-anchor":"middle"});a.canvas&&a.canvas[l](e);var f=new bN(e,a);f.attrs={x:b,y:c,"text-anchor":"middle",text:d,font:W.font,stroke:"none",fill:"#000"};f.type="text";bK(f,f.attrs);return f},bU=function(a,b){this.width=a||this.width;this.height=b||this.height;this.canvas[R]("width",this.width);this.canvas[R]("height",this.height);return this},bV=function(){var b=by[m](0,arguments),c=b&&b.container,d=b.x,e=b.y,f=b.width,h=b.height;if(!c)throw new Error("SVG container not found.");var i=bG("svg");d=d||0;e=e||0;f=f||512;h=h||342;bG(i,{xmlns:"http://www.w3.org/2000/svg",version:1.1,width:f,height:h});if(c==1){i.style.cssText="position:absolute;left:"+d+"px;top:"+e+"px";g.body[l](i)}else c.firstChild?c.insertBefore(i,c.firstChild):c[l](i);c=new j;c.width=f;c.height=h;c.canvas=i;bz.call(c,c,a.fn);c.clear();return c};k.clear=function(){var a=this.canvas;while(a.firstChild)a.removeChild(a.firstChild);this.bottom=this.top=null;(this.desc=bG("desc"))[l](g.createTextNode("Created with Raphaël"));a[l](this.desc);a[l](this.defs=bG("defs"))};k.remove=function(){this.canvas.parentNode&&this.canvas.parentNode.removeChild(this.canvas);for(var a in this)this[a]=bF(a)}}if(a.vml){var bW={M:"m",L:"l",C:"c",Z:"x",m:"t",l:"r",c:"v",z:"x"},bX=/([clmz]),?([^clmz]*)/gi,bY=/ progid:\S+Blur\([^\)]+\)/g,bZ=/-?[^,\s-]+/g,b$=1000+q+1000,b_=10,ca={path:1,rect:1},cb=function(a){var b=/[ahqstv]/ig,c=bq;r(a).match(b)&&(c=bw);b=/[clmz]/g;if(c==bq&&!r(a).match(b)){var d=r(a)[Y](bX,function(a,b,c){var d=[],e=x.call(b)=="m",f=bW[b];c[Y](bZ,function(a){if(e&&d[w]==2){f+=d+bW[b=="m"?"l":"L"];d=[]}d[L](Q(a*b_))});return f+d});return d}var e=c(a),f,g;d=[];for(var h=0,i=e[w];h<i;h++){f=e[h];g=x.call(e[h][0]);g=="z"&&(g="x");for(var j=1,k=f[w];j<k;j++)g+=Q(f[j]*b_)+(j!=k-1?",":p);d[L](g)}return d[v](q)};a[H]=function(){return"Your browser doesn’t support SVG. Falling down to VML.\nYou are running Raphaël "+this.version};bH=function(a,b){var c=cd("group");c.style.cssText="position:absolute;left:0;top:0;width:"+b.width+"px;height:"+b.height+"px";c.coordsize=b.coordsize;c.coordorigin=b.coordorigin;var d=cd("shape"),e=d.style;e.width=b.width+"px";e.height=b.height+"px";d.coordsize=b$;d.coordorigin=b.coordorigin;c[l](d);var f=new bN(d,c,b),g={fill:"none",stroke:"#000"};a&&(g.path=a);f.type="path";f.path=[];f.Path=p;bK(f,g);b.canvas[l](c);return f};bK=function(c,d){c.attrs=c.attrs||{};var e=c.node,h=c.attrs,i=e.style,j,k=(d.x!=h.x||d.y!=h.y||d.width!=h.width||d.height!=h.height||d.r!=h.r)&&c.type=="rect",m=c;for(var n in d)d[f](n)&&(h[n]=d[n]);if(k){h.path=cc(h.x,h.y,h.width,h.height,h.r);c.X=h.x;c.Y=h.y;c.W=h.width;c.H=h.height}d.href&&(e.href=d.href);d.title&&(e.title=d.title);d.target&&(e.target=d.target);d.cursor&&(i.cursor=d.cursor);"blur"in d&&c.blur(d.blur);if(d.path&&c.type=="path"||k)e.path=cb(h.path);d.rotation!=null&&c.rotate(d.rotation,true);if(d.translation){j=r(d.translation)[s](b);cz.call(c,j[0],j[1]);if(c._.rt.cx!=null){c._.rt.cx+=+j[0];c._.rt.cy+=+j[1];c.setBox(c.attrs,j[0],j[1])}}if(d.scale){j=r(d.scale)[s](b);c.scale(+j[0]||1,+j[1]||+j[0]||1,+j[2]||null,+j[3]||null)}if("clip-rect"in d){var o=r(d["clip-rect"])[s](b);if(o[w]==4){o[2]=+o[2]+ +o[0];o[3]=+o[3]+ +o[1];var q=e.clipRect||g.createElement("div"),t=q.style,u=e.parentNode;t.clip=a.format("rect({1}px {2}px {3}px {0}px)",o);if(!e.clipRect){t.position="absolute";t.top=0;t.left=0;t.width=c.paper.width+"px";t.height=c.paper.height+"px";u.parentNode.insertBefore(q,u);q[l](u);e.clipRect=q}}d["clip-rect"]||e.clipRect&&(e.clipRect.style.clip=p)}c.type=="image"&&d.src&&(e.src=d.src);if(c.type=="image"&&d.opacity){e.filterOpacity=U+".Alpha(opacity="+d.opacity*100+")";i.filter=(e.filterMatrix||p)+(e.filterOpacity||p)}d.font&&(i.font=d.font);d["font-family"]&&(i.fontFamily="\""+d["font-family"][s](",")[0][Y](/^['"]+|['"]+$/g,p)+"\"");d["font-size"]&&(i.fontSize=d["font-size"]);d["font-weight"]&&(i.fontWeight=d["font-weight"]);d["font-style"]&&(i.fontStyle=d["font-style"]);if(d.opacity!=null||d["stroke-width"]!=null||d.fill!=null||d.stroke!=null||d["stroke-width"]!=null||d["stroke-opacity"]!=null||d["fill-opacity"]!=null||d["stroke-dasharray"]!=null||d["stroke-miterlimit"]!=null||d["stroke-linejoin"]!=null||d["stroke-linecap"]!=null){e=c.shape||e;var v=e.getElementsByTagName(I)&&e.getElementsByTagName(I)[0],x=false;!v&&(x=v=cd(I));if("fill-opacity"in d||"opacity"in d){var y=((+h["fill-opacity"]+1||2)-1)*((+h.opacity+1||2)-1)*((+a.getRGB(d.fill).o+1||2)-1);y=A(z(y,0),1);v.opacity=y}d.fill&&(v.on=true);if(v.on==null||d.fill=="none")v.on=false;if(v.on&&d.fill){var B=d.fill.match(M);if(B){v.src=B[1];v.type="tile"}else{v.color=a.getRGB(d.fill).hex;v.src=p;v.type="solid";if(a.getRGB(d.fill).error&&(m.type in{circle:1,ellipse:1}||r(d.fill).charAt()!="r")&&bI(m,d.fill)){h.fill="none";h.gradient=d.fill}}}x&&e[l](v);var C=e.getElementsByTagName("stroke")&&e.getElementsByTagName("stroke")[0],D=false;!C&&(D=C=cd("stroke"));if(d.stroke&&d.stroke!="none"||d["stroke-width"]||d["stroke-opacity"]!=null||d["stroke-dasharray"]||d["stroke-miterlimit"]||d["stroke-linejoin"]||d["stroke-linecap"])C.on=true;(d.stroke=="none"||C.on==null||d.stroke==0||d["stroke-width"]==0)&&(C.on=false);var E=a.getRGB(d.stroke);C.on&&d.stroke&&(C.color=E.hex);y=((+h["stroke-opacity"]+1||2)-1)*((+h.opacity+1||2)-1)*((+E.o+1||2)-1);var F=(S(d["stroke-width"])||1)*0.75;y=A(z(y,0),1);d["stroke-width"]==null&&(F=h["stroke-width"]);d["stroke-width"]&&(C.weight=F);F&&F<1&&(y*=F)&&(C.weight=1);C.opacity=y;d["stroke-linejoin"]&&(C.joinstyle=d["stroke-linejoin"]||"miter");C.miterlimit=d["stroke-miterlimit"]||8;d["stroke-linecap"]&&(C.endcap=d["stroke-linecap"]=="butt"?"flat":d["stroke-linecap"]=="square"?"square":"round");if(d["stroke-dasharray"]){var G={"-":"shortdash",".":"shortdot","-.":"shortdashdot","-..":"shortdashdotdot",". ":"dot","- ":"dash","--":"longdash","- .":"dashdot","--.":"longdashdot","--..":"longdashdotdot"};C.dashstyle=G[f](d["stroke-dasharray"])?G[d["stroke-dasharray"]]:p}D&&e[l](C)}if(m.type=="text"){i=m.paper.span.style;h.font&&(i.font=h.font);h["font-family"]&&(i.fontFamily=h["font-family"]);h["font-size"]&&(i.fontSize=h["font-size"]);h["font-weight"]&&(i.fontWeight=h["font-weight"]);h["font-style"]&&(i.fontStyle=h["font-style"]);m.node.string&&(m.paper.span.innerHTML=r(m.node.string)[Y](/</g,"&#60;")[Y](/&/g,"&#38;")[Y](/\n/g,"<br>"));m.W=h.w=m.paper.span.offsetWidth;m.H=h.h=m.paper.span.offsetHeight;m.X=h.x;m.Y=h.y+Q(m.H/2);switch(h["text-anchor"]){case"start":m.node.style["v-text-align"]="left";m.bbx=Q(m.W/2);break;case"end":m.node.style["v-text-align"]="right";m.bbx=-Q(m.W/2);break;default:m.node.style["v-text-align"]="center";break}}};bI=function(a,b){a.attrs=a.attrs||{};var c=a.attrs,d,e="linear",f=".5 .5";a.attrs.gradient=b;b=r(b)[Y](bd,function(a,b,c){e="radial";if(b&&c){b=S(b);c=S(c);C(b-0.5,2)+C(c-0.5,2)>0.25&&(c=y.sqrt(0.25-C(b-0.5,2))*((c>0.5)*2-1)+0.5);f=b+q+c}return p});b=b[s](/\s*\-\s*/);if(e=="linear"){var g=b.shift();g=-S(g);if(isNaN(g))return null}var h=bx(b);if(!h)return null;a=a.shape||a.node;d=a.getElementsByTagName(I)[0]||cd(I);!d.parentNode&&a.appendChild(d);if(h[w]){d.on=true;d.method="none";d.color=h[0].color;d.color2=h[h[w]-1].color;var i=[];for(var j=0,k=h[w];j<k;j++)h[j].offset&&i[L](h[j].offset+q+h[j].color);d.colors&&(d.colors.value=i[w]?i[v]():"0% "+d.color);if(e=="radial"){d.type="gradientradial";d.focus="100%";d.focussize=f;d.focusposition=f}else{d.type="gradient";d.angle=(270-g)%360}}return 1};bN=function(b,c,d){var e=0,f=0,g=0,h=1;this[0]=b;this.id=a._oid++;this.node=b;b.raphael=this;this.X=0;this.Y=0;this.attrs={};this.Group=c;this.paper=d;this._={tx:0,ty:0,rt:{deg:0},sx:1,sy:1};!d.bottom&&(d.bottom=this);this.prev=d.top;d.top&&(d.top.next=this);d.top=this;this.next=null};bO=bN[e];bO.rotate=function(a,c,d){if(this.removed)return this;if(a==null){if(this._.rt.cx)return[this._.rt.deg,this._.rt.cx,this._.rt.cy][v](q);return this._.rt.deg}a=r(a)[s](b);if(a[w]-1){c=S(a[1]);d=S(a[2])}a=S(a[0]);c!=null?this._.rt.deg=a:this._.rt.deg+=a;d==null&&(c=null);this._.rt.cx=c;this._.rt.cy=d;this.setBox(this.attrs,c,d);this.Group.style.rotation=this._.rt.deg;return this};bO.setBox=function(a,b,c){if(this.removed)return this;var d=this.Group.style,e=this.shape&&this.shape.style||this.node.style;a=a||{};for(var g in a)a[f](g)&&(this.attrs[g]=a[g]);b=b||this._.rt.cx;c=c||this._.rt.cy;var h=this.attrs,i,j,k,l;switch(this.type){case"circle":i=h.cx-h.r;j=h.cy-h.r;k=l=h.r*2;break;case"ellipse":i=h.cx-h.rx;j=h.cy-h.ry;k=h.rx*2;l=h.ry*2;break;case"image":i=+h.x;j=+h.y;k=h.width||0;l=h.height||0;break;case"text":this.textpath.v=["m",Q(h.x),", ",Q(h.y-2),"l",Q(h.x)+1,", ",Q(h.y-2)][v](p);i=h.x-Q(this.W/2);j=h.y-this.H/2;k=this.W;l=this.H;break;case"rect":case"path":if(this.attrs.path){var m=bn(this.attrs.path);i=m.x;j=m.y;k=m.width;l=m.height}else{i=0;j=0;k=this.paper.width;l=this.paper.height}break;default:i=0;j=0;k=this.paper.width;l=this.paper.height;break}b=b==null?i+k/2:b;c=c==null?j+l/2:c;var n=b-this.paper.width/2,o=c-this.paper.height/2,q;d.left!=(q=n+"px")&&(d.left=q);d.top!=(q=o+"px")&&(d.top=q);this.X=ca[f](this.type)?-n:i;this.Y=ca[f](this.type)?-o:j;this.W=k;this.H=l;if(ca[f](this.type)){e.left!=(q=-n*b_+"px")&&(e.left=q);e.top!=(q=-o*b_+"px")&&(e.top=q)}else if(this.type=="text"){e.left!=(q=-n+"px")&&(e.left=q);e.top!=(q=-o+"px")&&(e.top=q)}else{d.width!=(q=this.paper.width+"px")&&(d.width=q);d.height!=(q=this.paper.height+"px")&&(d.height=q);e.left!=(q=i-n+"px")&&(e.left=q);e.top!=(q=j-o+"px")&&(e.top=q);e.width!=(q=k+"px")&&(e.width=q);e.height!=(q=l+"px")&&(e.height=q)}};bO.hide=function(){!this.removed&&(this.Group.style.display="none");return this};bO.show=function(){!this.removed&&(this.Group.style.display="block");return this};bO.getBBox=function(){if(this.removed)return this;if(ca[f](this.type))return bn(this.attrs.path);return{x:this.X+(this.bbx||0),y:this.Y,width:this.W,height:this.H}};bO.remove=function(){if(this.removed)return;bA(this,this.paper);this.node.parentNode.removeChild(this.node);this.Group.parentNode.removeChild(this.Group);this.shape&&this.shape.parentNode.removeChild(this.shape);for(var a in this)delete this[a];this.removed=true};bO.attr=function(b,c){if(this.removed)return this;if(b==null){var d={};for(var e in this.attrs)this.attrs[f](e)&&(d[e]=this.attrs[e]);this._.rt.deg&&(d.rotation=this.rotate());(this._.sx!=1||this._.sy!=1)&&(d.scale=this.scale());d.gradient&&d.fill=="none"&&(d.fill=d.gradient)&&delete d.gradient;return d}if(c==null&&a.is(b,"string")){if(b=="translation")return cz.call(this);if(b=="rotation")return this.rotate();if(b=="scale")return this.scale();if(b==I&&this.attrs.fill=="none"&&this.attrs.gradient)return this.attrs.gradient;return this.attrs[b]}if(this.attrs&&c==null&&a.is(b,G)){var g,h={};for(e=0,g=b[w];e<g;e++)h[b[e]]=this.attr(b[e]);return h}var i;if(c!=null){i={};i[b]=c}c==null&&a.is(b,"object")&&(i=b);if(i){for(var j in this.paper.customAttributes)if(this.paper.customAttributes[f](j)&&i[f](j)&&a.is(this.paper.customAttributes[j],"function")){var k=this.paper.customAttributes[j].apply(this,[][n](i[j]));this.attrs[j]=i[j];for(var l in k)k[f](l)&&(i[l]=k[l])}i.text&&this.type=="text"&&(this.node.string=i.text);bK(this,i);i.gradient&&(({circle:1,ellipse:1})[f](this.type)||r(i.gradient).charAt()!="r")&&bI(this,i.gradient);(!ca[f](this.type)||this._.rt.deg)&&this.setBox(this.attrs)}return this};bO.toFront=function(){!this.removed&&this.Group.parentNode[l](this.Group);this.paper.top!=this&&bB(this,this.paper);return this};bO.toBack=function(){if(this.removed)return this;if(this.Group.parentNode.firstChild!=this.Group){this.Group.parentNode.insertBefore(this.Group,this.Group.parentNode.firstChild);bC(this,this.paper)}return this};bO.insertAfter=function(a){if(this.removed)return this;a.constructor==cC&&(a=a[a.length-1]);a.Group.nextSibling?a.Group.parentNode.insertBefore(this.Group,a.Group.nextSibling):a.Group.parentNode[l](this.Group);bD(this,a,this.paper);return this};bO.insertBefore=function(a){if(this.removed)return this;a.constructor==cC&&(a=a[0]);a.Group.parentNode.insertBefore(this.Group,a.Group);bE(this,a,this.paper);return this};bO.blur=function(b){var c=this.node.runtimeStyle,d=c.filter;d=d.replace(bY,p);if(+b!==0){this.attrs.blur=b;c.filter=d+q+U+".Blur(pixelradius="+(+b||1.5)+")";c.margin=a.format("-{0}px 0 0 -{0}px",Q(+b||1.5))}else{c.filter=d;c.margin=0;delete this.attrs.blur}};bP=function(a,b,c,d){var e=cd("group"),f=cd("oval"),g=f.style;e.style.cssText="position:absolute;left:0;top:0;width:"+a.width+"px;height:"+a.height+"px";e.coordsize=b$;e.coordorigin=a.coordorigin;e[l](f);var h=new bN(f,e,a);h.type="circle";bK(h,{stroke:"#000",fill:"none"});h.attrs.cx=b;h.attrs.cy=c;h.attrs.r=d;h.setBox({x:b-d,y:c-d,width:d*2,height:d*2});a.canvas[l](e);return h};function cc(b,c,d,e,f){return f?a.format("M{0},{1}l{2},0a{3},{3},0,0,1,{3},{3}l0,{5}a{3},{3},0,0,1,{4},{3}l{6},0a{3},{3},0,0,1,{4},{4}l0,{7}a{3},{3},0,0,1,{3},{4}z",b+f,c,d-f*2,f,-f,e-f*2,f*2-d,f*2-e):a.format("M{0},{1}l{2},0,0,{3},{4},0z",b,c,d,e,-d)}bQ=function(a,b,c,d,e,f){var g=cc(b,c,d,e,f),h=a.path(g),i=h.attrs;h.X=i.x=b;h.Y=i.y=c;h.W=i.width=d;h.H=i.height=e;i.r=f;i.path=g;h.type="rect";return h};bR=function(a,b,c,d,e){var f=cd("group"),g=cd("oval"),h=g.style;f.style.cssText="position:absolute;left:0;top:0;width:"+a.width+"px;height:"+a.height+"px";f.coordsize=b$;f.coordorigin=a.coordorigin;f[l](g);var i=new bN(g,f,a);i.type="ellipse";bK(i,{stroke:"#000"});i.attrs.cx=b;i.attrs.cy=c;i.attrs.rx=d;i.attrs.ry=e;i.setBox({x:b-d,y:c-e,width:d*2,height:e*2});a.canvas[l](f);return i};bS=function(a,b,c,d,e,f){var g=cd("group"),h=cd("image");g.style.cssText="position:absolute;left:0;top:0;width:"+a.width+"px;height:"+a.height+"px";g.coordsize=b$;g.coordorigin=a.coordorigin;h.src=b;g[l](h);var i=new bN(h,g,a);i.type="image";i.attrs.src=b;i.attrs.x=c;i.attrs.y=d;i.attrs.w=e;i.attrs.h=f;i.setBox({x:c,y:d,width:e,height:f});a.canvas[l](g);return i};bT=function(b,c,d,e){var f=cd("group"),g=cd("shape"),h=g.style,i=cd("path"),j=i.style,k=cd("textpath");f.style.cssText="position:absolute;left:0;top:0;width:"+b.width+"px;height:"+b.height+"px";f.coordsize=b$;f.coordorigin=b.coordorigin;i.v=a.format("m{0},{1}l{2},{1}",Q(c*10),Q(d*10),Q(c*10)+1);i.textpathok=true;h.width=b.width;h.height=b.height;k.string=r(e);k.on=true;g[l](k);g[l](i);f[l](g);var m=new bN(k,f,b);m.shape=g;m.textpath=i;m.type="text";m.attrs.text=e;m.attrs.x=c;m.attrs.y=d;m.attrs.w=1;m.attrs.h=1;bK(m,{font:W.font,stroke:"none",fill:"#000"});m.setBox();b.canvas[l](f);return m};bU=function(a,b){var c=this.canvas.style;a==+a&&(a+="px");b==+b&&(b+="px");c.width=a;c.height=b;c.clip="rect(0 "+a+" "+b+" 0)";return this};var cd;g.createStyleSheet().addRule(".rvml","behavior:url(#default#VML)");try{!g.namespaces.rvml&&g.namespaces.add("rvml","urn:schemas-microsoft-com:vml");cd=function(a){return g.createElement("<rvml:"+a+" class=\"rvml\">")}}catch(a){cd=function(a){return g.createElement("<"+a+" xmlns=\"urn:schemas-microsoft.com:vml\" class=\"rvml\">")}}bV=function(){var b=by[m](0,arguments),c=b.container,d=b.height,e,f=b.width,h=b.x,i=b.y;if(!c)throw new Error("VML container not found.");var k=new j,n=k.canvas=g.createElement("div"),o=n.style;h=h||0;i=i||0;f=f||512;d=d||342;f==+f&&(f+="px");d==+d&&(d+="px");k.width=1000;k.height=1000;k.coordsize=b_*1000+q+b_*1000;k.coordorigin="0 0";k.span=g.createElement("span");k.span.style.cssText="position:absolute;left:-9999em;top:-9999em;padding:0;margin:0;line-height:1;display:inline;";n[l](k.span);o.cssText=a.format("top:0;left:0;width:{0};height:{1};display:inline-block;position:relative;clip:rect(0 {0} {1} 0);overflow:hidden",f,d);if(c==1){g.body[l](n);o.left=h+"px";o.top=i+"px";o.position="absolute"}else c.firstChild?c.insertBefore(n,c.firstChild):c[l](n);bz.call(k,k,a.fn);return k};k.clear=function(){this.canvas.innerHTML=p;this.span=g.createElement("span");this.span.style.cssText="position:absolute;left:-9999em;top:-9999em;padding:0;margin:0;line-height:1;display:inline;";this.canvas[l](this.span);this.bottom=this.top=null};k.remove=function(){this.canvas.parentNode.removeChild(this.canvas);for(var a in this)this[a]=bF(a);return true}}var ce=navigator.userAgent.match(/Version\\x2f(.*?)\s/);navigator.vendor=="Apple Computer, Inc."&&(ce&&ce[1]<4||navigator.platform.slice(0,2)=="iP")?k.safari=function(){var a=this.rect(-99,-99,this.width+99,this.height+99).attr({stroke:"none"});h.setTimeout(function(){a.remove()})}:k.safari=function(){};var cf=function(){this.returnValue=false},cg=function(){return this.originalEvent.preventDefault()},ch=function(){this.cancelBubble=true},ci=function(){return this.originalEvent.stopPropagation()},cj=(function(){{if(g.addEventListener)return function(a,b,c,d){var e=o&&u[b]?u[b]:b,g=function(e){if(o&&u[f](b))for(var g=0,h=e.targetTouches&&e.targetTouches.length;g<h;g++){if(e.targetTouches[g].target==a){var i=e;e=e.targetTouches[g];e.originalEvent=i;e.preventDefault=cg;e.stopPropagation=ci;break}}return c.call(d,e)};a.addEventListener(e,g,false);return function(){a.removeEventListener(e,g,false);return true}};if(g.attachEvent)return function(a,b,c,d){var e=function(a){a=a||h.event;a.preventDefault=a.preventDefault||cf;a.stopPropagation=a.stopPropagation||ch;return c.call(d,a)};a.attachEvent("on"+b,e);var f=function(){a.detachEvent("on"+b,e);return true};return f}}})(),ck=[],cl=function(a){var b=a.clientX,c=a.clientY,d=g.documentElement.scrollTop||g.body.scrollTop,e=g.documentElement.scrollLeft||g.body.scrollLeft,f,h=ck.length;while(h--){f=ck[h];if(o){var i=a.touches.length,j;while(i--){j=a.touches[i];if(j.identifier==f.el._drag.id){b=j.clientX;c=j.clientY;(a.originalEvent?a.originalEvent:a).preventDefault();break}}}else a.preventDefault();b+=e;c+=d;f.move&&f.move.call(f.move_scope||f.el,b-f.el._drag.x,c-f.el._drag.y,b,c,a)}},cm=function(b){a.unmousemove(cl).unmouseup(cm);var c=ck.length,d;while(c--){d=ck[c];d.el._drag={};d.end&&d.end.call(d.end_scope||d.start_scope||d.move_scope||d.el,b)}ck=[]};for(var cn=t[w];cn--;)(function(b){a[b]=bN[e][b]=function(c,d){if(a.is(c,"function")){this.events=this.events||[];this.events.push({name:b,f:c,unbind:cj(this.shape||this.node||g,b,c,d||this)})}return this};a["un"+b]=bN[e]["un"+b]=function(a){var c=this.events,d=c[w];while(d--)if(c[d].name==b&&c[d].f==a){c[d].unbind();c.splice(d,1);!c.length&&delete this.events;return this}return this}})(t[cn]);bO.hover=function(a,b,c,d){return this.mouseover(a,c).mouseout(b,d||c)};bO.unhover=function(a,b){return this.unmouseover(a).unmouseout(b)};bO.drag=function(b,c,d,e,f,h){this._drag={};this.mousedown(function(i){(i.originalEvent||i).preventDefault();var j=g.documentElement.scrollTop||g.body.scrollTop,k=g.documentElement.scrollLeft||g.body.scrollLeft;this._drag.x=i.clientX+k;this._drag.y=i.clientY+j;this._drag.id=i.identifier;c&&c.call(f||e||this,i.clientX+k,i.clientY+j,i);!ck.length&&a.mousemove(cl).mouseup(cm);ck.push({el:this,move:b,end:d,move_scope:e,start_scope:f,end_scope:h})});return this};bO.undrag=function(b,c,d){var e=ck.length;while(e--)ck[e].el==this&&(ck[e].move==b&&ck[e].end==d)&&ck.splice(e++,1);!ck.length&&a.unmousemove(cl).unmouseup(cm)};k.circle=function(a,b,c){return bP(this,a||0,b||0,c||0)};k.rect=function(a,b,c,d,e){return bQ(this,a||0,b||0,c||0,d||0,e||0)};k.ellipse=function(a,b,c,d){return bR(this,a||0,b||0,c||0,d||0)};k.path=function(b){b&&!a.is(b,F)&&!a.is(b[0],G)&&(b+=p);return bH(a.format[m](a,arguments),this)};k.image=function(a,b,c,d,e){return bS(this,a||"about:blank",b||0,c||0,d||0,e||0)};k.text=function(a,b,c){return bT(this,a||0,b||0,r(c))};k.set=function(a){arguments[w]>1&&(a=Array[e].splice.call(arguments,0,arguments[w]));return new cC(a)};k.setSize=bU;k.top=k.bottom=null;k.raphael=a;function co(){return this.x+q+this.y}bO.resetScale=function(){if(this.removed)return this;this._.sx=1;this._.sy=1;this.attrs.scale="1 1"};bO.scale=function(a,b,c,d){if(this.removed)return this;if(a==null&&b==null)return{x:this._.sx,y:this._.sy,toString:co};b=b||a;!(+b)&&(b=a);var e,f,g,h,i=this.attrs;if(a!=0){var j=this.getBBox(),k=j.x+j.width/2,l=j.y+j.height/2,m=B(a/this._.sx),o=B(b/this._.sy);c=+c||c==0?c:k;d=+d||d==0?d:l;var r=this._.sx>0,s=this._.sy>0,t=~(~(a/B(a))),u=~(~(b/B(b))),x=m*t,y=o*u,z=this.node.style,A=c+B(k-c)*x*(k>c==r?1:-1),C=d+B(l-d)*y*(l>d==s?1:-1),D=a*t>b*u?o:m;switch(this.type){case"rect":case"image":var E=i.width*m,F=i.height*o;this.attr({height:F,r:i.r*D,width:E,x:A-E/2,y:C-F/2});break;case"circle":case"ellipse":this.attr({rx:i.rx*m,ry:i.ry*o,r:i.r*D,cx:A,cy:C});break;case"text":this.attr({x:A,y:C});break;case"path":var G=bp(i.path),H=true,I=r?x:m,J=s?y:o;for(var K=0,L=G[w];K<L;K++){var M=G[K],N=V.call(M[0]);{if(N=="M"&&H)continue;H=false}if(N=="A"){M[G[K][w]-2]*=I;M[G[K][w]-1]*=J;M[1]*=m;M[2]*=o;M[5]=+(t+u?!(!(+M[5])):!(+M[5]))}else if(N=="H")for(var O=1,P=M[w];O<P;O++)M[O]*=I;else if(N=="V")for(O=1,P=M[w];O<P;O++)M[O]*=J;else for(O=1,P=M[w];O<P;O++)M[O]*=O%2?I:J}var Q=bn(G);e=A-Q.x-Q.width/2;f=C-Q.y-Q.height/2;G[0][1]+=e;G[0][2]+=f;this.attr({path:G});break}if(this.type in{text:1,image:1}&&(t!=1||u!=1))if(this.transformations){this.transformations[2]="scale("[n](t,",",u,")");this.node[R]("transform",this.transformations[v](q));e=t==-1?-i.x-(E||0):i.x;f=u==-1?-i.y-(F||0):i.y;this.attr({x:e,y:f});i.fx=t-1;i.fy=u-1}else{this.node.filterMatrix=U+".Matrix(M11="[n](t,", M12=0, M21=0, M22=",u,", Dx=0, Dy=0, sizingmethod='auto expand', filtertype='bilinear')");z.filter=(this.node.filterMatrix||p)+(this.node.filterOpacity||p)}else if(this.transformations){this.transformations[2]=p;this.node[R]("transform",this.transformations[v](q));i.fx=0;i.fy=0}else{this.node.filterMatrix=p;z.filter=(this.node.filterMatrix||p)+(this.node.filterOpacity||p)}i.scale=[a,b,c,d][v](q);this._.sx=a;this._.sy=b}return this};bO.clone=function(){if(this.removed)return null;var a=this.attr();delete a.scale;delete a.translation;return this.paper[this.type]().attr(a)};var cp={},cq=function(b,c,d,e,f,g,h,i,j){var k=0,l=100,m=[b,c,d,e,f,g,h,i].join(),n=cp[m],o,p;!n&&(cp[m]=n={data:[]});n.timer&&clearTimeout(n.timer);n.timer=setTimeout(function(){delete cp[m]},2000);if(j!=null){var q=cq(b,c,d,e,f,g,h,i);l=~(~q)*10}for(var r=0;r<l+1;r++){if(n.data[j]>r)p=n.data[r*l];else{p=a.findDotsAtSegment(b,c,d,e,f,g,h,i,r/l);n.data[r]=p}r&&(k+=C(C(o.x-p.x,2)+C(o.y-p.y,2),0.5));if(j!=null&&k>=j)return p;o=p}if(j==null)return k},cr=function(b,c){return function(d,e,f){d=bw(d);var g,h,i,j,k="",l={},m,n=0;for(var o=0,p=d.length;o<p;o++){i=d[o];if(i[0]=="M"){g=+i[1];h=+i[2]}else{j=cq(g,h,i[1],i[2],i[3],i[4],i[5],i[6]);if(n+j>e){if(c&&!l.start){m=cq(g,h,i[1],i[2],i[3],i[4],i[5],i[6],e-n);k+=["C",m.start.x,m.start.y,m.m.x,m.m.y,m.x,m.y];if(f)return k;l.start=k;k=["M",m.x,m.y+"C",m.n.x,m.n.y,m.end.x,m.end.y,i[5],i[6]][v]();n+=j;g=+i[5];h=+i[6];continue}if(!b&&!c){m=cq(g,h,i[1],i[2],i[3],i[4],i[5],i[6],e-n);return{x:m.x,y:m.y,alpha:m.alpha}}}n+=j;g=+i[5];h=+i[6]}k+=i}l.end=k;m=b?n:c?l:a.findDotsAtSegment(g,h,i[1],i[2],i[3],i[4],i[5],i[6],1);m.alpha&&(m={x:m.x,y:m.y,alpha:m.alpha});return m}},cs=cr(1),ct=cr(),cu=cr(0,1);bO.getTotalLength=function(){if(this.type!="path")return;if(this.node.getTotalLength)return this.node.getTotalLength();return cs(this.attrs.path)};bO.getPointAtLength=function(a){if(this.type!="path")return;return ct(this.attrs.path,a)};bO.getSubpath=function(a,b){if(this.type!="path")return;if(B(this.getTotalLength()-b)<"1e-6")return cu(this.attrs.path,a).end;var c=cu(this.attrs.path,b,1);return a?cu(c,a).end:c};a.easing_formulas={linear:function(a){return a},"<":function(a){return C(a,3)},">":function(a){return C(a-1,3)+1},"<>":function(a){a=a*2;if(a<1)return C(a,3)/2;a-=2;return(C(a,3)+2)/2},backIn:function(a){var b=1.70158;return a*a*((b+1)*a-b)},backOut:function(a){a=a-1;var b=1.70158;return a*a*((b+1)*a+b)+1},elastic:function(a){if(a==0||a==1)return a;var b=0.3,c=b/4;return C(2,-10*a)*y.sin((a-c)*(2*D)/b)+1},bounce:function(a){var b=7.5625,c=2.75,d;if(a<1/c)d=b*a*a;else if(a<2/c){a-=1.5/c;d=b*a*a+0.75}else if(a<2.5/c){a-=2.25/c;d=b*a*a+0.9375}else{a-=2.625/c;d=b*a*a+0.984375}return d}};var cv=[],cw=function(){var b=+(new Date);for(var c=0;c<cv[w];c++){var d=cv[c];if(d.stop||d.el.removed)continue;var e=b-d.start,g=d.ms,h=d.easing,i=d.from,j=d.diff,k=d.to,l=d.t,m=d.el,n={},o;if(e<g){var r=h(e/g);for(var s in i)if(i[f](s)){switch(X[s]){case"along":o=r*g*j[s];k.back&&(o=k.len-o);var t=ct(k[s],o);m.translate(j.sx-j.x||0,j.sy-j.y||0);j.x=t.x;j.y=t.y;m.translate(t.x-j.sx,t.y-j.sy);k.rot&&m.rotate(j.r+t.alpha,t.x,t.y);break;case E:o=+i[s]+r*g*j[s];break;case"colour":o="rgb("+[cy(Q(i[s].r+r*g*j[s].r)),cy(Q(i[s].g+r*g*j[s].g)),cy(Q(i[s].b+r*g*j[s].b))][v](",")+")";break;case"path":o=[];for(var u=0,x=i[s][w];u<x;u++){o[u]=[i[s][u][0]];for(var y=1,z=i[s][u][w];y<z;y++)o[u][y]=+i[s][u][y]+r*g*j[s][u][y];o[u]=o[u][v](q)}o=o[v](q);break;case"csv":switch(s){case"translation":var A=r*g*j[s][0]-l.x,B=r*g*j[s][1]-l.y;l.x+=A;l.y+=B;o=A+q+B;break;case"rotation":o=+i[s][0]+r*g*j[s][0];i[s][1]&&(o+=","+i[s][1]+","+i[s][2]);break;case"scale":o=[+i[s][0]+r*g*j[s][0],+i[s][1]+r*g*j[s][1],2 in k[s]?k[s][2]:p,3 in k[s]?k[s][3]:p][v](q);break;case"clip-rect":o=[];u=4;while(u--)o[u]=+i[s][u]+r*g*j[s][u];break}break;default:var C=[].concat(i[s]);o=[];u=m.paper.customAttributes[s].length;while(u--)o[u]=+C[u]+r*g*j[s][u];break}n[s]=o}m.attr(n);m._run&&m._run.call(m)}else{if(k.along){t=ct(k.along,k.len*!k.back);m.translate(j.sx-(j.x||0)+t.x-j.sx,j.sy-(j.y||0)+t.y-j.sy);k.rot&&m.rotate(j.r+t.alpha,t.x,t.y)}(l.x||l.y)&&m.translate(-l.x,-l.y);k.scale&&(k.scale+=p);m.attr(k);cv.splice(c--,1)}}a.svg&&m&&m.paper&&m.paper.safari();cv[w]&&setTimeout(cw)},cx=function(b,c,d,e,f){var g=d-e;c.timeouts.push(setTimeout(function(){a.is(f,"function")&&f.call(c);c.animate(b,g,b.easing)},e))},cy=function(a){return z(A(a,255),0)},cz=function(a,b){if(a==null)return{x:this._.tx,y:this._.ty,toString:co};this._.tx+=+a;this._.ty+=+b;switch(this.type){case"circle":case"ellipse":this.attr({cx:+a+this.attrs.cx,cy:+b+this.attrs.cy});break;case"rect":case"image":case"text":this.attr({x:+a+this.attrs.x,y:+b+this.attrs.y});break;case"path":var c=bp(this.attrs.path);c[0][1]+=+a;c[0][2]+=+b;this.attr({path:c});break}return this};bO.animateWith=function(a,b,c,d,e){for(var f=0,g=cv.length;f<g;f++)cv[f].el.id==a.id&&(b.start=cv[f].start);return this.animate(b,c,d,e)};bO.animateAlong=cA();bO.animateAlongBack=cA(1);function cA(b){return function(c,d,e,f){var g={back:b};a.is(e,"function")?f=e:g.rot=e;c&&c.constructor==bN&&(c=c.attrs.path);c&&(g.along=c);return this.animate(g,d,f)}}function cB(a,b,c,d,e,f){var g=3*b,h=3*(d-b)-g,i=1-g-h,j=3*c,k=3*(e-c)-j,l=1-j-k;function m(a){return((i*a+h)*a+g)*a}function n(a,b){var c=o(a,b);return((l*c+k)*c+j)*c}function o(a,b){var c,d,e,f,j,k;for(e=a,k=0;k<8;k++){f=m(e)-a;if(B(f)<b)return e;j=(3*i*e+2*h)*e+g;if(B(j)<0.000001)break;e=e-f/j}c=0;d=1;e=a;if(e<c)return c;if(e>d)return d;while(c<d){f=m(e);if(B(f-a)<b)return e;a>f?c=e:d=e;e=(d-c)/2+c}return e}return n(a,1/(200*f))}bO.onAnimation=function(a){this._run=a||0;return this};bO.animate=function(c,d,e,g){var h=this;h.timeouts=h.timeouts||[];if(a.is(e,"function")||!e)g=e||null;if(h.removed){g&&g.call(h);return h}var i={},j={},k=false,l={};for(var m in c)if(c[f](m)){if(X[f](m)||h.paper.customAttributes[f](m)){k=true;i[m]=h.attr(m);i[m]==null&&(i[m]=W[m]);j[m]=c[m];switch(X[m]){case"along":var n=cs(c[m]),o=ct(c[m],n*!(!c.back)),p=h.getBBox();l[m]=n/d;l.tx=p.x;l.ty=p.y;l.sx=o.x;l.sy=o.y;j.rot=c.rot;j.back=c.back;j.len=n;c.rot&&(l.r=S(h.rotate())||0);break;case E:l[m]=(j[m]-i[m])/d;break;case"colour":i[m]=a.getRGB(i[m]);var q=a.getRGB(j[m]);l[m]={r:(q.r-i[m].r)/d,g:(q.g-i[m].g)/d,b:(q.b-i[m].b)/d};break;case"path":var t=bw(i[m],j[m]);i[m]=t[0];var u=t[1];l[m]=[];for(var v=0,x=i[m][w];v<x;v++){l[m][v]=[0];for(var y=1,z=i[m][v][w];y<z;y++)l[m][v][y]=(u[v][y]-i[m][v][y])/d}break;case"csv":var A=r(c[m])[s](b),B=r(i[m])[s](b);switch(m){case"translation":i[m]=[0,0];l[m]=[A[0]/d,A[1]/d];break;case"rotation":i[m]=B[1]==A[1]&&B[2]==A[2]?B:[0,A[1],A[2]];l[m]=[(A[0]-i[m][0])/d,0,0];break;case"scale":c[m]=A;i[m]=r(i[m])[s](b);l[m]=[(A[0]-i[m][0])/d,(A[1]-i[m][1])/d,0,0];break;case"clip-rect":i[m]=r(i[m])[s](b);l[m]=[];v=4;while(v--)l[m][v]=(A[v]-i[m][v])/d;break}j[m]=A;break;default:A=[].concat(c[m]);B=[].concat(i[m]);l[m]=[];v=h.paper.customAttributes[m][w];while(v--)l[m][v]=((A[v]||0)-(B[v]||0))/d;break}}}if(k){var G=a.easing_formulas[e];if(!G){G=r(e).match(P);if(G&&G[w]==5){var H=G;G=function(a){return cB(a,+H[1],+H[2],+H[3],+H[4],d)}}else G=function(a){return a}}cv.push({start:c.start||+(new Date),ms:d,easing:G,from:i,diff:l,to:j,el:h,t:{x:0,y:0}});a.is(g,"function")&&(h._ac=setTimeout(function(){g.call(h)},d));cv[w]==1&&setTimeout(cw)}else{var C=[],D;for(var F in c)if(c[f](F)&&Z.test(F)){m={value:c[F]};F=="from"&&(F=0);F=="to"&&(F=100);m.key=T(F,10);C.push(m)}C.sort(be);C[0].key&&C.unshift({key:0,value:h.attrs});for(v=0,x=C[w];v<x;v++)cx(C[v].value,h,d/100*C[v].key,d/100*(C[v-1]&&C[v-1].key||0),C[v-1]&&C[v-1].value.callback);D=C[C[w]-1].value.callback;D&&h.timeouts.push(setTimeout(function(){D.call(h)},d))}return this};bO.stop=function(){for(var a=0;a<cv.length;a++)cv[a].el.id==this.id&&cv.splice(a--,1);for(a=0,ii=this.timeouts&&this.timeouts.length;a<ii;a++)clearTimeout(this.timeouts[a]);this.timeouts=[];clearTimeout(this._ac);delete this._ac;return this};bO.translate=function(a,b){return this.attr({translation:a+" "+b})};bO[H]=function(){return"Raphaël’s object"};a.ae=cv;var cC=function(a){this.items=[];this[w]=0;this.type="set";if(a)for(var b=0,c=a[w];b<c;b++){if(a[b]&&(a[b].constructor==bN||a[b].constructor==cC)){this[this.items[w]]=this.items[this.items[w]]=a[b];this[w]++}}};cC[e][L]=function(){var a,b;for(var c=0,d=arguments[w];c<d;c++){a=arguments[c];if(a&&(a.constructor==bN||a.constructor==cC)){b=this.items[w];this[b]=this.items[b]=a;this[w]++}}return this};cC[e].pop=function(){delete this[this[w]--];return this.items.pop()};for(var cD in bO)bO[f](cD)&&(cC[e][cD]=(function(a){return function(){for(var b=0,c=this.items[w];b<c;b++)this.items[b][a][m](this.items[b],arguments);return this}})(cD));cC[e].attr=function(b,c){if(b&&a.is(b,G)&&a.is(b[0],"object"))for(var d=0,e=b[w];d<e;d++)this.items[d].attr(b[d]);else for(var f=0,g=this.items[w];f<g;f++)this.items[f].attr(b,c);return this};cC[e].animate=function(b,c,d,e){(a.is(d,"function")||!d)&&(e=d||null);var f=this.items[w],g=f,h,i=this,j;e&&(j=function(){!(--f)&&e.call(i)});d=a.is(d,F)?d:j;h=this.items[--g].animate(b,c,d,j);while(g--)this.items[g]&&!this.items[g].removed&&this.items[g].animateWith(h,b,c,d,j);return this};cC[e].insertAfter=function(a){var b=this.items[w];while(b--)this.items[b].insertAfter(a);return this};cC[e].getBBox=function(){var a=[],b=[],c=[],d=[];for(var e=this.items[w];e--;){var f=this.items[e].getBBox();a[L](f.x);b[L](f.y);c[L](f.x+f.width);d[L](f.y+f.height)}a=A[m](0,a);b=A[m](0,b);return{x:a,y:b,width:z[m](0,c)-a,height:z[m](0,d)-b}};cC[e].clone=function(a){a=new cC;for(var b=0,c=this.items[w];b<c;b++)a[L](this.items[b].clone());return a};a.registerFont=function(a){if(!a.face)return a;this.fonts=this.fonts||{};var b={w:a.w,face:{},glyphs:{}},c=a.face["font-family"];for(var d in a.face)a.face[f](d)&&(b.face[d]=a.face[d]);this.fonts[c]?this.fonts[c][L](b):this.fonts[c]=[b];if(!a.svg){b.face["units-per-em"]=T(a.face["units-per-em"],10);for(var e in a.glyphs)if(a.glyphs[f](e)){var g=a.glyphs[e];b.glyphs[e]={w:g.w,k:{},d:g.d&&"M"+g.d[Y](/[mlcxtrv]/g,function(a){return({l:"L",c:"C",x:"z",t:"m",r:"l",v:"c"})[a]||"M"})+"z"};if(g.k)for(var h in g.k)g[f](h)&&(b.glyphs[e].k[h]=g.k[h])}}return a};k.getFont=function(b,c,d,e){e=e||"normal";d=d||"normal";c=+c||({normal:400,bold:700,lighter:300,bolder:800})[c]||400;if(!a.fonts)return;var g=a.fonts[b];if(!g){var h=new RegExp("(^|\\s)"+b[Y](/[^\w\d\s+!~.:_-]/g,p)+"(\\s|$)","i");for(var i in a.fonts)if(a.fonts[f](i)){if(h.test(i)){g=a.fonts[i];break}}}var j;if(g)for(var k=0,l=g[w];k<l;k++){j=g[k];if(j.face["font-weight"]==c&&(j.face["font-style"]==d||!j.face["font-style"])&&j.face["font-stretch"]==e)break}return j};k.print=function(c,d,e,f,g,h,i){h=h||"middle";i=z(A(i||0,1),-1);var j=this.set(),k=r(e)[s](p),l=0,m=p,n;a.is(f,e)&&(f=this.getFont(f));if(f){n=(g||16)/f.face["units-per-em"];var o=f.face.bbox.split(b),q=+o[0],t=+o[1]+(h=="baseline"?o[3]-o[1]+ +f.face.descent:(o[3]-o[1])/2);for(var u=0,v=k[w];u<v;u++){var x=u&&f.glyphs[k[u-1]]||{},y=f.glyphs[k[u]];l+=u?(x.w||f.w)+(x.k&&x.k[k[u]]||0)+f.w*i:0;y&&y.d&&j[L](this.path(y.d).attr({fill:"#000",stroke:"none",translation:[l,0]}))}j.scale(n,n,q,t).translate(c-q,d-t)}return j};a.format=function(b,c){var e=a.is(c,G)?[0][n](c):arguments;b&&a.is(b,F)&&e[w]-1&&(b=b[Y](d,function(a,b){return e[++b]==null?p:e[b]}));return b||p};a.ninja=function(){i.was?h.Raphael=i.is:delete Raphael;return a};a.el=bO;a.st=cC[e];i.was?h.Raphael=a:Raphael=a})()
\ No newline at end of file
diff --git a/timeside/static/timeside/js/libs/soundmanager2-jsmin.js b/timeside/static/timeside/js/libs/soundmanager2-jsmin.js
deleted file mode 100644 (file)
index 2f52e5f..0000000
+++ /dev/null
@@ -1,110 +0,0 @@
-/** @license
-
-
- SoundManager 2: JavaScript Sound for the Web
- ----------------------------------------------
- http://schillmania.com/projects/soundmanager2/
-
- Copyright (c) 2007, Scott Schiller. All rights reserved.
- Code provided under the BSD License:
- http://schillmania.com/projects/soundmanager2/license.txt
-
- V2.97a.20120916
-*/
-(function(Z){function $($,oa){function aa(a){return c.preferFlash&&z&&!c.ignoreFlash&&"undefined"!==typeof c.flash[a]&&c.flash[a]}function q(a){return function(d){var e=this._t;!e||!e._a?(e&&e.id?c._wD(s+"ignoring "+d.type+": "+e.id):c._wD(s+"ignoring "+d.type),d=null):d=a.call(this,d);return d}}this.setupOptions={url:$||null,flashVersion:8,debugMode:!0,debugFlash:!1,useConsole:!0,consoleOnly:!0,waitForWindowLoad:!1,bgColor:"#ffffff",useHighPerformance:!1,flashPollingInterval:null,html5PollingInterval:null,
-flashLoadTimeout:1E3,wmode:null,allowScriptAccess:"always",useFlashBlock:!1,useHTML5Audio:!0,html5Test:/^(probably|maybe)$/i,preferFlash:!0,noSWFCache:!1};this.defaultOptions={autoLoad:!1,autoPlay:!1,from:null,loops:1,onid3:null,onload:null,whileloading:null,onplay:null,onpause:null,onresume:null,whileplaying:null,onposition:null,onstop:null,onfailure:null,onfinish:null,multiShot:!0,multiShotEvents:!1,position:null,pan:0,stream:!0,to:null,type:null,usePolicyFile:!1,volume:100};this.flash9Options=
-{isMovieStar:null,usePeakData:!1,useWaveformData:!1,useEQData:!1,onbufferchange:null,ondataerror:null};this.movieStarOptions={bufferTime:3,serverURL:null,onconnect:null,duration:null};this.audioFormats={mp3:{type:['audio/mpeg; codecs="mp3"',"audio/mpeg","audio/mp3","audio/MPA","audio/mpa-robust"],required:!0},mp4:{related:["aac","m4a","m4b"],type:['audio/mp4; codecs="mp4a.40.2"',"audio/aac","audio/x-m4a","audio/MP4A-LATM","audio/mpeg4-generic"],required:!1},ogg:{type:["audio/ogg; codecs=vorbis"],
-required:!1},wav:{type:['audio/wav; codecs="1"',"audio/wav","audio/wave","audio/x-wav"],required:!1}};this.movieID="sm2-container";this.id=oa||"sm2movie";this.debugID="soundmanager-debug";this.debugURLParam=/([#?&])debug=1/i;this.versionNumber="V2.97a.20120916";this.altURL=this.movieURL=this.version=null;this.enabled=this.swfLoaded=!1;this.oMC=null;this.sounds={};this.soundIDs=[];this.didFlashBlock=this.muted=!1;this.filePattern=null;this.filePatterns={flash8:/\.mp3(\?.*)?$/i,flash9:/\.mp3(\?.*)?$/i};
-this.features={buffering:!1,peakData:!1,waveformData:!1,eqData:!1,movieStar:!1};this.sandbox={type:null,types:{remote:"remote (domain-based) rules",localWithFile:"local with file access (no internet access)",localWithNetwork:"local with network (internet access only, no local access)",localTrusted:"local, trusted (local+internet access)"},description:null,noRemote:null,noLocal:null};var pa;try{pa="undefined"!==typeof Audio&&"undefined"!==typeof(qa&&10>opera.version()?new Audio(null):new Audio).canPlayType}catch(ib){pa=
-!1}this.hasHTML5=pa;this.html5={usingFlash:null};this.flash={};this.ignoreFlash=this.html5Only=!1;var Ka,c=this,h=null,s="HTML5::",A,v=navigator.userAgent,k=Z,Q=k.location.href.toString(),i=document,ra,La,sa,j,D=[],ta=!0,x,R=!1,S=!1,m=!1,o=!1,ba=!1,n,eb=0,T,w,ua,H,va,I,J,K,Ma,wa,ca,da,ea,L,xa,U,fa,ga,M,Na,ya,fb=["log","info","warn","error"],Oa,ha,Pa,V=null,za=null,p,Aa,N,Qa,ia,ja,O,t,W=!1,Ba=!1,Ra,Sa,Ta,ka=0,X=null,la,B=null,Ua,ma,Y,E,Ca,Da,Va,u,Wa=Array.prototype.slice,G=!1,z,Ea,Xa,C,Ya,Fa=v.match(/(ipad|iphone|ipod)/i),
-F=v.match(/msie/i),gb=v.match(/webkit/i),Ga=v.match(/safari/i)&&!v.match(/chrome/i),qa=v.match(/opera/i),Ha=v.match(/(mobile|pre\/|xoom)/i)||Fa,Ia=!Q.match(/usehtml5audio/i)&&!Q.match(/sm2\-ignorebadua/i)&&Ga&&!v.match(/silk/i)&&v.match(/OS X 10_6_([3-7])/i),Za="undefined"!==typeof console&&"undefined"!==typeof console.log,Ja="undefined"!==typeof i.hasFocus?i.hasFocus():null,na=Ga&&("undefined"===typeof i.hasFocus||!i.hasFocus()),$a=!na,ab=/(mp3|mp4|mpa|m4a|m4b)/i,P=i.location?i.location.protocol.match(/http/i):
-null,bb=!P?"http://":"",cb=/^\s*audio\/(?:x-)?(?:mpeg4|aac|flv|mov|mp4||m4v|m4a|m4b|mp4v|3gp|3g2)\s*(?:$|;)/i,db="mpeg4,aac,flv,mov,mp4,m4v,f4v,m4a,m4b,mp4v,3gp,3g2".split(","),hb=RegExp("\\.("+db.join("|")+")(\\?.*)?$","i");this.mimePattern=/^\s*audio\/(?:x-)?(?:mp(?:eg|3))\s*(?:$|;)/i;this.useAltURL=!P;this._global_a=null;if(Ha&&(c.useHTML5Audio=!0,c.preferFlash=!1,Fa))G=c.ignoreFlash=!0;this.setup=function(a){var d=!c.url;"undefined"!==typeof a&&m&&B&&c.ok()&&("undefined"!==typeof a.flashVersion||
-"undefined"!==typeof a.url)&&O(p("setupLate"));ua(a);d&&U&&"undefined"!==typeof a.url&&c.beginDelayedInit();!U&&"undefined"!==typeof a.url&&"complete"===i.readyState&&setTimeout(L,1);return c};this.supported=this.ok=function(){return B?m&&!o:c.useHTML5Audio&&c.hasHTML5};this.getMovie=function(c){return A(c)||i[c]||k[c]};this.createSound=function(a,d){function e(){g=ia(g);c.sounds[f.id]=new Ka(f);c.soundIDs.push(f.id);return c.sounds[f.id]}var b,g=null,f=b=null;b="soundManager.createSound(): "+p(!m?
-"notReady":"notOK");if(!m||!c.ok())return O(b),!1;"undefined"!==typeof d&&(a={id:a,url:d});g=w(a);g.url=la(g.url);f=g;f.id.toString().charAt(0).match(/^[0-9]$/)&&c._wD("soundManager.createSound(): "+p("badID",f.id),2);c._wD("soundManager.createSound(): "+f.id+" ("+f.url+")",1);if(t(f.id,!0))return c._wD("soundManager.createSound(): "+f.id+" exists",1),c.sounds[f.id];if(ma(f))b=e(),c._wD("Creating sound "+f.id+", using HTML5"),b._setup_html5(f);else{if(8<j){if(null===f.isMovieStar)f.isMovieStar=!(!f.serverURL&&
-!(f.type&&f.type.match(cb)||f.url.match(hb)));f.isMovieStar&&(c._wD("soundManager.createSound(): using MovieStar handling"),1<f.loops&&n("noNSLoop"))}f=ja(f,"soundManager.createSound(): ");b=e();if(8===j)h._createSound(f.id,f.loops||1,f.usePolicyFile);else if(h._createSound(f.id,f.url,f.usePeakData,f.useWaveformData,f.useEQData,f.isMovieStar,f.isMovieStar?f.bufferTime:!1,f.loops||1,f.serverURL,f.duration||null,f.autoPlay,!0,f.autoLoad,f.usePolicyFile),!f.serverURL)b.connected=!0,f.onconnect&&f.onconnect.apply(b);
-!f.serverURL&&(f.autoLoad||f.autoPlay)&&b.load(f)}!f.serverURL&&f.autoPlay&&b.play();return b};this.destroySound=function(a,d){if(!t(a))return!1;var e=c.sounds[a],b;e._iO={};e.stop();e.unload();for(b=0;b<c.soundIDs.length;b++)if(c.soundIDs[b]===a){c.soundIDs.splice(b,1);break}d||e.destruct(!0);delete c.sounds[a];return!0};this.load=function(a,d){return!t(a)?!1:c.sounds[a].load(d)};this.unload=function(a){return!t(a)?!1:c.sounds[a].unload()};this.onposition=this.onPosition=function(a,d,e,b){return!t(a)?
-!1:c.sounds[a].onposition(d,e,b)};this.clearOnPosition=function(a,d,e){return!t(a)?!1:c.sounds[a].clearOnPosition(d,e)};this.start=this.play=function(a,d){var e=!1;if(!m||!c.ok())return O("soundManager.play(): "+p(!m?"notReady":"notOK")),e;if(!t(a)){d instanceof Object||(d={url:d});if(d&&d.url)c._wD('soundManager.play(): attempting to create "'+a+'"',1),d.id=a,e=c.createSound(d).play();return e}return c.sounds[a].play(d)};this.setPosition=function(a,d){return!t(a)?!1:c.sounds[a].setPosition(d)};this.stop=
-function(a){if(!t(a))return!1;c._wD("soundManager.stop("+a+")",1);return c.sounds[a].stop()};this.stopAll=function(){var a;c._wD("soundManager.stopAll()",1);for(a in c.sounds)c.sounds.hasOwnProperty(a)&&c.sounds[a].stop()};this.pause=function(a){return!t(a)?!1:c.sounds[a].pause()};this.pauseAll=function(){var a;for(a=c.soundIDs.length-1;0<=a;a--)c.sounds[c.soundIDs[a]].pause()};this.resume=function(a){return!t(a)?!1:c.sounds[a].resume()};this.resumeAll=function(){var a;for(a=c.soundIDs.length-1;0<=
-a;a--)c.sounds[c.soundIDs[a]].resume()};this.togglePause=function(a){return!t(a)?!1:c.sounds[a].togglePause()};this.setPan=function(a,d){return!t(a)?!1:c.sounds[a].setPan(d)};this.setVolume=function(a,d){return!t(a)?!1:c.sounds[a].setVolume(d)};this.mute=function(a){var d=0;"string"!==typeof a&&(a=null);if(a){if(!t(a))return!1;c._wD('soundManager.mute(): Muting "'+a+'"');return c.sounds[a].mute()}c._wD("soundManager.mute(): Muting all sounds");for(d=c.soundIDs.length-1;0<=d;d--)c.sounds[c.soundIDs[d]].mute();
-return c.muted=!0};this.muteAll=function(){c.mute()};this.unmute=function(a){"string"!==typeof a&&(a=null);if(a){if(!t(a))return!1;c._wD('soundManager.unmute(): Unmuting "'+a+'"');return c.sounds[a].unmute()}c._wD("soundManager.unmute(): Unmuting all sounds");for(a=c.soundIDs.length-1;0<=a;a--)c.sounds[c.soundIDs[a]].unmute();c.muted=!1;return!0};this.unmuteAll=function(){c.unmute()};this.toggleMute=function(a){return!t(a)?!1:c.sounds[a].toggleMute()};this.getMemoryUse=function(){var c=0;h&&8!==j&&
-(c=parseInt(h._getMemoryUse(),10));return c};this.disable=function(a){var d;"undefined"===typeof a&&(a=!1);if(o)return!1;o=!0;n("shutdown",1);for(d=c.soundIDs.length-1;0<=d;d--)Oa(c.sounds[c.soundIDs[d]]);T(a);u.remove(k,"load",J);return!0};this.canPlayMIME=function(a){var d;c.hasHTML5&&(d=Y({type:a}));!d&&B&&(d=a&&c.ok()?!!(8<j&&a.match(cb)||a.match(c.mimePattern)):null);return d};this.canPlayURL=function(a){var d;c.hasHTML5&&(d=Y({url:a}));!d&&B&&(d=a&&c.ok()?!!a.match(c.filePattern):null);return d};
-this.canPlayLink=function(a){return"undefined"!==typeof a.type&&a.type&&c.canPlayMIME(a.type)?!0:c.canPlayURL(a.href)};this.getSoundById=function(a,d){if(!a)throw Error("soundManager.getSoundById(): sID is null/undefined");var e=c.sounds[a];!e&&!d&&c._wD('"'+a+'" is an invalid sound ID.',2);return e};this.onready=function(a,d){var e=!1;if("function"===typeof a)m&&c._wD(p("queue","onready")),d||(d=k),va("onready",a,d),I();else throw p("needFunction","onready");return!0};this.ontimeout=function(a,d){var e=
-!1;if("function"===typeof a)m&&c._wD(p("queue","ontimeout")),d||(d=k),va("ontimeout",a,d),I({type:"ontimeout"});else throw p("needFunction","ontimeout");return!0};this._wD=this._writeDebug=function(a,d,e){var b,g;if(!c.debugMode)return!1;"undefined"!==typeof e&&e&&(a=a+" | "+(new Date).getTime());if(Za&&c.useConsole){e=fb[d];if("undefined"!==typeof console[e])console[e](a);else console.log(a);if(c.consoleOnly)return!0}try{b=A("soundmanager-debug");if(!b)return!1;g=i.createElement("div");if(0===++eb%
-2)g.className="sm2-alt";d="undefined"===typeof d?0:parseInt(d,10);g.appendChild(i.createTextNode(a));if(d){if(2<=d)g.style.fontWeight="bold";if(3===d)g.style.color="#ff3333"}b.insertBefore(g,b.firstChild)}catch(f){}return!0};this._debug=function(){var a,d;n("currentObj",1);for(a=0,d=c.soundIDs.length;a<d;a++)c.sounds[c.soundIDs[a]]._debug()};this.reboot=function(){c._wD("soundManager.reboot()");c.soundIDs.length&&c._wD("Destroying "+c.soundIDs.length+" SMSound objects...");var a,d;for(a=c.soundIDs.length-
-1;0<=a;a--)c.sounds[c.soundIDs[a]].destruct();if(h)try{if(F)za=h.innerHTML;V=h.parentNode.removeChild(h);c._wD("Flash movie removed.")}catch(e){n("badRemove",2)}za=V=B=null;c.enabled=U=m=W=Ba=R=S=o=c.swfLoaded=!1;c.soundIDs=[];c.sounds={};h=null;for(a in D)if(D.hasOwnProperty(a))for(d=D[a].length-1;0<=d;d--)D[a][d].fired=!1;c._wD("soundManager: Rebooting...");k.setTimeout(c.beginDelayedInit,20)};this.getMoviePercent=function(){return h&&"undefined"!==typeof h.PercentLoaded?h.PercentLoaded():null};
-this.beginDelayedInit=function(){ba=!0;L();setTimeout(function(){if(Ba)return!1;ga();ea();return Ba=!0},20);K()};this.destruct=function(){c._wD("soundManager.destruct()");c.disable(!0)};Ka=function(a){var d,e,b=this,g,f,r,l,i,k,m=!1,y=[],q=0,u,v,o=null;d=null;e=null;this.sID=this.id=a.id;this.url=a.url;this._iO=this.instanceOptions=this.options=w(a);this.pan=this.options.pan;this.volume=this.options.volume;this.isHTML5=!1;this._a=null;this.id3={};this._debug=function(){if(c.debugMode){var a=null,
-d=[],e,f;for(a in b.options)null!==b.options[a]&&("function"===typeof b.options[a]?(e=b.options[a].toString(),e=e.replace(/\s\s+/g," "),f=e.indexOf("{"),d.push(" "+a+": {"+e.substr(f+1,Math.min(Math.max(e.indexOf("\n")-1,64),64)).replace(/\n/g,"")+"... }")):d.push(" "+a+": "+b.options[a]));c._wD("SMSound() merged options: {\n"+d.join(", \n")+"\n}")}};this._debug();this.load=function(a){var d=null;if("undefined"!==typeof a)b._iO=w(a,b.options),b.instanceOptions=b._iO;else if(a=b.options,b._iO=a,b.instanceOptions=
-b._iO,o&&o!==b.url)n("manURL"),b._iO.url=b.url,b.url=null;if(!b._iO.url)b._iO.url=b.url;b._iO.url=la(b._iO.url);c._wD("SMSound.load(): "+b._iO.url,1);if(b._iO.url===b.url&&0!==b.readyState&&2!==b.readyState)return n("onURL",1),3===b.readyState&&b._iO.onload&&b._iO.onload.apply(b,[!!b.duration]),b;a=b._iO;o=b.url&&b.url.toString?b.url.toString():null;b.loaded=!1;b.readyState=1;b.playState=0;b.id3={};if(ma(a))if(d=b._setup_html5(a),d._called_load)c._wD(s+"ignoring request to load again: "+b.id);else{c._wD(s+
-"load: "+b.id);b._html5_canplay=!1;if(b._a.src!==a.url)c._wD(n("manURL")+": "+a.url),b._a.src=a.url,b.setPosition(0);b._a.autobuffer="auto";b._a.preload="auto";d._called_load=!0;a.autoPlay&&b.play()}else try{b.isHTML5=!1,b._iO=ja(ia(a)),a=b._iO,8===j?h._load(b.id,a.url,a.stream,a.autoPlay,a.whileloading?1:0,a.loops||1,a.usePolicyFile):h._load(b.id,a.url,!!a.stream,!!a.autoPlay,a.loops||1,!!a.autoLoad,a.usePolicyFile)}catch(e){n("smError",2),x("onload",!1),M({type:"SMSOUND_LOAD_JS_EXCEPTION",fatal:!0})}b.url=
-a.url;return b};this.unload=function(){if(0!==b.readyState){c._wD('SMSound.unload(): "'+b.id+'"');if(b.isHTML5){if(l(),b._a)b._a.pause(),Ca(b._a,"about:blank"),b.url="about:blank"}else 8===j?h._unload(b.id,"about:blank"):h._unload(b.id);g()}return b};this.destruct=function(a){c._wD('SMSound.destruct(): "'+b.id+'"');if(b.isHTML5){if(l(),b._a)b._a.pause(),Ca(b._a),G||r(),b._a._t=null,b._a=null}else b._iO.onfailure=null,h._destroySound(b.id);a||c.destroySound(b.id,!0)};this.start=this.play=function(a,
-d){var e,f;f=!0;f=null;d="undefined"===typeof d?!0:d;a||(a={});if(b.url)b._iO.url=b.url;b._iO=w(b._iO,b.options);b._iO=w(a,b._iO);b._iO.url=la(b._iO.url);b.instanceOptions=b._iO;if(b._iO.serverURL&&!b.connected)return b.getAutoPlay()||(c._wD("SMSound.play():  Netstream not connected yet - setting autoPlay"),b.setAutoPlay(!0)),b;ma(b._iO)&&(b._setup_html5(b._iO),i());if(1===b.playState&&!b.paused)(e=b._iO.multiShot)?c._wD('SMSound.play(): "'+b.id+'" already playing (multi-shot)',1):(c._wD('SMSound.play(): "'+
-b.id+'" already playing (one-shot)',1),f=b);if(null!==f)return f;a.url&&a.url!==b.url&&b.load(b._iO);if(b.loaded)c._wD('SMSound.play(): "'+b.id+'"');else if(0===b.readyState){c._wD('SMSound.play(): Attempting to load "'+b.id+'"',1);if(!b.isHTML5)b._iO.autoPlay=!0;b.load(b._iO)}else 2===b.readyState?(c._wD('SMSound.play(): Could not load "'+b.id+'" - exiting',2),f=b):c._wD('SMSound.play(): "'+b.id+'" is loading - attempting to play..',1);if(null!==f)return f;if(!b.isHTML5&&9===j&&0<b.position&&b.position===
-b.duration)c._wD('SMSound.play(): "'+b.id+'": Sound at end, resetting to position:0'),a.position=0;if(b.paused&&0<=b.position&&(!b._iO.serverURL||0<b.position))c._wD('SMSound.play(): "'+b.id+'" is resuming from paused state',1),b.resume();else{b._iO=w(a,b._iO);if(null!==b._iO.from&&null!==b._iO.to&&0===b.instanceCount&&0===b.playState&&!b._iO.serverURL){e=function(){b._iO=w(a,b._iO);b.play(b._iO)};if(b.isHTML5&&!b._html5_canplay)c._wD('SMSound.play(): Beginning load of "'+b.id+'" for from/to case'),
-b.load({_oncanplay:e}),f=!1;else if(!b.isHTML5&&!b.loaded&&(!b.readyState||2!==b.readyState))c._wD('SMSound.play(): Preloading "'+b.id+'" for from/to case'),b.load({onload:e}),f=!1;if(null!==f)return f;b._iO=v()}c._wD('SMSound.play(): "'+b.id+'" is starting to play');(!b.instanceCount||b._iO.multiShotEvents||!b.isHTML5&&8<j&&!b.getAutoPlay())&&b.instanceCount++;b._iO.onposition&&0===b.playState&&k(b);b.playState=1;b.paused=!1;b.position="undefined"!==typeof b._iO.position&&!isNaN(b._iO.position)?
-b._iO.position:0;if(!b.isHTML5)b._iO=ja(ia(b._iO));b._iO.onplay&&d&&(b._iO.onplay.apply(b),m=!0);b.setVolume(b._iO.volume,!0);b.setPan(b._iO.pan,!0);b.isHTML5?(i(),f=b._setup_html5(),b.setPosition(b._iO.position),f.play()):(f=h._start(b.id,b._iO.loops||1,9===j?b._iO.position:b._iO.position/1E3,b._iO.multiShot),9===j&&!f&&(c._wD("SMSound.play(): "+b.id+": No sound hardware, or 32-sound ceiling hit"),b._iO.onplayerror&&b._iO.onplayerror.apply(b)))}return b};this.stop=function(a){var c=b._iO;if(1===
-b.playState){b._onbufferchange(0);b._resetOnPosition(0);b.paused=!1;if(!b.isHTML5)b.playState=0;u();c.to&&b.clearOnPosition(c.to);if(b.isHTML5){if(b._a)a=b.position,b.setPosition(0),b.position=a,b._a.pause(),b.playState=0,b._onTimer(),l()}else h._stop(b.id,a),c.serverURL&&b.unload();b.instanceCount=0;b._iO={};c.onstop&&c.onstop.apply(b)}return b};this.setAutoPlay=function(a){c._wD("sound "+b.id+" turned autoplay "+(a?"on":"off"));b._iO.autoPlay=a;b.isHTML5||(h._setAutoPlay(b.id,a),a&&!b.instanceCount&&
-1===b.readyState&&(b.instanceCount++,c._wD("sound "+b.id+" incremented instance count to "+b.instanceCount)))};this.getAutoPlay=function(){return b._iO.autoPlay};this.setPosition=function(a){"undefined"===typeof a&&(a=0);var d=b.isHTML5?Math.max(a,0):Math.min(b.duration||b._iO.duration,Math.max(a,0));b.position=d;a=b.position/1E3;b._resetOnPosition(b.position);b._iO.position=d;if(b.isHTML5){if(b._a)if(b._html5_canplay){if(b._a.currentTime!==a){c._wD("setPosition("+a+"): setting position");try{b._a.currentTime=
-a,(0===b.playState||b.paused)&&b._a.pause()}catch(e){c._wD("setPosition("+a+"): setting position failed: "+e.message,2)}}}else c._wD("setPosition("+a+"): delaying, sound not ready")}else a=9===j?b.position:a,b.readyState&&2!==b.readyState&&h._setPosition(b.id,a,b.paused||!b.playState,b._iO.multiShot);b.isHTML5&&b.paused&&b._onTimer(!0);return b};this.pause=function(a){if(b.paused||0===b.playState&&1!==b.readyState)return b;c._wD("SMSound.pause()");b.paused=!0;b.isHTML5?(b._setup_html5().pause(),l()):
-(a||"undefined"===typeof a)&&h._pause(b.id,b._iO.multiShot);b._iO.onpause&&b._iO.onpause.apply(b);return b};this.resume=function(){var a=b._iO;if(!b.paused)return b;c._wD("SMSound.resume()");b.paused=!1;b.playState=1;b.isHTML5?(b._setup_html5().play(),i()):(a.isMovieStar&&!a.serverURL&&b.setPosition(b.position),h._pause(b.id,a.multiShot));!m&&a.onplay?(a.onplay.apply(b),m=!0):a.onresume&&a.onresume.apply(b);return b};this.togglePause=function(){c._wD("SMSound.togglePause()");if(0===b.playState)return b.play({position:9===
-j&&!b.isHTML5?b.position:b.position/1E3}),b;b.paused?b.resume():b.pause();return b};this.setPan=function(a,c){"undefined"===typeof a&&(a=0);"undefined"===typeof c&&(c=!1);b.isHTML5||h._setPan(b.id,a);b._iO.pan=a;if(!c)b.pan=a,b.options.pan=a;return b};this.setVolume=function(a,d){"undefined"===typeof a&&(a=100);"undefined"===typeof d&&(d=!1);if(b.isHTML5){if(b._a)b._a.volume=Math.max(0,Math.min(1,a/100))}else h._setVolume(b.id,c.muted&&!b.muted||b.muted?0:a);b._iO.volume=a;if(!d)b.volume=a,b.options.volume=
-a;return b};this.mute=function(){b.muted=!0;if(b.isHTML5){if(b._a)b._a.muted=!0}else h._setVolume(b.id,0);return b};this.unmute=function(){b.muted=!1;var a="undefined"!==typeof b._iO.volume;if(b.isHTML5){if(b._a)b._a.muted=!1}else h._setVolume(b.id,a?b._iO.volume:b.options.volume);return b};this.toggleMute=function(){return b.muted?b.unmute():b.mute()};this.onposition=this.onPosition=function(a,c,d){y.push({position:parseInt(a,10),method:c,scope:"undefined"!==typeof d?d:b,fired:!1});return b};this.clearOnPosition=
-function(b,a){var c,b=parseInt(b,10);if(isNaN(b))return!1;for(c=0;c<y.length;c++)if(b===y[c].position&&(!a||a===y[c].method))y[c].fired&&q--,y.splice(c,1)};this._processOnPosition=function(){var a,c;a=y.length;if(!a||!b.playState||q>=a)return!1;for(a-=1;0<=a;a--)if(c=y[a],!c.fired&&b.position>=c.position)c.fired=!0,q++,c.method.apply(c.scope,[c.position]);return!0};this._resetOnPosition=function(b){var a,c;a=y.length;if(!a)return!1;for(a-=1;0<=a;a--)if(c=y[a],c.fired&&b<=c.position)c.fired=!1,q--;
-return!0};v=function(){var a=b._iO,d=a.from,e=a.to,f,g;g=function(){c._wD(b.id+': "to" time of '+e+" reached.");b.clearOnPosition(e,g);b.stop()};f=function(){c._wD(b.id+': playing "from" '+d);if(null!==e&&!isNaN(e))b.onPosition(e,g)};if(null!==d&&!isNaN(d))a.position=d,a.multiShot=!1,f();return a};k=function(){var a,c=b._iO.onposition;if(c)for(a in c)if(c.hasOwnProperty(a))b.onPosition(parseInt(a,10),c[a])};u=function(){var a,c=b._iO.onposition;if(c)for(a in c)c.hasOwnProperty(a)&&b.clearOnPosition(parseInt(a,
-10))};i=function(){b.isHTML5&&Ra(b)};l=function(){b.isHTML5&&Sa(b)};g=function(a){a||(y=[],q=0);m=!1;b._hasTimer=null;b._a=null;b._html5_canplay=!1;b.bytesLoaded=null;b.bytesTotal=null;b.duration=b._iO&&b._iO.duration?b._iO.duration:null;b.durationEstimate=null;b.buffered=[];b.eqData=[];b.eqData.left=[];b.eqData.right=[];b.failures=0;b.isBuffering=!1;b.instanceOptions={};b.instanceCount=0;b.loaded=!1;b.metadata={};b.readyState=0;b.muted=!1;b.paused=!1;b.peakData={left:0,right:0};b.waveformData={left:[],
-right:[]};b.playState=0;b.position=null;b.id3={}};g();this._onTimer=function(a){var c,f=!1,g={};if(b._hasTimer||a){if(b._a&&(a||(0<b.playState||1===b.readyState)&&!b.paused)){c=b._get_html5_duration();if(c!==d)d=c,b.duration=c,f=!0;b.durationEstimate=b.duration;c=1E3*b._a.currentTime||0;c!==e&&(e=c,f=!0);(f||a)&&b._whileplaying(c,g,g,g,g)}return f}};this._get_html5_duration=function(){var a=b._iO;return(a=b._a&&b._a.duration?1E3*b._a.duration:a&&a.duration?a.duration:null)&&!isNaN(a)&&Infinity!==
-a?a:null};this._apply_loop=function(b,a){!b.loop&&1<a&&c._wD("Note: Native HTML5 looping is infinite.");b.loop=1<a?"loop":""};this._setup_html5=function(a){var a=w(b._iO,a),d=decodeURI,e=G?c._global_a:b._a,l=d(a.url),r=e&&e._t?e._t.instanceOptions:null,i;if(e){if(e._t){if(!G&&l===d(o))i=e;else if(G&&r.url===a.url&&(!o||o===r.url))i=e;if(i)return b._apply_loop(e,a.loops),i}c._wD("setting URL on existing object: "+l+(o?", old URL: "+o:""));G&&e._t&&e._t.playState&&a.url!==r.url&&e._t.stop();g(r&&r.url?
-a.url===r.url:o?o===a.url:!1);e.src=a.url;o=b.url=a.url;e._called_load=!1}else if(n("h5a"),b._a=a.autoLoad||a.autoPlay?new Audio(a.url):qa&&10>opera.version()?new Audio(null):new Audio,e=b._a,e._called_load=!1,G)c._global_a=e;b.isHTML5=!0;b._a=e;e._t=b;f();b._apply_loop(e,a.loops);a.autoLoad||a.autoPlay?b.load():(e.autobuffer=!1,e.preload="auto");return e};f=function(){if(b._a._added_events)return!1;var a;b._a._added_events=!0;for(a in C)C.hasOwnProperty(a)&&b._a&&b._a.addEventListener(a,C[a],!1);
-return!0};r=function(){var a;c._wD(s+"removing event listeners: "+b.id);b._a._added_events=!1;for(a in C)C.hasOwnProperty(a)&&b._a&&b._a.removeEventListener(a,C[a],!1)};this._onload=function(a){a=!!a||!b.isHTML5&&8===j&&b.duration;c._wD('SMSound._onload(): "'+b.id+'"'+(a?" loaded.":" failed to load? - "+b.url),a?1:2);!a&&!b.isHTML5&&(!0===c.sandbox.noRemote&&c._wD("SMSound._onload(): "+p("noNet"),1),!0===c.sandbox.noLocal&&c._wD("SMSound._onload(): "+p("noLocal"),1));b.loaded=a;b.readyState=a?3:2;
-b._onbufferchange(0);b._iO.onload&&b._iO.onload.apply(b,[a]);return!0};this._onbufferchange=function(a){if(0===b.playState||a&&b.isBuffering||!a&&!b.isBuffering)return!1;b.isBuffering=1===a;b._iO.onbufferchange&&(c._wD("SMSound._onbufferchange(): "+a),b._iO.onbufferchange.apply(b));return!0};this._onsuspend=function(){b._iO.onsuspend&&(c._wD("SMSound._onsuspend()"),b._iO.onsuspend.apply(b));return!0};this._onfailure=function(a,d,e){b.failures++;c._wD('SMSound._onfailure(): "'+b.id+'" count '+b.failures);
-if(b._iO.onfailure&&1===b.failures)b._iO.onfailure(b,a,d,e);else c._wD("SMSound._onfailure(): ignoring")};this._onfinish=function(){var a=b._iO.onfinish;b._onbufferchange(0);b._resetOnPosition(0);if(b.instanceCount){b.instanceCount--;if(!b.instanceCount&&(u(),b.playState=0,b.paused=!1,b.instanceCount=0,b.instanceOptions={},b._iO={},l(),b.isHTML5))b.position=0;if((!b.instanceCount||b._iO.multiShotEvents)&&a)c._wD('SMSound._onfinish(): "'+b.id+'"'),a.apply(b)}};this._whileloading=function(a,c,d,e){var f=
-b._iO;b.bytesLoaded=a;b.bytesTotal=c;b.duration=Math.floor(d);b.bufferLength=e;b.durationEstimate=!b.isHTML5&&!f.isMovieStar?f.duration?b.duration>f.duration?b.duration:f.duration:parseInt(b.bytesTotal/b.bytesLoaded*b.duration,10):b.duration;if(!b.isHTML5)b.buffered=[{start:0,end:b.duration}];(3!==b.readyState||b.isHTML5)&&f.whileloading&&f.whileloading.apply(b)};this._whileplaying=function(a,c,d,e,f){var g=b._iO;if(isNaN(a)||null===a)return!1;b.position=Math.max(0,a);b._processOnPosition();if(!b.isHTML5&&
-8<j){if(g.usePeakData&&"undefined"!==typeof c&&c)b.peakData={left:c.leftPeak,right:c.rightPeak};if(g.useWaveformData&&"undefined"!==typeof d&&d)b.waveformData={left:d.split(","),right:e.split(",")};if(g.useEQData&&"undefined"!==typeof f&&f&&f.leftEQ&&(a=f.leftEQ.split(","),b.eqData=a,b.eqData.left=a,"undefined"!==typeof f.rightEQ&&f.rightEQ))b.eqData.right=f.rightEQ.split(",")}1===b.playState&&(!b.isHTML5&&8===j&&!b.position&&b.isBuffering&&b._onbufferchange(0),g.whileplaying&&g.whileplaying.apply(b));
-return!0};this._oncaptiondata=function(a){c._wD('SMSound._oncaptiondata(): "'+this.id+'" caption data received.');b.captiondata=a;b._iO.oncaptiondata&&b._iO.oncaptiondata.apply(b,[a])};this._onmetadata=function(a,d){c._wD('SMSound._onmetadata(): "'+this.id+'" metadata received.');var e={},f,g;for(f=0,g=a.length;f<g;f++)e[a[f]]=d[f];b.metadata=e;b._iO.onmetadata&&b._iO.onmetadata.apply(b)};this._onid3=function(a,d){c._wD('SMSound._onid3(): "'+this.id+'" ID3 data received.');var e=[],f,g;for(f=0,g=
-a.length;f<g;f++)e[a[f]]=d[f];b.id3=w(b.id3,e);b._iO.onid3&&b._iO.onid3.apply(b)};this._onconnect=function(a){a=1===a;c._wD('SMSound._onconnect(): "'+b.id+'"'+(a?" connected.":" failed to connect? - "+b.url),a?1:2);if(b.connected=a)b.failures=0,t(b.id)&&(b.getAutoPlay()?b.play(void 0,b.getAutoPlay()):b._iO.autoLoad&&b.load()),b._iO.onconnect&&b._iO.onconnect.apply(b,[a])};this._ondataerror=function(a){0<b.playState&&(c._wD("SMSound._ondataerror(): "+a),b._iO.ondataerror&&b._iO.ondataerror.apply(b))}};
-fa=function(){return i.body||i._docElement||i.getElementsByTagName("div")[0]};A=function(a){return i.getElementById(a)};w=function(a,d){var e=a||{},b,g;b="undefined"===typeof d?c.defaultOptions:d;for(g in b)b.hasOwnProperty(g)&&"undefined"===typeof e[g]&&(e[g]="object"!==typeof b[g]||null===b[g]?b[g]:w(e[g],b[g]));return e};H={onready:1,ontimeout:1,defaultOptions:1,flash9Options:1,movieStarOptions:1};ua=function(a,d){var e,b=!0,g="undefined"!==typeof d,f=c.setupOptions;if("undefined"===typeof a){b=
-[];for(e in f)f.hasOwnProperty(e)&&b.push(e);for(e in H)H.hasOwnProperty(e)&&("object"===typeof c[e]?b.push(e+": {...}"):c[e]instanceof Function?b.push(e+": function() {...}"):b.push(e));c._wD(p("setup",b.join(", ")));return!1}for(e in a)if(a.hasOwnProperty(e))if("object"!==typeof a[e]||null===a[e]||a[e]instanceof Array)g&&"undefined"!==typeof H[d]?c[d][e]=a[e]:"undefined"!==typeof f[e]?(c.setupOptions[e]=a[e],c[e]=a[e]):"undefined"===typeof H[e]?(O(p("undefined"===typeof c[e]?"setupUndef":"setupError",
-e),2),b=!1):c[e]instanceof Function?c[e].apply(c,a[e]instanceof Array?a[e]:[a[e]]):c[e]=a[e];else if("undefined"===typeof H[e])O(p("undefined"===typeof c[e]?"setupUndef":"setupError",e),2),b=!1;else return ua(a[e],e);return b};u=function(){function a(a){var a=Wa.call(a),b=a.length;e?(a[1]="on"+a[1],3<b&&a.pop()):3===b&&a.push(!1);return a}function c(a,d){var r=a.shift(),l=[b[d]];if(e)r[l](a[0],a[1]);else r[l].apply(r,a)}var e=k.attachEvent,b={add:e?"attachEvent":"addEventListener",remove:e?"detachEvent":
-"removeEventListener"};return{add:function(){c(a(arguments),"add")},remove:function(){c(a(arguments),"remove")}}}();C={abort:q(function(){c._wD(s+"abort: "+this._t.id)}),canplay:q(function(){var a=this._t,d;if(a._html5_canplay)return!0;a._html5_canplay=!0;c._wD(s+"canplay: "+a.id+", "+a.url);a._onbufferchange(0);d="undefined"!==typeof a._iO.position&&!isNaN(a._iO.position)?a._iO.position/1E3:null;if(a.position&&this.currentTime!==d){c._wD(s+"canplay: setting position to "+d);try{this.currentTime=
-d}catch(e){c._wD(s+"setting position of "+d+" failed: "+e.message,2)}}a._iO._oncanplay&&a._iO._oncanplay()}),canplaythrough:q(function(){var a=this._t;a.loaded||(a._onbufferchange(0),a._whileloading(a.bytesLoaded,a.bytesTotal,a._get_html5_duration()),a._onload(!0))}),ended:q(function(){var a=this._t;c._wD(s+"ended: "+a.id);a._onfinish()}),error:q(function(){c._wD(s+"error: "+this.error.code);this._t._onload(!1)}),loadeddata:q(function(){var a=this._t;c._wD(s+"loadeddata: "+this._t.id);if(!a._loaded&&
-!Ga)a.duration=a._get_html5_duration()}),loadedmetadata:q(function(){c._wD(s+"loadedmetadata: "+this._t.id)}),loadstart:q(function(){c._wD(s+"loadstart: "+this._t.id);this._t._onbufferchange(1)}),play:q(function(){c._wD(s+"play: "+this._t.id+", "+this._t.url);this._t._onbufferchange(0)}),playing:q(function(){c._wD(s+"playing: "+this._t.id);this._t._onbufferchange(0)}),progress:q(function(a){var d=this._t,e,b,g;e=0;var f="progress"===a.type,r=a.target.buffered,l=a.loaded||0,i=a.total||1;d.buffered=
-[];if(r&&r.length){for(e=0,b=r.length;e<b;e++)d.buffered.push({start:1E3*r.start(e),end:1E3*r.end(e)});e=1E3*(r.end(0)-r.start(0));l=e/(1E3*a.target.duration);if(f&&1<r.length){g=[];b=r.length;for(e=0;e<b;e++)g.push(1E3*a.target.buffered.start(e)+"-"+1E3*a.target.buffered.end(e));c._wD(s+"progress: timeRanges: "+g.join(", "))}f&&!isNaN(l)&&c._wD(s+"progress: "+d.id+": "+Math.floor(100*l)+"% loaded")}isNaN(l)||(d._onbufferchange(0),d._whileloading(l,i,d._get_html5_duration()),l&&i&&l===i&&C.canplaythrough.call(this,
-a))}),ratechange:q(function(){c._wD(s+"ratechange: "+this._t.id)}),suspend:q(function(a){var d=this._t;c._wD(s+"suspend: "+d.id);C.progress.call(this,a);d._onsuspend()}),stalled:q(function(){c._wD(s+"stalled: "+this._t.id)}),timeupdate:q(function(){this._t._onTimer()}),waiting:q(function(){var a=this._t;c._wD(s+"waiting: "+a.id);a._onbufferchange(1)})};ma=function(a){return a.serverURL||a.type&&aa(a.type)?!1:a.type?Y({type:a.type}):Y({url:a.url})||c.html5Only};Ca=function(a,c){if(a)a.src=c};Y=function(a){if(!c.useHTML5Audio||
-!c.hasHTML5)return!1;var d=a.url||null,a=a.type||null,e=c.audioFormats,b;if(a&&"undefined"!==typeof c.html5[a])return c.html5[a]&&!aa(a);if(!E){E=[];for(b in e)e.hasOwnProperty(b)&&(E.push(b),e[b].related&&(E=E.concat(e[b].related)));E=RegExp("\\.("+E.join("|")+")(\\?.*)?$","i")}b=d?d.toLowerCase().match(E):null;!b||!b.length?a&&(d=a.indexOf(";"),b=(-1!==d?a.substr(0,d):a).substr(6)):b=b[1];b&&"undefined"!==typeof c.html5[b]?d=c.html5[b]&&!aa(b):(a="audio/"+b,d=c.html5.canPlayType({type:a}),d=(c.html5[b]=
-d)&&c.html5[a]&&!aa(a));return d};Va=function(){function a(a){var b,e,f=b=!1;if(!d||"function"!==typeof d.canPlayType)return b;if(a instanceof Array){for(b=0,e=a.length;b<e;b++)if(c.html5[a[b]]||d.canPlayType(a[b]).match(c.html5Test))f=!0,c.html5[a[b]]=!0,c.flash[a[b]]=!!a[b].match(ab);b=f}else a=d&&"function"===typeof d.canPlayType?d.canPlayType(a):!1,b=!(!a||!a.match(c.html5Test));return b}if(!c.useHTML5Audio||!c.hasHTML5)return!1;var d="undefined"!==typeof Audio?qa&&10>opera.version()?new Audio(null):
-new Audio:null,e,b,g={},f;f=c.audioFormats;for(e in f)if(f.hasOwnProperty(e)&&(b="audio/"+e,g[e]=a(f[e].type),g[b]=g[e],e.match(ab)?(c.flash[e]=!0,c.flash[b]=!0):(c.flash[e]=!1,c.flash[b]=!1),f[e]&&f[e].related))for(b=f[e].related.length-1;0<=b;b--)g["audio/"+f[e].related[b]]=g[e],c.html5[f[e].related[b]]=g[e],c.flash[f[e].related[b]]=g[e];g.canPlayType=d?a:null;c.html5=w(c.html5,g);return!0};da={notReady:"Not loaded yet - wait for soundManager.onready()",notOK:"Audio support is not available.",domError:"soundManager::createMovie(): appendChild/innerHTML call failed. DOM not ready or other error.",
-spcWmode:"soundManager::createMovie(): Removing wmode, preventing known SWF loading issue(s)",swf404:"soundManager: Verify that %s is a valid path.",tryDebug:"Try soundManager.debugFlash = true for more security details (output goes to SWF.)",checkSWF:"See SWF output for more debug info.",localFail:"soundManager: Non-HTTP page ("+i.location.protocol+" URL?) Review Flash player security settings for this special case:\nhttp://www.macromedia.com/support/documentation/en/flashplayer/help/settings_manager04.html\nMay need to add/allow path, eg. c:/sm2/ or /users/me/sm2/",
-waitFocus:"soundManager: Special case: Waiting for SWF to load with window focus...",waitImpatient:"soundManager: Getting impatient, still waiting for Flash%s...",waitForever:"soundManager: Waiting indefinitely for Flash (will recover if unblocked)...",waitSWF:"soundManager: Retrying, waiting for 100% SWF load...",needFunction:"soundManager: Function object expected for %s",badID:'Warning: Sound ID "%s" should be a string, starting with a non-numeric character',currentObj:"--- soundManager._debug(): Current sound objects ---",
-waitEI:"soundManager::initMovie(): Waiting for ExternalInterface call from Flash...",waitOnload:"soundManager: Waiting for window.onload()",docLoaded:"soundManager: Document already loaded",onload:"soundManager::initComplete(): calling soundManager.onload()",onloadOK:"soundManager.onload() complete",init:"soundManager::init()",didInit:"soundManager::init(): Already called?",flashJS:"soundManager: Attempting JS to Flash call...",secNote:"Flash security note: Network/internet URLs will not load due to security restrictions. Access can be configured via Flash Player Global Security Settings Page: http://www.macromedia.com/support/documentation/en/flashplayer/help/settings_manager04.html",
-badRemove:"Warning: Failed to remove flash movie.",shutdown:"soundManager.disable(): Shutting down",queue:"soundManager: Queueing %s handler",smFail:"soundManager: Failed to initialise.",smError:"SMSound.load(): Exception: JS-Flash communication failed, or JS error.",fbTimeout:"No flash response, applying .swf_timedout CSS...",fbLoaded:"Flash loaded",fbHandler:"soundManager::flashBlockHandler()",manURL:"SMSound.load(): Using manually-assigned URL",onURL:"soundManager.load(): current URL already assigned.",
-badFV:'soundManager.flashVersion must be 8 or 9. "%s" is invalid. Reverting to %s.',as2loop:"Note: Setting stream:false so looping can work (flash 8 limitation)",noNSLoop:"Note: Looping not implemented for MovieStar formats",needfl9:"Note: Switching to flash 9, required for MP4 formats.",mfTimeout:"Setting flashLoadTimeout = 0 (infinite) for off-screen, mobile flash case",needFlash:"soundManager: Fatal error: Flash is needed to play some required formats, but is not available.",gotFocus:"soundManager: Got window focus.",
-mfOn:"mobileFlash::enabling on-screen flash repositioning",policy:"Enabling usePolicyFile for data access",setup:"soundManager.setup(): allowed parameters: %s",setupError:'soundManager.setup(): "%s" cannot be assigned with this method.',setupUndef:'soundManager.setup(): Could not find option "%s"',setupLate:"soundManager.setup(): url + flashVersion changes will not take effect until reboot().",h5a:"creating HTML5 Audio() object",noURL:"soundManager: Flash URL required. Call soundManager.setup({url:...}) to get started."};
-p=function(){var a=Wa.call(arguments),c=a.shift(),c=da&&da[c]?da[c]:"",e,b;if(c&&a&&a.length)for(e=0,b=a.length;e<b;e++)c=c.replace("%s",a[e]);return c};ia=function(a){if(8===j&&1<a.loops&&a.stream)n("as2loop"),a.stream=!1;return a};ja=function(a,d){if(a&&!a.usePolicyFile&&(a.onid3||a.usePeakData||a.useWaveformData||a.useEQData))c._wD((d||"")+p("policy")),a.usePolicyFile=!0;return a};O=function(a){"undefined"!==typeof console&&"undefined"!==typeof console.warn?console.warn(a):c._wD(a)};ra=function(){return!1};
-Oa=function(a){for(var c in a)a.hasOwnProperty(c)&&"function"===typeof a[c]&&(a[c]=ra)};ha=function(a){"undefined"===typeof a&&(a=!1);if(o||a)n("smFail",2),c.disable(a)};Pa=function(a){var d=null;if(a)if(a.match(/\.swf(\?.*)?$/i)){if(d=a.substr(a.toLowerCase().lastIndexOf(".swf?")+4))return a}else a.lastIndexOf("/")!==a.length-1&&(a+="/");a=(a&&-1!==a.lastIndexOf("/")?a.substr(0,a.lastIndexOf("/")+1):"./")+c.movieURL;c.noSWFCache&&(a+="?ts="+(new Date).getTime());return a};wa=function(){j=parseInt(c.flashVersion,
-10);if(8!==j&&9!==j)c._wD(p("badFV",j,8)),c.flashVersion=j=8;var a=c.debugMode||c.debugFlash?"_debug.swf":".swf";if(c.useHTML5Audio&&!c.html5Only&&c.audioFormats.mp4.required&&9>j)c._wD(p("needfl9")),c.flashVersion=j=9;c.version=c.versionNumber+(c.html5Only?" (HTML5-only mode)":9===j?" (AS3/Flash 9)":" (AS2/Flash 8)");8<j?(c.defaultOptions=w(c.defaultOptions,c.flash9Options),c.features.buffering=!0,c.defaultOptions=w(c.defaultOptions,c.movieStarOptions),c.filePatterns.flash9=RegExp("\\.(mp3|"+db.join("|")+
-")(\\?.*)?$","i"),c.features.movieStar=!0):c.features.movieStar=!1;c.filePattern=c.filePatterns[8!==j?"flash9":"flash8"];c.movieURL=(8===j?"soundmanager2.swf":"soundmanager2_flash9.swf").replace(".swf",a);c.features.peakData=c.features.waveformData=c.features.eqData=8<j};Na=function(a,c){if(!h)return!1;h._setPolling(a,c)};ya=function(){if(c.debugURLParam.test(Q))c.debugMode=!0;if(A(c.debugID))return!1;var a,d,e,b;if(c.debugMode&&!A(c.debugID)&&(!Za||!c.useConsole||!c.consoleOnly)){a=i.createElement("div");
-a.id=c.debugID+"-toggle";d={position:"fixed",bottom:"0px",right:"0px",width:"1.2em",height:"1.2em",lineHeight:"1.2em",margin:"2px",textAlign:"center",border:"1px solid #999",cursor:"pointer",background:"#fff",color:"#333",zIndex:10001};a.appendChild(i.createTextNode("-"));a.onclick=Qa;a.title="Toggle SM2 debug console";if(v.match(/msie 6/i))a.style.position="absolute",a.style.cursor="hand";for(b in d)d.hasOwnProperty(b)&&(a.style[b]=d[b]);d=i.createElement("div");d.id=c.debugID;d.style.display=c.debugMode?
-"block":"none";if(c.debugMode&&!A(a.id)){try{e=fa(),e.appendChild(a)}catch(g){throw Error(p("domError")+" \n"+g.toString());}e.appendChild(d)}}};t=this.getSoundById;n=function(a,d){return!a?"":c._wD(p(a),d)};if(Q.indexOf("sm2-debug=alert")+1&&c.debugMode)c._wD=function(a){Z.alert(a)};Qa=function(){var a=A(c.debugID),d=A(c.debugID+"-toggle");if(!a)return!1;ta?(d.innerHTML="+",a.style.display="none"):(d.innerHTML="-",a.style.display="block");ta=!ta};x=function(a,c,e){if("undefined"!==typeof sm2Debugger)try{sm2Debugger.handleEvent(a,
-c,e)}catch(b){}return!0};N=function(){var a=[];c.debugMode&&a.push("sm2_debug");c.debugFlash&&a.push("flash_debug");c.useHighPerformance&&a.push("high_performance");return a.join(" ")};Aa=function(){var a=p("fbHandler"),d=c.getMoviePercent(),e={type:"FLASHBLOCK"};if(c.html5Only)return!1;if(c.ok()){if(c.didFlashBlock&&c._wD(a+": Unblocked"),c.oMC)c.oMC.className=[N(),"movieContainer","swf_loaded"+(c.didFlashBlock?" swf_unblocked":"")].join(" ")}else{if(B)c.oMC.className=N()+" movieContainer "+(null===
-d?"swf_timedout":"swf_error"),c._wD(a+": "+p("fbTimeout")+(d?" ("+p("fbLoaded")+")":""));c.didFlashBlock=!0;I({type:"ontimeout",ignoreInit:!0,error:e});M(e)}};va=function(a,c,e){"undefined"===typeof D[a]&&(D[a]=[]);D[a].push({method:c,scope:e||null,fired:!1})};I=function(a){a||(a={type:c.ok()?"onready":"ontimeout"});if(!m&&a&&!a.ignoreInit||"ontimeout"===a.type&&(c.ok()||o&&!a.ignoreInit))return!1;var d={success:a&&a.ignoreInit?c.ok():!o},e=a&&a.type?D[a.type]||[]:[],b=[],g,f=[d],i=B&&c.useFlashBlock&&
-!c.ok();if(a.error)f[0].error=a.error;for(d=0,g=e.length;d<g;d++)!0!==e[d].fired&&b.push(e[d]);if(b.length){c._wD("soundManager: Firing "+b.length+" "+a.type+"() item"+(1===b.length?"":"s"));for(d=0,g=b.length;d<g;d++)if(b[d].scope?b[d].method.apply(b[d].scope,f):b[d].method.apply(this,f),!i)b[d].fired=!0}return!0};J=function(){k.setTimeout(function(){c.useFlashBlock&&Aa();I();"function"===typeof c.onload&&(n("onload",1),c.onload.apply(k),n("onloadOK",1));c.waitForWindowLoad&&u.add(k,"load",J)},1)};
-Ea=function(){if("undefined"!==typeof z)return z;var a=!1,c=navigator,e=c.plugins,b,g=k.ActiveXObject;if(e&&e.length)(c=c.mimeTypes)&&c["application/x-shockwave-flash"]&&c["application/x-shockwave-flash"].enabledPlugin&&c["application/x-shockwave-flash"].enabledPlugin.description&&(a=!0);else if("undefined"!==typeof g){try{b=new g("ShockwaveFlash.ShockwaveFlash")}catch(f){}a=!!b}return z=a};Ua=function(){var a,d,e=c.audioFormats;if(Fa&&v.match(/os (1|2|3_0|3_1)/i)){if(c.hasHTML5=!1,c.html5Only=!0,
-c.oMC)c.oMC.style.display="none"}else if(c.useHTML5Audio){if(!c.html5||!c.html5.canPlayType)c._wD("SoundManager: No HTML5 Audio() support detected."),c.hasHTML5=!1;Ia&&c._wD("soundManager::Note: Buggy HTML5 Audio in Safari on this OS X release, see https://bugs.webkit.org/show_bug.cgi?id=32159 - "+(!z?" would use flash fallback for MP3/MP4, but none detected.":"will use flash fallback for MP3/MP4, if available"),1)}if(c.useHTML5Audio&&c.hasHTML5)for(d in e)if(e.hasOwnProperty(d)&&(e[d].required&&
-!c.html5.canPlayType(e[d].type)||c.preferFlash&&(c.flash[d]||c.flash[e[d].type])))a=!0;c.ignoreFlash&&(a=!1);c.html5Only=c.hasHTML5&&c.useHTML5Audio&&!a;return!c.html5Only};la=function(a){var d,e,b=0;if(a instanceof Array){for(d=0,e=a.length;d<e;d++)if(a[d]instanceof Object){if(c.canPlayMIME(a[d].type)){b=d;break}}else if(c.canPlayURL(a[d])){b=d;break}if(a[b].url)a[b]=a[b].url;a=a[b]}return a};Ra=function(a){if(!a._hasTimer)a._hasTimer=!0,!Ha&&c.html5PollingInterval&&(null===X&&0===ka&&(X=k.setInterval(Ta,
-c.html5PollingInterval)),ka++)};Sa=function(a){if(a._hasTimer)a._hasTimer=!1,!Ha&&c.html5PollingInterval&&ka--};Ta=function(){var a;if(null!==X&&!ka)return k.clearInterval(X),X=null,!1;for(a=c.soundIDs.length-1;0<=a;a--)c.sounds[c.soundIDs[a]].isHTML5&&c.sounds[c.soundIDs[a]]._hasTimer&&c.sounds[c.soundIDs[a]]._onTimer()};M=function(a){a="undefined"!==typeof a?a:{};"function"===typeof c.onerror&&c.onerror.apply(k,[{type:"undefined"!==typeof a.type?a.type:null}]);"undefined"!==typeof a.fatal&&a.fatal&&
-c.disable()};Xa=function(){if(!Ia||!Ea())return!1;var a=c.audioFormats,d,e;for(e in a)if(a.hasOwnProperty(e)&&("mp3"===e||"mp4"===e))if(c._wD("soundManager: Using flash fallback for "+e+" format"),c.html5[e]=!1,a[e]&&a[e].related)for(d=a[e].related.length-1;0<=d;d--)c.html5[a[e].related[d]]=!1};this._setSandboxType=function(a){var d=c.sandbox;d.type=a;d.description=d.types["undefined"!==typeof d.types[a]?a:"unknown"];c._wD("Flash security sandbox type: "+d.type);if("localWithFile"===d.type)d.noRemote=
-!0,d.noLocal=!1,n("secNote",2);else if("localWithNetwork"===d.type)d.noRemote=!1,d.noLocal=!0;else if("localTrusted"===d.type)d.noRemote=!1,d.noLocal=!1};this._externalInterfaceOK=function(a,d){if(c.swfLoaded)return!1;var e,b=(new Date).getTime();c._wD("soundManager::externalInterfaceOK()"+(a?" (~"+(b-a)+" ms)":""));x("swf",!0);x("flashtojs",!0);c.swfLoaded=!0;na=!1;Ia&&Xa();if(!d||d.replace(/\+dev/i,"")!==c.versionNumber.replace(/\+dev/i,""))return e='soundManager: Fatal: JavaScript file build "'+
-c.versionNumber+'" does not match Flash SWF build "'+d+'" at '+c.url+". Ensure both are up-to-date.",setTimeout(function(){throw Error(e);},0),!1;setTimeout(sa,F?100:1)};ga=function(a,d){function e(){c._wD("-- SoundManager 2 "+c.version+(!c.html5Only&&c.useHTML5Audio?c.hasHTML5?" + HTML5 audio":", no HTML5 audio support":"")+(!c.html5Only?(c.useHighPerformance?", high performance mode, ":", ")+((c.flashPollingInterval?"custom ("+c.flashPollingInterval+"ms)":"normal")+" polling")+(c.wmode?", wmode: "+
-c.wmode:"")+(c.debugFlash?", flash debug mode":"")+(c.useFlashBlock?", flashBlock mode":""):"")+" --",1)}function b(a,b){return'<param name="'+a+'" value="'+b+'" />'}if(R&&S)return!1;if(c.html5Only)return wa(),e(),c.oMC=A(c.movieID),sa(),S=R=!0,!1;var g=d||c.url,f=c.altURL||g,h=fa(),l=N(),k=null,k=i.getElementsByTagName("html")[0],j,o,m,k=k&&k.dir&&k.dir.match(/rtl/i),a="undefined"===typeof a?c.id:a;wa();c.url=Pa(P?g:f);d=c.url;c.wmode=!c.wmode&&c.useHighPerformance?"transparent":c.wmode;if(null!==
-c.wmode&&(v.match(/msie 8/i)||!F&&!c.useHighPerformance)&&navigator.platform.match(/win32|win64/i))n("spcWmode"),c.wmode=null;h={name:a,id:a,src:d,quality:"high",allowScriptAccess:c.allowScriptAccess,bgcolor:c.bgColor,pluginspage:bb+"www.macromedia.com/go/getflashplayer",title:"JS/Flash audio component (SoundManager 2)",type:"application/x-shockwave-flash",wmode:c.wmode,hasPriority:"true"};if(c.debugFlash)h.FlashVars="debug=1";c.wmode||delete h.wmode;if(F)g=i.createElement("div"),o=['<object id="'+
-a+'" data="'+d+'" type="'+h.type+'" title="'+h.title+'" classid="clsid:D27CDB6E-AE6D-11cf-96B8-444553540000" codebase="'+bb+'download.macromedia.com/pub/shockwave/cabs/flash/swflash.cab#version=6,0,40,0">',b("movie",d),b("AllowScriptAccess",c.allowScriptAccess),b("quality",h.quality),c.wmode?b("wmode",c.wmode):"",b("bgcolor",c.bgColor),b("hasPriority","true"),c.debugFlash?b("FlashVars",h.FlashVars):"","</object>"].join("");else for(j in g=i.createElement("embed"),h)h.hasOwnProperty(j)&&g.setAttribute(j,
-h[j]);ya();l=N();if(h=fa())if(c.oMC=A(c.movieID)||i.createElement("div"),c.oMC.id){m=c.oMC.className;c.oMC.className=(m?m+" ":"movieContainer")+(l?" "+l:"");c.oMC.appendChild(g);if(F)j=c.oMC.appendChild(i.createElement("div")),j.className="sm2-object-box",j.innerHTML=o;S=!0}else{c.oMC.id=c.movieID;c.oMC.className="movieContainer "+l;j=l=null;if(!c.useFlashBlock)if(c.useHighPerformance)l={position:"fixed",width:"8px",height:"8px",bottom:"0px",left:"0px",overflow:"hidden"};else if(l={position:"absolute",
-width:"6px",height:"6px",top:"-9999px",left:"-9999px"},k)l.left=Math.abs(parseInt(l.left,10))+"px";if(gb)c.oMC.style.zIndex=1E4;if(!c.debugFlash)for(m in l)l.hasOwnProperty(m)&&(c.oMC.style[m]=l[m]);try{F||c.oMC.appendChild(g);h.appendChild(c.oMC);if(F)j=c.oMC.appendChild(i.createElement("div")),j.className="sm2-object-box",j.innerHTML=o;S=!0}catch(q){throw Error(p("domError")+" \n"+q.toString());}}R=!0;e();c._wD("soundManager::createMovie(): Trying to load "+d+(!P&&c.altURL?" (alternate URL)":""),
-1);return!0};ea=function(){if(c.html5Only)return ga(),!1;if(h)return!1;if(!c.url)return n("noURL"),!1;h=c.getMovie(c.id);if(!h)V?(F?c.oMC.innerHTML=za:c.oMC.appendChild(V),V=null,R=!0):ga(c.id,c.url),h=c.getMovie(c.id);h&&n("waitEI");"function"===typeof c.oninitmovie&&setTimeout(c.oninitmovie,1);return!0};K=function(){setTimeout(Ma,1E3)};Ma=function(){var a,d=!1;if(!c.url||W)return!1;W=!0;u.remove(k,"load",K);if(na&&!Ja)return n("waitFocus"),!1;m||(a=c.getMoviePercent(),c._wD(p("waitImpatient",0<
-a?" (SWF "+a+"% loaded)":"")),0<a&&100>a&&(d=!0));setTimeout(function(){a=c.getMoviePercent();if(d)return W=!1,c._wD(p("waitSWF")),k.setTimeout(K,1),!1;m||(c._wD("soundManager: No Flash response within expected time.\nLikely causes: "+(0===a?"Loading "+c.movieURL+" may have failed (and/or Flash "+j+"+ not present?), ":"")+"Flash blocked or JS-Flash security error."+(c.debugFlash?" "+p("checkSWF"):""),2),!P&&a&&(n("localFail",2),c.debugFlash||n("tryDebug",2)),0===a&&c._wD(p("swf404",c.url)),x("flashtojs",
-!1,": Timed out"+P?" (Check flash security or flash blockers)":" (No plugin/missing SWF?)"));!m&&$a&&(null===a?c.useFlashBlock||0===c.flashLoadTimeout?(c.useFlashBlock&&Aa(),n("waitForever")):ha(!0):0===c.flashLoadTimeout?n("waitForever"):ha(!0))},c.flashLoadTimeout)};ca=function(){if(Ja||!na)return u.remove(k,"focus",ca),!0;Ja=$a=!0;n("gotFocus");W=!1;K();u.remove(k,"focus",ca);return!0};Ya=function(){var a,d=[];if(c.useHTML5Audio&&c.hasHTML5){for(a in c.audioFormats)c.audioFormats.hasOwnProperty(a)&&
-d.push(a+": "+c.html5[a]+(!c.html5[a]&&z&&c.flash[a]?" (using flash)":c.preferFlash&&c.flash[a]&&z?" (preferring flash)":!c.html5[a]?" ("+(c.audioFormats[a].required?"required, ":"")+"and no flash support)":""));c._wD("-- SoundManager 2: HTML5 support tests ("+c.html5Test+"): "+d.join(", ")+" --",1)}};T=function(a){if(m)return!1;if(c.html5Only)return c._wD("-- SoundManager 2: loaded --"),m=!0,J(),x("onload",!0),!0;var d=!0,e;if(!c.useFlashBlock||!c.flashLoadTimeout||c.getMoviePercent())m=!0,o&&(e=
-{type:!z&&B?"NO_FLASH":"INIT_TIMEOUT"});c._wD("-- SoundManager 2 "+(o?"failed to load":"loaded")+" ("+(o?"Flash security/load error":"OK")+") --",1);if(o||a){if(c.useFlashBlock&&c.oMC)c.oMC.className=N()+" "+(null===c.getMoviePercent()?"swf_timedout":"swf_error");I({type:"ontimeout",error:e,ignoreInit:!0});x("onload",!1);M(e);d=!1}else x("onload",!0);o||(c.waitForWindowLoad&&!ba?(n("waitOnload"),u.add(k,"load",J)):(c.waitForWindowLoad&&ba&&n("docLoaded"),J()));return d};La=function(){var a,d=c.setupOptions;
-for(a in d)d.hasOwnProperty(a)&&("undefined"===typeof c[a]?c[a]=d[a]:c[a]!==d[a]&&(c.setupOptions[a]=c[a]))};sa=function(){n("init");if(m)return n("didInit"),!1;if(c.html5Only){if(!m)u.remove(k,"load",c.beginDelayedInit),c.enabled=!0,T();return!0}ea();try{n("flashJS"),h._externalInterfaceTest(!1),Na(!0,c.flashPollingInterval||(c.useHighPerformance?10:50)),c.debugMode||h._disableDebug(),c.enabled=!0,x("jstoflash",!0),c.html5Only||u.add(k,"unload",ra)}catch(a){return c._wD("js/flash exception: "+a.toString()),
-x("jstoflash",!1),M({type:"JS_TO_FLASH_EXCEPTION",fatal:!0}),ha(!0),T(),!1}T();u.remove(k,"load",c.beginDelayedInit);return!0};L=function(){if(U)return!1;U=!0;La();ya();var a=null,a=null,d="undefined"!==typeof console&&"function"===typeof console.log,e=Q.toLowerCase();-1!==e.indexOf("sm2-usehtml5audio=")&&(a="1"===e.charAt(e.indexOf("sm2-usehtml5audio=")+18),d&&console.log((a?"Enabling ":"Disabling ")+"useHTML5Audio via URL parameter"),c.setup({useHTML5Audio:a}));-1!==e.indexOf("sm2-preferflash=")&&
-(a="1"===e.charAt(e.indexOf("sm2-preferflash=")+16),d&&console.log((a?"Enabling ":"Disabling ")+"preferFlash via URL parameter"),c.setup({preferFlash:a}));!z&&c.hasHTML5&&(c._wD("SoundManager: No Flash detected"+(!c.useHTML5Audio?", enabling HTML5.":". Trying HTML5-only mode.")),c.setup({useHTML5Audio:!0,preferFlash:!1}));Va();c.html5.usingFlash=Ua();B=c.html5.usingFlash;Ya();!z&&B&&(n("needFlash"),c.setup({flashLoadTimeout:1}));i.removeEventListener&&i.removeEventListener("DOMContentLoaded",L,!1);
-ea();return!0};Da=function(){"complete"===i.readyState&&(L(),i.detachEvent("onreadystatechange",Da));return!0};xa=function(){ba=!0;u.remove(k,"load",xa)};Ea();u.add(k,"focus",ca);u.add(k,"load",K);u.add(k,"load",xa);i.addEventListener?i.addEventListener("DOMContentLoaded",L,!1):i.attachEvent?i.attachEvent("onreadystatechange",Da):(x("onload",!1),M({type:"NO_DOM2_EVENTS",fatal:!0}))}var oa=null;if("undefined"===typeof SM2_DEFER||!SM2_DEFER)oa=new $;Z.SoundManager=$;Z.soundManager=oa})(window);
\ No newline at end of file
diff --git a/timeside/static/timeside/js/libs/soundmanager2-nodebug-jsmin.js b/timeside/static/timeside/js/libs/soundmanager2-nodebug-jsmin.js
deleted file mode 100644 (file)
index ca2fc0e..0000000
+++ /dev/null
@@ -1,80 +0,0 @@
-/** @license\r
- *\r
- * SoundManager 2: JavaScript Sound for the Web\r
- * ----------------------------------------------\r
- * http://schillmania.com/projects/soundmanager2/\r
- *\r
- * Copyright (c) 2007, Scott Schiller. All rights reserved.\r
- * Code provided under the BSD License:\r
- * http://schillmania.com/projects/soundmanager2/license.txt\r
- *\r
- * V2.97a.20120916\r
- */\r
-(function(fa){function R(R,ea){function S(a){return c.preferFlash&&y&&!c.ignoreFlash&&"undefined"!==typeof c.flash[a]&&c.flash[a]}function l(a){return function(c){var d=this._t;return!d||!d._a?null:a.call(this,c)}}this.setupOptions={url:R||null,flashVersion:8,debugMode:!0,debugFlash:!1,useConsole:!0,consoleOnly:!0,waitForWindowLoad:!1,bgColor:"#ffffff",useHighPerformance:!1,flashPollingInterval:null,html5PollingInterval:null,flashLoadTimeout:1E3,wmode:null,allowScriptAccess:"always",useFlashBlock:!1,
-useHTML5Audio:!0,html5Test:/^(probably|maybe)$/i,preferFlash:!0,noSWFCache:!1};this.defaultOptions={autoLoad:!1,autoPlay:!1,from:null,loops:1,onid3:null,onload:null,whileloading:null,onplay:null,onpause:null,onresume:null,whileplaying:null,onposition:null,onstop:null,onfailure:null,onfinish:null,multiShot:!0,multiShotEvents:!1,position:null,pan:0,stream:!0,to:null,type:null,usePolicyFile:!1,volume:100};this.flash9Options={isMovieStar:null,usePeakData:!1,useWaveformData:!1,useEQData:!1,onbufferchange:null,
-ondataerror:null};this.movieStarOptions={bufferTime:3,serverURL:null,onconnect:null,duration:null};this.audioFormats={mp3:{type:['audio/mpeg; codecs="mp3"',"audio/mpeg","audio/mp3","audio/MPA","audio/mpa-robust"],required:!0},mp4:{related:["aac","m4a","m4b"],type:['audio/mp4; codecs="mp4a.40.2"',"audio/aac","audio/x-m4a","audio/MP4A-LATM","audio/mpeg4-generic"],required:!1},ogg:{type:["audio/ogg; codecs=vorbis"],required:!1},wav:{type:['audio/wav; codecs="1"',"audio/wav","audio/wave","audio/x-wav"],
-required:!1}};this.movieID="sm2-container";this.id=ea||"sm2movie";this.debugID="soundmanager-debug";this.debugURLParam=/([#?&])debug=1/i;this.versionNumber="V2.97a.20120916";this.altURL=this.movieURL=this.version=null;this.enabled=this.swfLoaded=!1;this.oMC=null;this.sounds={};this.soundIDs=[];this.didFlashBlock=this.muted=!1;this.filePattern=null;this.filePatterns={flash8:/\.mp3(\?.*)?$/i,flash9:/\.mp3(\?.*)?$/i};this.features={buffering:!1,peakData:!1,waveformData:!1,eqData:!1,movieStar:!1};this.sandbox=
-{};var ga;try{ga="undefined"!==typeof Audio&&"undefined"!==typeof(ha&&10>opera.version()?new Audio(null):new Audio).canPlayType}catch(Za){ga=!1}this.hasHTML5=ga;this.html5={usingFlash:null};this.flash={};this.ignoreFlash=this.html5Only=!1;var Da,c=this,i=null,T,q=navigator.userAgent,h=fa,ia=h.location.href.toString(),m=document,ja,Ea,ka,j,v=[],J=!1,K=!1,k=!1,s=!1,la=!1,L,r,ma,U,na,B,C,D,Fa,oa,V,W,E,pa,M,qa,X,F,Ga,ra,Ha,Y,Ia,N=null,sa=null,t,ta,G,Z,$,H,p,O=!1,ua=!1,Ja,Ka,La,aa=0,P=null,ba,n=null,Ma,
-ca,Q,w,va,wa,Na,o,Wa=Array.prototype.slice,z=!1,y,xa,Oa,u,Pa,ya=q.match(/(ipad|iphone|ipod)/i),x=q.match(/msie/i),Xa=q.match(/webkit/i),za=q.match(/safari/i)&&!q.match(/chrome/i),ha=q.match(/opera/i),Aa=q.match(/(mobile|pre\/|xoom)/i)||ya,Qa=!ia.match(/usehtml5audio/i)&&!ia.match(/sm2\-ignorebadua/i)&&za&&!q.match(/silk/i)&&q.match(/OS X 10_6_([3-7])/i),Ba="undefined"!==typeof m.hasFocus?m.hasFocus():null,da=za&&("undefined"===typeof m.hasFocus||!m.hasFocus()),Ra=!da,Sa=/(mp3|mp4|mpa|m4a|m4b)/i,Ca=
-m.location?m.location.protocol.match(/http/i):null,Ta=!Ca?"http://":"",Ua=/^\s*audio\/(?:x-)?(?:mpeg4|aac|flv|mov|mp4||m4v|m4a|m4b|mp4v|3gp|3g2)\s*(?:$|;)/i,Va="mpeg4,aac,flv,mov,mp4,m4v,f4v,m4a,m4b,mp4v,3gp,3g2".split(","),Ya=RegExp("\\.("+Va.join("|")+")(\\?.*)?$","i");this.mimePattern=/^\s*audio\/(?:x-)?(?:mp(?:eg|3))\s*(?:$|;)/i;this.useAltURL=!Ca;this._global_a=null;if(Aa&&(c.useHTML5Audio=!0,c.preferFlash=!1,ya))z=c.ignoreFlash=!0;this.setup=function(a){var e=!c.url;"undefined"!==typeof a&&
-k&&n&&c.ok()&&("undefined"!==typeof a.flashVersion||"undefined"!==typeof a.url)&&H(t("setupLate"));ma(a);e&&M&&"undefined"!==typeof a.url&&c.beginDelayedInit();!M&&"undefined"!==typeof a.url&&"complete"===m.readyState&&setTimeout(E,1);return c};this.supported=this.ok=function(){return n?k&&!s:c.useHTML5Audio&&c.hasHTML5};this.getMovie=function(a){return T(a)||m[a]||h[a]};this.createSound=function(a,e){function d(){b=Z(b);c.sounds[f.id]=new Da(f);c.soundIDs.push(f.id);return c.sounds[f.id]}var b=null,
-g=null,f=null;if(!k||!c.ok())return H(void 0),!1;"undefined"!==typeof e&&(a={id:a,url:e});b=r(a);b.url=ba(b.url);f=b;if(p(f.id,!0))return c.sounds[f.id];if(ca(f))g=d(),g._setup_html5(f);else{if(8<j&&null===f.isMovieStar)f.isMovieStar=!(!f.serverURL&&!(f.type&&f.type.match(Ua)||f.url.match(Ya)));f=$(f,void 0);g=d();if(8===j)i._createSound(f.id,f.loops||1,f.usePolicyFile);else if(i._createSound(f.id,f.url,f.usePeakData,f.useWaveformData,f.useEQData,f.isMovieStar,f.isMovieStar?f.bufferTime:!1,f.loops||
-1,f.serverURL,f.duration||null,f.autoPlay,!0,f.autoLoad,f.usePolicyFile),!f.serverURL)g.connected=!0,f.onconnect&&f.onconnect.apply(g);!f.serverURL&&(f.autoLoad||f.autoPlay)&&g.load(f)}!f.serverURL&&f.autoPlay&&g.play();return g};this.destroySound=function(a,e){if(!p(a))return!1;var d=c.sounds[a],b;d._iO={};d.stop();d.unload();for(b=0;b<c.soundIDs.length;b++)if(c.soundIDs[b]===a){c.soundIDs.splice(b,1);break}e||d.destruct(!0);delete c.sounds[a];return!0};this.load=function(a,e){return!p(a)?!1:c.sounds[a].load(e)};
-this.unload=function(a){return!p(a)?!1:c.sounds[a].unload()};this.onposition=this.onPosition=function(a,e,d,b){return!p(a)?!1:c.sounds[a].onposition(e,d,b)};this.clearOnPosition=function(a,e,d){return!p(a)?!1:c.sounds[a].clearOnPosition(e,d)};this.start=this.play=function(a,e){var d=!1;if(!k||!c.ok())return H("soundManager.play(): "+t(!k?"notReady":"notOK")),d;if(!p(a)){e instanceof Object||(e={url:e});if(e&&e.url)e.id=a,d=c.createSound(e).play();return d}return c.sounds[a].play(e)};this.setPosition=
-function(a,e){return!p(a)?!1:c.sounds[a].setPosition(e)};this.stop=function(a){return!p(a)?!1:c.sounds[a].stop()};this.stopAll=function(){for(var a in c.sounds)c.sounds.hasOwnProperty(a)&&c.sounds[a].stop()};this.pause=function(a){return!p(a)?!1:c.sounds[a].pause()};this.pauseAll=function(){var a;for(a=c.soundIDs.length-1;0<=a;a--)c.sounds[c.soundIDs[a]].pause()};this.resume=function(a){return!p(a)?!1:c.sounds[a].resume()};this.resumeAll=function(){var a;for(a=c.soundIDs.length-1;0<=a;a--)c.sounds[c.soundIDs[a]].resume()};
-this.togglePause=function(a){return!p(a)?!1:c.sounds[a].togglePause()};this.setPan=function(a,e){return!p(a)?!1:c.sounds[a].setPan(e)};this.setVolume=function(a,e){return!p(a)?!1:c.sounds[a].setVolume(e)};this.mute=function(a){var e=0;"string"!==typeof a&&(a=null);if(a)return!p(a)?!1:c.sounds[a].mute();for(e=c.soundIDs.length-1;0<=e;e--)c.sounds[c.soundIDs[e]].mute();return c.muted=!0};this.muteAll=function(){c.mute()};this.unmute=function(a){"string"!==typeof a&&(a=null);if(a)return!p(a)?!1:c.sounds[a].unmute();
-for(a=c.soundIDs.length-1;0<=a;a--)c.sounds[c.soundIDs[a]].unmute();c.muted=!1;return!0};this.unmuteAll=function(){c.unmute()};this.toggleMute=function(a){return!p(a)?!1:c.sounds[a].toggleMute()};this.getMemoryUse=function(){var a=0;i&&8!==j&&(a=parseInt(i._getMemoryUse(),10));return a};this.disable=function(a){var e;"undefined"===typeof a&&(a=!1);if(s)return!1;s=!0;for(e=c.soundIDs.length-1;0<=e;e--)Ha(c.sounds[c.soundIDs[e]]);L(a);o.remove(h,"load",C);return!0};this.canPlayMIME=function(a){var e;
-c.hasHTML5&&(e=Q({type:a}));!e&&n&&(e=a&&c.ok()?!!(8<j&&a.match(Ua)||a.match(c.mimePattern)):null);return e};this.canPlayURL=function(a){var e;c.hasHTML5&&(e=Q({url:a}));!e&&n&&(e=a&&c.ok()?!!a.match(c.filePattern):null);return e};this.canPlayLink=function(a){return"undefined"!==typeof a.type&&a.type&&c.canPlayMIME(a.type)?!0:c.canPlayURL(a.href)};this.getSoundById=function(a){if(!a)throw Error("soundManager.getSoundById(): sID is null/undefined");return c.sounds[a]};this.onready=function(a,c){var d=
-!1;if("function"===typeof a)c||(c=h),na("onready",a,c),B();else throw t("needFunction","onready");return!0};this.ontimeout=function(a,c){var d=!1;if("function"===typeof a)c||(c=h),na("ontimeout",a,c),B({type:"ontimeout"});else throw t("needFunction","ontimeout");return!0};this._wD=this._writeDebug=function(){return!0};this._debug=function(){};this.reboot=function(){var a,e;for(a=c.soundIDs.length-1;0<=a;a--)c.sounds[c.soundIDs[a]].destruct();if(i)try{if(x)sa=i.innerHTML;N=i.parentNode.removeChild(i)}catch(d){}sa=
-N=n=null;c.enabled=M=k=O=ua=J=K=s=c.swfLoaded=!1;c.soundIDs=[];c.sounds={};i=null;for(a in v)if(v.hasOwnProperty(a))for(e=v[a].length-1;0<=e;e--)v[a][e].fired=!1;h.setTimeout(c.beginDelayedInit,20)};this.getMoviePercent=function(){return i&&"undefined"!==typeof i.PercentLoaded?i.PercentLoaded():null};this.beginDelayedInit=function(){la=!0;E();setTimeout(function(){if(ua)return!1;X();W();return ua=!0},20);D()};this.destruct=function(){c.disable(!0)};Da=function(a){var e,d,b=this,g,f,A,I,h,m,l=!1,k=
-[],o=0,q,s,n=null;e=null;d=null;this.sID=this.id=a.id;this.url=a.url;this._iO=this.instanceOptions=this.options=r(a);this.pan=this.options.pan;this.volume=this.options.volume;this.isHTML5=!1;this._a=null;this.id3={};this._debug=function(){};this.load=function(a){var c=null;if("undefined"!==typeof a)b._iO=r(a,b.options),b.instanceOptions=b._iO;else if(a=b.options,b._iO=a,b.instanceOptions=b._iO,n&&n!==b.url)b._iO.url=b.url,b.url=null;if(!b._iO.url)b._iO.url=b.url;b._iO.url=ba(b._iO.url);if(b._iO.url===
-b.url&&0!==b.readyState&&2!==b.readyState)return 3===b.readyState&&b._iO.onload&&b._iO.onload.apply(b,[!!b.duration]),b;a=b._iO;n=b.url&&b.url.toString?b.url.toString():null;b.loaded=!1;b.readyState=1;b.playState=0;b.id3={};if(ca(a)){if(c=b._setup_html5(a),!c._called_load){b._html5_canplay=!1;if(b._a.src!==a.url)b._a.src=a.url,b.setPosition(0);b._a.autobuffer="auto";b._a.preload="auto";c._called_load=!0;a.autoPlay&&b.play()}}else try{b.isHTML5=!1,b._iO=$(Z(a)),a=b._iO,8===j?i._load(b.id,a.url,a.stream,
-a.autoPlay,a.whileloading?1:0,a.loops||1,a.usePolicyFile):i._load(b.id,a.url,!!a.stream,!!a.autoPlay,a.loops||1,!!a.autoLoad,a.usePolicyFile)}catch(e){F({type:"SMSOUND_LOAD_JS_EXCEPTION",fatal:!0})}b.url=a.url;return b};this.unload=function(){if(0!==b.readyState){if(b.isHTML5){if(I(),b._a)b._a.pause(),va(b._a,"about:blank"),b.url="about:blank"}else 8===j?i._unload(b.id,"about:blank"):i._unload(b.id);g()}return b};this.destruct=function(a){if(b.isHTML5){if(I(),b._a)b._a.pause(),va(b._a),z||A(),b._a._t=
-null,b._a=null}else b._iO.onfailure=null,i._destroySound(b.id);a||c.destroySound(b.id,!0)};this.start=this.play=function(a,c){var e,d;d=!0;d=null;c="undefined"===typeof c?!0:c;a||(a={});if(b.url)b._iO.url=b.url;b._iO=r(b._iO,b.options);b._iO=r(a,b._iO);b._iO.url=ba(b._iO.url);b.instanceOptions=b._iO;if(b._iO.serverURL&&!b.connected)return b.getAutoPlay()||b.setAutoPlay(!0),b;ca(b._iO)&&(b._setup_html5(b._iO),h());if(1===b.playState&&!b.paused)(e=b._iO.multiShot)||(d=b);if(null!==d)return d;a.url&&
-a.url!==b.url&&b.load(b._iO);if(!b.loaded)if(0===b.readyState){if(!b.isHTML5)b._iO.autoPlay=!0;b.load(b._iO)}else 2===b.readyState&&(d=b);if(null!==d)return d;if(!b.isHTML5&&9===j&&0<b.position&&b.position===b.duration)a.position=0;if(b.paused&&0<=b.position&&(!b._iO.serverURL||0<b.position))b.resume();else{b._iO=r(a,b._iO);if(null!==b._iO.from&&null!==b._iO.to&&0===b.instanceCount&&0===b.playState&&!b._iO.serverURL){e=function(){b._iO=r(a,b._iO);b.play(b._iO)};if(b.isHTML5&&!b._html5_canplay)b.load({_oncanplay:e}),
-d=!1;else if(!b.isHTML5&&!b.loaded&&(!b.readyState||2!==b.readyState))b.load({onload:e}),d=!1;if(null!==d)return d;b._iO=s()}(!b.instanceCount||b._iO.multiShotEvents||!b.isHTML5&&8<j&&!b.getAutoPlay())&&b.instanceCount++;b._iO.onposition&&0===b.playState&&m(b);b.playState=1;b.paused=!1;b.position="undefined"!==typeof b._iO.position&&!isNaN(b._iO.position)?b._iO.position:0;if(!b.isHTML5)b._iO=$(Z(b._iO));b._iO.onplay&&c&&(b._iO.onplay.apply(b),l=!0);b.setVolume(b._iO.volume,!0);b.setPan(b._iO.pan,
-!0);b.isHTML5?(h(),d=b._setup_html5(),b.setPosition(b._iO.position),d.play()):(d=i._start(b.id,b._iO.loops||1,9===j?b._iO.position:b._iO.position/1E3,b._iO.multiShot),9===j&&!d&&b._iO.onplayerror&&b._iO.onplayerror.apply(b))}return b};this.stop=function(a){var c=b._iO;if(1===b.playState){b._onbufferchange(0);b._resetOnPosition(0);b.paused=!1;if(!b.isHTML5)b.playState=0;q();c.to&&b.clearOnPosition(c.to);if(b.isHTML5){if(b._a)a=b.position,b.setPosition(0),b.position=a,b._a.pause(),b.playState=0,b._onTimer(),
-I()}else i._stop(b.id,a),c.serverURL&&b.unload();b.instanceCount=0;b._iO={};c.onstop&&c.onstop.apply(b)}return b};this.setAutoPlay=function(a){b._iO.autoPlay=a;b.isHTML5||(i._setAutoPlay(b.id,a),a&&!b.instanceCount&&1===b.readyState&&b.instanceCount++)};this.getAutoPlay=function(){return b._iO.autoPlay};this.setPosition=function(a){"undefined"===typeof a&&(a=0);var c=b.isHTML5?Math.max(a,0):Math.min(b.duration||b._iO.duration,Math.max(a,0));b.position=c;a=b.position/1E3;b._resetOnPosition(b.position);
-b._iO.position=c;if(b.isHTML5){if(b._a&&b._html5_canplay&&b._a.currentTime!==a)try{b._a.currentTime=a,(0===b.playState||b.paused)&&b._a.pause()}catch(e){}}else a=9===j?b.position:a,b.readyState&&2!==b.readyState&&i._setPosition(b.id,a,b.paused||!b.playState,b._iO.multiShot);b.isHTML5&&b.paused&&b._onTimer(!0);return b};this.pause=function(a){if(b.paused||0===b.playState&&1!==b.readyState)return b;b.paused=!0;b.isHTML5?(b._setup_html5().pause(),I()):(a||"undefined"===typeof a)&&i._pause(b.id,b._iO.multiShot);
-b._iO.onpause&&b._iO.onpause.apply(b);return b};this.resume=function(){var a=b._iO;if(!b.paused)return b;b.paused=!1;b.playState=1;b.isHTML5?(b._setup_html5().play(),h()):(a.isMovieStar&&!a.serverURL&&b.setPosition(b.position),i._pause(b.id,a.multiShot));!l&&a.onplay?(a.onplay.apply(b),l=!0):a.onresume&&a.onresume.apply(b);return b};this.togglePause=function(){if(0===b.playState)return b.play({position:9===j&&!b.isHTML5?b.position:b.position/1E3}),b;b.paused?b.resume():b.pause();return b};this.setPan=
-function(a,c){"undefined"===typeof a&&(a=0);"undefined"===typeof c&&(c=!1);b.isHTML5||i._setPan(b.id,a);b._iO.pan=a;if(!c)b.pan=a,b.options.pan=a;return b};this.setVolume=function(a,e){"undefined"===typeof a&&(a=100);"undefined"===typeof e&&(e=!1);if(b.isHTML5){if(b._a)b._a.volume=Math.max(0,Math.min(1,a/100))}else i._setVolume(b.id,c.muted&&!b.muted||b.muted?0:a);b._iO.volume=a;if(!e)b.volume=a,b.options.volume=a;return b};this.mute=function(){b.muted=!0;if(b.isHTML5){if(b._a)b._a.muted=!0}else i._setVolume(b.id,
-0);return b};this.unmute=function(){b.muted=!1;var a="undefined"!==typeof b._iO.volume;if(b.isHTML5){if(b._a)b._a.muted=!1}else i._setVolume(b.id,a?b._iO.volume:b.options.volume);return b};this.toggleMute=function(){return b.muted?b.unmute():b.mute()};this.onposition=this.onPosition=function(a,c,e){k.push({position:parseInt(a,10),method:c,scope:"undefined"!==typeof e?e:b,fired:!1});return b};this.clearOnPosition=function(b,a){var c,b=parseInt(b,10);if(isNaN(b))return!1;for(c=0;c<k.length;c++)if(b===
-k[c].position&&(!a||a===k[c].method))k[c].fired&&o--,k.splice(c,1)};this._processOnPosition=function(){var a,c;a=k.length;if(!a||!b.playState||o>=a)return!1;for(a-=1;0<=a;a--)if(c=k[a],!c.fired&&b.position>=c.position)c.fired=!0,o++,c.method.apply(c.scope,[c.position]);return!0};this._resetOnPosition=function(b){var a,c;a=k.length;if(!a)return!1;for(a-=1;0<=a;a--)if(c=k[a],c.fired&&b<=c.position)c.fired=!1,o--;return!0};s=function(){var a=b._iO,c=a.from,e=a.to,d,f;f=function(){b.clearOnPosition(e,
-f);b.stop()};d=function(){if(null!==e&&!isNaN(e))b.onPosition(e,f)};if(null!==c&&!isNaN(c))a.position=c,a.multiShot=!1,d();return a};m=function(){var a,c=b._iO.onposition;if(c)for(a in c)if(c.hasOwnProperty(a))b.onPosition(parseInt(a,10),c[a])};q=function(){var a,c=b._iO.onposition;if(c)for(a in c)c.hasOwnProperty(a)&&b.clearOnPosition(parseInt(a,10))};h=function(){b.isHTML5&&Ja(b)};I=function(){b.isHTML5&&Ka(b)};g=function(a){a||(k=[],o=0);l=!1;b._hasTimer=null;b._a=null;b._html5_canplay=!1;b.bytesLoaded=
-null;b.bytesTotal=null;b.duration=b._iO&&b._iO.duration?b._iO.duration:null;b.durationEstimate=null;b.buffered=[];b.eqData=[];b.eqData.left=[];b.eqData.right=[];b.failures=0;b.isBuffering=!1;b.instanceOptions={};b.instanceCount=0;b.loaded=!1;b.metadata={};b.readyState=0;b.muted=!1;b.paused=!1;b.peakData={left:0,right:0};b.waveformData={left:[],right:[]};b.playState=0;b.position=null;b.id3={}};g();this._onTimer=function(a){var c,f=!1,g={};if(b._hasTimer||a){if(b._a&&(a||(0<b.playState||1===b.readyState)&&
-!b.paused)){c=b._get_html5_duration();if(c!==e)e=c,b.duration=c,f=!0;b.durationEstimate=b.duration;c=1E3*b._a.currentTime||0;c!==d&&(d=c,f=!0);(f||a)&&b._whileplaying(c,g,g,g,g)}return f}};this._get_html5_duration=function(){var a=b._iO;return(a=b._a&&b._a.duration?1E3*b._a.duration:a&&a.duration?a.duration:null)&&!isNaN(a)&&Infinity!==a?a:null};this._apply_loop=function(b,a){b.loop=1<a?"loop":""};this._setup_html5=function(a){var a=r(b._iO,a),e=decodeURI,d=z?c._global_a:b._a,i=e(a.url),h=d&&d._t?
-d._t.instanceOptions:null,A;if(d){if(d._t){if(!z&&i===e(n))A=d;else if(z&&h.url===a.url&&(!n||n===h.url))A=d;if(A)return b._apply_loop(d,a.loops),A}z&&d._t&&d._t.playState&&a.url!==h.url&&d._t.stop();g(h&&h.url?a.url===h.url:n?n===a.url:!1);d.src=a.url;n=b.url=a.url;d._called_load=!1}else if(b._a=a.autoLoad||a.autoPlay?new Audio(a.url):ha&&10>opera.version()?new Audio(null):new Audio,d=b._a,d._called_load=!1,z)c._global_a=d;b.isHTML5=!0;b._a=d;d._t=b;f();b._apply_loop(d,a.loops);a.autoLoad||a.autoPlay?
-b.load():(d.autobuffer=!1,d.preload="auto");return d};f=function(){if(b._a._added_events)return!1;var a;b._a._added_events=!0;for(a in u)u.hasOwnProperty(a)&&b._a&&b._a.addEventListener(a,u[a],!1);return!0};A=function(){var a;b._a._added_events=!1;for(a in u)u.hasOwnProperty(a)&&b._a&&b._a.removeEventListener(a,u[a],!1)};this._onload=function(a){a=!!a||!b.isHTML5&&8===j&&b.duration;b.loaded=a;b.readyState=a?3:2;b._onbufferchange(0);b._iO.onload&&b._iO.onload.apply(b,[a]);return!0};this._onbufferchange=
-function(a){if(0===b.playState||a&&b.isBuffering||!a&&!b.isBuffering)return!1;b.isBuffering=1===a;b._iO.onbufferchange&&b._iO.onbufferchange.apply(b);return!0};this._onsuspend=function(){b._iO.onsuspend&&b._iO.onsuspend.apply(b);return!0};this._onfailure=function(a,c,e){b.failures++;if(b._iO.onfailure&&1===b.failures)b._iO.onfailure(b,a,c,e)};this._onfinish=function(){var a=b._iO.onfinish;b._onbufferchange(0);b._resetOnPosition(0);if(b.instanceCount){b.instanceCount--;if(!b.instanceCount&&(q(),b.playState=
-0,b.paused=!1,b.instanceCount=0,b.instanceOptions={},b._iO={},I(),b.isHTML5))b.position=0;(!b.instanceCount||b._iO.multiShotEvents)&&a&&a.apply(b)}};this._whileloading=function(a,c,e,d){var f=b._iO;b.bytesLoaded=a;b.bytesTotal=c;b.duration=Math.floor(e);b.bufferLength=d;b.durationEstimate=!b.isHTML5&&!f.isMovieStar?f.duration?b.duration>f.duration?b.duration:f.duration:parseInt(b.bytesTotal/b.bytesLoaded*b.duration,10):b.duration;if(!b.isHTML5)b.buffered=[{start:0,end:b.duration}];(3!==b.readyState||
-b.isHTML5)&&f.whileloading&&f.whileloading.apply(b)};this._whileplaying=function(a,c,e,d,f){var g=b._iO;if(isNaN(a)||null===a)return!1;b.position=Math.max(0,a);b._processOnPosition();if(!b.isHTML5&&8<j){if(g.usePeakData&&"undefined"!==typeof c&&c)b.peakData={left:c.leftPeak,right:c.rightPeak};if(g.useWaveformData&&"undefined"!==typeof e&&e)b.waveformData={left:e.split(","),right:d.split(",")};if(g.useEQData&&"undefined"!==typeof f&&f&&f.leftEQ&&(a=f.leftEQ.split(","),b.eqData=a,b.eqData.left=a,"undefined"!==
-typeof f.rightEQ&&f.rightEQ))b.eqData.right=f.rightEQ.split(",")}1===b.playState&&(!b.isHTML5&&8===j&&!b.position&&b.isBuffering&&b._onbufferchange(0),g.whileplaying&&g.whileplaying.apply(b));return!0};this._oncaptiondata=function(a){b.captiondata=a;b._iO.oncaptiondata&&b._iO.oncaptiondata.apply(b,[a])};this._onmetadata=function(a,c){var e={},d,f;for(d=0,f=a.length;d<f;d++)e[a[d]]=c[d];b.metadata=e;b._iO.onmetadata&&b._iO.onmetadata.apply(b)};this._onid3=function(a,c){var e=[],d,f;for(d=0,f=a.length;d<
-f;d++)e[a[d]]=c[d];b.id3=r(b.id3,e);b._iO.onid3&&b._iO.onid3.apply(b)};this._onconnect=function(a){a=1===a;if(b.connected=a)b.failures=0,p(b.id)&&(b.getAutoPlay()?b.play(void 0,b.getAutoPlay()):b._iO.autoLoad&&b.load()),b._iO.onconnect&&b._iO.onconnect.apply(b,[a])};this._ondataerror=function(){0<b.playState&&b._iO.ondataerror&&b._iO.ondataerror.apply(b)}};qa=function(){return m.body||m._docElement||m.getElementsByTagName("div")[0]};T=function(a){return m.getElementById(a)};r=function(a,e){var d=
-a||{},b,g;b="undefined"===typeof e?c.defaultOptions:e;for(g in b)b.hasOwnProperty(g)&&"undefined"===typeof d[g]&&(d[g]="object"!==typeof b[g]||null===b[g]?b[g]:r(d[g],b[g]));return d};U={onready:1,ontimeout:1,defaultOptions:1,flash9Options:1,movieStarOptions:1};ma=function(a,e){var d,b=!0,g="undefined"!==typeof e,f=c.setupOptions;for(d in a)if(a.hasOwnProperty(d))if("object"!==typeof a[d]||null===a[d]||a[d]instanceof Array)g&&"undefined"!==typeof U[e]?c[e][d]=a[d]:"undefined"!==typeof f[d]?(c.setupOptions[d]=
-a[d],c[d]=a[d]):"undefined"===typeof U[d]?(H(t("undefined"===typeof c[d]?"setupUndef":"setupError",d),2),b=!1):c[d]instanceof Function?c[d].apply(c,a[d]instanceof Array?a[d]:[a[d]]):c[d]=a[d];else if("undefined"===typeof U[d])H(t("undefined"===typeof c[d]?"setupUndef":"setupError",d),2),b=!1;else return ma(a[d],d);return b};o=function(){function a(a){var a=Wa.call(a),b=a.length;d?(a[1]="on"+a[1],3<b&&a.pop()):3===b&&a.push(!1);return a}function c(a,e){var h=a.shift(),i=[b[e]];if(d)h[i](a[0],a[1]);
-else h[i].apply(h,a)}var d=h.attachEvent,b={add:d?"attachEvent":"addEventListener",remove:d?"detachEvent":"removeEventListener"};return{add:function(){c(a(arguments),"add")},remove:function(){c(a(arguments),"remove")}}}();u={abort:l(function(){}),canplay:l(function(){var a=this._t,c;if(a._html5_canplay)return!0;a._html5_canplay=!0;a._onbufferchange(0);c="undefined"!==typeof a._iO.position&&!isNaN(a._iO.position)?a._iO.position/1E3:null;if(a.position&&this.currentTime!==c)try{this.currentTime=c}catch(d){}a._iO._oncanplay&&
-a._iO._oncanplay()}),canplaythrough:l(function(){var a=this._t;a.loaded||(a._onbufferchange(0),a._whileloading(a.bytesLoaded,a.bytesTotal,a._get_html5_duration()),a._onload(!0))}),ended:l(function(){this._t._onfinish()}),error:l(function(){this._t._onload(!1)}),loadeddata:l(function(){var a=this._t;if(!a._loaded&&!za)a.duration=a._get_html5_duration()}),loadedmetadata:l(function(){}),loadstart:l(function(){this._t._onbufferchange(1)}),play:l(function(){this._t._onbufferchange(0)}),playing:l(function(){this._t._onbufferchange(0)}),
-progress:l(function(a){var c=this._t,d,b,g=0,g=a.target.buffered;d=a.loaded||0;var f=a.total||1;c.buffered=[];if(g&&g.length){for(d=0,b=g.length;d<b;d++)c.buffered.push({start:1E3*g.start(d),end:1E3*g.end(d)});g=1E3*(g.end(0)-g.start(0));d=g/(1E3*a.target.duration)}isNaN(d)||(c._onbufferchange(0),c._whileloading(d,f,c._get_html5_duration()),d&&f&&d===f&&u.canplaythrough.call(this,a))}),ratechange:l(function(){}),suspend:l(function(a){var c=this._t;u.progress.call(this,a);c._onsuspend()}),stalled:l(function(){}),
-timeupdate:l(function(){this._t._onTimer()}),waiting:l(function(){this._t._onbufferchange(1)})};ca=function(a){return a.serverURL||a.type&&S(a.type)?!1:a.type?Q({type:a.type}):Q({url:a.url})||c.html5Only};va=function(a,c){if(a)a.src=c};Q=function(a){if(!c.useHTML5Audio||!c.hasHTML5)return!1;var e=a.url||null,a=a.type||null,d=c.audioFormats,b;if(a&&"undefined"!==typeof c.html5[a])return c.html5[a]&&!S(a);if(!w){w=[];for(b in d)d.hasOwnProperty(b)&&(w.push(b),d[b].related&&(w=w.concat(d[b].related)));
-w=RegExp("\\.("+w.join("|")+")(\\?.*)?$","i")}b=e?e.toLowerCase().match(w):null;!b||!b.length?a&&(e=a.indexOf(";"),b=(-1!==e?a.substr(0,e):a).substr(6)):b=b[1];b&&"undefined"!==typeof c.html5[b]?e=c.html5[b]&&!S(b):(a="audio/"+b,e=c.html5.canPlayType({type:a}),e=(c.html5[b]=e)&&c.html5[a]&&!S(a));return e};Na=function(){function a(a){var b,d,f=b=!1;if(!e||"function"!==typeof e.canPlayType)return b;if(a instanceof Array){for(b=0,d=a.length;b<d;b++)if(c.html5[a[b]]||e.canPlayType(a[b]).match(c.html5Test))f=
-!0,c.html5[a[b]]=!0,c.flash[a[b]]=!!a[b].match(Sa);b=f}else a=e&&"function"===typeof e.canPlayType?e.canPlayType(a):!1,b=!(!a||!a.match(c.html5Test));return b}if(!c.useHTML5Audio||!c.hasHTML5)return!1;var e="undefined"!==typeof Audio?ha&&10>opera.version()?new Audio(null):new Audio:null,d,b,g={},f;f=c.audioFormats;for(d in f)if(f.hasOwnProperty(d)&&(b="audio/"+d,g[d]=a(f[d].type),g[b]=g[d],d.match(Sa)?(c.flash[d]=!0,c.flash[b]=!0):(c.flash[d]=!1,c.flash[b]=!1),f[d]&&f[d].related))for(b=f[d].related.length-
-1;0<=b;b--)g["audio/"+f[d].related[b]]=g[d],c.html5[f[d].related[b]]=g[d],c.flash[f[d].related[b]]=g[d];g.canPlayType=e?a:null;c.html5=r(c.html5,g);return!0};t=function(){};Z=function(a){if(8===j&&1<a.loops&&a.stream)a.stream=!1;return a};$=function(a){if(a&&!a.usePolicyFile&&(a.onid3||a.usePeakData||a.useWaveformData||a.useEQData))a.usePolicyFile=!0;return a};H=function(){};ja=function(){return!1};Ha=function(a){for(var c in a)a.hasOwnProperty(c)&&"function"===typeof a[c]&&(a[c]=ja)};Y=function(a){"undefined"===
-typeof a&&(a=!1);(s||a)&&c.disable(a)};Ia=function(a){var e=null;if(a)if(a.match(/\.swf(\?.*)?$/i)){if(e=a.substr(a.toLowerCase().lastIndexOf(".swf?")+4))return a}else a.lastIndexOf("/")!==a.length-1&&(a+="/");a=(a&&-1!==a.lastIndexOf("/")?a.substr(0,a.lastIndexOf("/")+1):"./")+c.movieURL;c.noSWFCache&&(a+="?ts="+(new Date).getTime());return a};oa=function(){j=parseInt(c.flashVersion,10);if(8!==j&&9!==j)c.flashVersion=j=8;var a=c.debugMode||c.debugFlash?"_debug.swf":".swf";if(c.useHTML5Audio&&!c.html5Only&&
-c.audioFormats.mp4.required&&9>j)c.flashVersion=j=9;c.version=c.versionNumber+(c.html5Only?" (HTML5-only mode)":9===j?" (AS3/Flash 9)":" (AS2/Flash 8)");8<j?(c.defaultOptions=r(c.defaultOptions,c.flash9Options),c.features.buffering=!0,c.defaultOptions=r(c.defaultOptions,c.movieStarOptions),c.filePatterns.flash9=RegExp("\\.(mp3|"+Va.join("|")+")(\\?.*)?$","i"),c.features.movieStar=!0):c.features.movieStar=!1;c.filePattern=c.filePatterns[8!==j?"flash9":"flash8"];c.movieURL=(8===j?"soundmanager2.swf":
-"soundmanager2_flash9.swf").replace(".swf",a);c.features.peakData=c.features.waveformData=c.features.eqData=8<j};Ga=function(a,c){if(!i)return!1;i._setPolling(a,c)};ra=function(){if(c.debugURLParam.test(ia))c.debugMode=!0};p=this.getSoundById;G=function(){var a=[];c.debugMode&&a.push("sm2_debug");c.debugFlash&&a.push("flash_debug");c.useHighPerformance&&a.push("high_performance");return a.join(" ")};ta=function(){t("fbHandler");var a=c.getMoviePercent(),e={type:"FLASHBLOCK"};if(c.html5Only)return!1;
-if(c.ok()){if(c.oMC)c.oMC.className=[G(),"movieContainer","swf_loaded"+(c.didFlashBlock?" swf_unblocked":"")].join(" ")}else{if(n)c.oMC.className=G()+" movieContainer "+(null===a?"swf_timedout":"swf_error");c.didFlashBlock=!0;B({type:"ontimeout",ignoreInit:!0,error:e});F(e)}};na=function(a,c,d){"undefined"===typeof v[a]&&(v[a]=[]);v[a].push({method:c,scope:d||null,fired:!1})};B=function(a){a||(a={type:c.ok()?"onready":"ontimeout"});if(!k&&a&&!a.ignoreInit||"ontimeout"===a.type&&(c.ok()||s&&!a.ignoreInit))return!1;
-var e={success:a&&a.ignoreInit?c.ok():!s},d=a&&a.type?v[a.type]||[]:[],b=[],g,e=[e],f=n&&c.useFlashBlock&&!c.ok();if(a.error)e[0].error=a.error;for(a=0,g=d.length;a<g;a++)!0!==d[a].fired&&b.push(d[a]);if(b.length)for(a=0,g=b.length;a<g;a++)if(b[a].scope?b[a].method.apply(b[a].scope,e):b[a].method.apply(this,e),!f)b[a].fired=!0;return!0};C=function(){h.setTimeout(function(){c.useFlashBlock&&ta();B();"function"===typeof c.onload&&c.onload.apply(h);c.waitForWindowLoad&&o.add(h,"load",C)},1)};xa=function(){if("undefined"!==
-typeof y)return y;var a=!1,c=navigator,d=c.plugins,b,g=h.ActiveXObject;if(d&&d.length)(c=c.mimeTypes)&&c["application/x-shockwave-flash"]&&c["application/x-shockwave-flash"].enabledPlugin&&c["application/x-shockwave-flash"].enabledPlugin.description&&(a=!0);else if("undefined"!==typeof g){try{b=new g("ShockwaveFlash.ShockwaveFlash")}catch(f){}a=!!b}return y=a};Ma=function(){var a,e,d=c.audioFormats;if(ya&&q.match(/os (1|2|3_0|3_1)/i)){if(c.hasHTML5=!1,c.html5Only=!0,c.oMC)c.oMC.style.display="none"}else if(c.useHTML5Audio&&
-(!c.html5||!c.html5.canPlayType))c.hasHTML5=!1;if(c.useHTML5Audio&&c.hasHTML5)for(e in d)if(d.hasOwnProperty(e)&&(d[e].required&&!c.html5.canPlayType(d[e].type)||c.preferFlash&&(c.flash[e]||c.flash[d[e].type])))a=!0;c.ignoreFlash&&(a=!1);c.html5Only=c.hasHTML5&&c.useHTML5Audio&&!a;return!c.html5Only};ba=function(a){var e,d,b=0;if(a instanceof Array){for(e=0,d=a.length;e<d;e++)if(a[e]instanceof Object){if(c.canPlayMIME(a[e].type)){b=e;break}}else if(c.canPlayURL(a[e])){b=e;break}if(a[b].url)a[b]=a[b].url;
-a=a[b]}return a};Ja=function(a){if(!a._hasTimer)a._hasTimer=!0,!Aa&&c.html5PollingInterval&&(null===P&&0===aa&&(P=h.setInterval(La,c.html5PollingInterval)),aa++)};Ka=function(a){if(a._hasTimer)a._hasTimer=!1,!Aa&&c.html5PollingInterval&&aa--};La=function(){var a;if(null!==P&&!aa)return h.clearInterval(P),P=null,!1;for(a=c.soundIDs.length-1;0<=a;a--)c.sounds[c.soundIDs[a]].isHTML5&&c.sounds[c.soundIDs[a]]._hasTimer&&c.sounds[c.soundIDs[a]]._onTimer()};F=function(a){a="undefined"!==typeof a?a:{};"function"===
-typeof c.onerror&&c.onerror.apply(h,[{type:"undefined"!==typeof a.type?a.type:null}]);"undefined"!==typeof a.fatal&&a.fatal&&c.disable()};Oa=function(){if(!Qa||!xa())return!1;var a=c.audioFormats,e,d;for(d in a)if(a.hasOwnProperty(d)&&("mp3"===d||"mp4"===d))if(c.html5[d]=!1,a[d]&&a[d].related)for(e=a[d].related.length-1;0<=e;e--)c.html5[a[d].related[e]]=!1};this._setSandboxType=function(){};this._externalInterfaceOK=function(){if(c.swfLoaded)return!1;(new Date).getTime();c.swfLoaded=!0;da=!1;Qa&&
-Oa();setTimeout(ka,x?100:1)};X=function(a,e){function d(a,b){return'<param name="'+a+'" value="'+b+'" />'}if(J&&K)return!1;if(c.html5Only)return oa(),c.oMC=T(c.movieID),ka(),K=J=!0,!1;var b=e||c.url,g=c.altURL||b,f=qa(),h=G(),i=null,i=m.getElementsByTagName("html")[0],j,k,l,i=i&&i.dir&&i.dir.match(/rtl/i),a="undefined"===typeof a?c.id:a;oa();c.url=Ia(Ca?b:g);e=c.url;c.wmode=!c.wmode&&c.useHighPerformance?"transparent":c.wmode;if(null!==c.wmode&&(q.match(/msie 8/i)||!x&&!c.useHighPerformance)&&navigator.platform.match(/win32|win64/i))c.wmode=
-null;f={name:a,id:a,src:e,quality:"high",allowScriptAccess:c.allowScriptAccess,bgcolor:c.bgColor,pluginspage:Ta+"www.macromedia.com/go/getflashplayer",title:"JS/Flash audio component (SoundManager 2)",type:"application/x-shockwave-flash",wmode:c.wmode,hasPriority:"true"};if(c.debugFlash)f.FlashVars="debug=1";c.wmode||delete f.wmode;if(x)b=m.createElement("div"),k=['<object id="'+a+'" data="'+e+'" type="'+f.type+'" title="'+f.title+'" classid="clsid:D27CDB6E-AE6D-11cf-96B8-444553540000" codebase="'+
-Ta+'download.macromedia.com/pub/shockwave/cabs/flash/swflash.cab#version=6,0,40,0">',d("movie",e),d("AllowScriptAccess",c.allowScriptAccess),d("quality",f.quality),c.wmode?d("wmode",c.wmode):"",d("bgcolor",c.bgColor),d("hasPriority","true"),c.debugFlash?d("FlashVars",f.FlashVars):"","</object>"].join("");else for(j in b=m.createElement("embed"),f)f.hasOwnProperty(j)&&b.setAttribute(j,f[j]);ra();h=G();if(f=qa())if(c.oMC=T(c.movieID)||m.createElement("div"),c.oMC.id){l=c.oMC.className;c.oMC.className=
-(l?l+" ":"movieContainer")+(h?" "+h:"");c.oMC.appendChild(b);if(x)j=c.oMC.appendChild(m.createElement("div")),j.className="sm2-object-box",j.innerHTML=k;K=!0}else{c.oMC.id=c.movieID;c.oMC.className="movieContainer "+h;j=h=null;if(!c.useFlashBlock)if(c.useHighPerformance)h={position:"fixed",width:"8px",height:"8px",bottom:"0px",left:"0px",overflow:"hidden"};else if(h={position:"absolute",width:"6px",height:"6px",top:"-9999px",left:"-9999px"},i)h.left=Math.abs(parseInt(h.left,10))+"px";if(Xa)c.oMC.style.zIndex=
-1E4;if(!c.debugFlash)for(l in h)h.hasOwnProperty(l)&&(c.oMC.style[l]=h[l]);try{x||c.oMC.appendChild(b);f.appendChild(c.oMC);if(x)j=c.oMC.appendChild(m.createElement("div")),j.className="sm2-object-box",j.innerHTML=k;K=!0}catch(n){throw Error(t("domError")+" \n"+n.toString());}}return J=!0};W=function(){if(c.html5Only)return X(),!1;if(i||!c.url)return!1;i=c.getMovie(c.id);if(!i)N?(x?c.oMC.innerHTML=sa:c.oMC.appendChild(N),N=null,J=!0):X(c.id,c.url),i=c.getMovie(c.id);"function"===typeof c.oninitmovie&&
-setTimeout(c.oninitmovie,1);return!0};D=function(){setTimeout(Fa,1E3)};Fa=function(){var a,e=!1;if(!c.url||O)return!1;O=!0;o.remove(h,"load",D);if(da&&!Ba)return!1;k||(a=c.getMoviePercent(),0<a&&100>a&&(e=!0));setTimeout(function(){a=c.getMoviePercent();if(e)return O=!1,h.setTimeout(D,1),!1;!k&&Ra&&(null===a?c.useFlashBlock||0===c.flashLoadTimeout?c.useFlashBlock&&ta():Y(!0):0!==c.flashLoadTimeout&&Y(!0))},c.flashLoadTimeout)};V=function(){if(Ba||!da)return o.remove(h,"focus",V),!0;Ba=Ra=!0;O=!1;
-D();o.remove(h,"focus",V);return!0};Pa=function(){};L=function(a){if(k)return!1;if(c.html5Only)return k=!0,C(),!0;var e=!0,d;if(!c.useFlashBlock||!c.flashLoadTimeout||c.getMoviePercent())k=!0,s&&(d={type:!y&&n?"NO_FLASH":"INIT_TIMEOUT"});if(s||a){if(c.useFlashBlock&&c.oMC)c.oMC.className=G()+" "+(null===c.getMoviePercent()?"swf_timedout":"swf_error");B({type:"ontimeout",error:d,ignoreInit:!0});F(d);e=!1}s||(c.waitForWindowLoad&&!la?o.add(h,"load",C):C());return e};Ea=function(){var a,e=c.setupOptions;
-for(a in e)e.hasOwnProperty(a)&&("undefined"===typeof c[a]?c[a]=e[a]:c[a]!==e[a]&&(c.setupOptions[a]=c[a]))};ka=function(){if(k)return!1;if(c.html5Only){if(!k)o.remove(h,"load",c.beginDelayedInit),c.enabled=!0,L();return!0}W();try{i._externalInterfaceTest(!1),Ga(!0,c.flashPollingInterval||(c.useHighPerformance?10:50)),c.debugMode||i._disableDebug(),c.enabled=!0,c.html5Only||o.add(h,"unload",ja)}catch(a){return F({type:"JS_TO_FLASH_EXCEPTION",fatal:!0}),Y(!0),L(),!1}L();o.remove(h,"load",c.beginDelayedInit);
-return!0};E=function(){if(M)return!1;M=!0;Ea();ra();!y&&c.hasHTML5&&c.setup({useHTML5Audio:!0,preferFlash:!1});Na();c.html5.usingFlash=Ma();n=c.html5.usingFlash;Pa();!y&&n&&c.setup({flashLoadTimeout:1});m.removeEventListener&&m.removeEventListener("DOMContentLoaded",E,!1);W();return!0};wa=function(){"complete"===m.readyState&&(E(),m.detachEvent("onreadystatechange",wa));return!0};pa=function(){la=!0;o.remove(h,"load",pa)};xa();o.add(h,"focus",V);o.add(h,"load",D);o.add(h,"load",pa);m.addEventListener?
-m.addEventListener("DOMContentLoaded",E,!1):m.attachEvent?m.attachEvent("onreadystatechange",wa):F({type:"NO_DOM2_EVENTS",fatal:!0})}var ea=null;if("undefined"===typeof SM2_DEFER||!SM2_DEFER)ea=new R;fa.SoundManager=R;fa.soundManager=ea})(window);
\ No newline at end of file
diff --git a/timeside/static/timeside/js/libs/soundmanager2-nodebug.js b/timeside/static/timeside/js/libs/soundmanager2-nodebug.js
deleted file mode 100644 (file)
index 856175b..0000000
+++ /dev/null
@@ -1,2511 +0,0 @@
-/** @license\r
- *\r
- * SoundManager 2: JavaScript Sound for the Web\r
- * ----------------------------------------------\r
- * http://schillmania.com/projects/soundmanager2/\r
- *\r
- * Copyright (c) 2007, Scott Schiller. All rights reserved.\r
- * Code provided under the BSD License:\r
- * http://schillmania.com/projects/soundmanager2/license.txt\r
- *\r
- * V2.97a.20120916\r
- */\r
-\r
-/*global window, SM2_DEFER, sm2Debugger, console, document, navigator, setTimeout, setInterval, clearInterval, Audio */\r
-/*jslint regexp: true, sloppy: true, white: true, nomen: true, plusplus: true */\r
-\r
-(function(window) {\r
-var soundManager = null;\r
-function SoundManager(smURL, smID) {\r
-  this.setupOptions = {\r
-    'url': (smURL || null),\r
-    'flashVersion': 8,\r
-    'debugMode': true,\r
-    'debugFlash': false,\r
-    'useConsole': true,\r
-    'consoleOnly': true,\r
-    'waitForWindowLoad': false,\r
-    'bgColor': '#ffffff',\r
-    'useHighPerformance': false,\r
-    'flashPollingInterval': null,\r
-    'html5PollingInterval': null,\r
-    'flashLoadTimeout': 1000,\r
-    'wmode': null,\r
-    'allowScriptAccess': 'always',\r
-    'useFlashBlock': false,\r
-    'useHTML5Audio': true,\r
-    'html5Test': /^(probably|maybe)$/i,\r
-    'preferFlash': true,\r
-    'noSWFCache': false\r
-  };\r
-  this.defaultOptions = {\r
-    'autoLoad': false,\r
-    'autoPlay': false,\r
-    'from': null,\r
-    'loops': 1,\r
-    'onid3': null,\r
-    'onload': null,\r
-    'whileloading': null,\r
-    'onplay': null,\r
-    'onpause': null,\r
-    'onresume': null,\r
-    'whileplaying': null,\r
-    'onposition': null,\r
-    'onstop': null,\r
-    'onfailure': null,\r
-    'onfinish': null,\r
-    'multiShot': true,\r
-    'multiShotEvents': false,\r
-    'position': null,\r
-    'pan': 0,\r
-    'stream': true,\r
-    'to': null,\r
-    'type': null,\r
-    'usePolicyFile': false,\r
-    'volume': 100\r
-  };\r
-  this.flash9Options = {\r
-    'isMovieStar': null,\r
-    'usePeakData': false,\r
-    'useWaveformData': false,\r
-    'useEQData': false,\r
-    'onbufferchange': null,\r
-    'ondataerror': null\r
-  };\r
-  this.movieStarOptions = {\r
-    'bufferTime': 3,\r
-    'serverURL': null,\r
-    'onconnect': null,\r
-    'duration': null\r
-  };\r
-  this.audioFormats = {\r
-    'mp3': {\r
-      'type': ['audio/mpeg; codecs="mp3"', 'audio/mpeg', 'audio/mp3', 'audio/MPA', 'audio/mpa-robust'],\r
-      'required': true\r
-    },\r
-    'mp4': {\r
-      'related': ['aac','m4a','m4b'],\r
-      'type': ['audio/mp4; codecs="mp4a.40.2"', 'audio/aac', 'audio/x-m4a', 'audio/MP4A-LATM', 'audio/mpeg4-generic'],\r
-      'required': false\r
-    },\r
-    'ogg': {\r
-      'type': ['audio/ogg; codecs=vorbis'],\r
-      'required': false\r
-    },\r
-    'wav': {\r
-      'type': ['audio/wav; codecs="1"', 'audio/wav', 'audio/wave', 'audio/x-wav'],\r
-      'required': false\r
-    }\r
-  };\r
-  this.movieID = 'sm2-container';\r
-  this.id = (smID || 'sm2movie');\r
-  this.debugID = 'soundmanager-debug';\r
-  this.debugURLParam = /([#?&])debug=1/i;\r
-  this.versionNumber = 'V2.97a.20120916';\r
-  this.version = null;\r
-  this.movieURL = null;\r
-  this.altURL = null;\r
-  this.swfLoaded = false;\r
-  this.enabled = false;\r
-  this.oMC = null;\r
-  this.sounds = {};\r
-  this.soundIDs = [];\r
-  this.muted = false;\r
-  this.didFlashBlock = false;\r
-  this.filePattern = null;\r
-  this.filePatterns = {\r
-    'flash8': /\.mp3(\?.*)?$/i,\r
-    'flash9': /\.mp3(\?.*)?$/i\r
-  };\r
-  this.features = {\r
-    'buffering': false,\r
-    'peakData': false,\r
-    'waveformData': false,\r
-    'eqData': false,\r
-    'movieStar': false\r
-  };\r
-  this.sandbox = {\r
-  };\r
-  this.hasHTML5 = (function() {\r
-    try {\r
-      return (typeof Audio !== 'undefined' && typeof (_isOpera && opera.version() < 10 ? new Audio(null) : new Audio()).canPlayType !== 'undefined');\r
-    } catch(e) {\r
-      return false;\r
-    }\r
-  }());\r
-  this.html5 = {\r
-    'usingFlash': null\r
-  };\r
-  this.flash = {};\r
-  this.html5Only = false;\r
-  this.ignoreFlash = false;\r
-  var SMSound,\r
-  _s = this, _flash = null, _sm = 'soundManager', _smc = _sm+'::', _h5 = 'HTML5::', _id, _ua = navigator.userAgent, _win = window, _wl = _win.location.href.toString(), _doc = document, _doNothing, _setProperties, _init, _fV, _on_queue = [], _debugOpen = true, _debugTS, _didAppend = false, _appendSuccess = false, _didInit = false, _disabled = false, _windowLoaded = false, _wDS, _wdCount = 0, _initComplete, _mixin, _assign, _extraOptions, _addOnEvent, _processOnEvents, _initUserOnload, _delayWaitForEI, _waitForEI, _setVersionInfo, _handleFocus, _strings, _initMovie, _domContentLoaded, _winOnLoad, _didDCLoaded, _getDocument, _createMovie, _catchError, _setPolling, _initDebug, _debugLevels = ['log', 'info', 'warn', 'error'], _defaultFlashVersion = 8, _disableObject, _failSafely, _normalizeMovieURL, _oRemoved = null, _oRemovedHTML = null, _str, _flashBlockHandler, _getSWFCSS, _swfCSS, _toggleDebug, _loopFix, _policyFix, _complain, _idCheck, _waitingForEI = false, _initPending = false, _startTimer, _stopTimer, _timerExecute, _h5TimerCount = 0, _h5IntervalTimer = null, _parseURL,\r
-  _needsFlash = null, _featureCheck, _html5OK, _html5CanPlay, _html5Ext, _html5Unload, _domContentLoadedIE, _testHTML5, _event, _slice = Array.prototype.slice, _useGlobalHTML5Audio = false, _hasFlash, _detectFlash, _badSafariFix, _html5_events, _showSupport,\r
-  _is_iDevice = _ua.match(/(ipad|iphone|ipod)/i), _isIE = _ua.match(/msie/i), _isWebkit = _ua.match(/webkit/i), _isSafari = (_ua.match(/safari/i) && !_ua.match(/chrome/i)), _isOpera = (_ua.match(/opera/i)),\r
-  _mobileHTML5 = (_ua.match(/(mobile|pre\/|xoom)/i) || _is_iDevice),\r
-  _isBadSafari = (!_wl.match(/usehtml5audio/i) && !_wl.match(/sm2\-ignorebadua/i) && _isSafari && !_ua.match(/silk/i) && _ua.match(/OS X 10_6_([3-7])/i)),\r
-  _hasConsole = (typeof console !== 'undefined' && typeof console.log !== 'undefined'), _isFocused = (typeof _doc.hasFocus !== 'undefined'?_doc.hasFocus():null), _tryInitOnFocus = (_isSafari && (typeof _doc.hasFocus === 'undefined' || !_doc.hasFocus())), _okToDisable = !_tryInitOnFocus, _flashMIME = /(mp3|mp4|mpa|m4a|m4b)/i,\r
-  _emptyURL = 'about:blank',\r
-  _overHTTP = (_doc.location?_doc.location.protocol.match(/http/i):null),\r
-  _http = (!_overHTTP ? 'http:/'+'/' : ''),\r
-  _netStreamMimeTypes = /^\s*audio\/(?:x-)?(?:mpeg4|aac|flv|mov|mp4||m4v|m4a|m4b|mp4v|3gp|3g2)\s*(?:$|;)/i,\r
-  _netStreamTypes = ['mpeg4', 'aac', 'flv', 'mov', 'mp4', 'm4v', 'f4v', 'm4a', 'm4b', 'mp4v', '3gp', '3g2'],\r
-  _netStreamPattern = new RegExp('\\.(' + _netStreamTypes.join('|') + ')(\\?.*)?$', 'i');\r
-  this.mimePattern = /^\s*audio\/(?:x-)?(?:mp(?:eg|3))\s*(?:$|;)/i;\r
-  this.useAltURL = !_overHTTP;\r
-  this._global_a = null;\r
-  _swfCSS = {\r
-    'swfBox': 'sm2-object-box',\r
-    'swfDefault': 'movieContainer',\r
-    'swfError': 'swf_error',\r
-    'swfTimedout': 'swf_timedout',\r
-    'swfLoaded': 'swf_loaded',\r
-    'swfUnblocked': 'swf_unblocked',\r
-    'sm2Debug': 'sm2_debug',\r
-    'highPerf': 'high_performance',\r
-    'flashDebug': 'flash_debug'\r
-  };\r
-  if (_mobileHTML5) {\r
-    _s.useHTML5Audio = true;\r
-    _s.preferFlash = false;\r
-    if (_is_iDevice) {\r
-      _s.ignoreFlash = true;\r
-      _useGlobalHTML5Audio = true;\r
-    }\r
-  }\r
-  this.setup = function(options) {\r
-    var noURL = (!_s.url);\r
-    if (typeof options !== 'undefined' && _didInit && _needsFlash && _s.ok() && (typeof options.flashVersion !== 'undefined' || typeof options.url !== 'undefined')) {\r
-      _complain(_str('setupLate'));\r
-    }\r
-    _assign(options);\r
-    if (noURL && _didDCLoaded && typeof options.url !== 'undefined') {\r
-      _s.beginDelayedInit();\r
-    }\r
-    if (!_didDCLoaded && typeof options.url !== 'undefined' && _doc.readyState === 'complete') {\r
-      setTimeout(_domContentLoaded, 1);\r
-    }\r
-    return _s;\r
-  };\r
-  this.ok = function() {\r
-    return (_needsFlash?(_didInit && !_disabled):(_s.useHTML5Audio && _s.hasHTML5));\r
-  };\r
-  this.supported = this.ok;\r
-  this.getMovie = function(smID) {\r
-    return _id(smID) || _doc[smID] || _win[smID];\r
-  };\r
-  this.createSound = function(oOptions, _url) {\r
-    var _cs, _cs_string, thisOptions = null, oSound = null, _tO = null;\r
-    if (!_didInit || !_s.ok()) {\r
-      _complain(_cs_string);\r
-      return false;\r
-    }\r
-    if (typeof _url !== 'undefined') {\r
-      oOptions = {\r
-        'id': oOptions,\r
-        'url': _url\r
-      };\r
-    }\r
-    thisOptions = _mixin(oOptions);\r
-    thisOptions.url = _parseURL(thisOptions.url);\r
-    _tO = thisOptions;\r
-    if (_idCheck(_tO.id, true)) {\r
-      return _s.sounds[_tO.id];\r
-    }\r
-    function make() {\r
-      thisOptions = _loopFix(thisOptions);\r
-      _s.sounds[_tO.id] = new SMSound(_tO);\r
-      _s.soundIDs.push(_tO.id);\r
-      return _s.sounds[_tO.id];\r
-    }\r
-    if (_html5OK(_tO)) {\r
-      oSound = make();\r
-      oSound._setup_html5(_tO);\r
-    } else {\r
-      if (_fV > 8) {\r
-        if (_tO.isMovieStar === null) {\r
-          _tO.isMovieStar = !!(_tO.serverURL || (_tO.type ? _tO.type.match(_netStreamMimeTypes) : false) || _tO.url.match(_netStreamPattern));\r
-        }\r
-      }\r
-      _tO = _policyFix(_tO, _cs);\r
-      oSound = make();\r
-      if (_fV === 8) {\r
-        _flash._createSound(_tO.id, _tO.loops||1, _tO.usePolicyFile);\r
-      } else {\r
-        _flash._createSound(_tO.id, _tO.url, _tO.usePeakData, _tO.useWaveformData, _tO.useEQData, _tO.isMovieStar, (_tO.isMovieStar?_tO.bufferTime:false), _tO.loops||1, _tO.serverURL, _tO.duration||null, _tO.autoPlay, true, _tO.autoLoad, _tO.usePolicyFile);\r
-        if (!_tO.serverURL) {\r
-          oSound.connected = true;\r
-          if (_tO.onconnect) {\r
-            _tO.onconnect.apply(oSound);\r
-          }\r
-        }\r
-      }\r
-      if (!_tO.serverURL && (_tO.autoLoad || _tO.autoPlay)) {\r
-        oSound.load(_tO);\r
-      }\r
-    }\r
-    if (!_tO.serverURL && _tO.autoPlay) {\r
-      oSound.play();\r
-    }\r
-    return oSound;\r
-  };\r
-  this.destroySound = function(sID, _bFromSound) {\r
-    if (!_idCheck(sID)) {\r
-      return false;\r
-    }\r
-    var oS = _s.sounds[sID], i;\r
-    oS._iO = {};\r
-    oS.stop();\r
-    oS.unload();\r
-    for (i = 0; i < _s.soundIDs.length; i++) {\r
-      if (_s.soundIDs[i] === sID) {\r
-        _s.soundIDs.splice(i, 1);\r
-        break;\r
-      }\r
-    }\r
-    if (!_bFromSound) {\r
-      oS.destruct(true);\r
-    }\r
-    oS = null;\r
-    delete _s.sounds[sID];\r
-    return true;\r
-  };\r
-  this.load = function(sID, oOptions) {\r
-    if (!_idCheck(sID)) {\r
-      return false;\r
-    }\r
-    return _s.sounds[sID].load(oOptions);\r
-  };\r
-  this.unload = function(sID) {\r
-    if (!_idCheck(sID)) {\r
-      return false;\r
-    }\r
-    return _s.sounds[sID].unload();\r
-  };\r
-  this.onPosition = function(sID, nPosition, oMethod, oScope) {\r
-    if (!_idCheck(sID)) {\r
-      return false;\r
-    }\r
-    return _s.sounds[sID].onposition(nPosition, oMethod, oScope);\r
-  };\r
-  this.onposition = this.onPosition;\r
-  this.clearOnPosition = function(sID, nPosition, oMethod) {\r
-    if (!_idCheck(sID)) {\r
-      return false;\r
-    }\r
-    return _s.sounds[sID].clearOnPosition(nPosition, oMethod);\r
-  };\r
-  this.play = function(sID, oOptions) {\r
-    var result = false;\r
-    if (!_didInit || !_s.ok()) {\r
-      _complain(_sm+'.play(): ' + _str(!_didInit?'notReady':'notOK'));\r
-      return result;\r
-    }\r
-    if (!_idCheck(sID)) {\r
-      if (!(oOptions instanceof Object)) {\r
-        oOptions = {\r
-          url: oOptions\r
-        };\r
-      }\r
-      if (oOptions && oOptions.url) {\r
-        oOptions.id = sID;\r
-        result = _s.createSound(oOptions).play();\r
-      }\r
-      return result;\r
-    }\r
-    return _s.sounds[sID].play(oOptions);\r
-  };\r
-  this.start = this.play;\r
-  this.setPosition = function(sID, nMsecOffset) {\r
-    if (!_idCheck(sID)) {\r
-      return false;\r
-    }\r
-    return _s.sounds[sID].setPosition(nMsecOffset);\r
-  };\r
-  this.stop = function(sID) {\r
-    if (!_idCheck(sID)) {\r
-      return false;\r
-    }\r
-    return _s.sounds[sID].stop();\r
-  };\r
-  this.stopAll = function() {\r
-    var oSound;\r
-    for (oSound in _s.sounds) {\r
-      if (_s.sounds.hasOwnProperty(oSound)) {\r
-        _s.sounds[oSound].stop();\r
-      }\r
-    }\r
-  };\r
-  this.pause = function(sID) {\r
-    if (!_idCheck(sID)) {\r
-      return false;\r
-    }\r
-    return _s.sounds[sID].pause();\r
-  };\r
-  this.pauseAll = function() {\r
-    var i;\r
-    for (i = _s.soundIDs.length-1; i >= 0; i--) {\r
-      _s.sounds[_s.soundIDs[i]].pause();\r
-    }\r
-  };\r
-  this.resume = function(sID) {\r
-    if (!_idCheck(sID)) {\r
-      return false;\r
-    }\r
-    return _s.sounds[sID].resume();\r
-  };\r
-  this.resumeAll = function() {\r
-    var i;\r
-    for (i = _s.soundIDs.length-1; i >= 0; i--) {\r
-      _s.sounds[_s.soundIDs[i]].resume();\r
-    }\r
-  };\r
-  this.togglePause = function(sID) {\r
-    if (!_idCheck(sID)) {\r
-      return false;\r
-    }\r
-    return _s.sounds[sID].togglePause();\r
-  };\r
-  this.setPan = function(sID, nPan) {\r
-    if (!_idCheck(sID)) {\r
-      return false;\r
-    }\r
-    return _s.sounds[sID].setPan(nPan);\r
-  };\r
-  this.setVolume = function(sID, nVol) {\r
-    if (!_idCheck(sID)) {\r
-      return false;\r
-    }\r
-    return _s.sounds[sID].setVolume(nVol);\r
-  };\r
-  this.mute = function(sID) {\r
-    var i = 0;\r
-    if (typeof sID !== 'string') {\r
-      sID = null;\r
-    }\r
-    if (!sID) {\r
-      for (i = _s.soundIDs.length-1; i >= 0; i--) {\r
-        _s.sounds[_s.soundIDs[i]].mute();\r
-      }\r
-      _s.muted = true;\r
-    } else {\r
-      if (!_idCheck(sID)) {\r
-        return false;\r
-      }\r
-      return _s.sounds[sID].mute();\r
-    }\r
-    return true;\r
-  };\r
-  this.muteAll = function() {\r
-    _s.mute();\r
-  };\r
-  this.unmute = function(sID) {\r
-    var i;\r
-    if (typeof sID !== 'string') {\r
-      sID = null;\r
-    }\r
-    if (!sID) {\r
-      for (i = _s.soundIDs.length-1; i >= 0; i--) {\r
-        _s.sounds[_s.soundIDs[i]].unmute();\r
-      }\r
-      _s.muted = false;\r
-    } else {\r
-      if (!_idCheck(sID)) {\r
-        return false;\r
-      }\r
-      return _s.sounds[sID].unmute();\r
-    }\r
-    return true;\r
-  };\r
-  this.unmuteAll = function() {\r
-    _s.unmute();\r
-  };\r
-  this.toggleMute = function(sID) {\r
-    if (!_idCheck(sID)) {\r
-      return false;\r
-    }\r
-    return _s.sounds[sID].toggleMute();\r
-  };\r
-  this.getMemoryUse = function() {\r
-    var ram = 0;\r
-    if (_flash && _fV !== 8) {\r
-      ram = parseInt(_flash._getMemoryUse(), 10);\r
-    }\r
-    return ram;\r
-  };\r
-  this.disable = function(bNoDisable) {\r
-    var i;\r
-    if (typeof bNoDisable === 'undefined') {\r
-      bNoDisable = false;\r
-    }\r
-    if (_disabled) {\r
-      return false;\r
-    }\r
-    _disabled = true;\r
-    for (i = _s.soundIDs.length-1; i >= 0; i--) {\r
-      _disableObject(_s.sounds[_s.soundIDs[i]]);\r
-    }\r
-    _initComplete(bNoDisable);\r
-    _event.remove(_win, 'load', _initUserOnload);\r
-    return true;\r
-  };\r
-  this.canPlayMIME = function(sMIME) {\r
-    var result;\r
-    if (_s.hasHTML5) {\r
-      result = _html5CanPlay({type:sMIME});\r
-    }\r
-    if (!result && _needsFlash) {\r
-      result = (sMIME && _s.ok() ? !!((_fV > 8 ? sMIME.match(_netStreamMimeTypes) : null) || sMIME.match(_s.mimePattern)) : null);\r
-    }\r
-    return result;\r
-  };\r
-  this.canPlayURL = function(sURL) {\r
-    var result;\r
-    if (_s.hasHTML5) {\r
-      result = _html5CanPlay({url: sURL});\r
-    }\r
-    if (!result && _needsFlash) {\r
-      result = (sURL && _s.ok() ? !!(sURL.match(_s.filePattern)) : null);\r
-    }\r
-    return result;\r
-  };\r
-  this.canPlayLink = function(oLink) {\r
-    if (typeof oLink.type !== 'undefined' && oLink.type) {\r
-      if (_s.canPlayMIME(oLink.type)) {\r
-        return true;\r
-      }\r
-    }\r
-    return _s.canPlayURL(oLink.href);\r
-  };\r
-  this.getSoundById = function(sID, _suppressDebug) {\r
-    if (!sID) {\r
-      throw new Error(_sm+'.getSoundById(): sID is null/undefined');\r
-    }\r
-    var result = _s.sounds[sID];\r
-    return result;\r
-  };\r
-  this.onready = function(oMethod, oScope) {\r
-    var sType = 'onready',\r
-        result = false;\r
-    if (typeof oMethod === 'function') {\r
-      if (!oScope) {\r
-        oScope = _win;\r
-      }\r
-      _addOnEvent(sType, oMethod, oScope);\r
-      _processOnEvents();\r
-      result = true;\r
-    } else {\r
-      throw _str('needFunction', sType);\r
-    }\r
-    return result;\r
-  };\r
-  this.ontimeout = function(oMethod, oScope) {\r
-    var sType = 'ontimeout',\r
-        result = false;\r
-    if (typeof oMethod === 'function') {\r
-      if (!oScope) {\r
-        oScope = _win;\r
-      }\r
-      _addOnEvent(sType, oMethod, oScope);\r
-      _processOnEvents({type:sType});\r
-      result = true;\r
-    } else {\r
-      throw _str('needFunction', sType);\r
-    }\r
-    return result;\r
-  };\r
-  this._writeDebug = function(sText, sType, _bTimestamp) {\r
-    return true;\r
-  };\r
-  this._wD = this._writeDebug;\r
-  this._debug = function() {\r
-  };\r
-  this.reboot = function() {\r
-    var i, j;\r
-    for (i = _s.soundIDs.length-1; i >= 0; i--) {\r
-      _s.sounds[_s.soundIDs[i]].destruct();\r
-    }\r
-    if (_flash) {\r
-      try {\r
-        if (_isIE) {\r
-          _oRemovedHTML = _flash.innerHTML;\r
-        }\r
-        _oRemoved = _flash.parentNode.removeChild(_flash);\r
-      } catch(e) {\r
-      }\r
-    }\r
-    _oRemovedHTML = _oRemoved = _needsFlash = null;\r
-    _s.enabled = _didDCLoaded = _didInit = _waitingForEI = _initPending = _didAppend = _appendSuccess = _disabled = _s.swfLoaded = false;\r
-    _s.soundIDs = [];\r
-    _s.sounds = {};\r
-    _flash = null;\r
-    for (i in _on_queue) {\r
-      if (_on_queue.hasOwnProperty(i)) {\r
-        for (j = _on_queue[i].length-1; j >= 0; j--) {\r
-          _on_queue[i][j].fired = false;\r
-        }\r
-      }\r
-    }\r
-    _win.setTimeout(_s.beginDelayedInit, 20);\r
-  };\r
-  this.getMoviePercent = function() {\r
-    return (_flash && typeof _flash.PercentLoaded !== 'undefined' ? _flash.PercentLoaded() : null);\r
-  };\r
-  this.beginDelayedInit = function() {\r
-    _windowLoaded = true;\r
-    _domContentLoaded();\r
-    setTimeout(function() {\r
-      if (_initPending) {\r
-        return false;\r
-      }\r
-      _createMovie();\r
-      _initMovie();\r
-      _initPending = true;\r
-      return true;\r
-    }, 20);\r
-    _delayWaitForEI();\r
-  };\r
-  this.destruct = function() {\r
-    _s.disable(true);\r
-  };\r
-  SMSound = function(oOptions) {\r
-    var _t = this, _resetProperties, _add_html5_events, _remove_html5_events, _stop_html5_timer, _start_html5_timer, _attachOnPosition, _onplay_called = false, _onPositionItems = [], _onPositionFired = 0, _detachOnPosition, _applyFromTo, _lastURL = null, _lastHTML5State;\r
-    _lastHTML5State = {\r
-      duration: null,\r
-      time: null\r
-    };\r
-    this.id = oOptions.id;\r
-    this.sID = this.id;\r
-    this.url = oOptions.url;\r
-    this.options = _mixin(oOptions);\r
-    this.instanceOptions = this.options;\r
-    this._iO = this.instanceOptions;\r
-    this.pan = this.options.pan;\r
-    this.volume = this.options.volume;\r
-    this.isHTML5 = false;\r
-    this._a = null;\r
-    this.id3 = {};\r
-    this._debug = function() {\r
-    };\r
-    this.load = function(oOptions) {\r
-      var oS = null, _iO;\r
-      if (typeof oOptions !== 'undefined') {\r
-        _t._iO = _mixin(oOptions, _t.options);\r
-        _t.instanceOptions = _t._iO;\r
-      } else {\r
-        oOptions = _t.options;\r
-        _t._iO = oOptions;\r
-        _t.instanceOptions = _t._iO;\r
-        if (_lastURL && _lastURL !== _t.url) {\r
-          _t._iO.url = _t.url;\r
-          _t.url = null;\r
-        }\r
-      }\r
-      if (!_t._iO.url) {\r
-        _t._iO.url = _t.url;\r
-      }\r
-      _t._iO.url = _parseURL(_t._iO.url);\r
-      if (_t._iO.url === _t.url && _t.readyState !== 0 && _t.readyState !== 2) {\r
-        if (_t.readyState === 3 && _t._iO.onload) {\r
-          _t._iO.onload.apply(_t, [(!!_t.duration)]);\r
-        }\r
-        return _t;\r
-      }\r
-      _iO = _t._iO;\r
-      _lastURL = (_t.url && _t.url.toString ? _t.url.toString() : null);\r
-      _t.loaded = false;\r
-      _t.readyState = 1;\r
-      _t.playState = 0;\r
-      _t.id3 = {};\r
-      if (_html5OK(_iO)) {\r
-        oS = _t._setup_html5(_iO);\r
-        if (!oS._called_load) {\r
-          _t._html5_canplay = false;\r
-          if (_t._a.src !== _iO.url) {\r
-            _t._a.src = _iO.url;\r
-            _t.setPosition(0);\r
-          }\r
-          _t._a.autobuffer = 'auto';\r
-          _t._a.preload = 'auto';\r
-          oS._called_load = true;\r
-          if (_iO.autoPlay) {\r
-            _t.play();\r
-          }\r
-        } else {\r
-        }\r
-      } else {\r
-        try {\r
-          _t.isHTML5 = false;\r
-          _t._iO = _policyFix(_loopFix(_iO));\r
-          _iO = _t._iO;\r
-          if (_fV === 8) {\r
-            _flash._load(_t.id, _iO.url, _iO.stream, _iO.autoPlay, (_iO.whileloading?1:0), _iO.loops||1, _iO.usePolicyFile);\r
-          } else {\r
-            _flash._load(_t.id, _iO.url, !!(_iO.stream), !!(_iO.autoPlay), _iO.loops||1, !!(_iO.autoLoad), _iO.usePolicyFile);\r
-          }\r
-        } catch(e) {\r
-          _catchError({type:'SMSOUND_LOAD_JS_EXCEPTION', fatal:true});\r
-        }\r
-      }\r
-      _t.url = _iO.url;\r
-      return _t;\r
-    };\r
-    this.unload = function() {\r
-      if (_t.readyState !== 0) {\r
-        if (!_t.isHTML5) {\r
-          if (_fV === 8) {\r
-            _flash._unload(_t.id, _emptyURL);\r
-          } else {\r
-            _flash._unload(_t.id);\r
-          }\r
-        } else {\r
-          _stop_html5_timer();\r
-          if (_t._a) {\r
-            _t._a.pause();\r
-            _html5Unload(_t._a, _emptyURL);\r
-            _t.url = _emptyURL;\r
-          }\r
-        }\r
-        _resetProperties();\r
-      }\r
-      return _t;\r
-    };\r
-    this.destruct = function(_bFromSM) {\r
-      if (!_t.isHTML5) {\r
-        _t._iO.onfailure = null;\r
-        _flash._destroySound(_t.id);\r
-      } else {\r
-        _stop_html5_timer();\r
-        if (_t._a) {\r
-          _t._a.pause();\r
-          _html5Unload(_t._a);\r
-          if (!_useGlobalHTML5Audio) {\r
-            _remove_html5_events();\r
-          }\r
-          _t._a._t = null;\r
-          _t._a = null;\r
-        }\r
-      }\r
-      if (!_bFromSM) {\r
-        _s.destroySound(_t.id, true);\r
-      }\r
-    };\r
-    this.play = function(oOptions, _updatePlayState) {\r
-      var fN, allowMulti, a, onready, startOK = true,\r
-          exit = null;\r
-      _updatePlayState = (typeof _updatePlayState === 'undefined' ? true : _updatePlayState);\r
-      if (!oOptions) {\r
-        oOptions = {};\r
-      }\r
-      if (_t.url) {\r
-        _t._iO.url = _t.url;\r
-      }\r
-      _t._iO = _mixin(_t._iO, _t.options);\r
-      _t._iO = _mixin(oOptions, _t._iO);\r
-      _t._iO.url = _parseURL(_t._iO.url);\r
-      _t.instanceOptions = _t._iO;\r
-      if (_t._iO.serverURL && !_t.connected) {\r
-        if (!_t.getAutoPlay()) {\r
-          _t.setAutoPlay(true);\r
-        }\r
-        return _t;\r
-      }\r
-      if (_html5OK(_t._iO)) {\r
-        _t._setup_html5(_t._iO);\r
-        _start_html5_timer();\r
-      }\r
-      if (_t.playState === 1 && !_t.paused) {\r
-        allowMulti = _t._iO.multiShot;\r
-        if (!allowMulti) {\r
-          exit = _t;\r
-        } else {\r
-        }\r
-      }\r
-      if (exit !== null) {\r
-        return exit;\r
-      }\r
-      if (oOptions.url && oOptions.url !== _t.url) {\r
-        _t.load(_t._iO);\r
-      }\r
-      if (!_t.loaded) {\r
-        if (_t.readyState === 0) {\r
-          if (!_t.isHTML5) {\r
-            _t._iO.autoPlay = true;\r
-            _t.load(_t._iO);\r
-          } else {\r
-            _t.load(_t._iO);\r
-          }\r
-        } else if (_t.readyState === 2) {\r
-          exit = _t;\r
-        } else {\r
-        }\r
-      } else {\r
-      }\r
-      if (exit !== null) {\r
-        return exit;\r
-      }\r
-      if (!_t.isHTML5 && _fV === 9 && _t.position > 0 && _t.position === _t.duration) {\r
-        oOptions.position = 0;\r
-      }\r
-      if (_t.paused && _t.position >= 0 && (!_t._iO.serverURL || _t.position > 0)) {\r
-        _t.resume();\r
-      } else {\r
-        _t._iO = _mixin(oOptions, _t._iO);\r
-        if (_t._iO.from !== null && _t._iO.to !== null && _t.instanceCount === 0 && _t.playState === 0 && !_t._iO.serverURL) {\r
-          onready = function() {\r
-            _t._iO = _mixin(oOptions, _t._iO);\r
-            _t.play(_t._iO);\r
-          };\r
-          if (_t.isHTML5 && !_t._html5_canplay) {\r
-            _t.load({\r
-              _oncanplay: onready\r
-            });\r
-            exit = false;\r
-          } else if (!_t.isHTML5 && !_t.loaded && (!_t.readyState || _t.readyState !== 2)) {\r
-            _t.load({\r
-              onload: onready\r
-            });\r
-            exit = false;\r
-          }\r
-          if (exit !== null) {\r
-            return exit;\r
-          }\r
-          _t._iO = _applyFromTo();\r
-        }\r
-        if (!_t.instanceCount || _t._iO.multiShotEvents || (!_t.isHTML5 && _fV > 8 && !_t.getAutoPlay())) {\r
-          _t.instanceCount++;\r
-        }\r
-        if (_t._iO.onposition && _t.playState === 0) {\r
-          _attachOnPosition(_t);\r
-        }\r
-        _t.playState = 1;\r
-        _t.paused = false;\r
-        _t.position = (typeof _t._iO.position !== 'undefined' && !isNaN(_t._iO.position) ? _t._iO.position : 0);\r
-        if (!_t.isHTML5) {\r
-          _t._iO = _policyFix(_loopFix(_t._iO));\r
-        }\r
-        if (_t._iO.onplay && _updatePlayState) {\r
-          _t._iO.onplay.apply(_t);\r
-          _onplay_called = true;\r
-        }\r
-        _t.setVolume(_t._iO.volume, true);\r
-        _t.setPan(_t._iO.pan, true);\r
-        if (!_t.isHTML5) {\r
-          startOK = _flash._start(_t.id, _t._iO.loops || 1, (_fV === 9 ? _t._iO.position : _t._iO.position / 1000), _t._iO.multiShot);\r
-          if (_fV === 9 && !startOK) {\r
-            if (_t._iO.onplayerror) {\r
-              _t._iO.onplayerror.apply(_t);\r
-            }\r
-          }\r
-        } else {\r
-          _start_html5_timer();\r
-          a = _t._setup_html5();\r
-          _t.setPosition(_t._iO.position);\r
-          a.play();\r
-        }\r
-      }\r
-      return _t;\r
-    };\r
-    this.start = this.play;\r
-    this.stop = function(bAll) {\r
-      var _iO = _t._iO, _oP;\r
-      if (_t.playState === 1) {\r
-        _t._onbufferchange(0);\r
-        _t._resetOnPosition(0);\r
-        _t.paused = false;\r
-        if (!_t.isHTML5) {\r
-          _t.playState = 0;\r
-        }\r
-        _detachOnPosition();\r
-        if (_iO.to) {\r
-          _t.clearOnPosition(_iO.to);\r
-        }\r
-        if (!_t.isHTML5) {\r
-          _flash._stop(_t.id, bAll);\r
-          if (_iO.serverURL) {\r
-            _t.unload();\r
-          }\r
-        } else {\r
-          if (_t._a) {\r
-            _oP = _t.position;\r
-            _t.setPosition(0);\r
-            _t.position = _oP;\r
-            _t._a.pause();\r
-            _t.playState = 0;\r
-            _t._onTimer();\r
-            _stop_html5_timer();\r
-          }\r
-        }\r
-        _t.instanceCount = 0;\r
-        _t._iO = {};\r
-        if (_iO.onstop) {\r
-          _iO.onstop.apply(_t);\r
-        }\r
-      }\r
-      return _t;\r
-    };\r
-    this.setAutoPlay = function(autoPlay) {\r
-      _t._iO.autoPlay = autoPlay;\r
-      if (!_t.isHTML5) {\r
-        _flash._setAutoPlay(_t.id, autoPlay);\r
-        if (autoPlay) {\r
-          if (!_t.instanceCount && _t.readyState === 1) {\r
-            _t.instanceCount++;\r
-          }\r
-        }\r
-      }\r
-    };\r
-    this.getAutoPlay = function() {\r
-      return _t._iO.autoPlay;\r
-    };\r
-    this.setPosition = function(nMsecOffset) {\r
-      if (typeof nMsecOffset === 'undefined') {\r
-        nMsecOffset = 0;\r
-      }\r
-      var original_pos,\r
-          position, position1K,\r
-          offset = (_t.isHTML5 ? Math.max(nMsecOffset, 0) : Math.min(_t.duration || _t._iO.duration, Math.max(nMsecOffset, 0)));\r
-      original_pos = _t.position;\r
-      _t.position = offset;\r
-      position1K = _t.position/1000;\r
-      _t._resetOnPosition(_t.position);\r
-      _t._iO.position = offset;\r
-      if (!_t.isHTML5) {\r
-        position = (_fV === 9 ? _t.position : position1K);\r
-        if (_t.readyState && _t.readyState !== 2) {\r
-          _flash._setPosition(_t.id, position, (_t.paused || !_t.playState), _t._iO.multiShot);\r
-        }\r
-      } else if (_t._a) {\r
-        if (_t._html5_canplay) {\r
-          if (_t._a.currentTime !== position1K) {\r
-            try {\r
-              _t._a.currentTime = position1K;\r
-              if (_t.playState === 0 || _t.paused) {\r
-                _t._a.pause();\r
-              }\r
-            } catch(e) {\r
-            }\r
-          }\r
-        } else {\r
-        }\r
-      }\r
-      if (_t.isHTML5) {\r
-        if (_t.paused) {\r
-          _t._onTimer(true);\r
-        }\r
-      }\r
-      return _t;\r
-    };\r
-    this.pause = function(_bCallFlash) {\r
-      if (_t.paused || (_t.playState === 0 && _t.readyState !== 1)) {\r
-        return _t;\r
-      }\r
-      _t.paused = true;\r
-      if (!_t.isHTML5) {\r
-        if (_bCallFlash || typeof _bCallFlash === 'undefined') {\r
-          _flash._pause(_t.id, _t._iO.multiShot);\r
-        }\r
-      } else {\r
-        _t._setup_html5().pause();\r
-        _stop_html5_timer();\r
-      }\r
-      if (_t._iO.onpause) {\r
-        _t._iO.onpause.apply(_t);\r
-      }\r
-      return _t;\r
-    };\r
-    this.resume = function() {\r
-      var _iO = _t._iO;\r
-      if (!_t.paused) {\r
-        return _t;\r
-      }\r
-      _t.paused = false;\r
-      _t.playState = 1;\r
-      if (!_t.isHTML5) {\r
-        if (_iO.isMovieStar && !_iO.serverURL) {\r
-          _t.setPosition(_t.position);\r
-        }\r
-        _flash._pause(_t.id, _iO.multiShot);\r
-      } else {\r
-        _t._setup_html5().play();\r
-        _start_html5_timer();\r
-      }\r
-      if (!_onplay_called && _iO.onplay) {\r
-        _iO.onplay.apply(_t);\r
-        _onplay_called = true;\r
-      } else if (_iO.onresume) {\r
-        _iO.onresume.apply(_t);\r
-      }\r
-      return _t;\r
-    };\r
-    this.togglePause = function() {\r
-      if (_t.playState === 0) {\r
-        _t.play({\r
-          position: (_fV === 9 && !_t.isHTML5 ? _t.position : _t.position / 1000)\r
-        });\r
-        return _t;\r
-      }\r
-      if (_t.paused) {\r
-        _t.resume();\r
-      } else {\r
-        _t.pause();\r
-      }\r
-      return _t;\r
-    };\r
-    this.setPan = function(nPan, bInstanceOnly) {\r
-      if (typeof nPan === 'undefined') {\r
-        nPan = 0;\r
-      }\r
-      if (typeof bInstanceOnly === 'undefined') {\r
-        bInstanceOnly = false;\r
-      }\r
-      if (!_t.isHTML5) {\r
-        _flash._setPan(_t.id, nPan);\r
-      }\r
-      _t._iO.pan = nPan;\r
-      if (!bInstanceOnly) {\r
-        _t.pan = nPan;\r
-        _t.options.pan = nPan;\r
-      }\r
-      return _t;\r
-    };\r
-    this.setVolume = function(nVol, _bInstanceOnly) {\r
-      if (typeof nVol === 'undefined') {\r
-        nVol = 100;\r
-      }\r
-      if (typeof _bInstanceOnly === 'undefined') {\r
-        _bInstanceOnly = false;\r
-      }\r
-      if (!_t.isHTML5) {\r
-        _flash._setVolume(_t.id, (_s.muted && !_t.muted) || _t.muted?0:nVol);\r
-      } else if (_t._a) {\r
-        _t._a.volume = Math.max(0, Math.min(1, nVol/100));\r
-      }\r
-      _t._iO.volume = nVol;\r
-      if (!_bInstanceOnly) {\r
-        _t.volume = nVol;\r
-        _t.options.volume = nVol;\r
-      }\r
-      return _t;\r
-    };\r
-    this.mute = function() {\r
-      _t.muted = true;\r
-      if (!_t.isHTML5) {\r
-        _flash._setVolume(_t.id, 0);\r
-      } else if (_t._a) {\r
-        _t._a.muted = true;\r
-      }\r
-      return _t;\r
-    };\r
-    this.unmute = function() {\r
-      _t.muted = false;\r
-      var hasIO = (typeof _t._iO.volume !== 'undefined');\r
-      if (!_t.isHTML5) {\r
-        _flash._setVolume(_t.id, hasIO?_t._iO.volume:_t.options.volume);\r
-      } else if (_t._a) {\r
-        _t._a.muted = false;\r
-      }\r
-      return _t;\r
-    };\r
-    this.toggleMute = function() {\r
-      return (_t.muted?_t.unmute():_t.mute());\r
-    };\r
-    this.onPosition = function(nPosition, oMethod, oScope) {\r
-      _onPositionItems.push({\r
-        position: parseInt(nPosition, 10),\r
-        method: oMethod,\r
-        scope: (typeof oScope !== 'undefined' ? oScope : _t),\r
-        fired: false\r
-      });\r
-      return _t;\r
-    };\r
-    this.onposition = this.onPosition;\r
-    this.clearOnPosition = function(nPosition, oMethod) {\r
-      var i;\r
-      nPosition = parseInt(nPosition, 10);\r
-      if (isNaN(nPosition)) {\r
-        return false;\r
-      }\r
-      for (i=0; i < _onPositionItems.length; i++) {\r
-        if (nPosition === _onPositionItems[i].position) {\r
-          if (!oMethod || (oMethod === _onPositionItems[i].method)) {\r
-            if (_onPositionItems[i].fired) {\r
-              _onPositionFired--;\r
-            }\r
-            _onPositionItems.splice(i, 1);\r
-          }\r
-        }\r
-      }\r
-    };\r
-    this._processOnPosition = function() {\r
-      var i, item, j = _onPositionItems.length;\r
-      if (!j || !_t.playState || _onPositionFired >= j) {\r
-        return false;\r
-      }\r
-      for (i=j-1; i >= 0; i--) {\r
-        item = _onPositionItems[i];\r
-        if (!item.fired && _t.position >= item.position) {\r
-          item.fired = true;\r
-          _onPositionFired++;\r
-          item.method.apply(item.scope, [item.position]);\r
-        }\r
-      }\r
-      return true;\r
-    };\r
-    this._resetOnPosition = function(nPosition) {\r
-      var i, item, j = _onPositionItems.length;\r
-      if (!j) {\r
-        return false;\r
-      }\r
-      for (i=j-1; i >= 0; i--) {\r
-        item = _onPositionItems[i];\r
-        if (item.fired && nPosition <= item.position) {\r
-          item.fired = false;\r
-          _onPositionFired--;\r
-        }\r
-      }\r
-      return true;\r
-    };\r
-    _applyFromTo = function() {\r
-      var _iO = _t._iO,\r
-          f = _iO.from,\r
-          t = _iO.to,\r
-          start, end;\r
-      end = function() {\r
-        _t.clearOnPosition(t, end);\r
-        _t.stop();\r
-      };\r
-      start = function() {\r
-        if (t !== null && !isNaN(t)) {\r
-          _t.onPosition(t, end);\r
-        }\r
-      };\r
-      if (f !== null && !isNaN(f)) {\r
-        _iO.position = f;\r
-        _iO.multiShot = false;\r
-        start();\r
-      }\r
-      return _iO;\r
-    };\r
-    _attachOnPosition = function() {\r
-      var item,\r
-          op = _t._iO.onposition;\r
-      if (op) {\r
-        for (item in op) {\r
-          if (op.hasOwnProperty(item)) {\r
-            _t.onPosition(parseInt(item, 10), op[item]);\r
-          }\r
-        }\r
-      }\r
-    };\r
-    _detachOnPosition = function() {\r
-      var item,\r
-          op = _t._iO.onposition;\r
-      if (op) {\r
-        for (item in op) {\r
-          if (op.hasOwnProperty(item)) {\r
-            _t.clearOnPosition(parseInt(item, 10));\r
-          }\r
-        }\r
-      }\r
-    };\r
-    _start_html5_timer = function() {\r
-      if (_t.isHTML5) {\r
-        _startTimer(_t);\r
-      }\r
-    };\r
-    _stop_html5_timer = function() {\r
-      if (_t.isHTML5) {\r
-        _stopTimer(_t);\r
-      }\r
-    };\r
-    _resetProperties = function(retainPosition) {\r
-      if (!retainPosition) {\r
-        _onPositionItems = [];\r
-        _onPositionFired = 0;\r
-      }\r
-      _onplay_called = false;\r
-      _t._hasTimer = null;\r
-      _t._a = null;\r
-      _t._html5_canplay = false;\r
-      _t.bytesLoaded = null;\r
-      _t.bytesTotal = null;\r
-      _t.duration = (_t._iO && _t._iO.duration ? _t._iO.duration : null);\r
-      _t.durationEstimate = null;\r
-      _t.buffered = [];\r
-      _t.eqData = [];\r
-      _t.eqData.left = [];\r
-      _t.eqData.right = [];\r
-      _t.failures = 0;\r
-      _t.isBuffering = false;\r
-      _t.instanceOptions = {};\r
-      _t.instanceCount = 0;\r
-      _t.loaded = false;\r
-      _t.metadata = {};\r
-      _t.readyState = 0;\r
-      _t.muted = false;\r
-      _t.paused = false;\r
-      _t.peakData = {\r
-        left: 0,\r
-        right: 0\r
-      };\r
-      _t.waveformData = {\r
-        left: [],\r
-        right: []\r
-      };\r
-      _t.playState = 0;\r
-      _t.position = null;\r
-      _t.id3 = {};\r
-    };\r
-    _resetProperties();\r
-    this._onTimer = function(bForce) {\r
-      var duration, isNew = false, time, x = {};\r
-      if (_t._hasTimer || bForce) {\r
-        if (_t._a && (bForce || ((_t.playState > 0 || _t.readyState === 1) && !_t.paused))) {\r
-          duration = _t._get_html5_duration();\r
-          if (duration !== _lastHTML5State.duration) {\r
-            _lastHTML5State.duration = duration;\r
-            _t.duration = duration;\r
-            isNew = true;\r
-          }\r
-          _t.durationEstimate = _t.duration;\r
-          time = (_t._a.currentTime * 1000 || 0);\r
-          if (time !== _lastHTML5State.time) {\r
-            _lastHTML5State.time = time;\r
-            isNew = true;\r
-          }\r
-          if (isNew || bForce) {\r
-            _t._whileplaying(time,x,x,x,x);\r
-          }\r
-        }\r
-        return isNew;\r
-      }\r
-    };\r
-    this._get_html5_duration = function() {\r
-      var _iO = _t._iO,\r
-          d = (_t._a && _t._a.duration ? _t._a.duration*1000 : (_iO && _iO.duration ? _iO.duration : null)),\r
-          result = (d && !isNaN(d) && d !== Infinity ? d : null);\r
-      return result;\r
-    };\r
-    this._apply_loop = function(a, nLoops) {\r
-      a.loop = (nLoops > 1 ? 'loop' : '');\r
-    };\r
-    this._setup_html5 = function(oOptions) {\r
-      var _iO = _mixin(_t._iO, oOptions), d = decodeURI,\r
-          _a = _useGlobalHTML5Audio ? _s._global_a : _t._a,\r
-          _dURL = d(_iO.url),\r
-          _oldIO = (_a && _a._t ? _a._t.instanceOptions : null),\r
-          result;\r
-      if (_a) {\r
-        if (_a._t) {\r
-          if (!_useGlobalHTML5Audio && _dURL === d(_lastURL)) {\r
-            result = _a;\r
-          } else if (_useGlobalHTML5Audio && _oldIO.url === _iO.url && (!_lastURL || (_lastURL === _oldIO.url))) {\r
-            result = _a;\r
-          }\r
-          if (result) {\r
-            _t._apply_loop(_a, _iO.loops);\r
-            return result;\r
-          }\r
-        }\r
-        if (_useGlobalHTML5Audio && _a._t && _a._t.playState && _iO.url !== _oldIO.url) {\r
-          _a._t.stop();\r
-        }\r
-        _resetProperties((_oldIO && _oldIO.url ? _iO.url === _oldIO.url : (_lastURL ? _lastURL === _iO.url : false)));\r
-        _a.src = _iO.url;\r
-        _t.url = _iO.url;\r
-        _lastURL = _iO.url;\r
-        _a._called_load = false;\r
-      } else {\r
-        if (_iO.autoLoad || _iO.autoPlay) {\r
-          _t._a = new Audio(_iO.url);\r
-        } else {\r
-          _t._a = (_isOpera && opera.version() < 10 ? new Audio(null) : new Audio());\r
-        }\r
-        _a = _t._a;\r
-        _a._called_load = false;\r
-        if (_useGlobalHTML5Audio) {\r
-          _s._global_a = _a;\r
-        }\r
-      }\r
-      _t.isHTML5 = true;\r
-      _t._a = _a;\r
-      _a._t = _t;\r
-      _add_html5_events();\r
-      _t._apply_loop(_a, _iO.loops);\r
-      if (_iO.autoLoad || _iO.autoPlay) {\r
-        _t.load();\r
-      } else {\r
-        _a.autobuffer = false;\r
-        _a.preload = 'auto';\r
-      }\r
-      return _a;\r
-    };\r
-    _add_html5_events = function() {\r
-      if (_t._a._added_events) {\r
-        return false;\r
-      }\r
-      var f;\r
-      function add(oEvt, oFn, bCapture) {\r
-        return _t._a ? _t._a.addEventListener(oEvt, oFn, bCapture||false) : null;\r
-      }\r
-      _t._a._added_events = true;\r
-      for (f in _html5_events) {\r
-        if (_html5_events.hasOwnProperty(f)) {\r
-          add(f, _html5_events[f]);\r
-        }\r
-      }\r
-      return true;\r
-    };\r
-    _remove_html5_events = function() {\r
-      var f;\r
-      function remove(oEvt, oFn, bCapture) {\r
-        return (_t._a ? _t._a.removeEventListener(oEvt, oFn, bCapture||false) : null);\r
-      }\r
-      _t._a._added_events = false;\r
-      for (f in _html5_events) {\r
-        if (_html5_events.hasOwnProperty(f)) {\r
-          remove(f, _html5_events[f]);\r
-        }\r
-      }\r
-    };\r
-    this._onload = function(nSuccess) {\r
-      var fN,\r
-          loadOK = (!!(nSuccess) || (!_t.isHTML5 && _fV === 8 && _t.duration));\r
-      _t.loaded = loadOK;\r
-      _t.readyState = loadOK?3:2;\r
-      _t._onbufferchange(0);\r
-      if (_t._iO.onload) {\r
-        _t._iO.onload.apply(_t, [loadOK]);\r
-      }\r
-      return true;\r
-    };\r
-    this._onbufferchange = function(nIsBuffering) {\r
-      if (_t.playState === 0) {\r
-        return false;\r
-      }\r
-      if ((nIsBuffering && _t.isBuffering) || (!nIsBuffering && !_t.isBuffering)) {\r
-        return false;\r
-      }\r
-      _t.isBuffering = (nIsBuffering === 1);\r
-      if (_t._iO.onbufferchange) {\r
-        _t._iO.onbufferchange.apply(_t);\r
-      }\r
-      return true;\r
-    };\r
-    this._onsuspend = function() {\r
-      if (_t._iO.onsuspend) {\r
-        _t._iO.onsuspend.apply(_t);\r
-      }\r
-      return true;\r
-    };\r
-    this._onfailure = function(msg, level, code) {\r
-      _t.failures++;\r
-      if (_t._iO.onfailure && _t.failures === 1) {\r
-        _t._iO.onfailure(_t, msg, level, code);\r
-      } else {\r
-      }\r
-    };\r
-    this._onfinish = function() {\r
-      var _io_onfinish = _t._iO.onfinish;\r
-      _t._onbufferchange(0);\r
-      _t._resetOnPosition(0);\r
-      if (_t.instanceCount) {\r
-        _t.instanceCount--;\r
-        if (!_t.instanceCount) {\r
-          _detachOnPosition();\r
-          _t.playState = 0;\r
-          _t.paused = false;\r
-          _t.instanceCount = 0;\r
-          _t.instanceOptions = {};\r
-          _t._iO = {};\r
-          _stop_html5_timer();\r
-          if (_t.isHTML5) {\r
-            _t.position = 0;\r
-          }\r
-        }\r
-        if (!_t.instanceCount || _t._iO.multiShotEvents) {\r
-          if (_io_onfinish) {\r
-            _io_onfinish.apply(_t);\r
-          }\r
-        }\r
-      }\r
-    };\r
-    this._whileloading = function(nBytesLoaded, nBytesTotal, nDuration, nBufferLength) {\r
-      var _iO = _t._iO;\r
-      _t.bytesLoaded = nBytesLoaded;\r
-      _t.bytesTotal = nBytesTotal;\r
-      _t.duration = Math.floor(nDuration);\r
-      _t.bufferLength = nBufferLength;\r
-      if (!_t.isHTML5 && !_iO.isMovieStar) {\r
-        if (_iO.duration) {\r
-          _t.durationEstimate = (_t.duration > _iO.duration) ? _t.duration : _iO.duration;\r
-        } else {\r
-          _t.durationEstimate = parseInt((_t.bytesTotal / _t.bytesLoaded) * _t.duration, 10);\r
-        }\r
-      } else {\r
-        _t.durationEstimate = _t.duration;\r
-      }\r
-      if (!_t.isHTML5) {\r
-        _t.buffered = [{\r
-          'start': 0,\r
-          'end': _t.duration\r
-        }];\r
-      }\r
-      if ((_t.readyState !== 3 || _t.isHTML5) && _iO.whileloading) {\r
-        _iO.whileloading.apply(_t);\r
-      }\r
-    };\r
-    this._whileplaying = function(nPosition, oPeakData, oWaveformDataLeft, oWaveformDataRight, oEQData) {\r
-      var _iO = _t._iO,\r
-          eqLeft;\r
-      if (isNaN(nPosition) || nPosition === null) {\r
-        return false;\r
-      }\r
-      _t.position = Math.max(0, nPosition);\r
-      _t._processOnPosition();\r
-      if (!_t.isHTML5 && _fV > 8) {\r
-        if (_iO.usePeakData && typeof oPeakData !== 'undefined' && oPeakData) {\r
-          _t.peakData = {\r
-            left: oPeakData.leftPeak,\r
-            right: oPeakData.rightPeak\r
-          };\r
-        }\r
-        if (_iO.useWaveformData && typeof oWaveformDataLeft !== 'undefined' && oWaveformDataLeft) {\r
-          _t.waveformData = {\r
-            left: oWaveformDataLeft.split(','),\r
-            right: oWaveformDataRight.split(',')\r
-          };\r
-        }\r
-        if (_iO.useEQData) {\r
-          if (typeof oEQData !== 'undefined' && oEQData && oEQData.leftEQ) {\r
-            eqLeft = oEQData.leftEQ.split(',');\r
-            _t.eqData = eqLeft;\r
-            _t.eqData.left = eqLeft;\r
-            if (typeof oEQData.rightEQ !== 'undefined' && oEQData.rightEQ) {\r
-              _t.eqData.right = oEQData.rightEQ.split(',');\r
-            }\r
-          }\r
-        }\r
-      }\r
-      if (_t.playState === 1) {\r
-        if (!_t.isHTML5 && _fV === 8 && !_t.position && _t.isBuffering) {\r
-          _t._onbufferchange(0);\r
-        }\r
-        if (_iO.whileplaying) {\r
-          _iO.whileplaying.apply(_t);\r
-        }\r
-      }\r
-      return true;\r
-    };\r
-    this._oncaptiondata = function(oData) {\r
-      _t.captiondata = oData;\r
-      if (_t._iO.oncaptiondata) {\r
-        _t._iO.oncaptiondata.apply(_t, [oData]);\r
-      }\r
-       };\r
-    this._onmetadata = function(oMDProps, oMDData) {\r
-      var oData = {}, i, j;\r
-      for (i = 0, j = oMDProps.length; i < j; i++) {\r
-        oData[oMDProps[i]] = oMDData[i];\r
-      }\r
-      _t.metadata = oData;\r
-      if (_t._iO.onmetadata) {\r
-        _t._iO.onmetadata.apply(_t);\r
-      }\r
-       };\r
-    this._onid3 = function(oID3Props, oID3Data) {\r
-      var oData = [], i, j;\r
-      for (i = 0, j = oID3Props.length; i < j; i++) {\r
-        oData[oID3Props[i]] = oID3Data[i];\r
-      }\r
-      _t.id3 = _mixin(_t.id3, oData);\r
-      if (_t._iO.onid3) {\r
-        _t._iO.onid3.apply(_t);\r
-      }\r
-    };\r
-    this._onconnect = function(bSuccess) {\r
-      bSuccess = (bSuccess === 1);\r
-      _t.connected = bSuccess;\r
-      if (bSuccess) {\r
-        _t.failures = 0;\r
-        if (_idCheck(_t.id)) {\r
-          if (_t.getAutoPlay()) {\r
-            _t.play(undefined, _t.getAutoPlay());\r
-          } else if (_t._iO.autoLoad) {\r
-            _t.load();\r
-          }\r
-        }\r
-        if (_t._iO.onconnect) {\r
-          _t._iO.onconnect.apply(_t, [bSuccess]);\r
-        }\r
-      }\r
-    };\r
-    this._ondataerror = function(sError) {\r
-      if (_t.playState > 0) {\r
-        if (_t._iO.ondataerror) {\r
-          _t._iO.ondataerror.apply(_t);\r
-        }\r
-      }\r
-    };\r
-  };\r
-  _getDocument = function() {\r
-    return (_doc.body || _doc._docElement || _doc.getElementsByTagName('div')[0]);\r
-  };\r
-  _id = function(sID) {\r
-    return _doc.getElementById(sID);\r
-  };\r
-  _mixin = function(oMain, oAdd) {\r
-    var o1 = (oMain || {}), o2, o;\r
-    o2 = (typeof oAdd === 'undefined' ? _s.defaultOptions : oAdd);\r
-    for (o in o2) {\r
-      if (o2.hasOwnProperty(o) && typeof o1[o] === 'undefined') {\r
-        if (typeof o2[o] !== 'object' || o2[o] === null) {\r
-          o1[o] = o2[o];\r
-        } else {\r
-          o1[o] = _mixin(o1[o], o2[o]);\r
-        }\r
-      }\r
-    }\r
-    return o1;\r
-  };\r
-  _extraOptions = {\r
-    'onready': 1,\r
-    'ontimeout': 1,\r
-    'defaultOptions': 1,\r
-    'flash9Options': 1,\r
-    'movieStarOptions': 1\r
-  };\r
-  _assign = function(o, oParent) {\r
-    var i,\r
-        result = true,\r
-        hasParent = (typeof oParent !== 'undefined'),\r
-        setupOptions = _s.setupOptions,\r
-        extraOptions = _extraOptions;\r
-    for (i in o) {\r
-      if (o.hasOwnProperty(i)) {\r
-        if (typeof o[i] !== 'object' || o[i] === null || o[i] instanceof Array) {\r
-          if (hasParent && typeof extraOptions[oParent] !== 'undefined') {\r
-            _s[oParent][i] = o[i];\r
-          } else if (typeof setupOptions[i] !== 'undefined') {\r
-            _s.setupOptions[i] = o[i];\r
-            _s[i] = o[i];\r
-          } else if (typeof extraOptions[i] === 'undefined') {\r
-            _complain(_str((typeof _s[i] === 'undefined' ? 'setupUndef' : 'setupError'), i), 2);\r
-            result = false;\r
-          } else {\r
-            if (_s[i] instanceof Function) {\r
-              _s[i].apply(_s, (o[i] instanceof Array? o[i] : [o[i]]));\r
-            } else {\r
-              _s[i] = o[i];\r
-            }\r
-          }\r
-        } else {\r
-          if (typeof extraOptions[i] === 'undefined') {\r
-            _complain(_str((typeof _s[i] === 'undefined' ? 'setupUndef' : 'setupError'), i), 2);\r
-            result = false;\r
-          } else {\r
-            return _assign(o[i], i);\r
-          }\r
-        }\r
-      }\r
-    }\r
-    return result;\r
-  };\r
-  function _preferFlashCheck(kind) {\r
-    return (_s.preferFlash && _hasFlash && !_s.ignoreFlash && (typeof _s.flash[kind] !== 'undefined' && _s.flash[kind]));\r
-  }\r
-  _event = (function() {\r
-    var old = (_win.attachEvent),\r
-    evt = {\r
-      add: (old?'attachEvent':'addEventListener'),\r
-      remove: (old?'detachEvent':'removeEventListener')\r
-    };\r
-    function getArgs(oArgs) {\r
-      var args = _slice.call(oArgs),\r
-          len = args.length;\r
-      if (old) {\r
-        args[1] = 'on' + args[1];\r
-        if (len > 3) {\r
-          args.pop();\r
-        }\r
-      } else if (len === 3) {\r
-        args.push(false);\r
-      }\r
-      return args;\r
-    }\r
-    function apply(args, sType) {\r
-      var element = args.shift(),\r
-          method = [evt[sType]];\r
-      if (old) {\r
-        element[method](args[0], args[1]);\r
-      } else {\r
-        element[method].apply(element, args);\r
-      }\r
-    }\r
-    function add() {\r
-      apply(getArgs(arguments), 'add');\r
-    }\r
-    function remove() {\r
-      apply(getArgs(arguments), 'remove');\r
-    }\r
-    return {\r
-      'add': add,\r
-      'remove': remove\r
-    };\r
-  }());\r
-  function _html5_event(oFn) {\r
-    return function(e) {\r
-      var t = this._t,\r
-          result;\r
-      if (!t || !t._a) {\r
-        result = null;\r
-      } else {\r
-        result = oFn.call(this, e);\r
-      }\r
-      return result;\r
-    };\r
-  }\r
-  _html5_events = {\r
-    abort: _html5_event(function() {\r
-    }),\r
-    canplay: _html5_event(function() {\r
-      var t = this._t,\r
-          position1K;\r
-      if (t._html5_canplay) {\r
-        return true;\r
-      }\r
-      t._html5_canplay = true;\r
-      t._onbufferchange(0);\r
-      position1K = (typeof t._iO.position !== 'undefined' && !isNaN(t._iO.position)?t._iO.position/1000:null);\r
-      if (t.position && this.currentTime !== position1K) {\r
-        try {\r
-          this.currentTime = position1K;\r
-        } catch(ee) {\r
-        }\r
-      }\r
-      if (t._iO._oncanplay) {\r
-        t._iO._oncanplay();\r
-      }\r
-    }),\r
-    canplaythrough: _html5_event(function() {\r
-      var t = this._t;\r
-      if (!t.loaded) {\r
-        t._onbufferchange(0);\r
-        t._whileloading(t.bytesLoaded, t.bytesTotal, t._get_html5_duration());\r
-        t._onload(true);\r
-      }\r
-    }),\r
-    ended: _html5_event(function() {\r
-      var t = this._t;\r
-      t._onfinish();\r
-    }),\r
-    error: _html5_event(function() {\r
-      this._t._onload(false);\r
-    }),\r
-    loadeddata: _html5_event(function() {\r
-      var t = this._t;\r
-      if (!t._loaded && !_isSafari) {\r
-        t.duration = t._get_html5_duration();\r
-      }\r
-    }),\r
-    loadedmetadata: _html5_event(function() {\r
-    }),\r
-    loadstart: _html5_event(function() {\r
-      this._t._onbufferchange(1);\r
-    }),\r
-    play: _html5_event(function() {\r
-      this._t._onbufferchange(0);\r
-    }),\r
-    playing: _html5_event(function() {\r
-      this._t._onbufferchange(0);\r
-    }),\r
-    progress: _html5_event(function(e) {\r
-      var t = this._t,\r
-          i, j, str, buffered = 0,\r
-          isProgress = (e.type === 'progress'),\r
-          ranges = e.target.buffered,\r
-          loaded = (e.loaded||0),\r
-          total = (e.total||1),\r
-          scale = 1000;\r
-      t.buffered = [];\r
-      if (ranges && ranges.length) {\r
-        for (i=0, j=ranges.length; i<j; i++) {\r
-          t.buffered.push({\r
-            'start': ranges.start(i) * scale,\r
-            'end': ranges.end(i) * scale\r
-          });\r
-        }\r
-        buffered = (ranges.end(0) - ranges.start(0)) * scale;\r
-        loaded = buffered/(e.target.duration*scale);\r
-      }\r
-      if (!isNaN(loaded)) {\r
-        t._onbufferchange(0);\r
-        t._whileloading(loaded, total, t._get_html5_duration());\r
-        if (loaded && total && loaded === total) {\r
-          _html5_events.canplaythrough.call(this, e);\r
-        }\r
-      }\r
-    }),\r
-    ratechange: _html5_event(function() {\r
-    }),\r
-    suspend: _html5_event(function(e) {\r
-      var t = this._t;\r
-      _html5_events.progress.call(this, e);\r
-      t._onsuspend();\r
-    }),\r
-    stalled: _html5_event(function() {\r
-    }),\r
-    timeupdate: _html5_event(function() {\r
-      this._t._onTimer();\r
-    }),\r
-    waiting: _html5_event(function() {\r
-      var t = this._t;\r
-      t._onbufferchange(1);\r
-    })\r
-  };\r
-  _html5OK = function(iO) {\r
-    var result;\r
-    if (iO.serverURL || (iO.type && _preferFlashCheck(iO.type))) {\r
-      result = false;\r
-    } else {\r
-      result = ((iO.type ? _html5CanPlay({type:iO.type}) : _html5CanPlay({url:iO.url}) || _s.html5Only));\r
-    }\r
-    return result;\r
-  };\r
-  _html5Unload = function(oAudio, url) {\r
-    if (oAudio) {\r
-      oAudio.src = url;\r
-    }\r
-  };\r
-  _html5CanPlay = function(o) {\r
-    if (!_s.useHTML5Audio || !_s.hasHTML5) {\r
-      return false;\r
-    }\r
-    var url = (o.url || null),\r
-        mime = (o.type || null),\r
-        aF = _s.audioFormats,\r
-        result,\r
-        offset,\r
-        fileExt,\r
-        item;\r
-    if (mime && typeof _s.html5[mime] !== 'undefined') {\r
-      return (_s.html5[mime] && !_preferFlashCheck(mime));\r
-    }\r
-    if (!_html5Ext) {\r
-      _html5Ext = [];\r
-      for (item in aF) {\r
-        if (aF.hasOwnProperty(item)) {\r
-          _html5Ext.push(item);\r
-          if (aF[item].related) {\r
-            _html5Ext = _html5Ext.concat(aF[item].related);\r
-          }\r
-        }\r
-      }\r
-      _html5Ext = new RegExp('\\.('+_html5Ext.join('|')+')(\\?.*)?$','i');\r
-    }\r
-    fileExt = (url ? url.toLowerCase().match(_html5Ext) : null);\r
-    if (!fileExt || !fileExt.length) {\r
-      if (!mime) {\r
-        result = false;\r
-      } else {\r
-        offset = mime.indexOf(';');\r
-        fileExt = (offset !== -1?mime.substr(0,offset):mime).substr(6);\r
-      }\r
-    } else {\r
-      fileExt = fileExt[1];\r
-    }\r
-    if (fileExt && typeof _s.html5[fileExt] !== 'undefined') {\r
-      result = (_s.html5[fileExt] && !_preferFlashCheck(fileExt));\r
-    } else {\r
-      mime = 'audio/'+fileExt;\r
-      result = _s.html5.canPlayType({type:mime});\r
-      _s.html5[fileExt] = result;\r
-      result = (result && _s.html5[mime] && !_preferFlashCheck(mime));\r
-    }\r
-    return result;\r
-  };\r
-  _testHTML5 = function() {\r
-    if (!_s.useHTML5Audio || !_s.hasHTML5) {\r
-      return false;\r
-    }\r
-    var a = (typeof Audio !== 'undefined' ? (_isOpera && opera.version() < 10 ? new Audio(null) : new Audio()) : null),\r
-        item, lookup, support = {}, aF, i;\r
-    function _cp(m) {\r
-      var canPlay, i, j,\r
-          result = false,\r
-          isOK = false;\r
-      if (!a || typeof a.canPlayType !== 'function') {\r
-        return result;\r
-      }\r
-      if (m instanceof Array) {\r
-        for (i=0, j=m.length; i<j; i++) {\r
-          if (_s.html5[m[i]] || a.canPlayType(m[i]).match(_s.html5Test)) {\r
-            isOK = true;\r
-            _s.html5[m[i]] = true;\r
-            _s.flash[m[i]] = !!(m[i].match(_flashMIME));\r
-          }\r
-        }\r
-        result = isOK;\r
-      } else {\r
-        canPlay = (a && typeof a.canPlayType === 'function' ? a.canPlayType(m) : false);\r
-        result = !!(canPlay && (canPlay.match(_s.html5Test)));\r
-      }\r
-      return result;\r
-    }\r
-    aF = _s.audioFormats;\r
-    for (item in aF) {\r
-      if (aF.hasOwnProperty(item)) {\r
-        lookup = 'audio/' + item;\r
-        support[item] = _cp(aF[item].type);\r
-        support[lookup] = support[item];\r
-        if (item.match(_flashMIME)) {\r
-          _s.flash[item] = true;\r
-          _s.flash[lookup] = true;\r
-        } else {\r
-          _s.flash[item] = false;\r
-          _s.flash[lookup] = false;\r
-        }\r
-        if (aF[item] && aF[item].related) {\r
-          for (i=aF[item].related.length-1; i >= 0; i--) {\r
-            support['audio/'+aF[item].related[i]] = support[item];\r
-            _s.html5[aF[item].related[i]] = support[item];\r
-            _s.flash[aF[item].related[i]] = support[item];\r
-          }\r
-        }\r
-      }\r
-    }\r
-    support.canPlayType = (a?_cp:null);\r
-    _s.html5 = _mixin(_s.html5, support);\r
-    return true;\r
-  };\r
-  _strings = {\r
-  };\r
-  _str = function() {\r
-  };\r
-  _loopFix = function(sOpt) {\r
-    if (_fV === 8 && sOpt.loops > 1 && sOpt.stream) {\r
-      sOpt.stream = false;\r
-    }\r
-    return sOpt;\r
-  };\r
-  _policyFix = function(sOpt, sPre) {\r
-    if (sOpt && !sOpt.usePolicyFile && (sOpt.onid3 || sOpt.usePeakData || sOpt.useWaveformData || sOpt.useEQData)) {\r
-      sOpt.usePolicyFile = true;\r
-    }\r
-    return sOpt;\r
-  };\r
-  _complain = function(sMsg) {\r
-  };\r
-  _doNothing = function() {\r
-    return false;\r
-  };\r
-  _disableObject = function(o) {\r
-    var oProp;\r
-    for (oProp in o) {\r
-      if (o.hasOwnProperty(oProp) && typeof o[oProp] === 'function') {\r
-        o[oProp] = _doNothing;\r
-      }\r
-    }\r
-    oProp = null;\r
-  };\r
-  _failSafely = function(bNoDisable) {\r
-    if (typeof bNoDisable === 'undefined') {\r
-      bNoDisable = false;\r
-    }\r
-    if (_disabled || bNoDisable) {\r
-      _s.disable(bNoDisable);\r
-    }\r
-  };\r
-  _normalizeMovieURL = function(smURL) {\r
-    var urlParams = null, url;\r
-    if (smURL) {\r
-      if (smURL.match(/\.swf(\?.*)?$/i)) {\r
-        urlParams = smURL.substr(smURL.toLowerCase().lastIndexOf('.swf?') + 4);\r
-        if (urlParams) {\r
-          return smURL;\r
-        }\r
-      } else if (smURL.lastIndexOf('/') !== smURL.length - 1) {\r
-        smURL += '/';\r
-      }\r
-    }\r
-    url = (smURL && smURL.lastIndexOf('/') !== - 1 ? smURL.substr(0, smURL.lastIndexOf('/') + 1) : './') + _s.movieURL;\r
-    if (_s.noSWFCache) {\r
-      url += ('?ts=' + new Date().getTime());\r
-    }\r
-    return url;\r
-  };\r
-  _setVersionInfo = function() {\r
-    _fV = parseInt(_s.flashVersion, 10);\r
-    if (_fV !== 8 && _fV !== 9) {\r
-      _s.flashVersion = _fV = _defaultFlashVersion;\r
-    }\r
-    var isDebug = (_s.debugMode || _s.debugFlash?'_debug.swf':'.swf');\r
-    if (_s.useHTML5Audio && !_s.html5Only && _s.audioFormats.mp4.required && _fV < 9) {\r
-      _s.flashVersion = _fV = 9;\r
-    }\r
-    _s.version = _s.versionNumber + (_s.html5Only?' (HTML5-only mode)':(_fV === 9?' (AS3/Flash 9)':' (AS2/Flash 8)'));\r
-    if (_fV > 8) {\r
-      _s.defaultOptions = _mixin(_s.defaultOptions, _s.flash9Options);\r
-      _s.features.buffering = true;\r
-      _s.defaultOptions = _mixin(_s.defaultOptions, _s.movieStarOptions);\r
-      _s.filePatterns.flash9 = new RegExp('\\.(mp3|' + _netStreamTypes.join('|') + ')(\\?.*)?$', 'i');\r
-      _s.features.movieStar = true;\r
-    } else {\r
-      _s.features.movieStar = false;\r
-    }\r
-    _s.filePattern = _s.filePatterns[(_fV !== 8?'flash9':'flash8')];\r
-    _s.movieURL = (_fV === 8?'soundmanager2.swf':'soundmanager2_flash9.swf').replace('.swf', isDebug);\r
-    _s.features.peakData = _s.features.waveformData = _s.features.eqData = (_fV > 8);\r
-  };\r
-  _setPolling = function(bPolling, bHighPerformance) {\r
-    if (!_flash) {\r
-      return false;\r
-    }\r
-    _flash._setPolling(bPolling, bHighPerformance);\r
-  };\r
-  _initDebug = function() {\r
-    if (_s.debugURLParam.test(_wl)) {\r
-      _s.debugMode = true;\r
-    }\r
-  };\r
-  _idCheck = this.getSoundById;\r
-  _getSWFCSS = function() {\r
-    var css = [];\r
-    if (_s.debugMode) {\r
-      css.push(_swfCSS.sm2Debug);\r
-    }\r
-    if (_s.debugFlash) {\r
-      css.push(_swfCSS.flashDebug);\r
-    }\r
-    if (_s.useHighPerformance) {\r
-      css.push(_swfCSS.highPerf);\r
-    }\r
-    return css.join(' ');\r
-  };\r
-  _flashBlockHandler = function() {\r
-    var name = _str('fbHandler'),\r
-        p = _s.getMoviePercent(),\r
-        css = _swfCSS,\r
-        error = {type:'FLASHBLOCK'};\r
-    if (_s.html5Only) {\r
-      return false;\r
-    }\r
-    if (!_s.ok()) {\r
-      if (_needsFlash) {\r
-        _s.oMC.className = _getSWFCSS() + ' ' + css.swfDefault + ' ' + (p === null?css.swfTimedout:css.swfError);\r
-      }\r
-      _s.didFlashBlock = true;\r
-      _processOnEvents({type:'ontimeout', ignoreInit:true, error:error});\r
-      _catchError(error);\r
-    } else {\r
-      if (_s.oMC) {\r
-        _s.oMC.className = [_getSWFCSS(), css.swfDefault, css.swfLoaded + (_s.didFlashBlock?' '+css.swfUnblocked:'')].join(' ');\r
-      }\r
-    }\r
-  };\r
-  _addOnEvent = function(sType, oMethod, oScope) {\r
-    if (typeof _on_queue[sType] === 'undefined') {\r
-      _on_queue[sType] = [];\r
-    }\r
-    _on_queue[sType].push({\r
-      'method': oMethod,\r
-      'scope': (oScope || null),\r
-      'fired': false\r
-    });\r
-  };\r
-  _processOnEvents = function(oOptions) {\r
-    if (!oOptions) {\r
-      oOptions = {\r
-        type: (_s.ok() ? 'onready' : 'ontimeout')\r
-      };\r
-    }\r
-    if (!_didInit && oOptions && !oOptions.ignoreInit) {\r
-      return false;\r
-    }\r
-    if (oOptions.type === 'ontimeout' && (_s.ok() || (_disabled && !oOptions.ignoreInit))) {\r
-      return false;\r
-    }\r
-    var status = {\r
-          success: (oOptions && oOptions.ignoreInit?_s.ok():!_disabled)\r
-        },\r
-        srcQueue = (oOptions && oOptions.type?_on_queue[oOptions.type]||[]:[]),\r
-        queue = [], i, j,\r
-        args = [status],\r
-        canRetry = (_needsFlash && _s.useFlashBlock && !_s.ok());\r
-    if (oOptions.error) {\r
-      args[0].error = oOptions.error;\r
-    }\r
-    for (i = 0, j = srcQueue.length; i < j; i++) {\r
-      if (srcQueue[i].fired !== true) {\r
-        queue.push(srcQueue[i]);\r
-      }\r
-    }\r
-    if (queue.length) {\r
-      for (i = 0, j = queue.length; i < j; i++) {\r
-        if (queue[i].scope) {\r
-          queue[i].method.apply(queue[i].scope, args);\r
-        } else {\r
-          queue[i].method.apply(this, args);\r
-        }\r
-        if (!canRetry) {\r
-          queue[i].fired = true;\r
-        }\r
-      }\r
-    }\r
-    return true;\r
-  };\r
-  _initUserOnload = function() {\r
-    _win.setTimeout(function() {\r
-      if (_s.useFlashBlock) {\r
-        _flashBlockHandler();\r
-      }\r
-      _processOnEvents();\r
-      if (typeof _s.onload === 'function') {\r
-        _s.onload.apply(_win);\r
-      }\r
-      if (_s.waitForWindowLoad) {\r
-        _event.add(_win, 'load', _initUserOnload);\r
-      }\r
-    },1);\r
-  };\r
-  _detectFlash = function() {\r
-    if (typeof _hasFlash !== 'undefined') {\r
-      return _hasFlash;\r
-    }\r
-    var hasPlugin = false, n = navigator, nP = n.plugins, obj, type, types, AX = _win.ActiveXObject;\r
-    if (nP && nP.length) {\r
-      type = 'application/x-shockwave-flash';\r
-      types = n.mimeTypes;\r
-      if (types && types[type] && types[type].enabledPlugin && types[type].enabledPlugin.description) {\r
-        hasPlugin = true;\r
-      }\r
-    } else if (typeof AX !== 'undefined') {\r
-      try {\r
-        obj = new AX('ShockwaveFlash.ShockwaveFlash');\r
-      } catch(e) {\r
-      }\r
-      hasPlugin = (!!obj);\r
-    }\r
-    _hasFlash = hasPlugin;\r
-    return hasPlugin;\r
-  };\r
-  _featureCheck = function() {\r
-    var needsFlash,\r
-        item,\r
-        result = true,\r
-        formats = _s.audioFormats,\r
-        isSpecial = (_is_iDevice && !!(_ua.match(/os (1|2|3_0|3_1)/i)));\r
-    if (isSpecial) {\r
-      _s.hasHTML5 = false;\r
-      _s.html5Only = true;\r
-      if (_s.oMC) {\r
-        _s.oMC.style.display = 'none';\r
-      }\r
-      result = false;\r
-    } else {\r
-      if (_s.useHTML5Audio) {\r
-        if (!_s.html5 || !_s.html5.canPlayType) {\r
-          _s.hasHTML5 = false;\r
-        }\r
-      }\r
-    }\r
-    if (_s.useHTML5Audio && _s.hasHTML5) {\r
-      for (item in formats) {\r
-        if (formats.hasOwnProperty(item)) {\r
-          if ((formats[item].required && !_s.html5.canPlayType(formats[item].type)) || (_s.preferFlash && (_s.flash[item] || _s.flash[formats[item].type]))) {\r
-            needsFlash = true;\r
-          }\r
-        }\r
-      }\r
-    }\r
-    if (_s.ignoreFlash) {\r
-      needsFlash = false;\r
-    }\r
-    _s.html5Only = (_s.hasHTML5 && _s.useHTML5Audio && !needsFlash);\r
-    return (!_s.html5Only);\r
-  };\r
-  _parseURL = function(url) {\r
-    var i, j, urlResult = 0, result;\r
-    if (url instanceof Array) {\r
-      for (i=0, j=url.length; i<j; i++) {\r
-        if (url[i] instanceof Object) {\r
-          if (_s.canPlayMIME(url[i].type)) {\r
-            urlResult = i;\r
-            break;\r
-          }\r
-        } else if (_s.canPlayURL(url[i])) {\r
-          urlResult = i;\r
-          break;\r
-        }\r
-      }\r
-      if (url[urlResult].url) {\r
-        url[urlResult] = url[urlResult].url;\r
-      }\r
-      result = url[urlResult];\r
-    } else {\r
-      result = url;\r
-    }\r
-    return result;\r
-  };\r
-  _startTimer = function(oSound) {\r
-    if (!oSound._hasTimer) {\r
-      oSound._hasTimer = true;\r
-      if (!_mobileHTML5 && _s.html5PollingInterval) {\r
-        if (_h5IntervalTimer === null && _h5TimerCount === 0) {\r
-          _h5IntervalTimer = _win.setInterval(_timerExecute, _s.html5PollingInterval);\r
-        }\r
-        _h5TimerCount++;\r
-      }\r
-    }\r
-  };\r
-  _stopTimer = function(oSound) {\r
-    if (oSound._hasTimer) {\r
-      oSound._hasTimer = false;\r
-      if (!_mobileHTML5 && _s.html5PollingInterval) {\r
-        _h5TimerCount--;\r
-      }\r
-    }\r
-  };\r
-  _timerExecute = function() {\r
-    var i;\r
-    if (_h5IntervalTimer !== null && !_h5TimerCount) {\r
-      _win.clearInterval(_h5IntervalTimer);\r
-      _h5IntervalTimer = null;\r
-      return false;\r
-    }\r
-    for (i = _s.soundIDs.length-1; i >= 0; i--) {\r
-      if (_s.sounds[_s.soundIDs[i]].isHTML5 && _s.sounds[_s.soundIDs[i]]._hasTimer) {\r
-        _s.sounds[_s.soundIDs[i]]._onTimer();\r
-      }\r
-    }\r
-  };\r
-  _catchError = function(options) {\r
-    options = (typeof options !== 'undefined' ? options : {});\r
-    if (typeof _s.onerror === 'function') {\r
-      _s.onerror.apply(_win, [{type:(typeof options.type !== 'undefined' ? options.type : null)}]);\r
-    }\r
-    if (typeof options.fatal !== 'undefined' && options.fatal) {\r
-      _s.disable();\r
-    }\r
-  };\r
-  _badSafariFix = function() {\r
-    if (!_isBadSafari || !_detectFlash()) {\r
-      return false;\r
-    }\r
-    var aF = _s.audioFormats, i, item;\r
-    for (item in aF) {\r
-      if (aF.hasOwnProperty(item)) {\r
-        if (item === 'mp3' || item === 'mp4') {\r
-          _s.html5[item] = false;\r
-          if (aF[item] && aF[item].related) {\r
-            for (i = aF[item].related.length-1; i >= 0; i--) {\r
-              _s.html5[aF[item].related[i]] = false;\r
-            }\r
-          }\r
-        }\r
-      }\r
-    }\r
-  };\r
-  this._setSandboxType = function(sandboxType) {\r
-  };\r
-  this._externalInterfaceOK = function(flashDate, swfVersion) {\r
-    if (_s.swfLoaded) {\r
-      return false;\r
-    }\r
-    var e, eiTime = new Date().getTime();\r
-    _s.swfLoaded = true;\r
-    _tryInitOnFocus = false;\r
-    if (_isBadSafari) {\r
-      _badSafariFix();\r
-    }\r
-    setTimeout(_init, _isIE ? 100 : 1);\r
-  };\r
-  _createMovie = function(smID, smURL) {\r
-    if (_didAppend && _appendSuccess) {\r
-      return false;\r
-    }\r
-    function _initMsg() {\r
-    }\r
-    if (_s.html5Only) {\r
-      _setVersionInfo();\r
-      _initMsg();\r
-      _s.oMC = _id(_s.movieID);\r
-      _init();\r
-      _didAppend = true;\r
-      _appendSuccess = true;\r
-      return false;\r
-    }\r
-    var remoteURL = (smURL || _s.url),\r
-    localURL = (_s.altURL || remoteURL),\r
-    swfTitle = 'JS/Flash audio component (SoundManager 2)',\r
-    oTarget = _getDocument(),\r
-    extraClass = _getSWFCSS(),\r
-    isRTL = null,\r
-    html = _doc.getElementsByTagName('html')[0],\r
-    oEmbed, oMovie, tmp, movieHTML, oEl, s, x, sClass;\r
-    isRTL = (html && html.dir && html.dir.match(/rtl/i));\r
-    smID = (typeof smID === 'undefined'?_s.id:smID);\r
-    function param(name, value) {\r
-      return '<param name="'+name+'" value="'+value+'" />';\r
-    }\r
-    _setVersionInfo();\r
-    _s.url = _normalizeMovieURL(_overHTTP?remoteURL:localURL);\r
-    smURL = _s.url;\r
-    _s.wmode = (!_s.wmode && _s.useHighPerformance ? 'transparent' : _s.wmode);\r
-    if (_s.wmode !== null && (_ua.match(/msie 8/i) || (!_isIE && !_s.useHighPerformance)) && navigator.platform.match(/win32|win64/i)) {\r
-      _s.wmode = null;\r
-    }\r
-    oEmbed = {\r
-      'name': smID,\r
-      'id': smID,\r
-      'src': smURL,\r
-      'quality': 'high',\r
-      'allowScriptAccess': _s.allowScriptAccess,\r
-      'bgcolor': _s.bgColor,\r
-      'pluginspage': _http+'www.macromedia.com/go/getflashplayer',\r
-      'title': swfTitle,\r
-      'type': 'application/x-shockwave-flash',\r
-      'wmode': _s.wmode,\r
-      'hasPriority': 'true'\r
-    };\r
-    if (_s.debugFlash) {\r
-      oEmbed.FlashVars = 'debug=1';\r
-    }\r
-    if (!_s.wmode) {\r
-      delete oEmbed.wmode;\r
-    }\r
-    if (_isIE) {\r
-      oMovie = _doc.createElement('div');\r
-      movieHTML = [\r
-        '<object id="' + smID + '" data="' + smURL + '" type="' + oEmbed.type + '" title="' + oEmbed.title +'" classid="clsid:D27CDB6E-AE6D-11cf-96B8-444553540000" codebase="' + _http+'download.macromedia.com/pub/shockwave/cabs/flash/swflash.cab#version=6,0,40,0">',\r
-        param('movie', smURL),\r
-        param('AllowScriptAccess', _s.allowScriptAccess),\r
-        param('quality', oEmbed.quality),\r
-        (_s.wmode? param('wmode', _s.wmode): ''),\r
-        param('bgcolor', _s.bgColor),\r
-        param('hasPriority', 'true'),\r
-        (_s.debugFlash ? param('FlashVars', oEmbed.FlashVars) : ''),\r
-        '</object>'\r
-      ].join('');\r
-    } else {\r
-      oMovie = _doc.createElement('embed');\r
-      for (tmp in oEmbed) {\r
-        if (oEmbed.hasOwnProperty(tmp)) {\r
-          oMovie.setAttribute(tmp, oEmbed[tmp]);\r
-        }\r
-      }\r
-    }\r
-    _initDebug();\r
-    extraClass = _getSWFCSS();\r
-    oTarget = _getDocument();\r
-    if (oTarget) {\r
-      _s.oMC = (_id(_s.movieID) || _doc.createElement('div'));\r
-      if (!_s.oMC.id) {\r
-        _s.oMC.id = _s.movieID;\r
-        _s.oMC.className = _swfCSS.swfDefault + ' ' + extraClass;\r
-        s = null;\r
-        oEl = null;\r
-        if (!_s.useFlashBlock) {\r
-          if (_s.useHighPerformance) {\r
-            s = {\r
-              'position': 'fixed',\r
-              'width': '8px',\r
-              'height': '8px',\r
-              'bottom': '0px',\r
-              'left': '0px',\r
-              'overflow': 'hidden'\r
-            };\r
-          } else {\r
-            s = {\r
-              'position': 'absolute',\r
-              'width': '6px',\r
-              'height': '6px',\r
-              'top': '-9999px',\r
-              'left': '-9999px'\r
-            };\r
-            if (isRTL) {\r
-              s.left = Math.abs(parseInt(s.left,10))+'px';\r
-            }\r
-          }\r
-        }\r
-        if (_isWebkit) {\r
-          _s.oMC.style.zIndex = 10000;\r
-        }\r
-        if (!_s.debugFlash) {\r
-          for (x in s) {\r
-            if (s.hasOwnProperty(x)) {\r
-              _s.oMC.style[x] = s[x];\r
-            }\r
-          }\r
-        }\r
-        try {\r
-          if (!_isIE) {\r
-            _s.oMC.appendChild(oMovie);\r
-          }\r
-          oTarget.appendChild(_s.oMC);\r
-          if (_isIE) {\r
-            oEl = _s.oMC.appendChild(_doc.createElement('div'));\r
-            oEl.className = _swfCSS.swfBox;\r
-            oEl.innerHTML = movieHTML;\r
-          }\r
-          _appendSuccess = true;\r
-        } catch(e) {\r
-          throw new Error(_str('domError')+' \n'+e.toString());\r
-        }\r
-      } else {\r
-        sClass = _s.oMC.className;\r
-        _s.oMC.className = (sClass?sClass+' ':_swfCSS.swfDefault) + (extraClass?' '+extraClass:'');\r
-        _s.oMC.appendChild(oMovie);\r
-        if (_isIE) {\r
-          oEl = _s.oMC.appendChild(_doc.createElement('div'));\r
-          oEl.className = _swfCSS.swfBox;\r
-          oEl.innerHTML = movieHTML;\r
-        }\r
-        _appendSuccess = true;\r
-      }\r
-    }\r
-    _didAppend = true;\r
-    _initMsg();\r
-    return true;\r
-  };\r
-  _initMovie = function() {\r
-    if (_s.html5Only) {\r
-      _createMovie();\r
-      return false;\r
-    }\r
-    if (_flash) {\r
-      return false;\r
-    }\r
-    if (!_s.url) {\r
-       return false;\r
-    }\r
-    _flash = _s.getMovie(_s.id);\r
-    if (!_flash) {\r
-      if (!_oRemoved) {\r
-        _createMovie(_s.id, _s.url);\r
-      } else {\r
-        if (!_isIE) {\r
-          _s.oMC.appendChild(_oRemoved);\r
-        } else {\r
-          _s.oMC.innerHTML = _oRemovedHTML;\r
-        }\r
-        _oRemoved = null;\r
-        _didAppend = true;\r
-      }\r
-      _flash = _s.getMovie(_s.id);\r
-    }\r
-    if (typeof _s.oninitmovie === 'function') {\r
-      setTimeout(_s.oninitmovie, 1);\r
-    }\r
-    return true;\r
-  };\r
-  _delayWaitForEI = function() {\r
-    setTimeout(_waitForEI, 1000);\r
-  };\r
-  _waitForEI = function() {\r
-    var p,\r
-        loadIncomplete = false;\r
-    if (!_s.url) {\r
-      return false;\r
-    }\r
-    if (_waitingForEI) {\r
-      return false;\r
-    }\r
-    _waitingForEI = true;\r
-    _event.remove(_win, 'load', _delayWaitForEI);\r
-    if (_tryInitOnFocus && !_isFocused) {\r
-      return false;\r
-    }\r
-    if (!_didInit) {\r
-      p = _s.getMoviePercent();\r
-      if (p > 0 && p < 100) {\r
-        loadIncomplete = true;\r
-      }\r
-    }\r
-    setTimeout(function() {\r
-      p = _s.getMoviePercent();\r
-      if (loadIncomplete) {\r
-        _waitingForEI = false;\r
-        _win.setTimeout(_delayWaitForEI, 1);\r
-        return false;\r
-      }\r
-      if (!_didInit && _okToDisable) {\r
-        if (p === null) {\r
-          if (_s.useFlashBlock || _s.flashLoadTimeout === 0) {\r
-            if (_s.useFlashBlock) {\r
-              _flashBlockHandler();\r
-            }\r
-          } else {\r
-            _failSafely(true);\r
-          }\r
-        } else {\r
-          if (_s.flashLoadTimeout === 0) {\r
-          } else {\r
-            _failSafely(true);\r
-          }\r
-        }\r
-      }\r
-    }, _s.flashLoadTimeout);\r
-  };\r
-  _handleFocus = function() {\r
-    function cleanup() {\r
-      _event.remove(_win, 'focus', _handleFocus);\r
-    }\r
-    if (_isFocused || !_tryInitOnFocus) {\r
-      cleanup();\r
-      return true;\r
-    }\r
-    _okToDisable = true;\r
-    _isFocused = true;\r
-    _waitingForEI = false;\r
-    _delayWaitForEI();\r
-    cleanup();\r
-    return true;\r
-  };\r
-  _showSupport = function() {\r
-  };\r
-  _initComplete = function(bNoDisable) {\r
-    if (_didInit) {\r
-      return false;\r
-    }\r
-    if (_s.html5Only) {\r
-      _didInit = true;\r
-      _initUserOnload();\r
-      return true;\r
-    }\r
-    var wasTimeout = (_s.useFlashBlock && _s.flashLoadTimeout && !_s.getMoviePercent()),\r
-        result = true,\r
-        error;\r
-    if (!wasTimeout) {\r
-      _didInit = true;\r
-      if (_disabled) {\r
-        error = {type: (!_hasFlash && _needsFlash ? 'NO_FLASH' : 'INIT_TIMEOUT')};\r
-      }\r
-    }\r
-    if (_disabled || bNoDisable) {\r
-      if (_s.useFlashBlock && _s.oMC) {\r
-        _s.oMC.className = _getSWFCSS() + ' ' + (_s.getMoviePercent() === null?_swfCSS.swfTimedout:_swfCSS.swfError);\r
-      }\r
-      _processOnEvents({type:'ontimeout', error:error, ignoreInit: true});\r
-      _catchError(error);\r
-      result = false;\r
-    } else {\r
-    }\r
-    if (!_disabled) {\r
-      if (_s.waitForWindowLoad && !_windowLoaded) {\r
-        _event.add(_win, 'load', _initUserOnload);\r
-      } else {\r
-        _initUserOnload();\r
-      }\r
-    }\r
-    return result;\r
-  };\r
-  _setProperties = function() {\r
-    var i,\r
-        o = _s.setupOptions;\r
-    for (i in o) {\r
-      if (o.hasOwnProperty(i)) {\r
-        if (typeof _s[i] === 'undefined') {\r
-          _s[i] = o[i];\r
-        } else if (_s[i] !== o[i]) {\r
-          _s.setupOptions[i] = _s[i];\r
-        }\r
-      }\r
-    }\r
-  };\r
-  _init = function() {\r
-    if (_didInit) {\r
-      return false;\r
-    }\r
-    function _cleanup() {\r
-      _event.remove(_win, 'load', _s.beginDelayedInit);\r
-    }\r
-    if (_s.html5Only) {\r
-      if (!_didInit) {\r
-        _cleanup();\r
-        _s.enabled = true;\r
-        _initComplete();\r
-      }\r
-      return true;\r
-    }\r
-    _initMovie();\r
-    try {\r
-      _flash._externalInterfaceTest(false);\r
-      _setPolling(true, (_s.flashPollingInterval || (_s.useHighPerformance ? 10 : 50)));\r
-      if (!_s.debugMode) {\r
-        _flash._disableDebug();\r
-      }\r
-      _s.enabled = true;\r
-      if (!_s.html5Only) {\r
-        _event.add(_win, 'unload', _doNothing);\r
-      }\r
-    } catch(e) {\r
-      _catchError({type:'JS_TO_FLASH_EXCEPTION', fatal:true});\r
-      _failSafely(true);\r
-      _initComplete();\r
-      return false;\r
-    }\r
-    _initComplete();\r
-    _cleanup();\r
-    return true;\r
-  };\r
-  _domContentLoaded = function() {\r
-    if (_didDCLoaded) {\r
-      return false;\r
-    }\r
-    _didDCLoaded = true;\r
-    _setProperties();\r
-    _initDebug();\r
-    if (!_hasFlash && _s.hasHTML5) {\r
-      _s.setup({\r
-        'useHTML5Audio': true,\r
-        'preferFlash': false\r
-      });\r
-    }\r
-    _testHTML5();\r
-    _s.html5.usingFlash = _featureCheck();\r
-    _needsFlash = _s.html5.usingFlash;\r
-    _showSupport();\r
-    if (!_hasFlash && _needsFlash) {\r
-      _s.setup({\r
-        'flashLoadTimeout': 1\r
-      });\r
-    }\r
-    if (_doc.removeEventListener) {\r
-      _doc.removeEventListener('DOMContentLoaded', _domContentLoaded, false);\r
-    }\r
-    _initMovie();\r
-    return true;\r
-  };\r
-  _domContentLoadedIE = function() {\r
-    if (_doc.readyState === 'complete') {\r
-      _domContentLoaded();\r
-      _doc.detachEvent('onreadystatechange', _domContentLoadedIE);\r
-    }\r
-    return true;\r
-  };\r
-  _winOnLoad = function() {\r
-    _windowLoaded = true;\r
-    _event.remove(_win, 'load', _winOnLoad);\r
-  };\r
-  _detectFlash();\r
-  _event.add(_win, 'focus', _handleFocus);\r
-  _event.add(_win, 'load', _delayWaitForEI);\r
-  _event.add(_win, 'load', _winOnLoad);\r
-  if (_doc.addEventListener) {\r
-    _doc.addEventListener('DOMContentLoaded', _domContentLoaded, false);\r
-  } else if (_doc.attachEvent) {\r
-    _doc.attachEvent('onreadystatechange', _domContentLoadedIE);\r
-  } else {\r
-    _catchError({type:'NO_DOM2_EVENTS', fatal:true});\r
-  }\r
-}\r
-// SM2_DEFER details: http://www.schillmania.com/projects/soundmanager2/doc/getstarted/#lazy-loading\r
-if (typeof SM2_DEFER === 'undefined' || !SM2_DEFER) {\r
-  soundManager = new SoundManager();\r
-}\r
-window.SoundManager = SoundManager;\r
-window.soundManager = soundManager;\r
-}(window));
\ No newline at end of file
diff --git a/timeside/static/timeside/js/libs/soundmanager2.js b/timeside/static/timeside/js/libs/soundmanager2.js
deleted file mode 100644 (file)
index d9d4422..0000000
+++ /dev/null
@@ -1,5530 +0,0 @@
-/** @license\r
- *\r
- * SoundManager 2: JavaScript Sound for the Web\r
- * ----------------------------------------------\r
- * http://schillmania.com/projects/soundmanager2/\r
- *\r
- * Copyright (c) 2007, Scott Schiller. All rights reserved.\r
- * Code provided under the BSD License:\r
- * http://schillmania.com/projects/soundmanager2/license.txt\r
- *\r
- * V2.97a.20120916\r
- */\r
-\r
-/*global window, SM2_DEFER, sm2Debugger, console, document, navigator, setTimeout, setInterval, clearInterval, Audio */\r
-/*jslint regexp: true, sloppy: true, white: true, nomen: true, plusplus: true */\r
-\r
-/**\r
- * About this file\r
- * ---------------\r
- * This is the fully-commented source version of the SoundManager 2 API,\r
- * recommended for use during development and testing.\r
- *\r
- * See soundmanager2-nodebug-jsmin.js for an optimized build (~11KB with gzip.)\r
- * http://schillmania.com/projects/soundmanager2/doc/getstarted/#basic-inclusion\r
- * Alternately, serve this file with gzip for 75% compression savings (~30KB over HTTP.)\r
- *\r
- * You may notice <d> and </d> comments in this source; these are delimiters for\r
- * debug blocks which are removed in the -nodebug builds, further optimizing code size.\r
- *\r
- * Also, as you may note: Whoa, reliable cross-platform/device audio support is hard! ;)\r
- */\r
-\r
-(function(window) {\r
-\r
-var soundManager = null;\r
-\r
-/**\r
- * The SoundManager constructor.\r
- *\r
- * @constructor\r
- * @param {string} smURL Optional: Path to SWF files\r
- * @param {string} smID Optional: The ID to use for the SWF container element\r
- * @this {SoundManager}\r
- * @return {SoundManager} The new SoundManager instance\r
- */\r
-\r
-function SoundManager(smURL, smID) {\r
-\r
-  /**\r
-   * soundManager configuration options list\r
-   * defines top-level configuration properties to be applied to the soundManager instance (eg. soundManager.flashVersion)\r
-   * to set these properties, use the setup() method - eg., soundManager.setup({url: '/swf/', flashVersion: 9})\r
-   */\r
-\r
-  this.setupOptions = {\r
-\r
-    'url': (smURL || null),             // path (directory) where SoundManager 2 SWFs exist, eg., /path/to/swfs/\r
-    'flashVersion': 8,                  // flash build to use (8 or 9.) Some API features require 9.\r
-    'debugMode': true,                  // enable debugging output (console.log() with HTML fallback)\r
-    'debugFlash': false,                // enable debugging output inside SWF, troubleshoot Flash/browser issues\r
-    'useConsole': true,                 // use console.log() if available (otherwise, writes to #soundmanager-debug element)\r
-    'consoleOnly': true,                // if console is being used, do not create/write to #soundmanager-debug\r
-    'waitForWindowLoad': false,         // force SM2 to wait for window.onload() before trying to call soundManager.onload()\r
-    'bgColor': '#ffffff',               // SWF background color. N/A when wmode = 'transparent'\r
-    'useHighPerformance': false,        // position:fixed flash movie can help increase js/flash speed, minimize lag\r
-    'flashPollingInterval': null,       // msec affecting whileplaying/loading callback frequency. If null, default of 50 msec is used.\r
-    'html5PollingInterval': null,       // msec affecting whileplaying() for HTML5 audio, excluding mobile devices. If null, native HTML5 update events are used.\r
-    'flashLoadTimeout': 1000,           // msec to wait for flash movie to load before failing (0 = infinity)\r
-    'wmode': null,                      // flash rendering mode - null, 'transparent', or 'opaque' (last two allow z-index to work)\r
-    'allowScriptAccess': 'always',      // for scripting the SWF (object/embed property), 'always' or 'sameDomain'\r
-    'useFlashBlock': false,             // *requires flashblock.css, see demos* - allow recovery from flash blockers. Wait indefinitely and apply timeout CSS to SWF, if applicable.\r
-    'useHTML5Audio': true,              // use HTML5 Audio() where API is supported (most Safari, Chrome versions), Firefox (no MP3/MP4.) Ideally, transparent vs. Flash API where possible.\r
-    'html5Test': /^(probably|maybe)$/i, // HTML5 Audio() format support test. Use /^probably$/i; if you want to be more conservative.\r
-    'preferFlash': true,                // overrides useHTML5audio. if true and flash support present, will try to use flash for MP3/MP4 as needed since HTML5 audio support is still quirky in browsers.\r
-    'noSWFCache': false                 // if true, appends ?ts={date} to break aggressive SWF caching.\r
-\r
-  };\r
-\r
-  this.defaultOptions = {\r
-\r
-    /**\r
-     * the default configuration for sound objects made with createSound() and related methods\r
-     * eg., volume, auto-load behaviour and so forth\r
-     */\r
-\r
-    'autoLoad': false,        // enable automatic loading (otherwise .load() will be called on demand with .play(), the latter being nicer on bandwidth - if you want to .load yourself, you also can)\r
-    'autoPlay': false,        // enable playing of file as soon as possible (much faster if "stream" is true)\r
-    'from': null,             // position to start playback within a sound (msec), default = beginning\r
-    'loops': 1,               // how many times to repeat the sound (position will wrap around to 0, setPosition() will break out of loop when >0)\r
-    'onid3': null,            // callback function for "ID3 data is added/available"\r
-    'onload': null,           // callback function for "load finished"\r
-    'whileloading': null,     // callback function for "download progress update" (X of Y bytes received)\r
-    'onplay': null,           // callback for "play" start\r
-    'onpause': null,          // callback for "pause"\r
-    'onresume': null,         // callback for "resume" (pause toggle)\r
-    'whileplaying': null,     // callback during play (position update)\r
-    'onposition': null,       // object containing times and function callbacks for positions of interest\r
-    'onstop': null,           // callback for "user stop"\r
-    'onfailure': null,        // callback function for when playing fails\r
-    'onfinish': null,         // callback function for "sound finished playing"\r
-    'multiShot': true,        // let sounds "restart" or layer on top of each other when played multiple times, rather than one-shot/one at a time\r
-    'multiShotEvents': false, // fire multiple sound events (currently onfinish() only) when multiShot is enabled\r
-    'position': null,         // offset (milliseconds) to seek to within loaded sound data.\r
-    'pan': 0,                 // "pan" settings, left-to-right, -100 to 100\r
-    'stream': true,           // allows playing before entire file has loaded (recommended)\r
-    'to': null,               // position to end playback within a sound (msec), default = end\r
-    'type': null,             // MIME-like hint for file pattern / canPlay() tests, eg. audio/mp3\r
-    'usePolicyFile': false,   // enable crossdomain.xml request for audio on remote domains (for ID3/waveform access)\r
-    'volume': 100             // self-explanatory. 0-100, the latter being the max.\r
-\r
-  };\r
-\r
-  this.flash9Options = {\r
-\r
-    /**\r
-     * flash 9-only options,\r
-     * merged into defaultOptions if flash 9 is being used\r
-     */\r
-\r
-    'isMovieStar': null,      // "MovieStar" MPEG4 audio mode. Null (default) = auto detect MP4, AAC etc. based on URL. true = force on, ignore URL\r
-    'usePeakData': false,     // enable left/right channel peak (level) data\r
-    'useWaveformData': false, // enable sound spectrum (raw waveform data) - NOTE: May increase CPU load.\r
-    'useEQData': false,       // enable sound EQ (frequency spectrum data) - NOTE: May increase CPU load.\r
-    'onbufferchange': null,   // callback for "isBuffering" property change\r
-    'ondataerror': null       // callback for waveform/eq data access error (flash playing audio in other tabs/domains)\r
-\r
-  };\r
-\r
-  this.movieStarOptions = {\r
-\r
-    /**\r
-     * flash 9.0r115+ MPEG4 audio options,\r
-     * merged into defaultOptions if flash 9+movieStar mode is enabled\r
-     */\r
-\r
-    'bufferTime': 3,          // seconds of data to buffer before playback begins (null = flash default of 0.1 seconds - if AAC playback is gappy, try increasing.)\r
-    'serverURL': null,        // rtmp: FMS or FMIS server to connect to, required when requesting media via RTMP or one of its variants\r
-    'onconnect': null,        // rtmp: callback for connection to flash media server\r
-    'duration': null          // rtmp: song duration (msec)\r
-\r
-  };\r
-\r
-  this.audioFormats = {\r
-\r
-    /**\r
-     * determines HTML5 support + flash requirements.\r
-     * if no support (via flash and/or HTML5) for a "required" format, SM2 will fail to start.\r
-     * flash fallback is used for MP3 or MP4 if HTML5 can't play it (or if preferFlash = true)\r
-     */\r
-\r
-    'mp3': {\r
-      'type': ['audio/mpeg; codecs="mp3"', 'audio/mpeg', 'audio/mp3', 'audio/MPA', 'audio/mpa-robust'],\r
-      'required': true\r
-    },\r
-\r
-    'mp4': {\r
-      'related': ['aac','m4a','m4b'], // additional formats under the MP4 container\r
-      'type': ['audio/mp4; codecs="mp4a.40.2"', 'audio/aac', 'audio/x-m4a', 'audio/MP4A-LATM', 'audio/mpeg4-generic'],\r
-      'required': false\r
-    },\r
-\r
-    'ogg': {\r
-      'type': ['audio/ogg; codecs=vorbis'],\r
-      'required': false\r
-    },\r
-\r
-    'wav': {\r
-      'type': ['audio/wav; codecs="1"', 'audio/wav', 'audio/wave', 'audio/x-wav'],\r
-      'required': false\r
-    }\r
-\r
-  };\r
-\r
-  // HTML attributes (id + class names) for the SWF container\r
-\r
-  this.movieID = 'sm2-container';\r
-  this.id = (smID || 'sm2movie');\r
-\r
-  this.debugID = 'soundmanager-debug';\r
-  this.debugURLParam = /([#?&])debug=1/i;\r
-\r
-  // dynamic attributes\r
-\r
-  this.versionNumber = 'V2.97a.20120916';\r
-  this.version = null;\r
-  this.movieURL = null;\r
-  this.altURL = null;\r
-  this.swfLoaded = false;\r
-  this.enabled = false;\r
-  this.oMC = null;\r
-  this.sounds = {};\r
-  this.soundIDs = [];\r
-  this.muted = false;\r
-  this.didFlashBlock = false;\r
-  this.filePattern = null;\r
-\r
-  this.filePatterns = {\r
-\r
-    'flash8': /\.mp3(\?.*)?$/i,\r
-    'flash9': /\.mp3(\?.*)?$/i\r
-\r
-  };\r
-\r
-  // support indicators, set at init\r
-\r
-  this.features = {\r
-\r
-    'buffering': false,\r
-    'peakData': false,\r
-    'waveformData': false,\r
-    'eqData': false,\r
-    'movieStar': false\r
-\r
-  };\r
-\r
-  // flash sandbox info, used primarily in troubleshooting\r
-\r
-  this.sandbox = {\r
-\r
-    // <d>\r
-    'type': null,\r
-    'types': {\r
-      'remote': 'remote (domain-based) rules',\r
-      'localWithFile': 'local with file access (no internet access)',\r
-      'localWithNetwork': 'local with network (internet access only, no local access)',\r
-      'localTrusted': 'local, trusted (local+internet access)'\r
-    },\r
-    'description': null,\r
-    'noRemote': null,\r
-    'noLocal': null\r
-    // </d>\r
-\r
-  };\r
-\r
-  /**\r
-   * basic HTML5 Audio() support test\r
-   * try...catch because of IE 9 "not implemented" nonsense\r
-   * https://github.com/Modernizr/Modernizr/issues/224\r
-   */\r
-\r
-  this.hasHTML5 = (function() {\r
-    try {\r
-      // new Audio(null) for stupid Opera 9.64 case, which throws not_enough_arguments exception otherwise.\r
-      return (typeof Audio !== 'undefined' && typeof (_isOpera && opera.version() < 10 ? new Audio(null) : new Audio()).canPlayType !== 'undefined');\r
-    } catch(e) {\r
-      return false;\r
-    }\r
-  }());\r
-\r
-  /**\r
-   * format support (html5/flash)\r
-   * stores canPlayType() results based on audioFormats.\r
-   * eg. { mp3: boolean, mp4: boolean }\r
-   * treat as read-only.\r
-   */\r
-\r
-  this.html5 = {\r
-    'usingFlash': null // set if/when flash fallback is needed\r
-  };\r
-\r
-  // file type support hash\r
-  this.flash = {};\r
-\r
-  // determined at init time\r
-  this.html5Only = false;\r
-\r
-  // used for special cases (eg. iPad/iPhone/palm OS?)\r
-  this.ignoreFlash = false;\r
-\r
-  /**\r
-   * a few private internals (OK, a lot. :D)\r
-   */\r
-\r
-  var SMSound,\r
-  _s = this, _flash = null, _sm = 'soundManager', _smc = _sm+'::', _h5 = 'HTML5::', _id, _ua = navigator.userAgent, _win = window, _wl = _win.location.href.toString(), _doc = document, _doNothing, _setProperties, _init, _fV, _on_queue = [], _debugOpen = true, _debugTS, _didAppend = false, _appendSuccess = false, _didInit = false, _disabled = false, _windowLoaded = false, _wDS, _wdCount = 0, _initComplete, _mixin, _assign, _extraOptions, _addOnEvent, _processOnEvents, _initUserOnload, _delayWaitForEI, _waitForEI, _setVersionInfo, _handleFocus, _strings, _initMovie, _domContentLoaded, _winOnLoad, _didDCLoaded, _getDocument, _createMovie, _catchError, _setPolling, _initDebug, _debugLevels = ['log', 'info', 'warn', 'error'], _defaultFlashVersion = 8, _disableObject, _failSafely, _normalizeMovieURL, _oRemoved = null, _oRemovedHTML = null, _str, _flashBlockHandler, _getSWFCSS, _swfCSS, _toggleDebug, _loopFix, _policyFix, _complain, _idCheck, _waitingForEI = false, _initPending = false, _startTimer, _stopTimer, _timerExecute, _h5TimerCount = 0, _h5IntervalTimer = null, _parseURL,\r
-  _needsFlash = null, _featureCheck, _html5OK, _html5CanPlay, _html5Ext, _html5Unload, _domContentLoadedIE, _testHTML5, _event, _slice = Array.prototype.slice, _useGlobalHTML5Audio = false, _hasFlash, _detectFlash, _badSafariFix, _html5_events, _showSupport,\r
-  _is_iDevice = _ua.match(/(ipad|iphone|ipod)/i), _isIE = _ua.match(/msie/i), _isWebkit = _ua.match(/webkit/i), _isSafari = (_ua.match(/safari/i) && !_ua.match(/chrome/i)), _isOpera = (_ua.match(/opera/i)), \r
-  _mobileHTML5 = (_ua.match(/(mobile|pre\/|xoom)/i) || _is_iDevice),\r
-  _isBadSafari = (!_wl.match(/usehtml5audio/i) && !_wl.match(/sm2\-ignorebadua/i) && _isSafari && !_ua.match(/silk/i) && _ua.match(/OS X 10_6_([3-7])/i)), // Safari 4 and 5 (excluding Kindle Fire, "Silk") occasionally fail to load/play HTML5 audio on Snow Leopard 10.6.3 through 10.6.7 due to bug(s) in QuickTime X and/or other underlying frameworks. :/ Confirmed bug. https://bugs.webkit.org/show_bug.cgi?id=32159\r
-  _hasConsole = (typeof console !== 'undefined' && typeof console.log !== 'undefined'), _isFocused = (typeof _doc.hasFocus !== 'undefined'?_doc.hasFocus():null), _tryInitOnFocus = (_isSafari && (typeof _doc.hasFocus === 'undefined' || !_doc.hasFocus())), _okToDisable = !_tryInitOnFocus, _flashMIME = /(mp3|mp4|mpa|m4a|m4b)/i,\r
-  _emptyURL = 'about:blank', // safe URL to unload, or load nothing from (flash 8 + most HTML5 UAs)\r
-  _overHTTP = (_doc.location?_doc.location.protocol.match(/http/i):null),\r
-  _http = (!_overHTTP ? 'http:/'+'/' : ''),\r
-  // mp3, mp4, aac etc.\r
-  _netStreamMimeTypes = /^\s*audio\/(?:x-)?(?:mpeg4|aac|flv|mov|mp4||m4v|m4a|m4b|mp4v|3gp|3g2)\s*(?:$|;)/i,\r
-  // Flash v9.0r115+ "moviestar" formats\r
-  _netStreamTypes = ['mpeg4', 'aac', 'flv', 'mov', 'mp4', 'm4v', 'f4v', 'm4a', 'm4b', 'mp4v', '3gp', '3g2'],\r
-  _netStreamPattern = new RegExp('\\.(' + _netStreamTypes.join('|') + ')(\\?.*)?$', 'i');\r
-\r
-  this.mimePattern = /^\s*audio\/(?:x-)?(?:mp(?:eg|3))\s*(?:$|;)/i; // default mp3 set\r
-\r
-  // use altURL if not "online"\r
-  this.useAltURL = !_overHTTP;\r
-\r
-  this._global_a = null;\r
-\r
-  _swfCSS = {\r
-\r
-    'swfBox': 'sm2-object-box',\r
-    'swfDefault': 'movieContainer',\r
-    'swfError': 'swf_error', // SWF loaded, but SM2 couldn't start (other error)\r
-    'swfTimedout': 'swf_timedout',\r
-    'swfLoaded': 'swf_loaded',\r
-    'swfUnblocked': 'swf_unblocked', // or loaded OK\r
-    'sm2Debug': 'sm2_debug',\r
-    'highPerf': 'high_performance',\r
-    'flashDebug': 'flash_debug'\r
-\r
-  };\r
-\r
-  if (_mobileHTML5) {\r
-\r
-    // prefer HTML5 for mobile + tablet-like devices, probably more reliable vs. flash at this point.\r
-    _s.useHTML5Audio = true;\r
-    _s.preferFlash = false;\r
-\r
-    if (_is_iDevice) {\r
-      // by default, use global feature. iOS onfinish() -> next may fail otherwise.\r
-      _s.ignoreFlash = true;\r
-      _useGlobalHTML5Audio = true;\r
-    }\r
-\r
-  }\r
-\r
-  /**\r
-   * Public SoundManager API\r
-   * -----------------------\r
-   */\r
-\r
-  /**\r
-   * Configures top-level soundManager properties.\r
-   *\r
-   * @param {object} options Option parameters, eg. { flashVersion: 9, url: '/path/to/swfs/' }\r
-   * onready and ontimeout are also accepted parameters. call soundManager.setup() to see the full list.\r
-   */\r
-\r
-  this.setup = function(options) {\r
-\r
-    var noURL = (!_s.url);\r
-\r
-    // warn if flash options have already been applied\r
-\r
-    if (typeof options !== 'undefined' && _didInit && _needsFlash && _s.ok() && (typeof options.flashVersion !== 'undefined' || typeof options.url !== 'undefined')) {\r
-      _complain(_str('setupLate'));\r
-    }\r
-\r
-    // TODO: defer: true?\r
-\r
-    _assign(options);\r
-\r
-    // special case 1: "Late setup". SM2 loaded normally, but user didn't assign flash URL eg., setup({url:...}) before SM2 init. Treat as delayed init.\r
-\r
-    if (noURL && _didDCLoaded && typeof options.url !== 'undefined') {\r
-      _s.beginDelayedInit();\r
-    }\r
-\r
-    // special case 2: If lazy-loading SM2 (DOMContentLoaded has already happened) and user calls setup() with url: parameter, try to init ASAP.\r
-\r
-    if (!_didDCLoaded && typeof options.url !== 'undefined' && _doc.readyState === 'complete') {\r
-      setTimeout(_domContentLoaded, 1);\r
-    }\r
-\r
-    return _s;\r
-\r
-  };\r
-\r
-  this.ok = function() {\r
-\r
-    return (_needsFlash?(_didInit && !_disabled):(_s.useHTML5Audio && _s.hasHTML5));\r
-\r
-  };\r
-\r
-  this.supported = this.ok; // legacy\r
-\r
-  this.getMovie = function(smID) {\r
-\r
-    // safety net: some old browsers differ on SWF references, possibly related to ExternalInterface / flash version\r
-    return _id(smID) || _doc[smID] || _win[smID];\r
-\r
-  };\r
-\r
-  /**\r
-   * Creates a SMSound sound object instance.\r
-   *\r
-   * @param {object} oOptions Sound options (at minimum, id and url parameters are required.)\r
-   * @return {object} SMSound The new SMSound object.\r
-   */\r
-\r
-  this.createSound = function(oOptions, _url) {\r
-\r
-    var _cs, _cs_string, thisOptions = null, oSound = null, _tO = null;\r
-\r
-    // <d>\r
-    _cs = _sm+'.createSound(): ';\r
-    _cs_string = _cs + _str(!_didInit?'notReady':'notOK');\r
-    // </d>\r
-\r
-    if (!_didInit || !_s.ok()) {\r
-      _complain(_cs_string);\r
-      return false;\r
-    }\r
-\r
-    if (typeof _url !== 'undefined') {\r
-      // function overloading in JS! :) ..assume simple createSound(id,url) use case\r
-      oOptions = {\r
-        'id': oOptions,\r
-        'url': _url\r
-      };\r
-    }\r
-\r
-    // inherit from defaultOptions\r
-    thisOptions = _mixin(oOptions);\r
-\r
-    thisOptions.url = _parseURL(thisOptions.url);\r
-\r
-    // local shortcut\r
-    _tO = thisOptions;\r
-\r
-    // <d>\r
-    if (_tO.id.toString().charAt(0).match(/^[0-9]$/)) {\r
-      _s._wD(_cs + _str('badID', _tO.id), 2);\r
-    }\r
-\r
-    _s._wD(_cs + _tO.id + ' (' + _tO.url + ')', 1);\r
-    // </d>\r
-\r
-    if (_idCheck(_tO.id, true)) {\r
-      _s._wD(_cs + _tO.id + ' exists', 1);\r
-      return _s.sounds[_tO.id];\r
-    }\r
-\r
-    function make() {\r
-\r
-      thisOptions = _loopFix(thisOptions);\r
-      _s.sounds[_tO.id] = new SMSound(_tO);\r
-      _s.soundIDs.push(_tO.id);\r
-      return _s.sounds[_tO.id];\r
-\r
-    }\r
-\r
-    if (_html5OK(_tO)) {\r
-\r
-      oSound = make();\r
-      _s._wD('Creating sound '+_tO.id+', using HTML5');\r
-      oSound._setup_html5(_tO);\r
-\r
-    } else {\r
-\r
-      if (_fV > 8) {\r
-        if (_tO.isMovieStar === null) {\r
-          // attempt to detect MPEG-4 formats\r
-          _tO.isMovieStar = !!(_tO.serverURL || (_tO.type ? _tO.type.match(_netStreamMimeTypes) : false) || _tO.url.match(_netStreamPattern));\r
-        }\r
-        // <d>\r
-        if (_tO.isMovieStar) {\r
-          _s._wD(_cs + 'using MovieStar handling');\r
-          if (_tO.loops > 1) {\r
-            _wDS('noNSLoop');\r
-          }\r
-        }\r
-        // </d>\r
-      }\r
-\r
-      _tO = _policyFix(_tO, _cs);\r
-      oSound = make();\r
-\r
-      if (_fV === 8) {\r
-        _flash._createSound(_tO.id, _tO.loops||1, _tO.usePolicyFile);\r
-      } else {\r
-        _flash._createSound(_tO.id, _tO.url, _tO.usePeakData, _tO.useWaveformData, _tO.useEQData, _tO.isMovieStar, (_tO.isMovieStar?_tO.bufferTime:false), _tO.loops||1, _tO.serverURL, _tO.duration||null, _tO.autoPlay, true, _tO.autoLoad, _tO.usePolicyFile);\r
-        if (!_tO.serverURL) {\r
-          // We are connected immediately\r
-          oSound.connected = true;\r
-          if (_tO.onconnect) {\r
-            _tO.onconnect.apply(oSound);\r
-          }\r
-        }\r
-      }\r
-\r
-      if (!_tO.serverURL && (_tO.autoLoad || _tO.autoPlay)) {\r
-        // call load for non-rtmp streams\r
-        oSound.load(_tO);\r
-      }\r
-\r
-    }\r
-\r
-    // rtmp will play in onconnect\r
-    if (!_tO.serverURL && _tO.autoPlay) {\r
-      oSound.play();\r
-    }\r
-\r
-    return oSound;\r
-\r
-  };\r
-\r
-  /**\r
-   * Destroys a SMSound sound object instance.\r
-   *\r
-   * @param {string} sID The ID of the sound to destroy\r
-   */\r
-\r
-  this.destroySound = function(sID, _bFromSound) {\r
-\r
-    // explicitly destroy a sound before normal page unload, etc.\r
-\r
-    if (!_idCheck(sID)) {\r
-      return false;\r
-    }\r
-\r
-    var oS = _s.sounds[sID], i;\r
-\r
-    // Disable all callbacks while the sound is being destroyed\r
-    oS._iO = {};\r
-\r
-    oS.stop();\r
-    oS.unload();\r
-\r
-    for (i = 0; i < _s.soundIDs.length; i++) {\r
-      if (_s.soundIDs[i] === sID) {\r
-        _s.soundIDs.splice(i, 1);\r
-        break;\r
-      }\r
-    }\r
-\r
-    if (!_bFromSound) {\r
-      // ignore if being called from SMSound instance\r
-      oS.destruct(true);\r
-    }\r
-\r
-    oS = null;\r
-    delete _s.sounds[sID];\r
-\r
-    return true;\r
-\r
-  };\r
-\r
-  /**\r
-   * Calls the load() method of a SMSound object by ID.\r
-   *\r
-   * @param {string} sID The ID of the sound\r
-   * @param {object} oOptions Optional: Sound options\r
-   */\r
-\r
-  this.load = function(sID, oOptions) {\r
-\r
-    if (!_idCheck(sID)) {\r
-      return false;\r
-    }\r
-    return _s.sounds[sID].load(oOptions);\r
-\r
-  };\r
-\r
-  /**\r
-   * Calls the unload() method of a SMSound object by ID.\r
-   *\r
-   * @param {string} sID The ID of the sound\r
-   */\r
-\r
-  this.unload = function(sID) {\r
-\r
-    if (!_idCheck(sID)) {\r
-      return false;\r
-    }\r
-    return _s.sounds[sID].unload();\r
-\r
-  };\r
-\r
-  /**\r
-   * Calls the onPosition() method of a SMSound object by ID.\r
-   *\r
-   * @param {string} sID The ID of the sound\r
-   * @param {number} nPosition The position to watch for\r
-   * @param {function} oMethod The relevant callback to fire\r
-   * @param {object} oScope Optional: The scope to apply the callback to\r
-   * @return {SMSound} The SMSound object\r
-   */\r
-\r
-  this.onPosition = function(sID, nPosition, oMethod, oScope) {\r
-\r
-    if (!_idCheck(sID)) {\r
-      return false;\r
-    }\r
-    return _s.sounds[sID].onposition(nPosition, oMethod, oScope);\r
-\r
-  };\r
-\r
-  // legacy/backwards-compability: lower-case method name\r
-  this.onposition = this.onPosition;\r
-\r
-  /**\r
-   * Calls the clearOnPosition() method of a SMSound object by ID.\r
-   *\r
-   * @param {string} sID The ID of the sound\r
-   * @param {number} nPosition The position to watch for\r
-   * @param {function} oMethod Optional: The relevant callback to fire\r
-   * @return {SMSound} The SMSound object\r
-   */\r
-\r
-  this.clearOnPosition = function(sID, nPosition, oMethod) {\r
-\r
-    if (!_idCheck(sID)) {\r
-      return false;\r
-    }\r
-    return _s.sounds[sID].clearOnPosition(nPosition, oMethod);\r
-\r
-  };\r
-\r
-  /**\r
-   * Calls the play() method of a SMSound object by ID.\r
-   *\r
-   * @param {string} sID The ID of the sound\r
-   * @param {object} oOptions Optional: Sound options\r
-   * @return {SMSound} The SMSound object\r
-   */\r
-\r
-  this.play = function(sID, oOptions) {\r
-\r
-    var result = false;\r
-\r
-    if (!_didInit || !_s.ok()) {\r
-      _complain(_sm+'.play(): ' + _str(!_didInit?'notReady':'notOK'));\r
-      return result;\r
-    }\r
-\r
-    if (!_idCheck(sID)) {\r
-      if (!(oOptions instanceof Object)) {\r
-        // overloading use case: play('mySound','/path/to/some.mp3');\r
-        oOptions = {\r
-          url: oOptions\r
-        };\r
-      }\r
-      if (oOptions && oOptions.url) {\r
-        // overloading use case, create+play: .play('someID',{url:'/path/to.mp3'});\r
-        _s._wD(_sm+'.play(): attempting to create "' + sID + '"', 1);\r
-        oOptions.id = sID;\r
-        result = _s.createSound(oOptions).play();\r
-      }\r
-      return result;\r
-    }\r
-\r
-    return _s.sounds[sID].play(oOptions);\r
-\r
-  };\r
-\r
-  this.start = this.play; // just for convenience\r
-\r
-  /**\r
-   * Calls the setPosition() method of a SMSound object by ID.\r
-   *\r
-   * @param {string} sID The ID of the sound\r
-   * @param {number} nMsecOffset Position (milliseconds)\r
-   * @return {SMSound} The SMSound object\r
-   */\r
-\r
-  this.setPosition = function(sID, nMsecOffset) {\r
-\r
-    if (!_idCheck(sID)) {\r
-      return false;\r
-    }\r
-    return _s.sounds[sID].setPosition(nMsecOffset);\r
-\r
-  };\r
-\r
-  /**\r
-   * Calls the stop() method of a SMSound object by ID.\r
-   *\r
-   * @param {string} sID The ID of the sound\r
-   * @return {SMSound} The SMSound object\r
-   */\r
-\r
-  this.stop = function(sID) {\r
-\r
-    if (!_idCheck(sID)) {\r
-      return false;\r
-    }\r
-\r
-    _s._wD(_sm+'.stop(' + sID + ')', 1);\r
-    return _s.sounds[sID].stop();\r
-\r
-  };\r
-\r
-  /**\r
-   * Stops all currently-playing sounds.\r
-   */\r
-\r
-  this.stopAll = function() {\r
-\r
-    var oSound;\r
-    _s._wD(_sm+'.stopAll()', 1);\r
-\r
-    for (oSound in _s.sounds) {\r
-      if (_s.sounds.hasOwnProperty(oSound)) {\r
-        // apply only to sound objects\r
-        _s.sounds[oSound].stop();\r
-      }\r
-    }\r
-\r
-  };\r
-\r
-  /**\r
-   * Calls the pause() method of a SMSound object by ID.\r
-   *\r
-   * @param {string} sID The ID of the sound\r
-   * @return {SMSound} The SMSound object\r
-   */\r
-\r
-  this.pause = function(sID) {\r
-\r
-    if (!_idCheck(sID)) {\r
-      return false;\r
-    }\r
-    return _s.sounds[sID].pause();\r
-\r
-  };\r
-\r
-  /**\r
-   * Pauses all currently-playing sounds.\r
-   */\r
-\r
-  this.pauseAll = function() {\r
-\r
-    var i;\r
-    for (i = _s.soundIDs.length-1; i >= 0; i--) {\r
-      _s.sounds[_s.soundIDs[i]].pause();\r
-    }\r
-\r
-  };\r
-\r
-  /**\r
-   * Calls the resume() method of a SMSound object by ID.\r
-   *\r
-   * @param {string} sID The ID of the sound\r
-   * @return {SMSound} The SMSound object\r
-   */\r
-\r
-  this.resume = function(sID) {\r
-\r
-    if (!_idCheck(sID)) {\r
-      return false;\r
-    }\r
-    return _s.sounds[sID].resume();\r
-\r
-  };\r
-\r
-  /**\r
-   * Resumes all currently-paused sounds.\r
-   */\r
-\r
-  this.resumeAll = function() {\r
-\r
-    var i;\r
-    for (i = _s.soundIDs.length-1; i >= 0; i--) {\r
-      _s.sounds[_s.soundIDs[i]].resume();\r
-    }\r
-\r
-  };\r
-\r
-  /**\r
-   * Calls the togglePause() method of a SMSound object by ID.\r
-   *\r
-   * @param {string} sID The ID of the sound\r
-   * @return {SMSound} The SMSound object\r
-   */\r
-\r
-  this.togglePause = function(sID) {\r
-\r
-    if (!_idCheck(sID)) {\r
-      return false;\r
-    }\r
-    return _s.sounds[sID].togglePause();\r
-\r
-  };\r
-\r
-  /**\r
-   * Calls the setPan() method of a SMSound object by ID.\r
-   *\r
-   * @param {string} sID The ID of the sound\r
-   * @param {number} nPan The pan value (-100 to 100)\r
-   * @return {SMSound} The SMSound object\r
-   */\r
-\r
-  this.setPan = function(sID, nPan) {\r
-\r
-    if (!_idCheck(sID)) {\r
-      return false;\r
-    }\r
-    return _s.sounds[sID].setPan(nPan);\r
-\r
-  };\r
-\r
-  /**\r
-   * Calls the setVolume() method of a SMSound object by ID.\r
-   *\r
-   * @param {string} sID The ID of the sound\r
-   * @param {number} nVol The volume value (0 to 100)\r
-   * @return {SMSound} The SMSound object\r
-   */\r
-\r
-  this.setVolume = function(sID, nVol) {\r
-\r
-    if (!_idCheck(sID)) {\r
-      return false;\r
-    }\r
-    return _s.sounds[sID].setVolume(nVol);\r
-\r
-  };\r
-\r
-  /**\r
-   * Calls the mute() method of either a single SMSound object by ID, or all sound objects.\r
-   *\r
-   * @param {string} sID Optional: The ID of the sound (if omitted, all sounds will be used.)\r
-   */\r
-\r
-  this.mute = function(sID) {\r
-\r
-    var i = 0;\r
-\r
-    if (typeof sID !== 'string') {\r
-      sID = null;\r
-    }\r
-\r
-    if (!sID) {\r
-      _s._wD(_sm+'.mute(): Muting all sounds');\r
-      for (i = _s.soundIDs.length-1; i >= 0; i--) {\r
-        _s.sounds[_s.soundIDs[i]].mute();\r
-      }\r
-      _s.muted = true;\r
-    } else {\r
-      if (!_idCheck(sID)) {\r
-        return false;\r
-      }\r
-      _s._wD(_sm+'.mute(): Muting "' + sID + '"');\r
-      return _s.sounds[sID].mute();\r
-    }\r
-\r
-    return true;\r
-\r
-  };\r
-\r
-  /**\r
-   * Mutes all sounds.\r
-   */\r
-\r
-  this.muteAll = function() {\r
-\r
-    _s.mute();\r
-\r
-  };\r
-\r
-  /**\r
-   * Calls the unmute() method of either a single SMSound object by ID, or all sound objects.\r
-   *\r
-   * @param {string} sID Optional: The ID of the sound (if omitted, all sounds will be used.)\r
-   */\r
-\r
-  this.unmute = function(sID) {\r
-\r
-    var i;\r
-\r
-    if (typeof sID !== 'string') {\r
-      sID = null;\r
-    }\r
-\r
-    if (!sID) {\r
-\r
-      _s._wD(_sm+'.unmute(): Unmuting all sounds');\r
-      for (i = _s.soundIDs.length-1; i >= 0; i--) {\r
-        _s.sounds[_s.soundIDs[i]].unmute();\r
-      }\r
-      _s.muted = false;\r
-\r
-    } else {\r
-\r
-      if (!_idCheck(sID)) {\r
-        return false;\r
-      }\r
-      _s._wD(_sm+'.unmute(): Unmuting "' + sID + '"');\r
-      return _s.sounds[sID].unmute();\r
-\r
-    }\r
-\r
-    return true;\r
-\r
-  };\r
-\r
-  /**\r
-   * Unmutes all sounds.\r
-   */\r
-\r
-  this.unmuteAll = function() {\r
-\r
-    _s.unmute();\r
-\r
-  };\r
-\r
-  /**\r
-   * Calls the toggleMute() method of a SMSound object by ID.\r
-   *\r
-   * @param {string} sID The ID of the sound\r
-   * @return {SMSound} The SMSound object\r
-   */\r
-\r
-  this.toggleMute = function(sID) {\r
-\r
-    if (!_idCheck(sID)) {\r
-      return false;\r
-    }\r
-    return _s.sounds[sID].toggleMute();\r
-\r
-  };\r
-\r
-  /**\r
-   * Retrieves the memory used by the flash plugin.\r
-   *\r
-   * @return {number} The amount of memory in use\r
-   */\r
-\r
-  this.getMemoryUse = function() {\r
-\r
-    // flash-only\r
-    var ram = 0;\r
-\r
-    if (_flash && _fV !== 8) {\r
-      ram = parseInt(_flash._getMemoryUse(), 10);\r
-    }\r
-\r
-    return ram;\r
-\r
-  };\r
-\r
-  /**\r
-   * Undocumented: NOPs soundManager and all SMSound objects.\r
-   */\r
-\r
-  this.disable = function(bNoDisable) {\r
-\r
-    // destroy all functions\r
-    var i;\r
-\r
-    if (typeof bNoDisable === 'undefined') {\r
-      bNoDisable = false;\r
-    }\r
-\r
-    if (_disabled) {\r
-      return false;\r
-    }\r
-\r
-    _disabled = true;\r
-    _wDS('shutdown', 1);\r
-\r
-    for (i = _s.soundIDs.length-1; i >= 0; i--) {\r
-      _disableObject(_s.sounds[_s.soundIDs[i]]);\r
-    }\r
-\r
-    // fire "complete", despite fail\r
-    _initComplete(bNoDisable);\r
-    _event.remove(_win, 'load', _initUserOnload);\r
-\r
-    return true;\r
-\r
-  };\r
-\r
-  /**\r
-   * Determines playability of a MIME type, eg. 'audio/mp3'.\r
-   */\r
-\r
-  this.canPlayMIME = function(sMIME) {\r
-\r
-    var result;\r
-\r
-    if (_s.hasHTML5) {\r
-      result = _html5CanPlay({type:sMIME});\r
-    }\r
-\r
-    if (!result && _needsFlash) {\r
-      // if flash 9, test netStream (movieStar) types as well.\r
-      result = (sMIME && _s.ok() ? !!((_fV > 8 ? sMIME.match(_netStreamMimeTypes) : null) || sMIME.match(_s.mimePattern)) : null);\r
-    }\r
-\r
-    return result;\r
-\r
-  };\r
-\r
-  /**\r
-   * Determines playability of a URL based on audio support.\r
-   *\r
-   * @param {string} sURL The URL to test\r
-   * @return {boolean} URL playability\r
-   */\r
-\r
-  this.canPlayURL = function(sURL) {\r
-\r
-    var result;\r
-\r
-    if (_s.hasHTML5) {\r
-      result = _html5CanPlay({url: sURL});\r
-    }\r
-\r
-    if (!result && _needsFlash) {\r
-      result = (sURL && _s.ok() ? !!(sURL.match(_s.filePattern)) : null);\r
-    }\r
-\r
-    return result;\r
-\r
-  };\r
-\r
-  /**\r
-   * Determines playability of an HTML DOM &lt;a&gt; object (or similar object literal) based on audio support.\r
-   *\r
-   * @param {object} oLink an HTML DOM &lt;a&gt; object or object literal including href and/or type attributes\r
-   * @return {boolean} URL playability\r
-   */\r
-\r
-  this.canPlayLink = function(oLink) {\r
-\r
-    if (typeof oLink.type !== 'undefined' && oLink.type) {\r
-      if (_s.canPlayMIME(oLink.type)) {\r
-        return true;\r
-      }\r
-    }\r
-\r
-    return _s.canPlayURL(oLink.href);\r
-\r
-  };\r
-\r
-  /**\r
-   * Retrieves a SMSound object by ID.\r
-   *\r
-   * @param {string} sID The ID of the sound\r
-   * @return {SMSound} The SMSound object\r
-   */\r
-\r
-  this.getSoundById = function(sID, _suppressDebug) {\r
-\r
-    if (!sID) {\r
-      throw new Error(_sm+'.getSoundById(): sID is null/undefined');\r
-    }\r
-\r
-    var result = _s.sounds[sID];\r
-\r
-    // <d>\r
-    if (!result && !_suppressDebug) {\r
-      _s._wD('"' + sID + '" is an invalid sound ID.', 2);\r
-    }\r
-    // </d>\r
-\r
-    return result;\r
-\r
-  };\r
-\r
-  /**\r
-   * Queues a callback for execution when SoundManager has successfully initialized.\r
-   *\r
-   * @param {function} oMethod The callback method to fire\r
-   * @param {object} oScope Optional: The scope to apply to the callback\r
-   */\r
-\r
-  this.onready = function(oMethod, oScope) {\r
-\r
-    var sType = 'onready',\r
-        result = false;\r
-\r
-    if (typeof oMethod === 'function') {\r
-\r
-      // <d>\r
-      if (_didInit) {\r
-        _s._wD(_str('queue', sType));\r
-      }\r
-      // </d>\r
-\r
-      if (!oScope) {\r
-        oScope = _win;\r
-      }\r
-\r
-      _addOnEvent(sType, oMethod, oScope);\r
-      _processOnEvents();\r
-\r
-      result = true;\r
-\r
-    } else {\r
-\r
-      throw _str('needFunction', sType);\r
-\r
-    }\r
-\r
-    return result;\r
-\r
-  };\r
-\r
-  /**\r
-   * Queues a callback for execution when SoundManager has failed to initialize.\r
-   *\r
-   * @param {function} oMethod The callback method to fire\r
-   * @param {object} oScope Optional: The scope to apply to the callback\r
-   */\r
-\r
-  this.ontimeout = function(oMethod, oScope) {\r
-\r
-    var sType = 'ontimeout',\r
-        result = false;\r
-\r
-    if (typeof oMethod === 'function') {\r
-\r
-      // <d>\r
-      if (_didInit) {\r
-        _s._wD(_str('queue', sType));\r
-      }\r
-      // </d>\r
-\r
-      if (!oScope) {\r
-        oScope = _win;\r
-      }\r
-\r
-      _addOnEvent(sType, oMethod, oScope);\r
-      _processOnEvents({type:sType});\r
-\r
-      result = true;\r
-\r
-    } else {\r
-\r
-      throw _str('needFunction', sType);\r
-\r
-    }\r
-\r
-    return result;\r
-\r
-  };\r
-\r
-  /**\r
-   * Writes console.log()-style debug output to a console or in-browser element.\r
-   * Applies when debugMode = true\r
-   *\r
-   * @param {string} sText The console message\r
-   * @param {string} sType Optional: Log type of 'info', 'warn' or 'error'\r
-   * @param {object} Optional: The scope to apply to the callback\r
-   */\r
-\r
-  this._writeDebug = function(sText, sType, _bTimestamp) {\r
-\r
-    // pseudo-private console.log()-style output\r
-    // <d>\r
-\r
-    var sDID = 'soundmanager-debug', o, oItem, sMethod;\r
-\r
-    if (!_s.debugMode) {\r
-      return false;\r
-    }\r
-\r
-    if (typeof _bTimestamp !== 'undefined' && _bTimestamp) {\r
-      sText = sText + ' | ' + new Date().getTime();\r
-    }\r
-\r
-    if (_hasConsole && _s.useConsole) {\r
-      sMethod = _debugLevels[sType];\r
-      if (typeof console[sMethod] !== 'undefined') {\r
-        console[sMethod](sText);\r
-      } else {\r
-        console.log(sText);\r
-      }\r
-      if (_s.consoleOnly) {\r
-        return true;\r
-      }\r
-    }\r
-\r
-    try {\r
-\r
-      o = _id(sDID);\r
-\r
-      if (!o) {\r
-        return false;\r
-      }\r
-\r
-      oItem = _doc.createElement('div');\r
-\r
-      if (++_wdCount % 2 === 0) {\r
-        oItem.className = 'sm2-alt';\r
-      }\r
-\r
-      if (typeof sType === 'undefined') {\r
-        sType = 0;\r
-      } else {\r
-        sType = parseInt(sType, 10);\r
-      }\r
-\r
-      oItem.appendChild(_doc.createTextNode(sText));\r
-\r
-      if (sType) {\r
-        if (sType >= 2) {\r
-          oItem.style.fontWeight = 'bold';\r
-        }\r
-        if (sType === 3) {\r
-          oItem.style.color = '#ff3333';\r
-        }\r
-      }\r
-\r
-      // top-to-bottom\r
-      // o.appendChild(oItem);\r
-\r
-      // bottom-to-top\r
-      o.insertBefore(oItem, o.firstChild);\r
-\r
-    } catch(e) {\r
-      // oh well\r
-    }\r
-\r
-    o = null;\r
-    // </d>\r
-\r
-    return true;\r
-\r
-  };\r
-\r
-  // alias\r
-  this._wD = this._writeDebug;\r
-\r
-  /**\r
-   * Provides debug / state information on all SMSound objects.\r
-   */\r
-\r
-  this._debug = function() {\r
-\r
-    // <d>\r
-    var i, j;\r
-    _wDS('currentObj', 1);\r
-\r
-    for (i = 0, j = _s.soundIDs.length; i < j; i++) {\r
-      _s.sounds[_s.soundIDs[i]]._debug();\r
-    }\r
-    // </d>\r
-\r
-  };\r
-\r
-  /**\r
-   * Restarts and re-initializes the SoundManager instance.\r
-   */\r
-\r
-  this.reboot = function() {\r
-\r
-    // attempt to reset and init SM2\r
-    _s._wD(_sm+'.reboot()');\r
-\r
-    // <d>\r
-    if (_s.soundIDs.length) {\r
-      _s._wD('Destroying ' + _s.soundIDs.length + ' SMSound objects...');\r
-    }\r
-    // </d>\r
-\r
-    var i, j;\r
-\r
-    for (i = _s.soundIDs.length-1; i >= 0; i--) {\r
-      _s.sounds[_s.soundIDs[i]].destruct();\r
-    }\r
-\r
-    // trash ze flash\r
-\r
-    if (_flash) {\r
-      try {\r
-        if (_isIE) {\r
-          _oRemovedHTML = _flash.innerHTML;\r
-        }\r
-        _oRemoved = _flash.parentNode.removeChild(_flash);\r
-        _s._wD('Flash movie removed.');\r
-      } catch(e) {\r
-        // uh-oh.\r
-        _wDS('badRemove', 2);\r
-      }\r
-    }\r
-\r
-    // actually, force recreate of movie.\r
-    _oRemovedHTML = _oRemoved = _needsFlash = null;\r
-\r
-    _s.enabled = _didDCLoaded = _didInit = _waitingForEI = _initPending = _didAppend = _appendSuccess = _disabled = _s.swfLoaded = false;\r
-    _s.soundIDs = [];\r
-    _s.sounds = {};\r
-    _flash = null;\r
-\r
-    for (i in _on_queue) {\r
-      if (_on_queue.hasOwnProperty(i)) {\r
-        for (j = _on_queue[i].length-1; j >= 0; j--) {\r
-          _on_queue[i][j].fired = false;\r
-        }\r
-      }\r
-    }\r
-\r
-    _s._wD(_sm + ': Rebooting...');\r
-    _win.setTimeout(_s.beginDelayedInit, 20);\r
-\r
-  };\r
-\r
-  /**\r
-   * Undocumented: Determines the SM2 flash movie's load progress.\r
-   *\r
-   * @return {number or null} Percent loaded, or if invalid/unsupported, null.\r
-   */\r
-\r
-  this.getMoviePercent = function() {\r
-\r
-    // interesting note: flash/ExternalInterface bridge methods are not typeof "function" nor instanceof Function, but are still valid.\r
-    return (_flash && typeof _flash.PercentLoaded !== 'undefined' ? _flash.PercentLoaded() : null);\r
-\r
-  };\r
-\r
-  /**\r
-   * Additional helper for manually invoking SM2's init process after DOM Ready / window.onload().\r
-   */\r
-\r
-  this.beginDelayedInit = function() {\r
-\r
-    _windowLoaded = true;\r
-    _domContentLoaded();\r
-\r
-    setTimeout(function() {\r
-\r
-      if (_initPending) {\r
-        return false;\r
-      }\r
-\r
-      _createMovie();\r
-      _initMovie();\r
-      _initPending = true;\r
-\r
-      return true;\r
-\r
-    }, 20);\r
-\r
-    _delayWaitForEI();\r
-\r
-  };\r
-\r
-  /**\r
-   * Destroys the SoundManager instance and all SMSound instances.\r
-   */\r
-\r
-  this.destruct = function() {\r
-\r
-    _s._wD(_sm+'.destruct()');\r
-    _s.disable(true);\r
-\r
-  };\r
-\r
-  /**\r
-   * SMSound() (sound object) constructor\r
-   * ------------------------------------\r
-   *\r
-   * @param {object} oOptions Sound options (id and url are required attributes)\r
-   * @return {SMSound} The new SMSound object\r
-   */\r
-\r
-  SMSound = function(oOptions) {\r
-\r
-    var _t = this, _resetProperties, _add_html5_events, _remove_html5_events, _stop_html5_timer, _start_html5_timer, _attachOnPosition, _onplay_called = false, _onPositionItems = [], _onPositionFired = 0, _detachOnPosition, _applyFromTo, _lastURL = null, _lastHTML5State;\r
-\r
-    _lastHTML5State = {\r
-      // tracks duration + position (time)\r
-      duration: null,\r
-      time: null\r
-    };\r
-\r
-    this.id = oOptions.id;\r
-\r
-    // legacy\r
-    this.sID = this.id;\r
-\r
-    this.url = oOptions.url;\r
-    this.options = _mixin(oOptions);\r
-\r
-    // per-play-instance-specific options\r
-    this.instanceOptions = this.options;\r
-\r
-    // short alias\r
-    this._iO = this.instanceOptions;\r
-\r
-    // assign property defaults\r
-    this.pan = this.options.pan;\r
-    this.volume = this.options.volume;\r
-\r
-    // whether or not this object is using HTML5\r
-    this.isHTML5 = false;\r
-\r
-    // internal HTML5 Audio() object reference\r
-    this._a = null;\r
-\r
-    /**\r
-     * SMSound() public methods\r
-     * ------------------------\r
-     */\r
-\r
-    this.id3 = {};\r
-\r
-    /**\r
-     * Writes SMSound object parameters to debug console\r
-     */\r
-\r
-    this._debug = function() {\r
-\r
-      // <d>\r
-      // pseudo-private console.log()-style output\r
-\r
-      if (_s.debugMode) {\r
-\r
-        var stuff = null, msg = [], sF, sfBracket, maxLength = 64;\r
-\r
-        for (stuff in _t.options) {\r
-          if (_t.options[stuff] !== null) {\r
-            if (typeof _t.options[stuff] === 'function') {\r
-              // handle functions specially\r
-              sF = _t.options[stuff].toString();\r
-              // normalize spaces\r
-              sF = sF.replace(/\s\s+/g, ' ');\r
-              sfBracket = sF.indexOf('{');\r
-              msg.push(' ' + stuff + ': {' + sF.substr(sfBracket + 1, (Math.min(Math.max(sF.indexOf('\n') - 1, maxLength), maxLength))).replace(/\n/g, '') + '... }');\r
-            } else {\r
-              msg.push(' ' + stuff + ': ' + _t.options[stuff]);\r
-            }\r
-          }\r
-        }\r
-\r
-        _s._wD('SMSound() merged options: {\n' + msg.join(', \n') + '\n}');\r
-\r
-      }\r
-      // </d>\r
-\r
-    };\r
-\r
-    // <d>\r
-    this._debug();\r
-    // </d>\r
-\r
-    /**\r
-     * Begins loading a sound per its *url*.\r
-     *\r
-     * @param {object} oOptions Optional: Sound options\r
-     * @return {SMSound} The SMSound object\r
-     */\r
-\r
-    this.load = function(oOptions) {\r
-\r
-      var oS = null, _iO;\r
-\r
-      if (typeof oOptions !== 'undefined') {\r
-        _t._iO = _mixin(oOptions, _t.options);\r
-        _t.instanceOptions = _t._iO;\r
-      } else {\r
-        oOptions = _t.options;\r
-        _t._iO = oOptions;\r
-        _t.instanceOptions = _t._iO;\r
-        if (_lastURL && _lastURL !== _t.url) {\r
-          _wDS('manURL');\r
-          _t._iO.url = _t.url;\r
-          _t.url = null;\r
-        }\r
-      }\r
-\r
-      if (!_t._iO.url) {\r
-        _t._iO.url = _t.url;\r
-      }\r
-\r
-      _t._iO.url = _parseURL(_t._iO.url);\r
-\r
-      _s._wD('SMSound.load(): ' + _t._iO.url, 1);\r
-\r
-      if (_t._iO.url === _t.url && _t.readyState !== 0 && _t.readyState !== 2) {\r
-        _wDS('onURL', 1);\r
-        // if loaded and an onload() exists, fire immediately.\r
-        if (_t.readyState === 3 && _t._iO.onload) {\r
-          // assume success based on truthy duration.\r
-          _t._iO.onload.apply(_t, [(!!_t.duration)]);\r
-        }\r
-        return _t;\r
-      }\r
-\r
-      // local shortcut\r
-      _iO = _t._iO;\r
-\r
-      // make a local copy of the old url before we re-assign it\r
-      _lastURL = (_t.url && _t.url.toString ? _t.url.toString() : null);\r
-\r
-      // reset a few state properties\r
-\r
-      _t.loaded = false;\r
-      _t.readyState = 1;\r
-      _t.playState = 0;\r
-      _t.id3 = {};\r
-\r
-      // TODO: If switching from HTML5 -> flash (or vice versa), stop currently-playing audio.\r
-\r
-      if (_html5OK(_iO)) {\r
-\r
-        oS = _t._setup_html5(_iO);\r
-\r
-        if (!oS._called_load) {\r
-\r
-          _s._wD(_h5+'load: '+_t.id);\r
-\r
-          _t._html5_canplay = false;\r
-\r
-          // TODO: review called_load / html5_canplay logic\r
-\r
-          // if url provided directly to load(), assign it here.\r
-\r
-          if (_t._a.src !== _iO.url) {\r
-\r
-            _s._wD(_wDS('manURL') + ': ' + _iO.url);\r
-\r
-            _t._a.src = _iO.url;\r
-\r
-            // TODO: review / re-apply all relevant options (volume, loop, onposition etc.)\r
-\r
-            // reset position for new URL\r
-            _t.setPosition(0);\r
-\r
-          }\r
-\r
-          // given explicit load call, try to preload.\r
-\r
-          // early HTML5 implementation (non-standard)\r
-          _t._a.autobuffer = 'auto';\r
-\r
-          // standard\r
-          _t._a.preload = 'auto';\r
-\r
-          oS._called_load = true;\r
-\r
-          if (_iO.autoPlay) {\r
-            _t.play();\r
-          }\r
-\r
-        } else {\r
-\r
-          _s._wD(_h5+'ignoring request to load again: '+_t.id);\r
-\r
-        }\r
-\r
-      } else {\r
-\r
-        try {\r
-          _t.isHTML5 = false;\r
-          _t._iO = _policyFix(_loopFix(_iO));\r
-          // re-assign local shortcut\r
-          _iO = _t._iO;\r
-          if (_fV === 8) {\r
-            _flash._load(_t.id, _iO.url, _iO.stream, _iO.autoPlay, (_iO.whileloading?1:0), _iO.loops||1, _iO.usePolicyFile);\r
-          } else {\r
-            _flash._load(_t.id, _iO.url, !!(_iO.stream), !!(_iO.autoPlay), _iO.loops||1, !!(_iO.autoLoad), _iO.usePolicyFile);\r
-          }\r
-        } catch(e) {\r
-          _wDS('smError', 2);\r
-          _debugTS('onload', false);\r
-          _catchError({type:'SMSOUND_LOAD_JS_EXCEPTION', fatal:true});\r
-\r
-        }\r
-\r
-      }\r
-\r
-      // after all of this, ensure sound url is up to date.\r
-      _t.url = _iO.url;\r
-\r
-      return _t;\r
-\r
-    };\r
-\r
-    /**\r
-     * Unloads a sound, canceling any open HTTP requests.\r
-     *\r
-     * @return {SMSound} The SMSound object\r
-     */\r
-\r
-    this.unload = function() {\r
-\r
-      // Flash 8/AS2 can't "close" a stream - fake it by loading an empty URL\r
-      // Flash 9/AS3: Close stream, preventing further load\r
-      // HTML5: Most UAs will use empty URL\r
-\r
-      if (_t.readyState !== 0) {\r
-\r
-        _s._wD('SMSound.unload(): "' + _t.id + '"');\r
-\r
-        if (!_t.isHTML5) {\r
-\r
-          if (_fV === 8) {\r
-            _flash._unload(_t.id, _emptyURL);\r
-          } else {\r
-            _flash._unload(_t.id);\r
-          }\r
-\r
-        } else {\r
-\r
-          _stop_html5_timer();\r
-\r
-          if (_t._a) {\r
-\r
-            _t._a.pause();\r
-            _html5Unload(_t._a, _emptyURL);\r
-\r
-            // reset local URL for next load / play call, too\r
-            _t.url = _emptyURL;\r
-\r
-          }\r
-\r
-        }\r
-\r
-        // reset load/status flags\r
-        _resetProperties();\r
-\r
-      }\r
-\r
-      return _t;\r
-\r
-    };\r
-\r
-    /**\r
-     * Unloads and destroys a sound.\r
-     */\r
-\r
-    this.destruct = function(_bFromSM) {\r
-\r
-      _s._wD('SMSound.destruct(): "' + _t.id + '"');\r
-\r
-      if (!_t.isHTML5) {\r
-\r
-        // kill sound within Flash\r
-        // Disable the onfailure handler\r
-        _t._iO.onfailure = null;\r
-        _flash._destroySound(_t.id);\r
-\r
-      } else {\r
-\r
-        _stop_html5_timer();\r
-\r
-        if (_t._a) {\r
-          _t._a.pause();\r
-          _html5Unload(_t._a);\r
-          if (!_useGlobalHTML5Audio) {\r
-            _remove_html5_events();\r
-          }\r
-          // break obvious circular reference\r
-          _t._a._t = null;\r
-          _t._a = null;\r
-        }\r
-\r
-      }\r
-\r
-      if (!_bFromSM) {\r
-        // ensure deletion from controller\r
-        _s.destroySound(_t.id, true);\r
-\r
-      }\r
-\r
-    };\r
-\r
-    /**\r
-     * Begins playing a sound.\r
-     *\r
-     * @param {object} oOptions Optional: Sound options\r
-     * @return {SMSound} The SMSound object\r
-     */\r
-\r
-    this.play = function(oOptions, _updatePlayState) {\r
-\r
-      var fN, allowMulti, a, onready, startOK = true,\r
-          exit = null;\r
-\r
-      // <d>\r
-      fN = 'SMSound.play(): ';\r
-      // </d>\r
-\r
-      // default to true\r
-      _updatePlayState = (typeof _updatePlayState === 'undefined' ? true : _updatePlayState);\r
-\r
-      if (!oOptions) {\r
-        oOptions = {};\r
-      }\r
-\r
-      // first, use local URL (if specified)\r
-      if (_t.url) {\r
-        _t._iO.url = _t.url;\r
-      }\r
-\r
-      // mix in any options defined at createSound()\r
-      _t._iO = _mixin(_t._iO, _t.options);\r
-\r
-      // mix in any options specific to this method\r
-      _t._iO = _mixin(oOptions, _t._iO);\r
-\r
-      _t._iO.url = _parseURL(_t._iO.url);\r
-\r
-      _t.instanceOptions = _t._iO;\r
-\r
-      // RTMP-only\r
-      if (_t._iO.serverURL && !_t.connected) {\r
-        if (!_t.getAutoPlay()) {\r
-          _s._wD(fN+' Netstream not connected yet - setting autoPlay');\r
-          _t.setAutoPlay(true);\r
-        }\r
-        // play will be called in _onconnect()\r
-        return _t;\r
-      }\r
-\r
-      if (_html5OK(_t._iO)) {\r
-        _t._setup_html5(_t._iO);\r
-        _start_html5_timer();\r
-      }\r
-\r
-      if (_t.playState === 1 && !_t.paused) {\r
-        allowMulti = _t._iO.multiShot;\r
-        if (!allowMulti) {\r
-          _s._wD(fN + '"' + _t.id + '" already playing (one-shot)', 1);\r
-          exit = _t;\r
-        } else {\r
-          _s._wD(fN + '"' + _t.id + '" already playing (multi-shot)', 1);\r
-        }\r
-      }\r
-\r
-      if (exit !== null) {\r
-        return exit;\r
-      }\r
-\r
-      // edge case: play() with explicit URL parameter\r
-      if (oOptions.url && oOptions.url !== _t.url) {\r
-        // load using merged options\r
-        _t.load(_t._iO);\r
-      }\r
-\r
-      if (!_t.loaded) {\r
-\r
-        if (_t.readyState === 0) {\r
-\r
-          _s._wD(fN + 'Attempting to load "' + _t.id + '"', 1);\r
-\r
-          // try to get this sound playing ASAP\r
-          if (!_t.isHTML5) {\r
-            // assign directly because setAutoPlay() increments the instanceCount\r
-            _t._iO.autoPlay = true;\r
-            _t.load(_t._iO);\r
-          } else {\r
-            // iOS needs this when recycling sounds, loading a new URL on an existing object.\r
-            _t.load(_t._iO);\r
-          }\r
-\r
-        } else if (_t.readyState === 2) {\r
-\r
-          _s._wD(fN + 'Could not load "' + _t.id + '" - exiting', 2);\r
-          exit = _t;\r
-\r
-        } else {\r
-\r
-          _s._wD(fN + '"' + _t.id + '" is loading - attempting to play..', 1);\r
-\r
-        }\r
-\r
-      } else {\r
-\r
-        _s._wD(fN + '"' + _t.id + '"');\r
-\r
-      }\r
-\r
-      if (exit !== null) {\r
-        return exit;\r
-      }\r
-\r
-      if (!_t.isHTML5 && _fV === 9 && _t.position > 0 && _t.position === _t.duration) {\r
-        // flash 9 needs a position reset if play() is called while at the end of a sound.\r
-        _s._wD(fN + '"' + _t.id + '": Sound at end, resetting to position:0');\r
-        oOptions.position = 0;\r
-      }\r
-\r
-      /**\r
-       * Streams will pause when their buffer is full if they are being loaded.\r
-       * In this case paused is true, but the song hasn't started playing yet.\r
-       * If we just call resume() the onplay() callback will never be called.\r
-       * So only call resume() if the position is > 0.\r
-       * Another reason is because options like volume won't have been applied yet.\r
-       * For normal sounds, just resume.\r
-       */\r
-\r
-      if (_t.paused && _t.position >= 0 && (!_t._iO.serverURL || _t.position > 0)) {\r
-\r
-        // https://gist.github.com/37b17df75cc4d7a90bf6\r
-        _s._wD(fN + '"' + _t.id + '" is resuming from paused state',1);\r
-        _t.resume();\r
-\r
-      } else {\r
-\r
-        _t._iO = _mixin(oOptions, _t._iO);\r
-\r
-        // apply from/to parameters, if they exist (and not using RTMP)\r
-        if (_t._iO.from !== null && _t._iO.to !== null && _t.instanceCount === 0 && _t.playState === 0 && !_t._iO.serverURL) {\r
-\r
-          onready = function() {\r
-            // sound "canplay" or onload()\r
-            // re-apply from/to to instance options, and start playback\r
-            _t._iO = _mixin(oOptions, _t._iO);\r
-            _t.play(_t._iO);\r
-          };\r
-\r
-          // HTML5 needs to at least have "canplay" fired before seeking.\r
-          if (_t.isHTML5 && !_t._html5_canplay) {\r
-\r
-            // this hasn't been loaded yet. load it first, and then do this again.\r
-            _s._wD(fN+'Beginning load of "'+ _t.id+'" for from/to case');\r
-\r
-            _t.load({\r
-              _oncanplay: onready\r
-            });\r
-\r
-            exit = false;\r
-\r
-          } else if (!_t.isHTML5 && !_t.loaded && (!_t.readyState || _t.readyState !== 2)) {\r
-\r
-            // to be safe, preload the whole thing in Flash.\r
-\r
-            _s._wD(fN+'Preloading "'+ _t.id+'" for from/to case');\r
-\r
-            _t.load({\r
-              onload: onready\r
-            });\r
-\r
-            exit = false;\r
-\r
-          }\r
-\r
-          if (exit !== null) {\r
-            return exit;\r
-          }\r
-\r
-          // otherwise, we're ready to go. re-apply local options, and continue\r
-\r
-          _t._iO = _applyFromTo();\r
-\r
-        }\r
-\r
-        _s._wD(fN+'"'+ _t.id+'" is starting to play');\r
-\r
-        if (!_t.instanceCount || _t._iO.multiShotEvents || (!_t.isHTML5 && _fV > 8 && !_t.getAutoPlay())) {\r
-          _t.instanceCount++;\r
-        }\r
-\r
-        // if first play and onposition parameters exist, apply them now\r
-        if (_t._iO.onposition && _t.playState === 0) {\r
-          _attachOnPosition(_t);\r
-        }\r
-\r
-        _t.playState = 1;\r
-        _t.paused = false;\r
-\r
-        _t.position = (typeof _t._iO.position !== 'undefined' && !isNaN(_t._iO.position) ? _t._iO.position : 0);\r
-\r
-        if (!_t.isHTML5) {\r
-          _t._iO = _policyFix(_loopFix(_t._iO));\r
-        }\r
-\r
-        if (_t._iO.onplay && _updatePlayState) {\r
-          _t._iO.onplay.apply(_t);\r
-          _onplay_called = true;\r
-        }\r
-\r
-        _t.setVolume(_t._iO.volume, true);\r
-        _t.setPan(_t._iO.pan, true);\r
-\r
-        if (!_t.isHTML5) {\r
-\r
-          startOK = _flash._start(_t.id, _t._iO.loops || 1, (_fV === 9 ? _t._iO.position : _t._iO.position / 1000), _t._iO.multiShot);\r
-\r
-          if (_fV === 9 && !startOK) {\r
-            // edge case: no sound hardware, or 32-channel flash ceiling hit.\r
-            // applies only to Flash 9, non-NetStream/MovieStar sounds.\r
-            // http://help.adobe.com/en_US/FlashPlatform/reference/actionscript/3/flash/media/Sound.html#play%28%29\r
-            _s._wD(fN+ _t.id+': No sound hardware, or 32-sound ceiling hit');\r
-            if (_t._iO.onplayerror) {\r
-              _t._iO.onplayerror.apply(_t);\r
-            }\r
-\r
-          }\r
-\r
-        } else {\r
-\r
-          _start_html5_timer();\r
-\r
-          a = _t._setup_html5();\r
-\r
-          _t.setPosition(_t._iO.position);\r
-\r
-          a.play();\r
-\r
-        }\r
-\r
-      }\r
-\r
-      return _t;\r
-\r
-    };\r
-\r
-    // just for convenience\r
-    this.start = this.play;\r
-\r
-    /**\r
-     * Stops playing a sound (and optionally, all sounds)\r
-     *\r
-     * @param {boolean} bAll Optional: Whether to stop all sounds\r
-     * @return {SMSound} The SMSound object\r
-     */\r
-\r
-    this.stop = function(bAll) {\r
-\r
-      var _iO = _t._iO, _oP;\r
-\r
-      if (_t.playState === 1) {\r
-\r
-        _t._onbufferchange(0);\r
-        _t._resetOnPosition(0);\r
-        _t.paused = false;\r
-\r
-        if (!_t.isHTML5) {\r
-          _t.playState = 0;\r
-        }\r
-\r
-        // remove onPosition listeners, if any\r
-        _detachOnPosition();\r
-\r
-        // and "to" position, if set\r
-        if (_iO.to) {\r
-          _t.clearOnPosition(_iO.to);\r
-        }\r
-\r
-        if (!_t.isHTML5) {\r
-\r
-          _flash._stop(_t.id, bAll);\r
-\r
-          // hack for netStream: just unload\r
-          if (_iO.serverURL) {\r
-            _t.unload();\r
-          }\r
-\r
-        } else {\r
-\r
-          if (_t._a) {\r
-\r
-            _oP = _t.position;\r
-\r
-            // act like Flash, though\r
-            _t.setPosition(0);\r
-\r
-            // hack: reflect old position for onstop() (also like Flash)\r
-            _t.position = _oP;\r
-\r
-            // html5 has no stop()\r
-            // NOTE: pausing means iOS requires interaction to resume.\r
-            _t._a.pause();\r
-\r
-            _t.playState = 0;\r
-\r
-            // and update UI\r
-            _t._onTimer();\r
-\r
-            _stop_html5_timer();\r
-\r
-          }\r
-\r
-        }\r
-\r
-        _t.instanceCount = 0;\r
-        _t._iO = {};\r
-\r
-        if (_iO.onstop) {\r
-          _iO.onstop.apply(_t);\r
-        }\r
-\r
-      }\r
-\r
-      return _t;\r
-\r
-    };\r
-\r
-    /**\r
-     * Undocumented/internal: Sets autoPlay for RTMP.\r
-     *\r
-     * @param {boolean} autoPlay state\r
-     */\r
-\r
-    this.setAutoPlay = function(autoPlay) {\r
-\r
-      _s._wD('sound '+_t.id+' turned autoplay ' + (autoPlay ? 'on' : 'off'));\r
-      _t._iO.autoPlay = autoPlay;\r
-\r
-      if (!_t.isHTML5) {\r
-        _flash._setAutoPlay(_t.id, autoPlay);\r
-        if (autoPlay) {\r
-          // only increment the instanceCount if the sound isn't loaded (TODO: verify RTMP)\r
-          if (!_t.instanceCount && _t.readyState === 1) {\r
-            _t.instanceCount++;\r
-            _s._wD('sound '+_t.id+' incremented instance count to '+_t.instanceCount);\r
-          }\r
-        }\r
-      }\r
-\r
-    };\r
-\r
-    /**\r
-     * Undocumented/internal: Returns the autoPlay boolean.\r
-     *\r
-     * @return {boolean} The current autoPlay value\r
-     */\r
-\r
-    this.getAutoPlay = function() {\r
-\r
-      return _t._iO.autoPlay;\r
-\r
-    };\r
-\r
-    /**\r
-     * Sets the position of a sound.\r
-     *\r
-     * @param {number} nMsecOffset Position (milliseconds)\r
-     * @return {SMSound} The SMSound object\r
-     */\r
-\r
-    this.setPosition = function(nMsecOffset) {\r
-\r
-      if (typeof nMsecOffset === 'undefined') {\r
-        nMsecOffset = 0;\r
-      }\r
-\r
-      var original_pos,\r
-          position, position1K,\r
-          // Use the duration from the instance options, if we don't have a track duration yet.\r
-          // position >= 0 and <= current available (loaded) duration\r
-          offset = (_t.isHTML5 ? Math.max(nMsecOffset, 0) : Math.min(_t.duration || _t._iO.duration, Math.max(nMsecOffset, 0)));\r
-\r
-      original_pos = _t.position;\r
-      _t.position = offset;\r
-      position1K = _t.position/1000;\r
-      _t._resetOnPosition(_t.position);\r
-      _t._iO.position = offset;\r
-\r
-      if (!_t.isHTML5) {\r
-\r
-        position = (_fV === 9 ? _t.position : position1K);\r
-        if (_t.readyState && _t.readyState !== 2) {\r
-          // if paused or not playing, will not resume (by playing)\r
-          _flash._setPosition(_t.id, position, (_t.paused || !_t.playState), _t._iO.multiShot);\r
-        }\r
-\r
-      } else if (_t._a) {\r
-\r
-        // Set the position in the canplay handler if the sound is not ready yet\r
-        if (_t._html5_canplay) {\r
-          if (_t._a.currentTime !== position1K) {\r
-            /**\r
-             * DOM/JS errors/exceptions to watch out for:\r
-             * if seek is beyond (loaded?) position, "DOM exception 11"\r
-             * "INDEX_SIZE_ERR": DOM exception 1\r
-             */\r
-            _s._wD('setPosition('+position1K+'): setting position');\r
-            try {\r
-              _t._a.currentTime = position1K;\r
-              if (_t.playState === 0 || _t.paused) {\r
-                // allow seek without auto-play/resume\r
-                _t._a.pause();\r
-              }\r
-            } catch(e) {\r
-              _s._wD('setPosition('+position1K+'): setting position failed: '+e.message, 2);\r
-            }\r
-          }\r
-        } else {\r
-          _s._wD('setPosition('+position1K+'): delaying, sound not ready');\r
-        }\r
-\r
-      }\r
-\r
-      if (_t.isHTML5) {\r
-        if (_t.paused) {\r
-          // if paused, refresh UI right away\r
-          // force update\r
-          _t._onTimer(true);\r
-        }\r
-      }\r
-\r
-      return _t;\r
-\r
-    };\r
-\r
-    /**\r
-     * Pauses sound playback.\r
-     *\r
-     * @return {SMSound} The SMSound object\r
-     */\r
-\r
-    this.pause = function(_bCallFlash) {\r
-\r
-      if (_t.paused || (_t.playState === 0 && _t.readyState !== 1)) {\r
-        return _t;\r
-      }\r
-\r
-      _s._wD('SMSound.pause()');\r
-      _t.paused = true;\r
-\r
-      if (!_t.isHTML5) {\r
-        if (_bCallFlash || typeof _bCallFlash === 'undefined') {\r
-          _flash._pause(_t.id, _t._iO.multiShot);\r
-        }\r
-      } else {\r
-        _t._setup_html5().pause();\r
-        _stop_html5_timer();\r
-      }\r
-\r
-      if (_t._iO.onpause) {\r
-        _t._iO.onpause.apply(_t);\r
-      }\r
-\r
-      return _t;\r
-\r
-    };\r
-\r
-    /**\r
-     * Resumes sound playback.\r
-     *\r
-     * @return {SMSound} The SMSound object\r
-     */\r
-\r
-    /**\r
-     * When auto-loaded streams pause on buffer full they have a playState of 0.\r
-     * We need to make sure that the playState is set to 1 when these streams "resume".\r
-     * When a paused stream is resumed, we need to trigger the onplay() callback if it\r
-     * hasn't been called already. In this case since the sound is being played for the\r
-     * first time, I think it's more appropriate to call onplay() rather than onresume().\r
-     */\r
-\r
-    this.resume = function() {\r
-\r
-      var _iO = _t._iO;\r
-\r
-      if (!_t.paused) {\r
-        return _t;\r
-      }\r
-\r
-      _s._wD('SMSound.resume()');\r
-      _t.paused = false;\r
-      _t.playState = 1;\r
-\r
-      if (!_t.isHTML5) {\r
-        if (_iO.isMovieStar && !_iO.serverURL) {\r
-          // Bizarre Webkit bug (Chrome reported via 8tracks.com dudes): AAC content paused for 30+ seconds(?) will not resume without a reposition.\r
-          _t.setPosition(_t.position);\r
-        }\r
-        // flash method is toggle-based (pause/resume)\r
-        _flash._pause(_t.id, _iO.multiShot);\r
-      } else {\r
-        _t._setup_html5().play();\r
-        _start_html5_timer();\r
-      }\r
-\r
-      if (!_onplay_called && _iO.onplay) {\r
-        _iO.onplay.apply(_t);\r
-        _onplay_called = true;\r
-      } else if (_iO.onresume) {\r
-        _iO.onresume.apply(_t);\r
-      }\r
-\r
-      return _t;\r
-\r
-    };\r
-\r
-    /**\r
-     * Toggles sound playback.\r
-     *\r
-     * @return {SMSound} The SMSound object\r
-     */\r
-\r
-    this.togglePause = function() {\r
-\r
-      _s._wD('SMSound.togglePause()');\r
-\r
-      if (_t.playState === 0) {\r
-        _t.play({\r
-          position: (_fV === 9 && !_t.isHTML5 ? _t.position : _t.position / 1000)\r
-        });\r
-        return _t;\r
-      }\r
-\r
-      if (_t.paused) {\r
-        _t.resume();\r
-      } else {\r
-        _t.pause();\r
-      }\r
-\r
-      return _t;\r
-\r
-    };\r
-\r
-    /**\r
-     * Sets the panning (L-R) effect.\r
-     *\r
-     * @param {number} nPan The pan value (-100 to 100)\r
-     * @return {SMSound} The SMSound object\r
-     */\r
-\r
-    this.setPan = function(nPan, bInstanceOnly) {\r
-\r
-      if (typeof nPan === 'undefined') {\r
-        nPan = 0;\r
-      }\r
-\r
-      if (typeof bInstanceOnly === 'undefined') {\r
-        bInstanceOnly = false;\r
-      }\r
-\r
-      if (!_t.isHTML5) {\r
-        _flash._setPan(_t.id, nPan);\r
-      } // else { no HTML5 pan? }\r
-\r
-      _t._iO.pan = nPan;\r
-\r
-      if (!bInstanceOnly) {\r
-        _t.pan = nPan;\r
-        _t.options.pan = nPan;\r
-      }\r
-\r
-      return _t;\r
-\r
-    };\r
-\r
-    /**\r
-     * Sets the volume.\r
-     *\r
-     * @param {number} nVol The volume value (0 to 100)\r
-     * @return {SMSound} The SMSound object\r
-     */\r
-\r
-    this.setVolume = function(nVol, _bInstanceOnly) {\r
-\r
-      /**\r
-       * Note: Setting volume has no effect on iOS "special snowflake" devices.\r
-       * Hardware volume control overrides software, and volume\r
-       * will always return 1 per Apple docs. (iOS 4 + 5.)\r
-       * http://developer.apple.com/library/safari/documentation/AudioVideo/Conceptual/HTML-canvas-guide/AddingSoundtoCanvasAnimations/AddingSoundtoCanvasAnimations.html\r
-       */\r
-\r
-      if (typeof nVol === 'undefined') {\r
-        nVol = 100;\r
-      }\r
-\r
-      if (typeof _bInstanceOnly === 'undefined') {\r
-        _bInstanceOnly = false;\r
-      }\r
-\r
-      if (!_t.isHTML5) {\r
-        _flash._setVolume(_t.id, (_s.muted && !_t.muted) || _t.muted?0:nVol);\r
-      } else if (_t._a) {\r
-        // valid range: 0-1\r
-        _t._a.volume = Math.max(0, Math.min(1, nVol/100));\r
-      }\r
-\r
-      _t._iO.volume = nVol;\r
-\r
-      if (!_bInstanceOnly) {\r
-        _t.volume = nVol;\r
-        _t.options.volume = nVol;\r
-      }\r
-\r
-      return _t;\r
-\r
-    };\r
-\r
-    /**\r
-     * Mutes the sound.\r
-     *\r
-     * @return {SMSound} The SMSound object\r
-     */\r
-\r
-    this.mute = function() {\r
-\r
-      _t.muted = true;\r
-\r
-      if (!_t.isHTML5) {\r
-        _flash._setVolume(_t.id, 0);\r
-      } else if (_t._a) {\r
-        _t._a.muted = true;\r
-      }\r
-\r
-      return _t;\r
-\r
-    };\r
-\r
-    /**\r
-     * Unmutes the sound.\r
-     *\r
-     * @return {SMSound} The SMSound object\r
-     */\r
-\r
-    this.unmute = function() {\r
-\r
-      _t.muted = false;\r
-      var hasIO = (typeof _t._iO.volume !== 'undefined');\r
-\r
-      if (!_t.isHTML5) {\r
-        _flash._setVolume(_t.id, hasIO?_t._iO.volume:_t.options.volume);\r
-      } else if (_t._a) {\r
-        _t._a.muted = false;\r
-      }\r
-\r
-      return _t;\r
-\r
-    };\r
-\r
-    /**\r
-     * Toggles the muted state of a sound.\r
-     *\r
-     * @return {SMSound} The SMSound object\r
-     */\r
-\r
-    this.toggleMute = function() {\r
-\r
-      return (_t.muted?_t.unmute():_t.mute());\r
-\r
-    };\r
-\r
-    /**\r
-     * Registers a callback to be fired when a sound reaches a given position during playback.\r
-     *\r
-     * @param {number} nPosition The position to watch for\r
-     * @param {function} oMethod The relevant callback to fire\r
-     * @param {object} oScope Optional: The scope to apply the callback to\r
-     * @return {SMSound} The SMSound object\r
-     */\r
-\r
-    this.onPosition = function(nPosition, oMethod, oScope) {\r
-\r
-      // TODO: basic dupe checking?\r
-\r
-      _onPositionItems.push({\r
-        position: parseInt(nPosition, 10),\r
-        method: oMethod,\r
-        scope: (typeof oScope !== 'undefined' ? oScope : _t),\r
-        fired: false\r
-      });\r
-\r
-      return _t;\r
-\r
-    };\r
-\r
-    // legacy/backwards-compability: lower-case method name\r
-    this.onposition = this.onPosition;\r
-\r
-    /**\r
-     * Removes registered callback(s) from a sound, by position and/or callback.\r
-     *\r
-     * @param {number} nPosition The position to clear callback(s) for\r
-     * @param {function} oMethod Optional: Identify one callback to be removed when multiple listeners exist for one position\r
-     * @return {SMSound} The SMSound object\r
-     */\r
-\r
-    this.clearOnPosition = function(nPosition, oMethod) {\r
-\r
-      var i;\r
-\r
-      nPosition = parseInt(nPosition, 10);\r
-\r
-      if (isNaN(nPosition)) {\r
-        // safety check\r
-        return false;\r
-      }\r
-\r
-      for (i=0; i < _onPositionItems.length; i++) {\r
-\r
-        if (nPosition === _onPositionItems[i].position) {\r
-          // remove this item if no method was specified, or, if the method matches\r
-          if (!oMethod || (oMethod === _onPositionItems[i].method)) {\r
-            if (_onPositionItems[i].fired) {\r
-              // decrement "fired" counter, too\r
-              _onPositionFired--;\r
-            }\r
-            _onPositionItems.splice(i, 1);\r
-          }\r
-        }\r
-\r
-      }\r
-\r
-    };\r
-\r
-    this._processOnPosition = function() {\r
-\r
-      var i, item, j = _onPositionItems.length;\r
-\r
-      if (!j || !_t.playState || _onPositionFired >= j) {\r
-        return false;\r
-      }\r
-\r
-      for (i=j-1; i >= 0; i--) {\r
-        item = _onPositionItems[i];\r
-        if (!item.fired && _t.position >= item.position) {\r
-          item.fired = true;\r
-          _onPositionFired++;\r
-          item.method.apply(item.scope, [item.position]);\r
-        }\r
-      }\r
-\r
-      return true;\r
-\r
-    };\r
-\r
-    this._resetOnPosition = function(nPosition) {\r
-\r
-      // reset "fired" for items interested in this position\r
-      var i, item, j = _onPositionItems.length;\r
-\r
-      if (!j) {\r
-        return false;\r
-      }\r
-\r
-      for (i=j-1; i >= 0; i--) {\r
-        item = _onPositionItems[i];\r
-        if (item.fired && nPosition <= item.position) {\r
-          item.fired = false;\r
-          _onPositionFired--;\r
-        }\r
-      }\r
-\r
-      return true;\r
-\r
-    };\r
-\r
-    /**\r
-     * SMSound() private internals\r
-     * --------------------------------\r
-     */\r
-\r
-    _applyFromTo = function() {\r
-\r
-      var _iO = _t._iO,\r
-          f = _iO.from,\r
-          t = _iO.to,\r
-          start, end;\r
-\r
-      end = function() {\r
-\r
-        // end has been reached.\r
-        _s._wD(_t.id + ': "to" time of ' + t + ' reached.');\r
-\r
-        // detach listener\r
-        _t.clearOnPosition(t, end);\r
-\r
-        // stop should clear this, too\r
-        _t.stop();\r
-\r
-      };\r
-\r
-      start = function() {\r
-\r
-        _s._wD(_t.id + ': playing "from" ' + f);\r
-\r
-        // add listener for end\r
-        if (t !== null && !isNaN(t)) {\r
-          _t.onPosition(t, end);\r
-        }\r
-\r
-      };\r
-\r
-      if (f !== null && !isNaN(f)) {\r
-\r
-        // apply to instance options, guaranteeing correct start position.\r
-        _iO.position = f;\r
-\r
-        // multiShot timing can't be tracked, so prevent that.\r
-        _iO.multiShot = false;\r
-\r
-        start();\r
-\r
-      }\r
-\r
-      // return updated instanceOptions including starting position\r
-      return _iO;\r
-\r
-    };\r
-\r
-    _attachOnPosition = function() {\r
-\r
-      var item,\r
-          op = _t._iO.onposition;\r
-\r
-      // attach onposition things, if any, now.\r
-\r
-      if (op) {\r
-\r
-        for (item in op) {\r
-          if (op.hasOwnProperty(item)) {\r
-            _t.onPosition(parseInt(item, 10), op[item]); \r
-          }\r
-        }\r
-\r
-      }\r
-\r
-    };\r
-\r
-    _detachOnPosition = function() {\r
-\r
-      var item,\r
-          op = _t._iO.onposition;\r
-\r
-      // detach any onposition()-style listeners.\r
-\r
-      if (op) {\r
-\r
-        for (item in op) {\r
-          if (op.hasOwnProperty(item)) {\r
-            _t.clearOnPosition(parseInt(item, 10));\r
-          }\r
-        }\r
-\r
-      }\r
-\r
-    };\r
-\r
-    _start_html5_timer = function() {\r
-\r
-      if (_t.isHTML5) {\r
-        _startTimer(_t);\r
-      }\r
-\r
-    };\r
-\r
-    _stop_html5_timer = function() {\r
-\r
-      if (_t.isHTML5) {\r
-        _stopTimer(_t);\r
-      }\r
-\r
-    };\r
-\r
-    _resetProperties = function(retainPosition) {\r
-\r
-      if (!retainPosition) {\r
-        _onPositionItems = [];\r
-        _onPositionFired = 0;\r
-      }\r
-\r
-      _onplay_called = false;\r
-\r
-      _t._hasTimer = null;\r
-      _t._a = null;\r
-      _t._html5_canplay = false;\r
-      _t.bytesLoaded = null;\r
-      _t.bytesTotal = null;\r
-      _t.duration = (_t._iO && _t._iO.duration ? _t._iO.duration : null);\r
-      _t.durationEstimate = null;\r
-      _t.buffered = [];\r
-\r
-      // legacy: 1D array\r
-      _t.eqData = [];\r
-\r
-      _t.eqData.left = [];\r
-      _t.eqData.right = [];\r
-\r
-      _t.failures = 0;\r
-      _t.isBuffering = false;\r
-      _t.instanceOptions = {};\r
-      _t.instanceCount = 0;\r
-      _t.loaded = false;\r
-      _t.metadata = {};\r
-\r
-      // 0 = uninitialised, 1 = loading, 2 = failed/error, 3 = loaded/success\r
-      _t.readyState = 0;\r
-\r
-      _t.muted = false;\r
-      _t.paused = false;\r
-\r
-      _t.peakData = {\r
-        left: 0,\r
-        right: 0\r
-      };\r
-\r
-      _t.waveformData = {\r
-        left: [],\r
-        right: []\r
-      };\r
-\r
-      _t.playState = 0;\r
-      _t.position = null;\r
-\r
-      _t.id3 = {};\r
-\r
-    };\r
-\r
-    _resetProperties();\r
-\r
-    /**\r
-     * Pseudo-private SMSound internals\r
-     * --------------------------------\r
-     */\r
-\r
-    this._onTimer = function(bForce) {\r
-\r
-      /**\r
-       * HTML5-only _whileplaying() etc.\r
-       * called from both HTML5 native events, and polling/interval-based timers\r
-       * mimics flash and fires only when time/duration change, so as to be polling-friendly\r
-       */\r
-\r
-      var duration, isNew = false, time, x = {};\r
-\r
-      if (_t._hasTimer || bForce) {\r
-\r
-        // TODO: May not need to track readyState (1 = loading)\r
-\r
-        if (_t._a && (bForce || ((_t.playState > 0 || _t.readyState === 1) && !_t.paused))) {\r
-\r
-          duration = _t._get_html5_duration();\r
-\r
-          if (duration !== _lastHTML5State.duration) {\r
-\r
-            _lastHTML5State.duration = duration;\r
-            _t.duration = duration;\r
-            isNew = true;\r
-\r
-          }\r
-\r
-          // TODO: investigate why this goes wack if not set/re-set each time.\r
-          _t.durationEstimate = _t.duration;\r
-\r
-          time = (_t._a.currentTime * 1000 || 0);\r
-\r
-          if (time !== _lastHTML5State.time) {\r
-\r
-            _lastHTML5State.time = time;\r
-            isNew = true;\r
-\r
-          }\r
-\r
-          if (isNew || bForce) {\r
-\r
-            _t._whileplaying(time,x,x,x,x);\r
-\r
-          }\r
-\r
-        }/* else {\r
-\r
-          // _s._wD('_onTimer: Warn for "'+_t.id+'": '+(!_t._a?'Could not find element. ':'')+(_t.playState === 0?'playState bad, 0?':'playState = '+_t.playState+', OK'));\r
-\r
-          return false;\r
-\r
-        }*/\r
-\r
-        return isNew;\r
-\r
-      }\r
-\r
-    };\r
-\r
-    this._get_html5_duration = function() {\r
-\r
-      var _iO = _t._iO,\r
-          // if audio object exists, use its duration - else, instance option duration (if provided - it's a hack, really, and should be retired) OR null\r
-          d = (_t._a && _t._a.duration ? _t._a.duration*1000 : (_iO && _iO.duration ? _iO.duration : null)),\r
-          result = (d && !isNaN(d) && d !== Infinity ? d : null);\r
-\r
-      return result;\r
-\r
-    };\r
-\r
-    this._apply_loop = function(a, nLoops) {\r
-\r
-      /**\r
-       * boolean instead of "loop", for webkit? - spec says string. http://www.w3.org/TR/html-markup/audio.html#audio.attrs.loop\r
-       * note that loop is either off or infinite under HTML5, unlike Flash which allows arbitrary loop counts to be specified.\r
-       */\r
-\r
-      // <d>\r
-      if (!a.loop && nLoops > 1) {\r
-        _s._wD('Note: Native HTML5 looping is infinite.');\r
-      }\r
-      // </d>\r
-\r
-      a.loop = (nLoops > 1 ? 'loop' : '');\r
-\r
-    };\r
-\r
-    this._setup_html5 = function(oOptions) {\r
-\r
-      var _iO = _mixin(_t._iO, oOptions), d = decodeURI,\r
-          _a = _useGlobalHTML5Audio ? _s._global_a : _t._a,\r
-          _dURL = d(_iO.url),\r
-          _oldIO = (_a && _a._t ? _a._t.instanceOptions : null),\r
-          result;\r
-\r
-      if (_a) {\r
-\r
-        if (_a._t) {\r
-\r
-          if (!_useGlobalHTML5Audio && _dURL === d(_lastURL)) {\r
-\r
-            // same url, ignore request\r
-            result = _a; \r
-\r
-          } else if (_useGlobalHTML5Audio && _oldIO.url === _iO.url && (!_lastURL || (_lastURL === _oldIO.url))) {\r
-\r
-            // iOS-type reuse case\r
-            result = _a;\r
-\r
-          }\r
-\r
-          if (result) {\r
-\r
-            _t._apply_loop(_a, _iO.loops);\r
-            return result;\r
-\r
-          }\r
-\r
-        }\r
-\r
-        _s._wD('setting URL on existing object: ' + _dURL + (_lastURL ? ', old URL: ' + _lastURL : ''));\r
-\r
-        /**\r
-         * "First things first, I, Poppa.." (reset the previous state of the old sound, if playing)\r
-         * Fixes case with devices that can only play one sound at a time\r
-         * Otherwise, other sounds in mid-play will be terminated without warning and in a stuck state\r
-         */\r
-\r
-        if (_useGlobalHTML5Audio && _a._t && _a._t.playState && _iO.url !== _oldIO.url) {\r
-\r
-          _a._t.stop();\r
-\r
-        }\r
-\r
-        // reset load/playstate, onPosition etc. if the URL is new.\r
-        // somewhat-tricky object re-use vs. new SMSound object, old vs. new URL comparisons\r
-        _resetProperties((_oldIO && _oldIO.url ? _iO.url === _oldIO.url : (_lastURL ? _lastURL === _iO.url : false)));\r
-\r
-        _a.src = _iO.url;\r
-        _t.url = _iO.url;\r
-        _lastURL = _iO.url;\r
-        _a._called_load = false;\r
-\r
-      } else {\r
-\r
-        _wDS('h5a');\r
-\r
-        if (_iO.autoLoad || _iO.autoPlay) {\r
-\r
-          _t._a = new Audio(_iO.url);\r
-\r
-        } else {\r
-\r
-          // null for stupid Opera 9.64 case\r
-          _t._a = (_isOpera && opera.version() < 10 ? new Audio(null) : new Audio());\r
-\r
-        }\r
-\r
-        // assign local reference\r
-        _a = _t._a;\r
-\r
-        _a._called_load = false;\r
-\r
-        if (_useGlobalHTML5Audio) {\r
-\r
-          _s._global_a = _a;\r
-\r
-        }\r
-\r
-      }\r
-\r
-      _t.isHTML5 = true;\r
-\r
-      // store a ref on the track\r
-      _t._a = _a;\r
-\r
-      // store a ref on the audio\r
-      _a._t = _t;\r
-\r
-      _add_html5_events();\r
-\r
-      _t._apply_loop(_a, _iO.loops);\r
-\r
-      if (_iO.autoLoad || _iO.autoPlay) {\r
-\r
-        _t.load();\r
-\r
-      } else {\r
-\r
-        // early HTML5 implementation (non-standard)\r
-        _a.autobuffer = false;\r
-\r
-        // standard ('none' is also an option.)\r
-        _a.preload = 'auto';\r
-\r
-      }\r
-\r
-      return _a;\r
-\r
-    };\r
-\r
-    _add_html5_events = function() {\r
-\r
-      if (_t._a._added_events) {\r
-        return false;\r
-      }\r
-\r
-      var f;\r
-\r
-      function add(oEvt, oFn, bCapture) {\r
-        return _t._a ? _t._a.addEventListener(oEvt, oFn, bCapture||false) : null;\r
-      }\r
-\r
-      _t._a._added_events = true;\r
-\r
-      for (f in _html5_events) {\r
-        if (_html5_events.hasOwnProperty(f)) {\r
-          add(f, _html5_events[f]);\r
-        }\r
-      }\r
-\r
-      return true;\r
-\r
-    };\r
-\r
-    _remove_html5_events = function() {\r
-\r
-      // Remove event listeners\r
-\r
-      var f;\r
-\r
-      function remove(oEvt, oFn, bCapture) {\r
-        return (_t._a ? _t._a.removeEventListener(oEvt, oFn, bCapture||false) : null);\r
-      }\r
-\r
-      _s._wD(_h5+'removing event listeners: '+_t.id);\r
-      _t._a._added_events = false;\r
-\r
-      for (f in _html5_events) {\r
-        if (_html5_events.hasOwnProperty(f)) {\r
-          remove(f, _html5_events[f]);\r
-        }\r
-      }\r
-\r
-    };\r
-\r
-    /**\r
-     * Pseudo-private event internals\r
-     * ------------------------------\r
-     */\r
-\r
-    this._onload = function(nSuccess) {\r
-\r
-\r
-      var fN,\r
-          // check for duration to prevent false positives from flash 8 when loading from cache.\r
-          loadOK = (!!(nSuccess) || (!_t.isHTML5 && _fV === 8 && _t.duration));\r
-\r
-      // <d>\r
-      fN = 'SMSound._onload(): ';\r
-      _s._wD(fN + '"' + _t.id + '"' + (loadOK?' loaded.':' failed to load? - ' + _t.url), (loadOK?1:2));\r
-      if (!loadOK && !_t.isHTML5) {\r
-        if (_s.sandbox.noRemote === true) {\r
-          _s._wD(fN + _str('noNet'), 1);\r
-        }\r
-        if (_s.sandbox.noLocal === true) {\r
-          _s._wD(fN + _str('noLocal'), 1);\r
-        }\r
-      }\r
-      // </d>\r
-\r
-      _t.loaded = loadOK;\r
-      _t.readyState = loadOK?3:2;\r
-      _t._onbufferchange(0);\r
-\r
-      if (_t._iO.onload) {\r
-        _t._iO.onload.apply(_t, [loadOK]);\r
-      }\r
-\r
-      return true;\r
-\r
-    };\r
-\r
-    this._onbufferchange = function(nIsBuffering) {\r
-\r
-      if (_t.playState === 0) {\r
-        // ignore if not playing\r
-        return false;\r
-      }\r
-\r
-      if ((nIsBuffering && _t.isBuffering) || (!nIsBuffering && !_t.isBuffering)) {\r
-        return false;\r
-      }\r
-\r
-      _t.isBuffering = (nIsBuffering === 1);\r
-      if (_t._iO.onbufferchange) {\r
-        _s._wD('SMSound._onbufferchange(): ' + nIsBuffering);\r
-        _t._iO.onbufferchange.apply(_t);\r
-      }\r
-\r
-      return true;\r
-\r
-    };\r
-\r
-    /**\r
-     * Notify Mobile Safari that user action is required\r
-     * to continue playing / loading the audio file.\r
-     */\r
-\r
-    this._onsuspend = function() {\r
-\r
-      if (_t._iO.onsuspend) {\r
-        _s._wD('SMSound._onsuspend()');\r
-        _t._iO.onsuspend.apply(_t);\r
-      }\r
-\r
-      return true;\r
-\r
-    };\r
-\r
-    /**\r
-     * flash 9/movieStar + RTMP-only method, should fire only once at most\r
-     * at this point we just recreate failed sounds rather than trying to reconnect\r
-     */\r
-\r
-    this._onfailure = function(msg, level, code) {\r
-\r
-      _t.failures++;\r
-      _s._wD('SMSound._onfailure(): "'+_t.id+'" count '+_t.failures);\r
-\r
-      if (_t._iO.onfailure && _t.failures === 1) {\r
-        _t._iO.onfailure(_t, msg, level, code);\r
-      } else {\r
-        _s._wD('SMSound._onfailure(): ignoring');\r
-      }\r
-\r
-    };\r
-\r
-    this._onfinish = function() {\r
-\r
-      // store local copy before it gets trashed..\r
-      var _io_onfinish = _t._iO.onfinish;\r
-\r
-      _t._onbufferchange(0);\r
-      _t._resetOnPosition(0);\r
-\r
-      // reset some state items\r
-      if (_t.instanceCount) {\r
-\r
-        _t.instanceCount--;\r
-\r
-        if (!_t.instanceCount) {\r
-\r
-          // remove onPosition listeners, if any\r
-          _detachOnPosition();\r
-\r
-          // reset instance options\r
-          _t.playState = 0;\r
-          _t.paused = false;\r
-          _t.instanceCount = 0;\r
-          _t.instanceOptions = {};\r
-          _t._iO = {};\r
-          _stop_html5_timer();\r
-\r
-          // reset position, too\r
-          if (_t.isHTML5) {\r
-            _t.position = 0;\r
-          }\r
-\r
-        }\r
-\r
-        if (!_t.instanceCount || _t._iO.multiShotEvents) {\r
-          // fire onfinish for last, or every instance\r
-          if (_io_onfinish) {\r
-            _s._wD('SMSound._onfinish(): "' + _t.id + '"');\r
-            _io_onfinish.apply(_t);\r
-          }\r
-        }\r
-\r
-      }\r
-\r
-    };\r
-\r
-    this._whileloading = function(nBytesLoaded, nBytesTotal, nDuration, nBufferLength) {\r
-\r
-      var _iO = _t._iO;\r
-\r
-      _t.bytesLoaded = nBytesLoaded;\r
-      _t.bytesTotal = nBytesTotal;\r
-      _t.duration = Math.floor(nDuration);\r
-      _t.bufferLength = nBufferLength;\r
-\r
-      if (!_t.isHTML5 && !_iO.isMovieStar) {\r
-\r
-        if (_iO.duration) {\r
-          // use duration from options, if specified and larger. nobody should be specifying duration in options, actually, and it should be retired.\r
-          _t.durationEstimate = (_t.duration > _iO.duration) ? _t.duration : _iO.duration;\r
-        } else {\r
-          _t.durationEstimate = parseInt((_t.bytesTotal / _t.bytesLoaded) * _t.duration, 10);\r
-        }\r
-\r
-      } else {\r
-\r
-        _t.durationEstimate = _t.duration;\r
-\r
-      }\r
-\r
-      // for flash, reflect sequential-load-style buffering\r
-      if (!_t.isHTML5) {\r
-        _t.buffered = [{\r
-          'start': 0,\r
-          'end': _t.duration\r
-        }];\r
-      }\r
-\r
-      // allow whileloading to fire even if "load" fired under HTML5, due to HTTP range/partials\r
-      if ((_t.readyState !== 3 || _t.isHTML5) && _iO.whileloading) {\r
-        _iO.whileloading.apply(_t);\r
-      }\r
-\r
-    };\r
-\r
-    this._whileplaying = function(nPosition, oPeakData, oWaveformDataLeft, oWaveformDataRight, oEQData) {\r
-\r
-      var _iO = _t._iO,\r
-          eqLeft;\r
-\r
-      if (isNaN(nPosition) || nPosition === null) {\r
-        // flash safety net\r
-        return false;\r
-      }\r
-\r
-      // Safari HTML5 play() may return small -ve values when starting from position: 0, eg. -50.120396875. Unexpected/invalid per W3, I think. Normalize to 0.\r
-      _t.position = Math.max(0, nPosition);\r
-\r
-      _t._processOnPosition();\r
-\r
-      if (!_t.isHTML5 && _fV > 8) {\r
-\r
-        if (_iO.usePeakData && typeof oPeakData !== 'undefined' && oPeakData) {\r
-          _t.peakData = {\r
-            left: oPeakData.leftPeak,\r
-            right: oPeakData.rightPeak\r
-          };\r
-        }\r
-\r
-        if (_iO.useWaveformData && typeof oWaveformDataLeft !== 'undefined' && oWaveformDataLeft) {\r
-          _t.waveformData = {\r
-            left: oWaveformDataLeft.split(','),\r
-            right: oWaveformDataRight.split(',')\r
-          };\r
-        }\r
-\r
-        if (_iO.useEQData) {\r
-          if (typeof oEQData !== 'undefined' && oEQData && oEQData.leftEQ) {\r
-            eqLeft = oEQData.leftEQ.split(',');\r
-            _t.eqData = eqLeft;\r
-            _t.eqData.left = eqLeft;\r
-            if (typeof oEQData.rightEQ !== 'undefined' && oEQData.rightEQ) {\r
-              _t.eqData.right = oEQData.rightEQ.split(',');\r
-            }\r
-          }\r
-        }\r
-\r
-      }\r
-\r
-      if (_t.playState === 1) {\r
-\r
-        // special case/hack: ensure buffering is false if loading from cache (and not yet started)\r
-        if (!_t.isHTML5 && _fV === 8 && !_t.position && _t.isBuffering) {\r
-          _t._onbufferchange(0);\r
-        }\r
-\r
-        if (_iO.whileplaying) {\r
-          // flash may call after actual finish\r
-          _iO.whileplaying.apply(_t);\r
-        }\r
-\r
-      }\r
-\r
-      return true;\r
-\r
-    };\r
-\r
-    this._oncaptiondata = function(oData) {\r
-\r
-      /**\r
-       * internal: flash 9 + NetStream (MovieStar/RTMP-only) feature\r
-       * \r
-       * @param {object} oData\r
-       */\r
-\r
-      _s._wD('SMSound._oncaptiondata(): "' + this.id + '" caption data received.');\r
-\r
-      _t.captiondata = oData;\r
-\r
-      if (_t._iO.oncaptiondata) {\r
-        _t._iO.oncaptiondata.apply(_t, [oData]);\r
-      }\r
-\r
-       };\r
-\r
-    this._onmetadata = function(oMDProps, oMDData) {\r
-\r
-      /**\r
-       * internal: flash 9 + NetStream (MovieStar/RTMP-only) feature\r
-       * RTMP may include song title, MovieStar content may include encoding info\r
-       * \r
-       * @param {array} oMDProps (names)\r
-       * @param {array} oMDData (values)\r
-       */\r
-\r
-      _s._wD('SMSound._onmetadata(): "' + this.id + '" metadata received.');\r
-\r
-      var oData = {}, i, j;\r
-\r
-      for (i = 0, j = oMDProps.length; i < j; i++) {\r
-        oData[oMDProps[i]] = oMDData[i];\r
-      }\r
-      _t.metadata = oData;\r
-\r
-      if (_t._iO.onmetadata) {\r
-        _t._iO.onmetadata.apply(_t);\r
-      }\r
-\r
-       };\r
-\r
-    this._onid3 = function(oID3Props, oID3Data) {\r
-\r
-      /**\r
-       * internal: flash 8 + flash 9 ID3 feature\r
-       * may include artist, song title etc.\r
-       * \r
-       * @param {array} oID3Props (names)\r
-       * @param {array} oID3Data (values)\r
-       */\r
-\r
-      _s._wD('SMSound._onid3(): "' + this.id + '" ID3 data received.');\r
-\r
-      var oData = [], i, j;\r
-\r
-      for (i = 0, j = oID3Props.length; i < j; i++) {\r
-        oData[oID3Props[i]] = oID3Data[i];\r
-      }\r
-      _t.id3 = _mixin(_t.id3, oData);\r
-\r
-      if (_t._iO.onid3) {\r
-        _t._iO.onid3.apply(_t);\r
-      }\r
-\r
-    };\r
-\r
-    // flash/RTMP-only\r
-\r
-    this._onconnect = function(bSuccess) {\r
-\r
-      bSuccess = (bSuccess === 1);\r
-      _s._wD('SMSound._onconnect(): "'+_t.id+'"'+(bSuccess?' connected.':' failed to connect? - '+_t.url), (bSuccess?1:2));\r
-      _t.connected = bSuccess;\r
-\r
-      if (bSuccess) {\r
-\r
-        _t.failures = 0;\r
-\r
-        if (_idCheck(_t.id)) {\r
-          if (_t.getAutoPlay()) {\r
-            // only update the play state if auto playing\r
-            _t.play(undefined, _t.getAutoPlay());\r
-          } else if (_t._iO.autoLoad) {\r
-            _t.load();\r
-          }\r
-        }\r
-\r
-        if (_t._iO.onconnect) {\r
-          _t._iO.onconnect.apply(_t, [bSuccess]);\r
-        }\r
-\r
-      }\r
-\r
-    };\r
-\r
-    this._ondataerror = function(sError) {\r
-\r
-      // flash 9 wave/eq data handler\r
-      // hack: called at start, and end from flash at/after onfinish()\r
-      if (_t.playState > 0) {\r
-        _s._wD('SMSound._ondataerror(): ' + sError);\r
-        if (_t._iO.ondataerror) {\r
-          _t._iO.ondataerror.apply(_t);\r
-        }\r
-      }\r
-\r
-    };\r
-\r
-  }; // SMSound()\r
-\r
-  /**\r
-   * Private SoundManager internals\r
-   * ------------------------------\r
-   */\r
-\r
-  _getDocument = function() {\r
-\r
-    return (_doc.body || _doc._docElement || _doc.getElementsByTagName('div')[0]);\r
-\r
-  };\r
-\r
-  _id = function(sID) {\r
-\r
-    return _doc.getElementById(sID);\r
-\r
-  };\r
-\r
-  _mixin = function(oMain, oAdd) {\r
-\r
-    // non-destructive merge\r
-    var o1 = (oMain || {}), o2, o;\r
-\r
-    // if unspecified, o2 is the default options object\r
-    o2 = (typeof oAdd === 'undefined' ? _s.defaultOptions : oAdd);\r
-\r
-    for (o in o2) {\r
-\r
-      if (o2.hasOwnProperty(o) && typeof o1[o] === 'undefined') {\r
-\r
-        if (typeof o2[o] !== 'object' || o2[o] === null) {\r
-\r
-          // assign directly\r
-          o1[o] = o2[o];\r
-\r
-        } else {\r
-\r
-          // recurse through o2\r
-          o1[o] = _mixin(o1[o], o2[o]);\r
-\r
-        }\r
-\r
-      }\r
-\r
-    }\r
-\r
-    return o1;\r
-\r
-  };\r
-\r
-  // additional soundManager properties that soundManager.setup() will accept\r
-\r
-  _extraOptions = {\r
-    'onready': 1,\r
-    'ontimeout': 1,\r
-    'defaultOptions': 1,\r
-    'flash9Options': 1,\r
-    'movieStarOptions': 1\r
-  };\r
-\r
-  _assign = function(o, oParent) {\r
-\r
-    /**\r
-     * recursive assignment of properties, soundManager.setup() helper\r
-     * allows property assignment based on whitelist\r
-     */\r
-\r
-    var i,\r
-        result = true,\r
-        hasParent = (typeof oParent !== 'undefined'),\r
-        setupOptions = _s.setupOptions,\r
-        extraOptions = _extraOptions;\r
-\r
-    // <d>\r
-\r
-    // if soundManager.setup() called, show accepted parameters.\r
-\r
-    if (typeof o === 'undefined') {\r
-\r
-      result = [];\r
-\r
-      for (i in setupOptions) {\r
-\r
-        if (setupOptions.hasOwnProperty(i)) {\r
-          result.push(i);\r
-        }\r
-\r
-      }\r
-\r
-      for (i in extraOptions) {\r
-\r
-        if (extraOptions.hasOwnProperty(i)) {\r
-\r
-          if (typeof _s[i] === 'object') {\r
-\r
-            result.push(i+': {...}');\r
-\r
-          } else if (_s[i] instanceof Function) {\r
-\r
-            result.push(i+': function() {...}');\r
-\r
-          } else {\r
-\r
-            result.push(i);\r
-\r
-          }\r
-\r
-        }\r
-\r
-      }\r
-\r
-      _s._wD(_str('setup', result.join(', ')));\r
-\r
-      return false;\r
-\r
-    }\r
-\r
-    // </d>\r
-\r
-    for (i in o) {\r
-\r
-      if (o.hasOwnProperty(i)) {\r
-\r
-        // if not an {object} we want to recurse through...\r
-\r
-        if (typeof o[i] !== 'object' || o[i] === null || o[i] instanceof Array) {\r
-\r
-          // check "allowed" options\r
-\r
-          if (hasParent && typeof extraOptions[oParent] !== 'undefined') {\r
-\r
-            // valid recursive / nested object option, eg., { defaultOptions: { volume: 50 } }\r
-            _s[oParent][i] = o[i];\r
-\r
-          } else if (typeof setupOptions[i] !== 'undefined') {\r
-\r
-            // special case: assign to setupOptions object, which soundManager property references\r
-            _s.setupOptions[i] = o[i];\r
-\r
-            // assign directly to soundManager, too\r
-            _s[i] = o[i];\r
-\r
-          } else if (typeof extraOptions[i] === 'undefined') {\r
-\r
-            // invalid or disallowed parameter. complain.\r
-            _complain(_str((typeof _s[i] === 'undefined' ? 'setupUndef' : 'setupError'), i), 2);\r
-\r
-            result = false;\r
-\r
-          } else {\r
-\r
-            /**\r
-             * valid extraOptions parameter.\r
-             * is it a method, like onready/ontimeout? call it.\r
-             * multiple parameters should be in an array, eg. soundManager.setup({onready: [myHandler, myScope]});\r
-             */\r
-\r
-            if (_s[i] instanceof Function) {\r
-\r
-              _s[i].apply(_s, (o[i] instanceof Array? o[i] : [o[i]]));\r
-\r
-            } else {\r
-\r
-              // good old-fashioned direct assignment\r
-              _s[i] = o[i];\r
-\r
-            }\r
-\r
-          }\r
-\r
-        } else {\r
-\r
-          // recursion case, eg., { defaultOptions: { ... } }\r
-\r
-          if (typeof extraOptions[i] === 'undefined') {\r
-\r
-            // invalid or disallowed parameter. complain.\r
-            _complain(_str((typeof _s[i] === 'undefined' ? 'setupUndef' : 'setupError'), i), 2);\r
-\r
-            result = false;\r
-\r
-          } else {\r
-\r
-            // recurse through object\r
-            return _assign(o[i], i);\r
-\r
-          }\r
-\r
-        }\r
-\r
-      }\r
-\r
-    }\r
-\r
-    return result;\r
-\r
-  };\r
-\r
-  function _preferFlashCheck(kind) {\r
-\r
-    // whether flash should play a given type\r
-    return (_s.preferFlash && _hasFlash && !_s.ignoreFlash && (typeof _s.flash[kind] !== 'undefined' && _s.flash[kind]));\r
-\r
-  }\r
-\r
-  /**\r
-   * Internal DOM2-level event helpers\r
-   * ---------------------------------\r
-   */\r
-\r
-  _event = (function() {\r
-\r
-    var old = (_win.attachEvent),\r
-    evt = {\r
-      add: (old?'attachEvent':'addEventListener'),\r
-      remove: (old?'detachEvent':'removeEventListener')\r
-    };\r
-\r
-    function getArgs(oArgs) {\r
-\r
-      var args = _slice.call(oArgs),\r
-          len = args.length;\r
-\r
-      if (old) {\r
-        // prefix\r
-        args[1] = 'on' + args[1];\r
-        if (len > 3) {\r
-          // no capture\r
-          args.pop();\r
-        }\r
-      } else if (len === 3) {\r
-        args.push(false);\r
-      }\r
-\r
-      return args;\r
-\r
-    }\r
-\r
-    function apply(args, sType) {\r
-\r
-      var element = args.shift(),\r
-          method = [evt[sType]];\r
-\r
-      if (old) {\r
-        element[method](args[0], args[1]);\r
-      } else {\r
-        element[method].apply(element, args);\r
-      }\r
-\r
-    }\r
-\r
-    function add() {\r
-\r
-      apply(getArgs(arguments), 'add');\r
-\r
-    }\r
-\r
-    function remove() {\r
-\r
-      apply(getArgs(arguments), 'remove');\r
-\r
-    }\r
-\r
-    return {\r
-      'add': add,\r
-      'remove': remove\r
-    };\r
-\r
-  }());\r
-\r
-  /**\r
-   * Internal HTML5 event handling\r
-   * -----------------------------\r
-   */\r
-\r
-  function _html5_event(oFn) {\r
-\r
-    // wrap html5 event handlers so we don't call them on destroyed sounds\r
-\r
-    return function(e) {\r
-\r
-      var t = this._t,\r
-          result;\r
-\r
-      if (!t || !t._a) {\r
-        // <d>\r
-        if (t && t.id) {\r
-          _s._wD(_h5+'ignoring '+e.type+': '+t.id);\r
-        } else {\r
-          _s._wD(_h5+'ignoring '+e.type);\r
-        }\r
-        // </d>\r
-        result = null;\r
-      } else {\r
-        result = oFn.call(this, e);\r
-      }\r
-\r
-      return result;\r
-\r
-    };\r
-\r
-  }\r
-\r
-  _html5_events = {\r
-\r
-    // HTML5 event-name-to-handler map\r
-\r
-    abort: _html5_event(function() {\r
-\r
-      _s._wD(_h5+'abort: '+this._t.id);\r
-\r
-    }),\r
-\r
-    // enough has loaded to play\r
-\r
-    canplay: _html5_event(function() {\r
-\r
-      var t = this._t,\r
-          position1K;\r
-\r
-      if (t._html5_canplay) {\r
-        // this event has already fired. ignore.\r
-        return true;\r
-      }\r
-\r
-      t._html5_canplay = true;\r
-      _s._wD(_h5+'canplay: '+t.id+', '+t.url);\r
-      t._onbufferchange(0);\r
-\r
-      // position according to instance options\r
-      position1K = (typeof t._iO.position !== 'undefined' && !isNaN(t._iO.position)?t._iO.position/1000:null);\r
-\r
-      // set the position if position was set before the sound loaded\r
-      if (t.position && this.currentTime !== position1K) {\r
-        _s._wD(_h5+'canplay: setting position to '+position1K);\r
-        try {\r
-          this.currentTime = position1K;\r
-        } catch(ee) {\r
-          _s._wD(_h5+'setting position of ' + position1K + ' failed: '+ee.message, 2);\r
-        }\r
-      }\r
-\r
-      // hack for HTML5 from/to case\r
-      if (t._iO._oncanplay) {\r
-        t._iO._oncanplay();\r
-      }\r
-\r
-    }),\r
-\r
-    canplaythrough: _html5_event(function() {\r
-\r
-      var t = this._t;\r
-\r
-      if (!t.loaded) {\r
-        t._onbufferchange(0);\r
-        t._whileloading(t.bytesLoaded, t.bytesTotal, t._get_html5_duration());\r
-        t._onload(true);\r
-      }\r
-\r
-    }),\r
-\r
-    // TODO: Reserved for potential use\r
-    /*\r
-    emptied: _html5_event(function() {\r
-\r
-      _s._wD(_h5+'emptied: '+this._t.id);\r
-\r
-    }),\r
-    */\r
-\r
-    ended: _html5_event(function() {\r
-\r
-      var t = this._t;\r
-\r
-      _s._wD(_h5+'ended: '+t.id);\r
-      t._onfinish();\r
-\r
-    }),\r
-\r
-    error: _html5_event(function() {\r
-\r
-      _s._wD(_h5+'error: '+this.error.code);\r
-      // call load with error state?\r
-      this._t._onload(false);\r
-\r
-    }),\r
-\r
-    loadeddata: _html5_event(function() {\r
-\r
-      var t = this._t;\r
-\r
-      _s._wD(_h5+'loadeddata: '+this._t.id);\r
-\r
-      // safari seems to nicely report progress events, eventually totalling 100%\r
-      if (!t._loaded && !_isSafari) {\r
-        t.duration = t._get_html5_duration();\r
-      }\r
-\r
-    }),\r
-\r
-    loadedmetadata: _html5_event(function() {\r
-\r
-      _s._wD(_h5+'loadedmetadata: '+this._t.id);\r
-\r
-    }),\r
-\r
-    loadstart: _html5_event(function() {\r
-\r
-      _s._wD(_h5+'loadstart: '+this._t.id);\r
-      // assume buffering at first\r
-      this._t._onbufferchange(1);\r
-\r
-    }),\r
-\r
-    play: _html5_event(function() {\r
-\r
-      _s._wD(_h5+'play: '+this._t.id+', '+this._t.url);\r
-      // once play starts, no buffering\r
-      this._t._onbufferchange(0);\r
-\r
-    }),\r
-\r
-    playing: _html5_event(function() {\r
-\r
-      _s._wD(_h5+'playing: '+this._t.id);\r
-\r
-      // once play starts, no buffering\r
-      this._t._onbufferchange(0);\r
-\r
-    }),\r
-\r
-    progress: _html5_event(function(e) {\r
-\r
-      // note: can fire repeatedly after "loaded" event, due to use of HTTP range/partials\r
-\r
-      var t = this._t,\r
-          i, j, str, buffered = 0,\r
-          isProgress = (e.type === 'progress'),\r
-          ranges = e.target.buffered,\r
-          // firefox 3.6 implements e.loaded/total (bytes)\r
-          loaded = (e.loaded||0),\r
-          total = (e.total||1),\r
-          // HTML5 returns msec. SM2 API uses seconds for setPosition() etc., whether Flash or HTML5.\r
-          scale = 1000;\r
-\r
-      // reset the "buffered" (loaded byte ranges) array\r
-      t.buffered = [];\r
-\r
-      if (ranges && ranges.length) {\r
-\r
-        // if loaded is 0, try TimeRanges implementation as % of load\r
-        // https://developer.mozilla.org/en/DOM/TimeRanges\r
-\r
-        // re-build "buffered" array\r
-        for (i=0, j=ranges.length; i<j; i++) {\r
-          t.buffered.push({\r
-            'start': ranges.start(i) * scale,\r
-            'end': ranges.end(i) * scale\r
-          });\r
-        }\r
-\r
-        // use the last value locally\r
-        buffered = (ranges.end(0) - ranges.start(0)) * scale;\r
-\r
-        // linear case, buffer sum; does not account for seeking and HTTP partials / byte ranges\r
-        loaded = buffered/(e.target.duration*scale);\r
-\r
-        // <d>\r
-        if (isProgress && ranges.length > 1) {\r
-          str = [];\r
-          j = ranges.length;\r
-          for (i=0; i<j; i++) {\r
-            str.push(e.target.buffered.start(i)*scale +'-'+ e.target.buffered.end(i)*scale);\r
-          }\r
-          _s._wD(_h5+'progress: timeRanges: '+str.join(', '));\r
-        }\r
-\r
-        if (isProgress && !isNaN(loaded)) {\r
-          _s._wD(_h5+'progress: '+t.id+': ' + Math.floor(loaded*100)+'% loaded');\r
-        }\r
-        // </d>\r
-\r
-      }\r
-\r
-      if (!isNaN(loaded)) {\r
-\r
-        // if progress, likely not buffering\r
-        t._onbufferchange(0);\r
-        // TODO: prevent calls with duplicate values.\r
-        t._whileloading(loaded, total, t._get_html5_duration());\r
-        if (loaded && total && loaded === total) {\r
-          // in case "onload" doesn't fire (eg. gecko 1.9.2)\r
-          _html5_events.canplaythrough.call(this, e);\r
-        }\r
-\r
-      }\r
-\r
-    }),\r
-\r
-    ratechange: _html5_event(function() {\r
-\r
-      _s._wD(_h5+'ratechange: '+this._t.id);\r
-\r
-    }),\r
-\r
-    suspend: _html5_event(function(e) {\r
-\r
-      // download paused/stopped, may have finished (eg. onload)\r
-      var t = this._t;\r
-\r
-      _s._wD(_h5+'suspend: '+t.id);\r
-      _html5_events.progress.call(this, e);\r
-      t._onsuspend();\r
-\r
-    }),\r
-\r
-    stalled: _html5_event(function() {\r
-\r
-      _s._wD(_h5+'stalled: '+this._t.id);\r
-\r
-    }),\r
-\r
-    timeupdate: _html5_event(function() {\r
-\r
-      this._t._onTimer();\r
-\r
-    }),\r
-\r
-    waiting: _html5_event(function() {\r
-\r
-      var t = this._t;\r
-\r
-      // see also: seeking\r
-      _s._wD(_h5+'waiting: '+t.id);\r
-\r
-      // playback faster than download rate, etc.\r
-      t._onbufferchange(1);\r
-\r
-    })\r
-\r
-  };\r
-\r
-  _html5OK = function(iO) {\r
-\r
-    // playability test based on URL or MIME type\r
-\r
-    var result;\r
-\r
-    if (iO.serverURL || (iO.type && _preferFlashCheck(iO.type))) {\r
-\r
-      // RTMP, or preferring flash\r
-      result = false;\r
-\r
-    } else {\r
-\r
-      // Use type, if specified. If HTML5-only mode, no other options, so just give 'er\r
-      result = ((iO.type ? _html5CanPlay({type:iO.type}) : _html5CanPlay({url:iO.url}) || _s.html5Only));\r
-\r
-    }\r
-\r
-    return result;\r
-\r
-  };\r
-\r
-  _html5Unload = function(oAudio, url) {\r
-\r
-    /**\r
-     * Internal method: Unload media, and cancel any current/pending network requests.\r
-     * Firefox can load an empty URL, which allegedly destroys the decoder and stops the download.\r
-     * https://developer.mozilla.org/En/Using_audio_and_video_in_Firefox#Stopping_the_download_of_media\r
-     * However, Firefox has been seen loading a relative URL from '' and thus requesting the hosting page on unload.\r
-     * Other UA behaviour is unclear, so everyone else gets an about:blank-style URL.\r
-     */\r
-\r
-    if (oAudio) {\r
-      // Firefox likes '' for unload (used to work?) - however, may request hosting page URL (bad.) Most other UAs dislike '' and fail to unload.\r
-      oAudio.src = url;\r
-    }\r
-\r
-  };\r
-\r
-  _html5CanPlay = function(o) {\r
-\r
-    /**\r
-     * Try to find MIME, test and return truthiness\r
-     * o = {\r
-     *  url: '/path/to/an.mp3',\r
-     *  type: 'audio/mp3'\r
-     * }\r
-     */\r
-\r
-    if (!_s.useHTML5Audio || !_s.hasHTML5) {\r
-      return false;\r
-    }\r
-\r
-    var url = (o.url || null),\r
-        mime = (o.type || null),\r
-        aF = _s.audioFormats,\r
-        result,\r
-        offset,\r
-        fileExt,\r
-        item;\r
-\r
-    // account for known cases like audio/mp3\r
-\r
-    if (mime && typeof _s.html5[mime] !== 'undefined') {\r
-      return (_s.html5[mime] && !_preferFlashCheck(mime));\r
-    }\r
-\r
-    if (!_html5Ext) {\r
-      _html5Ext = [];\r
-      for (item in aF) {\r
-        if (aF.hasOwnProperty(item)) {\r
-          _html5Ext.push(item);\r
-          if (aF[item].related) {\r
-            _html5Ext = _html5Ext.concat(aF[item].related);\r
-          }\r
-        }\r
-      }\r
-      _html5Ext = new RegExp('\\.('+_html5Ext.join('|')+')(\\?.*)?$','i');\r
-    }\r
-\r
-    // TODO: Strip URL queries, etc.\r
-    fileExt = (url ? url.toLowerCase().match(_html5Ext) : null);\r
-\r
-    if (!fileExt || !fileExt.length) {\r
-      if (!mime) {\r
-        result = false;\r
-      } else {\r
-        // audio/mp3 -> mp3, result should be known\r
-        offset = mime.indexOf(';');\r
-        // strip "audio/X; codecs.."\r
-        fileExt = (offset !== -1?mime.substr(0,offset):mime).substr(6);\r
-      }\r
-    } else {\r
-      // match the raw extension name - "mp3", for example\r
-      fileExt = fileExt[1];\r
-    }\r
-\r
-    if (fileExt && typeof _s.html5[fileExt] !== 'undefined') {\r
-      // result known\r
-      result = (_s.html5[fileExt] && !_preferFlashCheck(fileExt));\r
-    } else {\r
-      mime = 'audio/'+fileExt;\r
-      result = _s.html5.canPlayType({type:mime});\r
-      _s.html5[fileExt] = result;\r
-      // _s._wD('canPlayType, found result: '+result);\r
-      result = (result && _s.html5[mime] && !_preferFlashCheck(mime));\r
-    }\r
-\r
-    return result;\r
-\r
-  };\r
-\r
-  _testHTML5 = function() {\r
-\r
-    /**\r
-     * Internal: Iterates over audioFormats, determining support eg. audio/mp3, audio/mpeg and so on\r
-     * assigns results to html5[] and flash[].\r
-     */\r
-\r
-    if (!_s.useHTML5Audio || !_s.hasHTML5) {\r
-      return false;\r
-    }\r
-\r
-    // double-whammy: Opera 9.64 throws WRONG_ARGUMENTS_ERR if no parameter passed to Audio(), and Webkit + iOS happily tries to load "null" as a URL. :/\r
-    var a = (typeof Audio !== 'undefined' ? (_isOpera && opera.version() < 10 ? new Audio(null) : new Audio()) : null),\r
-        item, lookup, support = {}, aF, i;\r
-\r
-    function _cp(m) {\r
-\r
-      var canPlay, i, j,\r
-          result = false,\r
-          isOK = false;\r
-\r
-      if (!a || typeof a.canPlayType !== 'function') {\r
-        return result;\r
-      }\r
-\r
-      if (m instanceof Array) {\r
-        // iterate through all mime types, return any successes\r
-        for (i=0, j=m.length; i<j; i++) {\r
-          if (_s.html5[m[i]] || a.canPlayType(m[i]).match(_s.html5Test)) {\r
-            isOK = true;\r
-            _s.html5[m[i]] = true;\r
-            // note flash support, too\r
-            _s.flash[m[i]] = !!(m[i].match(_flashMIME));\r
-          }\r
-        }\r
-        result = isOK;\r
-      } else {\r
-        canPlay = (a && typeof a.canPlayType === 'function' ? a.canPlayType(m) : false);\r
-        result = !!(canPlay && (canPlay.match(_s.html5Test)));\r
-      }\r
-\r
-      return result;\r
-\r
-    }\r
-\r
-    // test all registered formats + codecs\r
-\r
-    aF = _s.audioFormats;\r
-\r
-    for (item in aF) {\r
-\r
-      if (aF.hasOwnProperty(item)) {\r
-\r
-        lookup = 'audio/' + item;\r
-\r
-        support[item] = _cp(aF[item].type);\r
-\r
-        // write back generic type too, eg. audio/mp3\r
-        support[lookup] = support[item];\r
-\r
-        // assign flash\r
-        if (item.match(_flashMIME)) {\r
-\r
-          _s.flash[item] = true;\r
-          _s.flash[lookup] = true;\r
-\r
-        } else {\r
-\r
-          _s.flash[item] = false;\r
-          _s.flash[lookup] = false;\r
-\r
-        }\r
-\r
-        // assign result to related formats, too\r
-\r
-        if (aF[item] && aF[item].related) {\r
-\r
-          for (i=aF[item].related.length-1; i >= 0; i--) {\r
-\r
-            // eg. audio/m4a\r
-            support['audio/'+aF[item].related[i]] = support[item];\r
-            _s.html5[aF[item].related[i]] = support[item];\r
-            _s.flash[aF[item].related[i]] = support[item];\r
-\r
-          }\r
-\r
-        }\r
-\r
-      }\r
-\r
-    }\r
-\r
-    support.canPlayType = (a?_cp:null);\r
-    _s.html5 = _mixin(_s.html5, support);\r
-\r
-    return true;\r
-\r
-  };\r
-\r
-  _strings = {\r
-\r
-    // <d>\r
-    notReady: 'Not loaded yet - wait for soundManager.onready()',\r
-    notOK: 'Audio support is not available.',\r
-    domError: _smc + 'createMovie(): appendChild/innerHTML call failed. DOM not ready or other error.',\r
-    spcWmode: _smc + 'createMovie(): Removing wmode, preventing known SWF loading issue(s)',\r
-    swf404: _sm + ': Verify that %s is a valid path.',\r
-    tryDebug: 'Try ' + _sm + '.debugFlash = true for more security details (output goes to SWF.)',\r
-    checkSWF: 'See SWF output for more debug info.',\r
-    localFail: _sm + ': Non-HTTP page (' + _doc.location.protocol + ' URL?) Review Flash player security settings for this special case:\nhttp://www.macromedia.com/support/documentation/en/flashplayer/help/settings_manager04.html\nMay need to add/allow path, eg. c:/sm2/ or /users/me/sm2/',\r
-    waitFocus: _sm + ': Special case: Waiting for SWF to load with window focus...',\r
-    waitImpatient: _sm + ': Getting impatient, still waiting for Flash%s...',\r
-    waitForever: _sm + ': Waiting indefinitely for Flash (will recover if unblocked)...',\r
-    waitSWF: _sm + ': Retrying, waiting for 100% SWF load...',\r
-    needFunction: _sm + ': Function object expected for %s',\r
-    badID: 'Warning: Sound ID "%s" should be a string, starting with a non-numeric character',\r
-    currentObj: '--- ' + _sm + '._debug(): Current sound objects ---',\r
-    waitEI: _smc + 'initMovie(): Waiting for ExternalInterface call from Flash...',\r
-    waitOnload: _sm + ': Waiting for window.onload()',\r
-    docLoaded: _sm + ': Document already loaded',\r
-    onload: _smc + 'initComplete(): calling soundManager.onload()',\r
-    onloadOK: _sm + '.onload() complete',\r
-    init: _smc + 'init()',\r
-    didInit: _smc + 'init(): Already called?',\r
-    flashJS: _sm + ': Attempting JS to Flash call...',\r
-    secNote: 'Flash security note: Network/internet URLs will not load due to security restrictions. Access can be configured via Flash Player Global Security Settings Page: http://www.macromedia.com/support/documentation/en/flashplayer/help/settings_manager04.html',\r
-    badRemove: 'Warning: Failed to remove flash movie.',\r
-    shutdown: _sm + '.disable(): Shutting down',\r
-    queue: _sm + ': Queueing %s handler',\r
-    smFail: _sm + ': Failed to initialise.',\r
-    smError: 'SMSound.load(): Exception: JS-Flash communication failed, or JS error.',\r
-    fbTimeout: 'No flash response, applying .'+_swfCSS.swfTimedout+' CSS...',\r
-    fbLoaded: 'Flash loaded',\r
-    fbHandler: _smc+'flashBlockHandler()',\r
-    manURL: 'SMSound.load(): Using manually-assigned URL',\r
-    onURL: _sm + '.load(): current URL already assigned.',\r
-    badFV: _sm + '.flashVersion must be 8 or 9. "%s" is invalid. Reverting to %s.',\r
-    as2loop: 'Note: Setting stream:false so looping can work (flash 8 limitation)',\r
-    noNSLoop: 'Note: Looping not implemented for MovieStar formats',\r
-    needfl9: 'Note: Switching to flash 9, required for MP4 formats.',\r
-    mfTimeout: 'Setting flashLoadTimeout = 0 (infinite) for off-screen, mobile flash case',\r
-    needFlash: _sm + ': Fatal error: Flash is needed to play some required formats, but is not available.',\r
-    gotFocus: _sm + ': Got window focus.',\r
-    mfOn: 'mobileFlash::enabling on-screen flash repositioning',\r
-    policy: 'Enabling usePolicyFile for data access',\r
-    setup: _sm + '.setup(): allowed parameters: %s',\r
-    setupError: _sm + '.setup(): "%s" cannot be assigned with this method.',\r
-    setupUndef: _sm + '.setup(): Could not find option "%s"',\r
-    setupLate: _sm + '.setup(): url + flashVersion changes will not take effect until reboot().',\r
-    h5a: 'creating HTML5 Audio() object',\r
-    noURL: _sm + ': Flash URL required. Call soundManager.setup({url:...}) to get started.'\r
-    // </d>\r
-\r
-  };\r
-\r
-  _str = function() {\r
-\r
-    // internal string replace helper.\r
-    // arguments: o [,items to replace]\r
-    // <d>\r
-\r
-    // real array, please\r
-    var args = _slice.call(arguments),\r
-\r
-    // first arg\r
-    o = args.shift(),\r
-\r
-    str = (_strings && _strings[o]?_strings[o]:''), i, j;\r
-    if (str && args && args.length) {\r
-      for (i = 0, j = args.length; i < j; i++) {\r
-        str = str.replace('%s', args[i]);\r
-      }\r
-    }\r
-\r
-    return str;\r
-    // </d>\r
-\r
-  };\r
-\r
-  _loopFix = function(sOpt) {\r
-\r
-    // flash 8 requires stream = false for looping to work\r
-    if (_fV === 8 && sOpt.loops > 1 && sOpt.stream) {\r
-      _wDS('as2loop');\r
-      sOpt.stream = false;\r
-    }\r
-\r
-    return sOpt;\r
-\r
-  };\r
-\r
-  _policyFix = function(sOpt, sPre) {\r
-\r
-    if (sOpt && !sOpt.usePolicyFile && (sOpt.onid3 || sOpt.usePeakData || sOpt.useWaveformData || sOpt.useEQData)) {\r
-      _s._wD((sPre || '') + _str('policy'));\r
-      sOpt.usePolicyFile = true;\r
-    }\r
-\r
-    return sOpt;\r
-\r
-  };\r
-\r
-  _complain = function(sMsg) {\r
-\r
-    // <d>\r
-    if (typeof console !== 'undefined' && typeof console.warn !== 'undefined') {\r
-      console.warn(sMsg);\r
-    } else {\r
-      _s._wD(sMsg);\r
-    }\r
-    // </d>\r
-\r
-  };\r
-\r
-  _doNothing = function() {\r
-\r
-    return false;\r
-\r
-  };\r
-\r
-  _disableObject = function(o) {\r
-\r
-    var oProp;\r
-\r
-    for (oProp in o) {\r
-      if (o.hasOwnProperty(oProp) && typeof o[oProp] === 'function') {\r
-        o[oProp] = _doNothing;\r
-      }\r
-    }\r
-\r
-    oProp = null;\r
-\r
-  };\r
-\r
-  _failSafely = function(bNoDisable) {\r
-\r
-    // general failure exception handler\r
-\r
-    if (typeof bNoDisable === 'undefined') {\r
-      bNoDisable = false;\r
-    }\r
-\r
-    if (_disabled || bNoDisable) {\r
-      _wDS('smFail', 2);\r
-      _s.disable(bNoDisable);\r
-    }\r
-\r
-  };\r
-\r
-  _normalizeMovieURL = function(smURL) {\r
-\r
-    var urlParams = null, url;\r
-\r
-    if (smURL) {\r
-      if (smURL.match(/\.swf(\?.*)?$/i)) {\r
-        urlParams = smURL.substr(smURL.toLowerCase().lastIndexOf('.swf?') + 4);\r
-        if (urlParams) {\r
-          // assume user knows what they're doing\r
-          return smURL;\r
-        }\r
-      } else if (smURL.lastIndexOf('/') !== smURL.length - 1) {\r
-        // append trailing slash, if needed\r
-        smURL += '/';\r
-      }\r
-    }\r
-\r
-    url = (smURL && smURL.lastIndexOf('/') !== - 1 ? smURL.substr(0, smURL.lastIndexOf('/') + 1) : './') + _s.movieURL;\r
-\r
-    if (_s.noSWFCache) {\r
-      url += ('?ts=' + new Date().getTime());\r
-    }\r
-\r
-    return url;\r
-\r
-  };\r
-\r
-  _setVersionInfo = function() {\r
-\r
-    // short-hand for internal use\r
-\r
-    _fV = parseInt(_s.flashVersion, 10);\r
-\r
-    if (_fV !== 8 && _fV !== 9) {\r
-      _s._wD(_str('badFV', _fV, _defaultFlashVersion));\r
-      _s.flashVersion = _fV = _defaultFlashVersion;\r
-    }\r
-\r
-    // debug flash movie, if applicable\r
-\r
-    var isDebug = (_s.debugMode || _s.debugFlash?'_debug.swf':'.swf');\r
-\r
-    if (_s.useHTML5Audio && !_s.html5Only && _s.audioFormats.mp4.required && _fV < 9) {\r
-      _s._wD(_str('needfl9'));\r
-      _s.flashVersion = _fV = 9;\r
-    }\r
-\r
-    _s.version = _s.versionNumber + (_s.html5Only?' (HTML5-only mode)':(_fV === 9?' (AS3/Flash 9)':' (AS2/Flash 8)'));\r
-\r
-    // set up default options\r
-    if (_fV > 8) {\r
-      // +flash 9 base options\r
-      _s.defaultOptions = _mixin(_s.defaultOptions, _s.flash9Options);\r
-      _s.features.buffering = true;\r
-      // +moviestar support\r
-      _s.defaultOptions = _mixin(_s.defaultOptions, _s.movieStarOptions);\r
-      _s.filePatterns.flash9 = new RegExp('\\.(mp3|' + _netStreamTypes.join('|') + ')(\\?.*)?$', 'i');\r
-      _s.features.movieStar = true;\r
-    } else {\r
-      _s.features.movieStar = false;\r
-    }\r
-\r
-    // regExp for flash canPlay(), etc.\r
-    _s.filePattern = _s.filePatterns[(_fV !== 8?'flash9':'flash8')];\r
-\r
-    // if applicable, use _debug versions of SWFs\r
-    _s.movieURL = (_fV === 8?'soundmanager2.swf':'soundmanager2_flash9.swf').replace('.swf', isDebug);\r
-\r
-    _s.features.peakData = _s.features.waveformData = _s.features.eqData = (_fV > 8);\r
-\r
-  };\r
-\r
-  _setPolling = function(bPolling, bHighPerformance) {\r
-\r
-    if (!_flash) {\r
-      return false;\r
-    }\r
-\r
-    _flash._setPolling(bPolling, bHighPerformance);\r
-\r
-  };\r
-\r
-  _initDebug = function() {\r
-\r
-    // starts debug mode, creating output <div> for UAs without console object\r
-\r
-    // allow force of debug mode via URL\r
-    if (_s.debugURLParam.test(_wl)) {\r
-      _s.debugMode = true;\r
-    }\r
-\r
-    // <d>\r
-    if (_id(_s.debugID)) {\r
-      return false;\r
-    }\r
-\r
-    var oD, oDebug, oTarget, oToggle, tmp;\r
-\r
-    if (_s.debugMode && !_id(_s.debugID) && (!_hasConsole || !_s.useConsole || !_s.consoleOnly)) {\r
-\r
-      oD = _doc.createElement('div');\r
-      oD.id = _s.debugID + '-toggle';\r
-\r
-      oToggle = {\r
-        'position': 'fixed',\r
-        'bottom': '0px',\r
-        'right': '0px',\r
-        'width': '1.2em',\r
-        'height': '1.2em',\r
-        'lineHeight': '1.2em',\r
-        'margin': '2px',\r
-        'textAlign': 'center',\r
-        'border': '1px solid #999',\r
-        'cursor': 'pointer',\r
-        'background': '#fff',\r
-        'color': '#333',\r
-        'zIndex': 10001\r
-      };\r
-\r
-      oD.appendChild(_doc.createTextNode('-'));\r
-      oD.onclick = _toggleDebug;\r
-      oD.title = 'Toggle SM2 debug console';\r
-\r
-      if (_ua.match(/msie 6/i)) {\r
-        oD.style.position = 'absolute';\r
-        oD.style.cursor = 'hand';\r
-      }\r
-\r
-      for (tmp in oToggle) {\r
-        if (oToggle.hasOwnProperty(tmp)) {\r
-          oD.style[tmp] = oToggle[tmp];\r
-        }\r
-      }\r
-\r
-      oDebug = _doc.createElement('div');\r
-      oDebug.id = _s.debugID;\r
-      oDebug.style.display = (_s.debugMode?'block':'none');\r
-\r
-      if (_s.debugMode && !_id(oD.id)) {\r
-        try {\r
-          oTarget = _getDocument();\r
-          oTarget.appendChild(oD);\r
-        } catch(e2) {\r
-          throw new Error(_str('domError')+' \n'+e2.toString());\r
-        }\r
-        oTarget.appendChild(oDebug);\r
-      }\r
-\r
-    }\r
-\r
-    oTarget = null;\r
-    // </d>\r
-\r
-  };\r
-\r
-  _idCheck = this.getSoundById;\r
-\r
-  // <d>\r
-  _wDS = function(o, errorLevel) {\r
-\r
-    return (!o ? '' : _s._wD(_str(o), errorLevel));\r
-\r
-  };\r
-\r
-  // last-resort debugging option\r
-\r
-  if (_wl.indexOf('sm2-debug=alert') + 1 && _s.debugMode) {\r
-    _s._wD = function(sText) {window.alert(sText);};\r
-  }\r
-\r
-  _toggleDebug = function() {\r
-\r
-    var o = _id(_s.debugID),\r
-    oT = _id(_s.debugID + '-toggle');\r
-\r
-    if (!o) {\r
-      return false;\r
-    }\r
-\r
-    if (_debugOpen) {\r
-      // minimize\r
-      oT.innerHTML = '+';\r
-      o.style.display = 'none';\r
-    } else {\r
-      oT.innerHTML = '-';\r
-      o.style.display = 'block';\r
-    }\r
-\r
-    _debugOpen = !_debugOpen;\r
-\r
-  };\r
-\r
-  _debugTS = function(sEventType, bSuccess, sMessage) {\r
-\r
-    // troubleshooter debug hooks\r
-\r
-    if (typeof sm2Debugger !== 'undefined') {\r
-      try {\r
-        sm2Debugger.handleEvent(sEventType, bSuccess, sMessage);\r
-      } catch(e) {\r
-        // oh well\r
-      }\r
-    }\r
-\r
-    return true;\r
-\r
-  };\r
-  // </d>\r
-\r
-  _getSWFCSS = function() {\r
-\r
-    var css = [];\r
-\r
-    if (_s.debugMode) {\r
-      css.push(_swfCSS.sm2Debug);\r
-    }\r
-\r
-    if (_s.debugFlash) {\r
-      css.push(_swfCSS.flashDebug);\r
-    }\r
-\r
-    if (_s.useHighPerformance) {\r
-      css.push(_swfCSS.highPerf);\r
-    }\r
-\r
-    return css.join(' ');\r
-\r
-  };\r
-\r
-  _flashBlockHandler = function() {\r
-\r
-    // *possible* flash block situation.\r
-\r
-    var name = _str('fbHandler'),\r
-        p = _s.getMoviePercent(),\r
-        css = _swfCSS,\r
-        error = {type:'FLASHBLOCK'};\r
-\r
-    if (_s.html5Only) {\r
-      return false;\r
-    }\r
-\r
-    if (!_s.ok()) {\r
-\r
-      if (_needsFlash) {\r
-        // make the movie more visible, so user can fix\r
-        _s.oMC.className = _getSWFCSS() + ' ' + css.swfDefault + ' ' + (p === null?css.swfTimedout:css.swfError);\r
-        _s._wD(name+': '+_str('fbTimeout')+(p?' ('+_str('fbLoaded')+')':''));\r
-      }\r
-\r
-      _s.didFlashBlock = true;\r
-\r
-      // fire onready(), complain lightly\r
-      _processOnEvents({type:'ontimeout', ignoreInit:true, error:error});\r
-      _catchError(error);\r
-\r
-    } else {\r
-\r
-      // SM2 loaded OK (or recovered)\r
-\r
-      // <d>\r
-      if (_s.didFlashBlock) {\r
-        _s._wD(name+': Unblocked');\r
-      }\r
-      // </d>\r
-\r
-      if (_s.oMC) {\r
-        _s.oMC.className = [_getSWFCSS(), css.swfDefault, css.swfLoaded + (_s.didFlashBlock?' '+css.swfUnblocked:'')].join(' ');\r
-      }\r
-\r
-    }\r
-\r
-  };\r
-\r
-  _addOnEvent = function(sType, oMethod, oScope) {\r
-\r
-    if (typeof _on_queue[sType] === 'undefined') {\r
-      _on_queue[sType] = [];\r
-    }\r
-\r
-    _on_queue[sType].push({\r
-      'method': oMethod,\r
-      'scope': (oScope || null),\r
-      'fired': false\r
-    });\r
-\r
-  };\r
-\r
-  _processOnEvents = function(oOptions) {\r
-\r
-    // if unspecified, assume OK/error\r
-\r
-    if (!oOptions) {\r
-      oOptions = {\r
-        type: (_s.ok() ? 'onready' : 'ontimeout')\r
-      };\r
-    }\r
-\r
-    if (!_didInit && oOptions && !oOptions.ignoreInit) {\r
-      // not ready yet.\r
-      return false;\r
-    }\r
-\r
-    if (oOptions.type === 'ontimeout' && (_s.ok() || (_disabled && !oOptions.ignoreInit))) {\r
-      // invalid case\r
-      return false;\r
-    }\r
-\r
-    var status = {\r
-          success: (oOptions && oOptions.ignoreInit?_s.ok():!_disabled)\r
-        },\r
-\r
-        // queue specified by type, or none\r
-        srcQueue = (oOptions && oOptions.type?_on_queue[oOptions.type]||[]:[]),\r
-\r
-        queue = [], i, j,\r
-        args = [status],\r
-        canRetry = (_needsFlash && _s.useFlashBlock && !_s.ok());\r
-\r
-    if (oOptions.error) {\r
-      args[0].error = oOptions.error;\r
-    }\r
-\r
-    for (i = 0, j = srcQueue.length; i < j; i++) {\r
-      if (srcQueue[i].fired !== true) {\r
-        queue.push(srcQueue[i]);\r
-      }\r
-    }\r
-\r
-    if (queue.length) {\r
-      _s._wD(_sm + ': Firing ' + queue.length + ' '+oOptions.type+'() item' + (queue.length === 1?'':'s'));\r
-      for (i = 0, j = queue.length; i < j; i++) {\r
-        if (queue[i].scope) {\r
-          queue[i].method.apply(queue[i].scope, args);\r
-        } else {\r
-          queue[i].method.apply(this, args);\r
-        }\r
-        if (!canRetry) {\r
-          // flashblock case doesn't count here\r
-          queue[i].fired = true;\r
-        }\r
-      }\r
-    }\r
-\r
-    return true;\r
-\r
-  };\r
-\r
-  _initUserOnload = function() {\r
-\r
-    _win.setTimeout(function() {\r
-\r
-      if (_s.useFlashBlock) {\r
-        _flashBlockHandler();\r
-      }\r
-\r
-      _processOnEvents();\r
-\r
-      // call user-defined "onload", scoped to window\r
-\r
-      if (typeof _s.onload === 'function') {\r
-        _wDS('onload', 1);\r
-        _s.onload.apply(_win);\r
-        _wDS('onloadOK', 1);\r
-      }\r
-\r
-      if (_s.waitForWindowLoad) {\r
-        _event.add(_win, 'load', _initUserOnload);\r
-      }\r
-\r
-    },1);\r
-\r
-  };\r
-\r
-  _detectFlash = function() {\r
-\r
-    // hat tip: Flash Detect library (BSD, (C) 2007) by Carl "DocYes" S. Yestrau - http://featureblend.com/javascript-flash-detection-library.html / http://featureblend.com/license.txt\r
-\r
-    if (typeof _hasFlash !== 'undefined') {\r
-      // this work has already been done.\r
-      return _hasFlash;\r
-    }\r
-\r
-    var hasPlugin = false, n = navigator, nP = n.plugins, obj, type, types, AX = _win.ActiveXObject;\r
-\r
-    if (nP && nP.length) {\r
-      type = 'application/x-shockwave-flash';\r
-      types = n.mimeTypes;\r
-      if (types && types[type] && types[type].enabledPlugin && types[type].enabledPlugin.description) {\r
-        hasPlugin = true;\r
-      }\r
-    } else if (typeof AX !== 'undefined') {\r
-      try {\r
-        obj = new AX('ShockwaveFlash.ShockwaveFlash');\r
-      } catch(e) {\r
-        // oh well\r
-      }\r
-      hasPlugin = (!!obj);\r
-    }\r
-\r
-    _hasFlash = hasPlugin;\r
-\r
-    return hasPlugin;\r
-\r
-  };\r
-\r
-  _featureCheck = function() {\r
-\r
-    var needsFlash,\r
-        item,\r
-        result = true,\r
-        formats = _s.audioFormats,\r
-        // iPhone <= 3.1 has broken HTML5 audio(), but firmware 3.2 (original iPad) + iOS4 works.\r
-        isSpecial = (_is_iDevice && !!(_ua.match(/os (1|2|3_0|3_1)/i)));\r
-\r
-    if (isSpecial) {\r
-\r
-      // has Audio(), but is broken; let it load links directly.\r
-      _s.hasHTML5 = false;\r
-\r
-      // ignore flash case, however\r
-      _s.html5Only = true;\r
-\r
-      if (_s.oMC) {\r
-        _s.oMC.style.display = 'none';\r
-      }\r
-\r
-      result = false;\r
-\r
-    } else {\r
-\r
-      if (_s.useHTML5Audio) {\r
-\r
-        if (!_s.html5 || !_s.html5.canPlayType) {\r
-          _s._wD('SoundManager: No HTML5 Audio() support detected.');\r
-          _s.hasHTML5 = false;\r
-        }\r
-\r
-        // <d>\r
-        if (_isBadSafari) {\r
-          _s._wD(_smc+'Note: Buggy HTML5 Audio in Safari on this OS X release, see https://bugs.webkit.org/show_bug.cgi?id=32159 - '+(!_hasFlash?' would use flash fallback for MP3/MP4, but none detected.':'will use flash fallback for MP3/MP4, if available'),1);\r
-        }\r
-        // </d>\r
-\r
-      }\r
-\r
-    }\r
-\r
-    if (_s.useHTML5Audio && _s.hasHTML5) {\r
-\r
-      for (item in formats) {\r
-        if (formats.hasOwnProperty(item)) {\r
-          if ((formats[item].required && !_s.html5.canPlayType(formats[item].type)) || (_s.preferFlash && (_s.flash[item] || _s.flash[formats[item].type]))) {\r
-            // flash may be required, or preferred for this format\r
-            needsFlash = true;\r
-          }\r
-        }\r
-      }\r
-\r
-    }\r
-\r
-    // sanity check...\r
-    if (_s.ignoreFlash) {\r
-      needsFlash = false;\r
-    }\r
-\r
-    _s.html5Only = (_s.hasHTML5 && _s.useHTML5Audio && !needsFlash);\r
-\r
-    return (!_s.html5Only);\r
-\r
-  };\r
-\r
-  _parseURL = function(url) {\r
-\r
-    /**\r
-     * Internal: Finds and returns the first playable URL (or failing that, the first URL.)\r
-     * @param {string or array} url A single URL string, OR, an array of URL strings or {url:'/path/to/resource', type:'audio/mp3'} objects.\r
-     */\r
-\r
-    var i, j, urlResult = 0, result;\r
-\r
-    if (url instanceof Array) {\r
-\r
-      // find the first good one\r
-      for (i=0, j=url.length; i<j; i++) {\r
-\r
-        if (url[i] instanceof Object) {\r
-          // MIME check\r
-          if (_s.canPlayMIME(url[i].type)) {\r
-            urlResult = i;\r
-            break;\r
-          }\r
-\r
-        } else if (_s.canPlayURL(url[i])) {\r
-          // URL string check\r
-          urlResult = i;\r
-          break;\r
-        }\r
-\r
-      }\r
-\r
-      // normalize to string\r
-      if (url[urlResult].url) {\r
-        url[urlResult] = url[urlResult].url;\r
-      }\r
-\r
-      result = url[urlResult];\r
-\r
-    } else {\r
-\r
-      // single URL case\r
-      result = url;\r
-\r
-    }\r
-\r
-    return result;\r
-\r
-  };\r
-\r
-\r
-  _startTimer = function(oSound) {\r
-\r
-    /**\r
-     * attach a timer to this sound, and start an interval if needed\r
-     */\r
-\r
-    if (!oSound._hasTimer) {\r
-\r
-      oSound._hasTimer = true;\r
-\r
-      if (!_mobileHTML5 && _s.html5PollingInterval) {\r
-\r
-        if (_h5IntervalTimer === null && _h5TimerCount === 0) {\r
-\r
-          _h5IntervalTimer = _win.setInterval(_timerExecute, _s.html5PollingInterval);\r
-   \r
-        }\r
-\r
-        _h5TimerCount++;\r
-\r
-      }\r
-\r
-    }\r
-\r
-  };\r
-\r
-  _stopTimer = function(oSound) {\r
-\r
-    /**\r
-     * detach a timer\r
-     */\r
-\r
-    if (oSound._hasTimer) {\r
-\r
-      oSound._hasTimer = false;\r
-\r
-      if (!_mobileHTML5 && _s.html5PollingInterval) {\r
-\r
-        // interval will stop itself at next execution.\r
-\r
-        _h5TimerCount--;\r
-\r
-      }\r
-\r
-    }\r
-\r
-  };\r
-\r
-  _timerExecute = function() {\r
-\r
-    /**\r
-     * manual polling for HTML5 progress events, ie., whileplaying() (can achieve greater precision than conservative default HTML5 interval)\r
-     */\r
-\r
-    var i;\r
-\r
-    if (_h5IntervalTimer !== null && !_h5TimerCount) {\r
-\r
-      // no active timers, stop polling interval.\r
-\r
-      _win.clearInterval(_h5IntervalTimer);\r
-\r
-      _h5IntervalTimer = null;\r
-\r
-      return false;\r
-\r
-    }\r
-\r
-    // check all HTML5 sounds with timers\r
-\r
-    for (i = _s.soundIDs.length-1; i >= 0; i--) {\r
-\r
-      if (_s.sounds[_s.soundIDs[i]].isHTML5 && _s.sounds[_s.soundIDs[i]]._hasTimer) {\r
-\r
-        _s.sounds[_s.soundIDs[i]]._onTimer();\r
-\r
-      }\r
-\r
-    }\r
-\r
-  };\r
-\r
-  _catchError = function(options) {\r
-\r
-    options = (typeof options !== 'undefined' ? options : {});\r
-\r
-    if (typeof _s.onerror === 'function') {\r
-      _s.onerror.apply(_win, [{type:(typeof options.type !== 'undefined' ? options.type : null)}]);\r
-    }\r
-\r
-    if (typeof options.fatal !== 'undefined' && options.fatal) {\r
-      _s.disable();\r
-    }\r
-\r
-  };\r
-\r
-  _badSafariFix = function() {\r
-\r
-    // special case: "bad" Safari (OS X 10.3 - 10.7) must fall back to flash for MP3/MP4\r
-    if (!_isBadSafari || !_detectFlash()) {\r
-      // doesn't apply\r
-      return false;\r
-    }\r
-\r
-    var aF = _s.audioFormats, i, item;\r
-\r
-    for (item in aF) {\r
-      if (aF.hasOwnProperty(item)) {\r
-        if (item === 'mp3' || item === 'mp4') {\r
-          _s._wD(_sm+': Using flash fallback for '+item+' format');\r
-          _s.html5[item] = false;\r
-          // assign result to related formats, too\r
-          if (aF[item] && aF[item].related) {\r
-            for (i = aF[item].related.length-1; i >= 0; i--) {\r
-              _s.html5[aF[item].related[i]] = false;\r
-            }\r
-          }\r
-        }\r
-      }\r
-    }\r
-\r
-  };\r
-\r
-  /**\r
-   * Pseudo-private flash/ExternalInterface methods\r
-   * ----------------------------------------------\r
-   */\r
-\r
-  this._setSandboxType = function(sandboxType) {\r
-\r
-    // <d>\r
-    var sb = _s.sandbox;\r
-\r
-    sb.type = sandboxType;\r
-    sb.description = sb.types[(typeof sb.types[sandboxType] !== 'undefined'?sandboxType:'unknown')];\r
-\r
-    _s._wD('Flash security sandbox type: ' + sb.type);\r
-\r
-    if (sb.type === 'localWithFile') {\r
-\r
-      sb.noRemote = true;\r
-      sb.noLocal = false;\r
-      _wDS('secNote', 2);\r
-\r
-    } else if (sb.type === 'localWithNetwork') {\r
-\r
-      sb.noRemote = false;\r
-      sb.noLocal = true;\r
-\r
-    } else if (sb.type === 'localTrusted') {\r
-\r
-      sb.noRemote = false;\r
-      sb.noLocal = false;\r
-\r
-    }\r
-    // </d>\r
-\r
-  };\r
-\r
-  this._externalInterfaceOK = function(flashDate, swfVersion) {\r
-\r
-    // flash callback confirming flash loaded, EI working etc.\r
-    // flashDate = approx. timing/delay info for JS/flash bridge\r
-    // swfVersion: SWF build string\r
-\r
-    if (_s.swfLoaded) {\r
-      return false;\r
-    }\r
-\r
-    var e, eiTime = new Date().getTime();\r
-\r
-    _s._wD(_smc+'externalInterfaceOK()' + (flashDate?' (~' + (eiTime - flashDate) + ' ms)':''));\r
-    _debugTS('swf', true);\r
-    _debugTS('flashtojs', true);\r
-    _s.swfLoaded = true;\r
-    _tryInitOnFocus = false;\r
-\r
-    if (_isBadSafari) {\r
-      _badSafariFix();\r
-    }\r
-\r
-    // complain if JS + SWF build/version strings don't match, excluding +DEV builds\r
-    // <d>\r
-    if (!swfVersion || swfVersion.replace(/\+dev/i,'') !== _s.versionNumber.replace(/\+dev/i, '')) {\r
-\r
-      e = _sm + ': Fatal: JavaScript file build "' + _s.versionNumber + '" does not match Flash SWF build "' + swfVersion + '" at ' + _s.url + '. Ensure both are up-to-date.';\r
-\r
-      // escape flash -> JS stack so this error fires in window.\r
-      setTimeout(function versionMismatch() {\r
-        throw new Error(e);\r
-      }, 0);\r
-\r
-      // exit, init will fail with timeout\r
-      return false;\r
-\r
-    }\r
-    // </d>\r
-\r
-    // slight delay before init\r
-    setTimeout(_init, _isIE ? 100 : 1);\r
-\r
-  };\r
-\r
-  /**\r
-   * Private initialization helpers\r
-   * ------------------------------\r
-   */\r
-\r
-  _createMovie = function(smID, smURL) {\r
-\r
-    if (_didAppend && _appendSuccess) {\r
-      // ignore if already succeeded\r
-      return false;\r
-    }\r
-\r
-    function _initMsg() {\r
-      _s._wD('-- SoundManager 2 ' + _s.version + (!_s.html5Only && _s.useHTML5Audio?(_s.hasHTML5?' + HTML5 audio':', no HTML5 audio support'):'') + (!_s.html5Only ? (_s.useHighPerformance?', high performance mode, ':', ') + (( _s.flashPollingInterval ? 'custom (' + _s.flashPollingInterval + 'ms)' : 'normal') + ' polling') + (_s.wmode?', wmode: ' + _s.wmode:'') + (_s.debugFlash?', flash debug mode':'') + (_s.useFlashBlock?', flashBlock mode':'') : '') + ' --', 1);\r
-    }\r
-\r
-    if (_s.html5Only) {\r
-\r
-      // 100% HTML5 mode\r
-      _setVersionInfo();\r
-\r
-      _initMsg();\r
-      _s.oMC = _id(_s.movieID);\r
-      _init();\r
-\r
-      // prevent multiple init attempts\r
-      _didAppend = true;\r
-\r
-      _appendSuccess = true;\r
-\r
-      return false;\r
-\r
-    }\r
-\r
-    // flash path\r
-    var remoteURL = (smURL || _s.url),\r
-    localURL = (_s.altURL || remoteURL),\r
-    swfTitle = 'JS/Flash audio component (SoundManager 2)',\r
-    oTarget = _getDocument(),\r
-    extraClass = _getSWFCSS(),\r
-    isRTL = null,\r
-    html = _doc.getElementsByTagName('html')[0],\r
-    oEmbed, oMovie, tmp, movieHTML, oEl, s, x, sClass;\r
-\r
-    isRTL = (html && html.dir && html.dir.match(/rtl/i));\r
-    smID = (typeof smID === 'undefined'?_s.id:smID);\r
-\r
-    function param(name, value) {\r
-      return '<param name="'+name+'" value="'+value+'" />';\r
-    }\r
-\r
-    // safety check for legacy (change to Flash 9 URL)\r
-    _setVersionInfo();\r
-    _s.url = _normalizeMovieURL(_overHTTP?remoteURL:localURL);\r
-    smURL = _s.url;\r
-\r
-    _s.wmode = (!_s.wmode && _s.useHighPerformance ? 'transparent' : _s.wmode);\r
-\r
-    if (_s.wmode !== null && (_ua.match(/msie 8/i) || (!_isIE && !_s.useHighPerformance)) && navigator.platform.match(/win32|win64/i)) {\r
-      /**\r
-       * extra-special case: movie doesn't load until scrolled into view when using wmode = anything but 'window' here\r
-       * does not apply when using high performance (position:fixed means on-screen), OR infinite flash load timeout\r
-       * wmode breaks IE 8 on Vista + Win7 too in some cases, as of January 2011 (?)\r
-       */\r
-      _wDS('spcWmode');\r
-      _s.wmode = null;\r
-    }\r
-\r
-    oEmbed = {\r
-      'name': smID,\r
-      'id': smID,\r
-      'src': smURL,\r
-      'quality': 'high',\r
-      'allowScriptAccess': _s.allowScriptAccess,\r
-      'bgcolor': _s.bgColor,\r
-      'pluginspage': _http+'www.macromedia.com/go/getflashplayer',\r
-      'title': swfTitle,\r
-      'type': 'application/x-shockwave-flash',\r
-      'wmode': _s.wmode,\r
-      // http://help.adobe.com/en_US/as3/mobile/WS4bebcd66a74275c36cfb8137124318eebc6-7ffd.html\r
-      'hasPriority': 'true'\r
-    };\r
-\r
-    if (_s.debugFlash) {\r
-      oEmbed.FlashVars = 'debug=1';\r
-    }\r
-\r
-    if (!_s.wmode) {\r
-      // don't write empty attribute\r
-      delete oEmbed.wmode;\r
-    }\r
-\r
-    if (_isIE) {\r
-\r
-      // IE is "special".\r
-      oMovie = _doc.createElement('div');\r
-      movieHTML = [\r
-        '<object id="' + smID + '" data="' + smURL + '" type="' + oEmbed.type + '" title="' + oEmbed.title +'" classid="clsid:D27CDB6E-AE6D-11cf-96B8-444553540000" codebase="' + _http+'download.macromedia.com/pub/shockwave/cabs/flash/swflash.cab#version=6,0,40,0">',\r
-        param('movie', smURL),\r
-        param('AllowScriptAccess', _s.allowScriptAccess),\r
-        param('quality', oEmbed.quality),\r
-        (_s.wmode? param('wmode', _s.wmode): ''),\r
-        param('bgcolor', _s.bgColor),\r
-        param('hasPriority', 'true'),\r
-        (_s.debugFlash ? param('FlashVars', oEmbed.FlashVars) : ''),\r
-        '</object>'\r
-      ].join('');\r
-\r
-    } else {\r
-\r
-      oMovie = _doc.createElement('embed');\r
-      for (tmp in oEmbed) {\r
-        if (oEmbed.hasOwnProperty(tmp)) {\r
-          oMovie.setAttribute(tmp, oEmbed[tmp]);\r
-        }\r
-      }\r
-\r
-    }\r
-\r
-    _initDebug();\r
-    extraClass = _getSWFCSS();\r
-    oTarget = _getDocument();\r
-\r
-    if (oTarget) {\r
-\r
-      _s.oMC = (_id(_s.movieID) || _doc.createElement('div'));\r
-\r
-      if (!_s.oMC.id) {\r
-\r
-        _s.oMC.id = _s.movieID;\r
-        _s.oMC.className = _swfCSS.swfDefault + ' ' + extraClass;\r
-        s = null;\r
-        oEl = null;\r
-\r
-        if (!_s.useFlashBlock) {\r
-          if (_s.useHighPerformance) {\r
-            // on-screen at all times\r
-            s = {\r
-              'position': 'fixed',\r
-              'width': '8px',\r
-              'height': '8px',\r
-              // >= 6px for flash to run fast, >= 8px to start up under Firefox/win32 in some cases. odd? yes.\r
-              'bottom': '0px',\r
-              'left': '0px',\r
-              'overflow': 'hidden'\r
-            };\r
-          } else {\r
-            // hide off-screen, lower priority\r
-            s = {\r
-              'position': 'absolute',\r
-              'width': '6px',\r
-              'height': '6px',\r
-              'top': '-9999px',\r
-              'left': '-9999px'\r
-            };\r
-            if (isRTL) {\r
-              s.left = Math.abs(parseInt(s.left,10))+'px';\r
-            }\r
-          }\r
-        }\r
-\r
-        if (_isWebkit) {\r
-          // soundcloud-reported render/crash fix, safari 5\r
-          _s.oMC.style.zIndex = 10000;\r
-        }\r
-\r
-        if (!_s.debugFlash) {\r
-          for (x in s) {\r
-            if (s.hasOwnProperty(x)) {\r
-              _s.oMC.style[x] = s[x];\r
-            }\r
-          }\r
-        }\r
-\r
-        try {\r
-          if (!_isIE) {\r
-            _s.oMC.appendChild(oMovie);\r
-          }\r
-          oTarget.appendChild(_s.oMC);\r
-          if (_isIE) {\r
-            oEl = _s.oMC.appendChild(_doc.createElement('div'));\r
-            oEl.className = _swfCSS.swfBox;\r
-            oEl.innerHTML = movieHTML;\r
-          }\r
-          _appendSuccess = true;\r
-        } catch(e) {\r
-          throw new Error(_str('domError')+' \n'+e.toString());\r
-        }\r
-\r
-      } else {\r
-\r
-        // SM2 container is already in the document (eg. flashblock use case)\r
-        sClass = _s.oMC.className;\r
-        _s.oMC.className = (sClass?sClass+' ':_swfCSS.swfDefault) + (extraClass?' '+extraClass:'');\r
-        _s.oMC.appendChild(oMovie);\r
-        if (_isIE) {\r
-          oEl = _s.oMC.appendChild(_doc.createElement('div'));\r
-          oEl.className = _swfCSS.swfBox;\r
-          oEl.innerHTML = movieHTML;\r
-        }\r
-        _appendSuccess = true;\r
-\r
-      }\r
-\r
-    }\r
-\r
-    _didAppend = true;\r
-    _initMsg();\r
-    _s._wD(_smc+'createMovie(): Trying to load ' + smURL + (!_overHTTP && _s.altURL?' (alternate URL)':''), 1);\r
-\r
-    return true;\r
-\r
-  };\r
-\r
-  _initMovie = function() {\r
-\r
-    if (_s.html5Only) {\r
-      _createMovie();\r
-      return false;\r
-    }\r
-\r
-    // attempt to get, or create, movie (may already exist)\r
-    if (_flash) {\r
-      return false;\r
-    }\r
-\r
-    if (!_s.url) {\r
-\r
-      /**\r
-       * Something isn't right - we've reached init, but the soundManager url property has not been set.\r
-       * User has not called setup({url: ...}), or has not set soundManager.url (legacy use case) directly before init time.\r
-       * Notify and exit. If user calls setup() with a url: property, init will be restarted as in the deferred loading case.\r
-       */\r
-\r
-       _wDS('noURL');\r
-       return false;\r
-\r
-    }\r
-\r
-    // inline markup case\r
-    _flash = _s.getMovie(_s.id);\r
-\r
-    if (!_flash) {\r
-      if (!_oRemoved) {\r
-        // try to create\r
-        _createMovie(_s.id, _s.url);\r
-      } else {\r
-        // try to re-append removed movie after reboot()\r
-        if (!_isIE) {\r
-          _s.oMC.appendChild(_oRemoved);\r
-        } else {\r
-          _s.oMC.innerHTML = _oRemovedHTML;\r
-        }\r
-        _oRemoved = null;\r
-        _didAppend = true;\r
-      }\r
-      _flash = _s.getMovie(_s.id);\r
-    }\r
-\r
-    // <d>\r
-    if (_flash) {\r
-      _wDS('waitEI');\r
-    }\r
-    // </d>\r
-\r
-    if (typeof _s.oninitmovie === 'function') {\r
-      setTimeout(_s.oninitmovie, 1);\r
-    }\r
-\r
-    return true;\r
-\r
-  };\r
-\r
-  _delayWaitForEI = function() {\r
-\r
-    setTimeout(_waitForEI, 1000);\r
-\r
-  };\r
-\r
-  _waitForEI = function() {\r
-\r
-    var p,\r
-        loadIncomplete = false;\r
-\r
-    if (!_s.url) {\r
-      // No SWF url to load (noURL case) - exit for now. Will be retried when url is set.\r
-      return false;\r
-    }\r
-\r
-    if (_waitingForEI) {\r
-      return false;\r
-    }\r
-\r
-    _waitingForEI = true;\r
-    _event.remove(_win, 'load', _delayWaitForEI);\r
-\r
-    if (_tryInitOnFocus && !_isFocused) {\r
-      // Safari won't load flash in background tabs, only when focused.\r
-      _wDS('waitFocus');\r
-      return false;\r
-    }\r
-\r
-    if (!_didInit) {\r
-      p = _s.getMoviePercent();\r
-      _s._wD(_str('waitImpatient', (p > 0 ? ' (SWF ' + p + '% loaded)' : '')));\r
-      if (p > 0 && p < 100) {\r
-        loadIncomplete = true;\r
-      }\r
-    }\r
-\r
-    setTimeout(function() {\r
-\r
-      p = _s.getMoviePercent();\r
-\r
-      if (loadIncomplete) {\r
-        // special case: if movie *partially* loaded, retry until it's 100% before assuming failure.\r
-        _waitingForEI = false;\r
-        _s._wD(_str('waitSWF'));\r
-        _win.setTimeout(_delayWaitForEI, 1);\r
-        return false;\r
-      }\r
-\r
-      // <d>\r
-      if (!_didInit) {\r
-        _s._wD(_sm + ': No Flash response within expected time.\nLikely causes: ' + (p === 0?'Loading ' + _s.movieURL + ' may have failed (and/or Flash ' + _fV + '+ not present?), ':'') + 'Flash blocked or JS-Flash security error.' + (_s.debugFlash?' ' + _str('checkSWF'):''), 2);\r
-        if (!_overHTTP && p) {\r
-          _wDS('localFail', 2);\r
-          if (!_s.debugFlash) {\r
-            _wDS('tryDebug', 2);\r
-          }\r
-        }\r
-        if (p === 0) {\r
-          // if 0 (not null), probably a 404.\r
-          _s._wD(_str('swf404', _s.url));\r
-        }\r
-        _debugTS('flashtojs', false, ': Timed out' + _overHTTP?' (Check flash security or flash blockers)':' (No plugin/missing SWF?)');\r
-      }\r
-      // </d>\r
-\r
-      // give up / time-out, depending\r
-\r
-      if (!_didInit && _okToDisable) {\r
-        if (p === null) {\r
-          // SWF failed. Maybe blocked.\r
-          if (_s.useFlashBlock || _s.flashLoadTimeout === 0) {\r
-            if (_s.useFlashBlock) {\r
-              _flashBlockHandler();\r
-            }\r
-            _wDS('waitForever');\r
-          } else {\r
-            // old SM2 behaviour, simply fail\r
-            _failSafely(true);\r
-          }\r
-        } else {\r
-          // flash loaded? Shouldn't be a blocking issue, then.\r
-          if (_s.flashLoadTimeout === 0) {\r
-             _wDS('waitForever');\r
-          } else {\r
-            _failSafely(true);\r
-          }\r
-        }\r
-      }\r
-\r
-    }, _s.flashLoadTimeout);\r
-\r
-  };\r
-\r
-  _handleFocus = function() {\r
-\r
-    function cleanup() {\r
-      _event.remove(_win, 'focus', _handleFocus);\r
-    }\r
-\r
-    if (_isFocused || !_tryInitOnFocus) {\r
-      // already focused, or not special Safari background tab case\r
-      cleanup();\r
-      return true;\r
-    }\r
-\r
-    _okToDisable = true;\r
-    _isFocused = true;\r
-    _wDS('gotFocus');\r
-\r
-    // allow init to restart\r
-    _waitingForEI = false;\r
-\r
-    // kick off ExternalInterface timeout, now that the SWF has started\r
-    _delayWaitForEI();\r
-\r
-    cleanup();\r
-    return true;\r
-\r
-  };\r
-\r
-  _showSupport = function() {\r
-\r
-    // <d>\r
-\r
-    var item, tests = [];\r
-\r
-    if (_s.useHTML5Audio && _s.hasHTML5) {\r
-      for (item in _s.audioFormats) {\r
-        if (_s.audioFormats.hasOwnProperty(item)) {\r
-          tests.push(item + ': ' + _s.html5[item] + (!_s.html5[item] && _hasFlash && _s.flash[item] ? ' (using flash)' : (_s.preferFlash && _s.flash[item] && _hasFlash ? ' (preferring flash)': (!_s.html5[item] ? ' (' + (_s.audioFormats[item].required ? 'required, ':'') + 'and no flash support)' : ''))));\r
-        }\r
-      }\r
-      _s._wD('-- SoundManager 2: HTML5 support tests ('+_s.html5Test+'): '+tests.join(', ')+' --',1);\r
-    }\r
-\r
-    // </d>\r
-\r
-  };\r
-\r
-  _initComplete = function(bNoDisable) {\r
-\r
-    if (_didInit) {\r
-      return false;\r
-    }\r
-\r
-    if (_s.html5Only) {\r
-      // all good.\r
-      _s._wD('-- SoundManager 2: loaded --');\r
-      _didInit = true;\r
-      _initUserOnload();\r
-      _debugTS('onload', true);\r
-      return true;\r
-    }\r
-\r
-    var wasTimeout = (_s.useFlashBlock && _s.flashLoadTimeout && !_s.getMoviePercent()),\r
-        result = true,\r
-        error;\r
-\r
-    if (!wasTimeout) {\r
-      _didInit = true;\r
-      if (_disabled) {\r
-        error = {type: (!_hasFlash && _needsFlash ? 'NO_FLASH' : 'INIT_TIMEOUT')};\r
-      }\r
-    }\r
-\r
-    _s._wD('-- SoundManager 2 ' + (_disabled?'failed to load':'loaded') + ' (' + (_disabled?'Flash security/load error':'OK') + ') --', 1);\r
-\r
-    if (_disabled || bNoDisable) {\r
-      if (_s.useFlashBlock && _s.oMC) {\r
-        _s.oMC.className = _getSWFCSS() + ' ' + (_s.getMoviePercent() === null?_swfCSS.swfTimedout:_swfCSS.swfError);\r
-      }\r
-      _processOnEvents({type:'ontimeout', error:error, ignoreInit: true});\r
-      _debugTS('onload', false);\r
-      _catchError(error);\r
-      result = false;\r
-    } else {\r
-      _debugTS('onload', true);\r
-    }\r
-\r
-    if (!_disabled) {\r
-      if (_s.waitForWindowLoad && !_windowLoaded) {\r
-        _wDS('waitOnload');\r
-        _event.add(_win, 'load', _initUserOnload);\r
-      } else {\r
-        // <d>\r
-        if (_s.waitForWindowLoad && _windowLoaded) {\r
-          _wDS('docLoaded');\r
-        }\r
-        // </d>\r
-        _initUserOnload();\r
-      }\r
-    }\r
-\r
-    return result;\r
-\r
-  };\r
-\r
-  /**\r
-   * apply top-level setupOptions object as local properties, eg., this.setupOptions.flashVersion -> this.flashVersion (soundManager.flashVersion)\r
-   * this maintains backward compatibility, and allows properties to be defined separately for use by soundManager.setup().\r
-   */\r
-\r
-  _setProperties = function() {\r
-\r
-    var i,\r
-        o = _s.setupOptions;\r
-\r
-    for (i in o) {\r
-\r
-      if (o.hasOwnProperty(i)) {\r
-\r
-        // assign local property if not already defined\r
-\r
-        if (typeof _s[i] === 'undefined') {\r
-\r
-          _s[i] = o[i];\r
-\r
-        } else if (_s[i] !== o[i]) {\r
-\r
-          // legacy support: write manually-assigned property (eg., soundManager.url) back to setupOptions to keep things in sync\r
-          _s.setupOptions[i] = _s[i];\r
-\r
-        }\r
-\r
-      }\r
-\r
-    }\r
-\r
-  };\r
-\r
-\r
-  _init = function() {\r
-\r
-    _wDS('init');\r
-\r
-    // called after onload()\r
-\r
-    if (_didInit) {\r
-      _wDS('didInit');\r
-      return false;\r
-    }\r
-\r
-    function _cleanup() {\r
-      _event.remove(_win, 'load', _s.beginDelayedInit);\r
-    }\r
-\r
-    if (_s.html5Only) {\r
-      if (!_didInit) {\r
-        // we don't need no steenking flash!\r
-        _cleanup();\r
-        _s.enabled = true;\r
-        _initComplete();\r
-      }\r
-      return true;\r
-    }\r
-\r
-    // flash path\r
-    _initMovie();\r
-\r
-    try {\r
-\r
-      _wDS('flashJS');\r
-\r
-      // attempt to talk to Flash\r
-      _flash._externalInterfaceTest(false);\r
-\r
-      // apply user-specified polling interval, OR, if "high performance" set, faster vs. default polling\r
-      // (determines frequency of whileloading/whileplaying callbacks, effectively driving UI framerates)\r
-      _setPolling(true, (_s.flashPollingInterval || (_s.useHighPerformance ? 10 : 50)));\r
-\r
-      if (!_s.debugMode) {\r
-        // stop the SWF from making debug output calls to JS\r
-        _flash._disableDebug();\r
-      }\r
-\r
-      _s.enabled = true;\r
-      _debugTS('jstoflash', true);\r
-\r
-      if (!_s.html5Only) {\r
-        // prevent browser from showing cached page state (or rather, restoring "suspended" page state) via back button, because flash may be dead\r
-        // http://www.webkit.org/blog/516/webkit-page-cache-ii-the-unload-event/\r
-        _event.add(_win, 'unload', _doNothing);\r
-      }\r
-\r
-    } catch(e) {\r
-\r
-      _s._wD('js/flash exception: ' + e.toString());\r
-      _debugTS('jstoflash', false);\r
-      _catchError({type:'JS_TO_FLASH_EXCEPTION', fatal:true});\r
-      // don't disable, for reboot()\r
-      _failSafely(true);\r
-      _initComplete();\r
-\r
-      return false;\r
-\r
-    }\r
-\r
-    _initComplete();\r
-\r
-    // disconnect events\r
-    _cleanup();\r
-\r
-    return true;\r
-\r
-  };\r
-\r
-  _domContentLoaded = function() {\r
-\r
-    if (_didDCLoaded) {\r
-      return false;\r
-    }\r
-\r
-    _didDCLoaded = true;\r
-\r
-    // assign top-level soundManager properties eg. soundManager.url\r
-    _setProperties();\r
-\r
-    _initDebug();\r
-\r
-    /**\r
-     * Temporary feature: allow force of HTML5 via URL params: sm2-usehtml5audio=0 or 1\r
-     * Ditto for sm2-preferFlash, too.\r
-     */\r
-    // <d>\r
-    (function(){\r
-\r
-      var a = 'sm2-usehtml5audio=',\r
-          a2 = 'sm2-preferflash=',\r
-          b = null, \r
-          b2 = null,\r
-          hasCon = (typeof console !== 'undefined' && typeof console.log === 'function'),\r
-          l = _wl.toLowerCase();\r
-\r
-      if (l.indexOf(a) !== -1) {\r
-        b = (l.charAt(l.indexOf(a)+a.length) === '1');\r
-        if (hasCon) {\r
-          console.log((b?'Enabling ':'Disabling ')+'useHTML5Audio via URL parameter');\r
-        }\r
-        _s.setup({\r
-          'useHTML5Audio': b\r
-        });\r
-      }\r
-\r
-      if (l.indexOf(a2) !== -1) {\r
-        b2 = (l.charAt(l.indexOf(a2)+a2.length) === '1');\r
-        if (hasCon) {\r
-          console.log((b2?'Enabling ':'Disabling ')+'preferFlash via URL parameter');\r
-        }\r
-        _s.setup({\r
-          'preferFlash': b2\r
-        });\r
-      }\r
-\r
-    }());\r
-    // </d>\r
-\r
-    if (!_hasFlash && _s.hasHTML5) {\r
-      _s._wD('SoundManager: No Flash detected'+(!_s.useHTML5Audio?', enabling HTML5.':'. Trying HTML5-only mode.'));\r
-      _s.setup({\r
-        'useHTML5Audio': true,\r
-        // make sure we aren't preferring flash, either\r
-        // TODO: preferFlash should not matter if flash is not installed. Currently, stuff breaks without the below tweak.\r
-        'preferFlash': false\r
-      });\r
-    }\r
-\r
-    _testHTML5();\r
-    _s.html5.usingFlash = _featureCheck();\r
-    _needsFlash = _s.html5.usingFlash;\r
-    _showSupport();\r
-\r
-    if (!_hasFlash && _needsFlash) {\r
-      _wDS('needFlash');\r
-      // TODO: Fatal here vs. timeout approach, etc.\r
-      // hack: fail sooner.\r
-      _s.setup({\r
-        'flashLoadTimeout': 1\r
-      });\r
-    }\r
-\r
-    if (_doc.removeEventListener) {\r
-      _doc.removeEventListener('DOMContentLoaded', _domContentLoaded, false);\r
-    }\r
-\r
-    _initMovie();\r
-    return true;\r
-\r
-  };\r
-\r
-  _domContentLoadedIE = function() {\r
-\r
-    if (_doc.readyState === 'complete') {\r
-      _domContentLoaded();\r
-      _doc.detachEvent('onreadystatechange', _domContentLoadedIE);\r
-    }\r
-\r
-    return true;\r
-\r
-  };\r
-\r
-  _winOnLoad = function() {\r
-    // catch edge case of _initComplete() firing after window.load()\r
-    _windowLoaded = true;\r
-    _event.remove(_win, 'load', _winOnLoad);\r
-  };\r
-\r
-  // sniff up-front\r
-  _detectFlash();\r
-\r
-  // focus and window load, init (primarily flash-driven)\r
-  _event.add(_win, 'focus', _handleFocus);\r
-  _event.add(_win, 'load', _delayWaitForEI);\r
-  _event.add(_win, 'load', _winOnLoad);\r
-\r
-  if (_doc.addEventListener) {\r
-\r
-    _doc.addEventListener('DOMContentLoaded', _domContentLoaded, false);\r
-\r
-  } else if (_doc.attachEvent) {\r
-\r
-    _doc.attachEvent('onreadystatechange', _domContentLoadedIE);\r
-\r
-  } else {\r
-\r
-    // no add/attachevent support - safe to assume no JS -> Flash either\r
-    _debugTS('onload', false);\r
-    _catchError({type:'NO_DOM2_EVENTS', fatal:true});\r
-\r
-  }\r
-\r
-} // SoundManager()\r
-\r
-// SM2_DEFER details: http://www.schillmania.com/projects/soundmanager2/doc/getstarted/#lazy-loading\r
-\r
-if (typeof SM2_DEFER === 'undefined' || !SM2_DEFER) {\r
-  soundManager = new SoundManager();\r
-}\r
-\r
-/**\r
- * SoundManager public interfaces\r
- * ------------------------------\r
- */\r
-\r
-window.SoundManager = SoundManager; // constructor\r
-window.soundManager = soundManager; // public API, flash callbacks etc.\r
-\r
-}(window));
\ No newline at end of file
diff --git a/timeside/static/timeside/js/markermap.js b/timeside/static/timeside/js/markermap.js
deleted file mode 100644 (file)
index ad3ae8c..0000000
+++ /dev/null
@@ -1,252 +0,0 @@
-/*
- * Copyright (C) 2007-2011 Parisson
- * Copyright (c) 2011 Riccardo Zaccarelli <riccardo.zaccarelli@gmail.com>
- *
- * This file is part of TimeSide.
- *
- * TimeSide is free software: you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation, either version 2 of the License, or
- * (at your option) any later version.
- *
- * TimeSide is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
- * GNU General Public License for more details.
- *
- * You should have received a copy of the GNU General Public License
- * along with TimeSide.  If not, see <http://www.gnu.org/licenses/>.
- *
- * Author: Riccardo Zaccarelli <riccardo.zaccarelli@gmail.com>
- */
-
-/**
- * class fior managing markers in the player. This class extends TimesideArray (see timeside.js), and communicates with the other 
- * two TimesideArrays of the player which receive edit events (click, keys events etcetera): the ruler (ruler.js) and the markermapdiv (divmarker.js)
- * All bindings between these three classes are set in in the player (See player.js , in particular loadMarkers method)
- */
-Timeside.classes.MarkerMap = Timeside.classes.TimesideArray.extend({
-
-    init: function() { 
-        this._super();
-    },
-
-    pFloat: parseFloat, //reference to function parseFloat for faster lookup
-    //overridden
-    add: function(newMarker) {
-        if(!('offset' in newMarker)){
-            return -1;
-        }
-
-        if(typeof newMarker.offset != 'number'){ //check to be sure:
-            newMarker.offset = this.pFloat(newMarker.offset);
-        }
-        if(!('id' in newMarker)){
-            newMarker.id = this.$TU.uniqid(); //Timeside.utils.uniqid();
-        }
-        if(!('isEditable' in newMarker)){
-            newMarker.isEditable = false;
-        }
-        var marker = newMarker; 
-        var idx = this.insertionIndex(marker);
-        if(idx>=0){ //it exists? there is a problem....
-            this.debug('markermap.add: adding an already existing marker!!'); //should not happen. however...
-            return -1;
-        }
-       
-        idx = -idx-1;
-        //we do not call the super add cause we want to insert at a specified index
-        this._super(marker,idx);
-        //notifies controller.onMarkerMapAdd
-
-        this.fire('add', {
-            marker: marker,
-            index: idx
-        });
-            
-        return idx;
-    },
-
-    //overridden method. Contrarily to super method,
-    //where the first argument is the index (integer), here the
-    //the first argument can also be a marker. Its index will be found and, if valid, the super method will be called
-    //RETURNS -1 IF SOMETHING HAS GONE WRONG, OTHERWISE THE
-    remove: function(markerOrMarkerIndex) {
-        var idx = -1;
-        if(typeof markerOrMarkerIndex == 'number'){
-            idx = markerOrMarkerIndex;
-        }else if('id' in markerOrMarkerIndex && 'offset' in markerOrMarkerIndex){
-            idx = this.insertionIndex(markerOrMarkerIndex);
-            //idx>=0 ONLY if marker has been found
-        }
-        if(idx<0 || idx>=this.length){
-            this.debug('markermap.remove: index out of bounds or marker not found');
-            return -1;
-        }
-        var marker = this._super(idx);
-        this.fire('remove',{
-            'index':idx,
-            'marker':marker
-        });
-        return idx;
-    },
-
-    //overridden method. Contrarily to super method,
-    //where the first argument is the 'from' index, here the 
-    //the first argument can also be a marker
-    move: function(markerOrMarkerIndex, newOffset){
-        var oldIndex = -1;
-        if(typeof markerOrMarkerIndex == 'number'){
-            oldIndex = markerOrMarkerIndex;
-        }else if('id' in markerOrMarkerIndex && 'offset' in markerOrMarkerIndex){
-            oldIndex = this.insertionIndex(markerOrMarkerIndex);
-            //oldIndex>=0 ONLY if marker has been found
-        }
-        if(oldIndex<0 || oldIndex>=this.length){
-            this.debug('markermap.move: index out of bounds or marker not found');
-            return -1;
-        }
-
-        var newIndex = this.insertionIndex(newOffset);
-        //select the case:
-        if(newIndex<0){ //newindex should ALWAYS be lower than zero, as insertionIndex(number) should not match any marker
-            //we didn't move the marker on another marker (newOffset does not correspond to any marker)
-            //just return the real insertionIndex
-            newIndex = -newIndex-1;
-        }
-        
-        //now: if the isnertionIndex is greater than the marker index (oldIndex), 
-        //we decrement newIndex cause super.move will first REMOVE the marker and then set it at newIndex
-        if(newIndex > oldIndex){
-            newIndex--;
-        }
-        newIndex = this._super(oldIndex,newIndex);
-        
-        if(newIndex <0){
-            this.debug('markermap.move: new index out of bounds');
-            return -1;
-        }
-        
-        var markers = this.toArray();
-        var marker = markers[newIndex];
-        var oldOffset = marker.offset;
-        marker.offset = newOffset;
-        this.fire('move', {
-            marker: marker,
-            fromIndex: oldIndex,
-            toIndex: newIndex,
-            oldOffset: oldOffset
-        });
-        return newIndex;
-    },
-       
-    
-    //returns the insertion index of object in this sorted array by means of a binary search algorithm.
-    // A) If object is a marker and:
-    //   a1) Is found (ie, there is a marker in this map
-    //       with same offset and same id), returns the index of the marker found, in the range [0, this.length-1]. Otherwise, if
-    //   a2) Is not found, then returns -(insertionIndex-1), where insertionIndex is the
-    //       index at which object would be inserted preserving the array order. Note that this assures that a
-    //       number lower than zero means that object is not present in the array, and viceversa
-    // B) If object is a number or a string number (eg, "12.567"), then a marker with offset = object is built and compared 
-    //    against the markers in the map. Note however that in this case that equality between marker's offset is sufficient,
-    //    as object is not provided with an id. THEREFORE, IF THE MAP CONTAINS SEVERAL MARKERS AT INDICES i, i+1, ... i+n
-    //    WITH SAME OFFSET == object, THERE IS NO WAY TO DETERMINE WHICH INDEX IN [i, i+1, ... i+n] WILL BE RETURNED.
-    //    See player.forward and player.rewind for an example of the B) case.
-    //LAST NOTE: BE SURE object is either a number (float) or object.offset is a number (float).
-    //In case it is not known, If it is a string number such as
-    //"4.562" the comparison falis (eg, "2.567" > "10.544") but obviously, no error is thrown in javascript
-    //
-    insertionIndex: function(object){
-        //default comparator function:
-        //returns 1 as the first argument is greater than the second
-        //returns -1 as the first argument is lower than the second
-        //returns 0 if the arguments are equal
-        var comparatorFunction = function(markerInMap,newMarker){
-            var a = markerInMap.offset;
-            var b = newMarker.offset;
-            if(a<b){
-                return -1;
-            }else if(a >b){
-                return 1;
-            }else{
-                var a1 = markerInMap.id;
-                var b1 = newMarker.id;
-                if(a1<b1){
-                    return -1;
-                }else if(a1>b1){
-                    return 1;
-                }
-            }
-            return 0;
-        };
-        if(!(typeof object == 'object')){
-            var offset;
-            if(typeof object == 'number'){
-                offset = object;
-            }else{ //to be sure...
-                offset = parseFloat(object);
-            }
-            object = {
-                'offset':offset
-            };
-            //key will never be found, so return either 1 or -1:
-            comparatorFunction = function(markerInMap,newMarker){
-                var a = markerInMap.offset;
-                var b = newMarker.offset;
-                return a < b ? -1 : (a>b ? 1 : 0);
-            };
-        }
-        
-        var data = this.toArray();
-        var low = 0;
-        var high = data.length-1;
-
-        while (low <= high) {
-            var mid = (low + high) >>> 1;
-            //biwise operation is not as fast as in compiled languages such as C and java (see Jslint web page)
-            //However (tested on a PC in Chrome, IE and FF), it is faster than the equivalent:
-            //var mid = parseInt((low + high)/2);
-            //even if we reference parseInt before this loop and we call the variable assigned to it
-            var midVal = data[mid];
-            var cmp = comparatorFunction(midVal,object);
-            if (cmp < 0){
-                //the midvalue is lower than the searched index element
-                low = mid + 1;
-            }else if (cmp > 0){
-                //the midvalue is greater than the searched index element
-                high = mid - 1;
-            }else{
-                return mid; // key found
-            }
-        }
-        return -(low + 1);  // key not found
-    },
-
-    //sets isEditable to value
-    setEditable: function(markerOrMarkerIndex, value) {
-        var idx = -1;
-        if(typeof markerOrMarkerIndex == 'number'){
-            idx = markerOrMarkerIndex;
-        }else if('id' in markerOrMarkerIndex && 'offset' in markerOrMarkerIndex){
-            idx = this.insertionIndex(markerOrMarkerIndex);
-            //idx>=0 ONLY if marker has been found
-        }
-        if(idx<0 || idx>=this.length){
-            this.debug('markermap.setEditable: index out of bounds or marker not found');
-            return -1;
-        }
-        var marker = this.toArray()[idx];
-        var oldVal = marker.isEditable ? true : false;
-        marker.isEditable = value;
-        this.fire('markerEditStateChanged',{
-            'index':idx,
-            'marker':marker,
-            'oldValue':oldVal,
-            'value':value
-        });
-        return idx;
-    }
-
-}
-);
\ No newline at end of file
diff --git a/timeside/static/timeside/js/player.js b/timeside/static/timeside/js/player.js
deleted file mode 100644 (file)
index d43e53c..0000000
+++ /dev/null
@@ -1,1067 +0,0 @@
-/*
- * Copyright (C) 2007-2011 Parisson
- * Copyright (c) 2011 Riccardo Zaccarelli <riccardo.zaccarelli@gmail.com>
- * Copyright (c) 2010 Olivier Guilyardi <olivier@samalyse.com>
- *
- * This file is part of TimeSide.
- *
- * TimeSide is free software: you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation, either version 2 of the License, or
- * (at your option) any later version.
- *
- * TimeSide is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
- * GNU General Public License for more details.
- *
- * You should have received a copy of the GNU General Public License
- * along with TimeSide.  If not, see <http://www.gnu.org/licenses/>.
- *
- * Authors: Riccardo Zaccarelli <riccardo.zaccarelli@gmail.com>
- *          Olivier Guilyardi <olivier@samalyse.com>
- */
-
-/**
- * The player class to instantiate a new player. Requires all necessary js (timeside, ruler, markermap etcetera...) and
- * jQuery
- */
-
-//playerDiv, sound, durationInMsec, visualizers, markerMap);
-Timeside.classes.Player = Timeside.classes.TimesideClass.extend({
-
-    //sound duration is in milliseconds because the soundmanager has that unit,
-    //player (according to timeside syntax) has durations in seconds
-    // newMarkerCallback must be either a string or a function, the necessary checks is done in Timeside.load
-    // (which calls this method)
-    //if markersArray is not an array, it defaults to []
-    init: function(configObject) {
-        this._super();
-        var $J = this.$J;
-        var me=this;
-
-        var msgs = configObject.messages;
-        if(msgs){
-            for(var k in msgs){
-                if(msgs.hasOwnProperty(k)){
-                    var ms = msgs[k];
-                    if(typeof ms === 'string'){
-                        this.msgs[k] = ms;
-                    }
-                }
-            }
-        }
-
-        var onError = configObject.onError;
-        if(typeof onError !== 'function'){
-            onError = function(msg){};
-        }
-
-        var onReady = configObject.onReady;
-        if(typeof onReady !== 'function'){
-            onReady = function(player){};
-        }
-
-        var onReadyWithImage = configObject.onReadyWithImage;
-
-        if(typeof onReadyWithImage === 'function'){
-            var onReadyWithImageNamespace = 'imgRefreshed.temp_'+new Date().getTime(); //get an unique namespace
-            this.bind(onReadyWithImageNamespace,function(data){
-                onReadyWithImage(me);
-                me.unbind(onReadyWithImageNamespace);
-            });
-        }
-
-        var container = configObject.container;
-        container = container instanceof $J ? container : $J(container);
-        container = container.length ? container.eq(0) : undefined;
-        if (!container || !container.length){
-            onError('container not defined or invalid');
-            return;
-        }
-
-        var sMan = soundManager;
-        var sound = configObject.sound;
-        var createSound = false;
-        if(this.$TU.flashFailed){
-            this.soundErrorMsg = 'soundManager error. If your browser does not support HTML5, Flash player (version '+sMan.flashVersion+'+) must be installed.\nIf flash is installed, try to:\n - Reload the page\n - Empty the cache (see browser preferences/options/tools) and reload the page\n - Restart the browser';
-        }else{
-            if(typeof sound !== 'string' && typeof sound !== 'object'){
-                this.soundErrorMsg ='bad sound parameter: specify a a valid soundManager sound-object, an object with at least two properties, url and id, or URL as string';
-            }else if(typeof sound === 'string'){
-                createSound = true;
-                var soundURL = sound;
-                sound = {
-                    id: 'ts-sound',
-                    autoLoad: false,
-                    url: soundURL,
-                    multiShot: false
-                };
-            //do a raw check to see if it is a soundmanager object
-            }else if(!sound.hasWonProperty('sID') || !sound.hasWonProperty('_iO') || !sound.hasWonProperty('url')){
-                if(!sound.hasWonProperty('url') || !sound.hasWonProperty('id')){ //it is not a soundManager object, has at least an url???
-                    this.soundErrorMsg = 'bad sound parameter: object requires properties url and id at minimum';
-                }else{
-                    createSound = true;
-                }
-            }
-            if(createSound){
-                var soundOptions = sound;
-                if(sMan.canPlayURL(soundOptions.url)){ //this actually checks only if the url is well formed, not if the file is there
-                    //check if we specified a valid sound duration, otherwise the sound must be loaded
-
-                    sound = sMan.createSound(soundOptions);
-                }else{
-                    this.soundErrorMsg = 'bad sound parameter (soundManager.canPlayURL returned false)';
-                }
-            }
-        }
-        if(this.soundErrorMsg){
-            this.getSound = function(){
-                return undefined;
-            };
-        }else{
-            //            sound.play = function(){
-            //                alert(this.readyState);
-            //            };
-            this.getSound = function(){
-                return sound;
-            };
-        }
-        var soundDurationInMsec = configObject.soundDuration;
-        if(typeof soundDurationInMsec !== 'number' || soundDurationInMsec<=0){
-            onError('invalid soundDurationInMsec: NaN or not positive');
-            return;
-        }
-
-
-        var soundImgFcn = configObject.soundImage;
-
-        if(!(typeof soundImgFcn === 'string' || typeof soundImgFcn === 'function')){
-            onError('invalid sound soundImgFcn. Provide a callback(width,height) or a string denoting a valid URL');
-            return;
-        }else{
-            if(typeof soundImgFcn === 'string'){
-                var url = soundImgFcn;
-                this.imageCallback =  new function(w,h){
-                    return url;
-                };
-            }else{ //surely a function
-                this.imageCallback = soundImgFcn;
-            }
-        }
-
-        var soundImgSize = configObject.imageSize;
-        var markersArray = configObject.markersArray;
-        var newMarker = configObject.newMarker;
-
-
-
-        this.playState = 0; //0: not playing, 1: loading, 2:buffering, 3 playing (sound heard)
-        //container is the div #player
-
-        this.getContainer = function(){
-            return container;
-        };
-
-
-
-        var sd = this.toSec(soundDurationInMsec);
-        this.getSoundDuration = function(){
-            return sd;
-        };
-
-        this.soundPosition =  sound.position ? this.toSec(sound.position) : 0;
-
-
-
-        //
-
-        //initializing markermap and markerui
-        var map = new Timeside.classes.MarkerMap();
-        this.getMarkerMap = function(){
-            return map;
-        };
-
-        var canAddMarkers = false;
-        if(newMarker === true || (typeof newMarker === 'function')){
-            canAddMarkers = true;
-            if(typeof newMarker === 'function'){
-                this.newMarker = newMarker;
-            }
-        }
-
-        //build the innerHTML as array, then join it. This is usually faster than string concatenation in some browsers.
-        //Note that the player image (see below) is not created now, however, if it was, it should be given a src
-        //as NOT specifying any src for image tags can be harmful,
-        //see http://www.nczonline.net/blog/2009/11/30/empty-image-src-can-destroy-your-site/ and
-        //http://geekswithblogs.net/bcaraway/archive/2007/08/24/114945.aspx for details
-        var html = [
-        "<div class='ts-ruler'></div>",
-        "<div class='ts-wave'>",
-        "<div class='ts-image-canvas'></div>",
-        "<div class='ts-image-container'>",
-        //lazily created:  "<img class='ts-image' src='xyz.png' alt='' />", //not providing a src attribute is harmful. Dummy src attribute
-        "</div>",
-        "</div>",
-        "<div class='ts-control'>",
-        "<a class='ts-play ts-button'></a>",
-        "<a class='ts-pause ts-button'></a>",
-        "<a class='ts-rewind ts-button'></a>",
-        "<a class='ts-forward ts-button'></a>",
-        "<a class='ts-set-marker ts-button'></a>",
-        "<a class='ts-volume-speaker ts-button'></a>",
-        "<div class='ts-volume-wrapper-div'>",
-        "<a class='ts-volume-bar-container'>",
-        "<span class='ts-volume-bar'></span>",
-        "</a>",
-        "</div>",
-        "<div class='ts-wait'></div>",
-        "</div>"];
-
-        container.html(html.join(''));
-
-        var control = container.find('.ts-control');
-
-        //bind events to buttons:
-        var rewind = control.find('.ts-rewind');
-        rewind.attr('href', '#').click(function(e){
-            me.rewind.apply(me);
-            return false;
-        });
-
-        var forward = control.find('.ts-forward');
-        forward.attr('href', '#').click(function(e){
-            me.forward.apply(me);
-            return false;
-        });
-
-        var pause = control.find('.ts-pause');
-        pause.attr('href', '#').bind('click', function(){
-            me.pause.apply(me);
-            return false;
-        });
-
-        var play = control.find('.ts-play');
-        play.attr('href', '#').bind('click', function(){
-            me.play.apply(me);
-            return false;
-        });
-
-        var setMarkerButton = control.find('.ts-set-marker');
-
-        if(canAddMarkers){
-            setMarkerButton.show().attr('href','#').unbind('click').bind('click', function(){
-                me.addMarker(me.soundPosition);
-                return false;
-            });
-        }else{
-            setMarkerButton.hide().unbind('click');
-        }
-
-
-        //volume:
-        var volumeSpeaker = control.find('.ts-volume-speaker');
-        var volumeBarContainer = control.find('.ts-volume-bar-container');
-        var volumeBar = volumeBarContainer.find('.ts-volume-bar');
-
-        var getVol = function(x){
-            var vol = 100*x/volumeBarContainer.width();
-            //allow click to easily set to zero or 100, ie set a margin to 5%:
-            var margin = 5;
-            if (vol < margin){
-                vol=0;
-            }else if(vol >100-margin){
-                vol = 100;
-            }
-            return vol;
-        };
-        function setVolume(event,volumeElement){
-            var x = event.pageX - volumeElement.offset().left; //using absolute coordinates allows us to
-            //avoid using layerX (not supported in all browsers) and clientX (which needs the window scrollLeft variable)
-            me.setSoundVolume(getVol(x));
-            return false;
-        }
-        volumeBarContainer.attr('href', '#').click(function(event){
-            return setVolume(event,volumeBar);
-        });
-        volumeSpeaker.attr('href', '#').click(function(){
-            me.setSoundVolume(me.getSoundVolume()>0 ? 0 : getVol(volumeBar.outerWidth()));
-            return false;
-        });
-        this.setSoundVolume(this.getSoundVolume());
-
-        control.find('a').attr('href', '#') ;
-
-        //SET NECESSARY CSS (THIS WILL OVERRIDE CSS SET IN STYLESHEETS):
-        //var viewer = container.find('.ts-viewer');
-        var wave = container.find('.ts-wave');
-        var ruler_ = container.find('.ts-ruler');
-        wave.add(control).add(ruler_).css({
-            'position':'relative',
-            'overflow':'hidden'
-        });
-        //assigning display and title to all anchors
-        var subcontrolsToBeSetVisible = control.find('*');
-        if(!canAddMarkers){
-            subcontrolsToBeSetVisible = subcontrolsToBeSetVisible.filter(':not(a.ts-set-marker)');
-        }
-        subcontrolsToBeSetVisible.css({
-            'display':'inline-block',
-            'overflow':'hidden'
-        });
-
-        var waitImg = control.find('.ts-wait');
-        waitImg.html('wait').css({
-            'position':'absolute'
-        });
-
-        var div = control.find('.ts-volume-wrapper-div');
-        div.css({
-            'position':'absolute',
-            'left':(volumeSpeaker.position().left+volumeSpeaker.outerWidth(true))+'px',
-            'top':0,
-            'width':'auto',
-            'height':'100%'
-        });
-        //END NECESSARY CSS
-
-        //creating the ruler
-        var waveImage =  container.find('.ts-image-canvas');
-        var ruler = new Timeside.classes.Ruler(ruler_, waveImage, this.getSoundDuration());
-        //var ruler = new Timeside.classes.Ruler(viewer, this.getSoundDuration());
-        this.getRuler = function(){
-            return ruler;
-        };
-        //bind mouse events:
-        ruler.bind('rulermarkermouseevent', function(data){
-            var idx = data.index;
-            data.marker = idx > -1 ? me.getMarker(idx) : undefined;
-            me.fire('markerMouseEvent',data);
-        });
-
-        //setting image size (if provided) and resize player. Note that _setImageSize (with underscore) is intended to be
-        //a private method (faster). setImageSize (without underscore) is the public method to use outside of player object
-        if(soundImgSize){
-            this._setImageSize(soundImgSize.width,soundImgSize.height,container, wave,true); //calls this.resize which calls ruler.resize
-        }else{
-            this._setImageSize('','',container, wave,true); //calls this.resize which calls ruler.resize
-        }
-
-        //binds click for the pointer:
-        var v = wave; //.add(ruler);
-        v.unbind('click').click(function(evt){
-            var w = v.width();
-            var x = evt.pageX - v.offset().left; //using absolute coordinates allows us to
-            //avoid checking whether or not we are clicking on a vertical marker line, on a subdiv etcetera
-            var sd = me.getSoundDuration();
-            me.setSoundPosition(sd*x/w);
-        });
-
-
-
-        //finally, load markers and bind events for markers (see method below):
-        //NOTE: loadMarkers ASYNCHRONOUSLY CALLS THE SERVER, SO METHODS WRITTEN AFTER IT MIGHT BE EXECUTED BEFORE
-        //loadMarkers has finished its job
-        //this.loadMarkers(callback);
-        if(!(markersArray) || !(markersArray.length)){
-            markersArray = [];
-        }
-        this.loadMarkers(markersArray);
-
-
-        //IE7 BUG: the divs wave and control do not shift downwards after canvas is drawn and covers part of the rulrer.
-        //Weird enough (with IE it isn't actually), we have just to set the property we already set in the css:
-        //ie, top: auto. This is however useful even if somebody specified a top property on the divs
-        ruler_.add(wave).add(control).css('top','auto');
-        onReady(this);
-    },
-
-
-
-    //functions for converting seconds (player unit) to milliseconds (sound manager unit) and viceversa:
-    toSec: function(milliseconds){
-        return milliseconds/1000;
-    },
-    toMsec : function(seconds){ //this function has less performances than toSec, as it calls Math.round
-        return Math.round(1000*seconds); //however, it is assumed that it is NOT called in loops
-    },
-    isPlaying : function(){
-        var sound = this.getSound();
-        if(!sound){
-            return false;
-        }
-        return this.playState;
-    /*Numeric value indicating the current playing state of the sound.
-             * 0 = stopped/uninitialised
-             * 1 = playing or buffering sound (play has been called, waiting for data etc.)
-             *Note that a 1 may not always guarantee that sound is being heard, given buffering and autoPlay status.*/
-    //return sound && sound.playState==1;
-    },
-    setSoundPosition: function(newPositionInSeconds){
-        //if the player is playing and NOT yet fully loaded, simply calling:
-        //this.getSound().setPosition(this.toMsec(newPositionInSeconds));
-        //resets the position to zero. So we use this workaround:
-        //    this.getSound().stop(); //calling this.pause() hides the waiting bar, which is not the case here
-        //    this.soundPosition = newPositionInSeconds;
-        //    this.play();
-        //however, that causes fast pointer move effect is undesiderable
-        //So:
-        var wasPlaying = this.isPlaying();
-        if(wasPlaying){
-            this.getSound().stop(); //dont call this.pause cause it hides the waitbar, if visible and resets the playState
-        }
-        //update pointer position. If this call is due to a pointer move (mouse release),
-        //ruler.isPointerMovingFromMouse=true and the following code has no effect (the pointer is already at the good position)
-        var ruler = this.getRuler();
-        if(ruler){
-            ruler.movePointer(newPositionInSeconds);
-        }
-        //set sound position:
-        var oldSoundPosition = this.soundPosition;
-        this.soundPosition = newPositionInSeconds;
-
-        //resume playing if it was playing:
-        if(wasPlaying){
-            var player = this;
-
-            //delay a little bit the play resume, this might avoid fast pointer repositioning
-            //(it should not be the case, but it happens. why??)
-            setTimeout(function(){
-                player.play.apply(player);
-            },100);
-        }
-        this.fire('soundPositionSet',{
-            player:this,
-            oldSoundPosition:oldSoundPosition
-        });
-
-    },
-    showSoundErroMessage: function(){
-        alert(this.soundErrorMsg);
-    },
-    //given a marker at index I, specifies that a marker corss event is fired whenever the sound position (pointer)
-    //is in the interval ]markerCrossedOffsetMargin-I,I+markerCrossedOffsetMargin[
-    //the value is in seconds
-    //markerCrossedOffsetMargin : 0.5,
-    play : function(){
-
-        if(this.soundErrorMsg){
-            alert(this.soundErrorMsg);
-            return false;
-        }
-
-        var player = this;
-        var sound = player.getSound();
-
-        if(!player || !sound){ //just check. The cases here (especially, sound = undefined, should be
-            //together with this.soundErrorMsg != "", so we should have catch the case above
-            return false;
-        }
-
-
-        var fireOnMarkerPosition = function(seconds){}; //does nothing by default
-        var map = player.getMarkerMap();
-        var markerCrossListeners = player.listenersMap['markerCrossed'];
-        //optimizing: if no listeners associated to markerCrossListeners, avoid creating a function
-        if(map && map.length && markerCrossListeners){
-            var idx = 0;
-            if(player.soundPosition>0){
-                idx = map.insertionIndex(player.soundPosition);
-                if(idx<0){
-                    idx=-idx-1;
-                }
-            }
-            var len = map.length;
-            if(idx>-1 && idx < len){
-                var markers = map.toArray();
-                var marker = markers[idx];
-                var margin = 0.5; //1 second (0.5*2) of margin (before+after)
-                var offs = marker.offset;
-                var intervalUpperBound =  offs+margin;
-                var intervalLowerBound =  offs-margin;
-                var data = { //if you change data, change it also below
-                    index:idx,
-                    marker:marker,
-                    currentSoundPosition: player.soundPosition,
-                    nextMarkerTimeInterval: undefined
-                };
-                fireOnMarkerPosition = function(seconds){
-                    if(marker){
-                        if(seconds>intervalLowerBound && seconds < intervalUpperBound){
-                            idx++;
-                            marker = idx < len ?  markers[idx] : undefined;
-                            offs = marker ? marker.offset : undefined;
-                            data.currentSoundPosition = seconds;
-                            data.nextMarkerTimeInterval = marker ? [offs-margin, offs+margin] : undefined;
-                            player.fire('markerCrossed',data);
-
-                            if(idx<len){
-                                intervalUpperBound =  offs+margin;
-                                intervalLowerBound =  offs-margin;
-                                data.index = idx;
-                                data.marker = marker;
-                            }
-                        }
-                    }
-                };
-            }
-        }
-
-        var toSec = player.toSec;
-        var ruler = player.getRuler();
-        var sPosInMsec = player.toMsec(player.soundPosition);
-        var bufferingString = this.msgs.buffering;
-        var loadingString = this.msgs.loading;
-
-        var updateWaitBar = this.setWait;
-        //building immediately data events to be passed instead of bulding them in the loop whileplaying
-        var loadData = {
-            player:this,
-            oldPlayState:0,
-            endOfPlayback:false
-        };
-        var bufferData = {
-            player:this,
-            oldPlayState:0,
-            endOfPlayback:false
-        };
-        var playData = {
-            player:this,
-            oldPlayState:0,
-            endOfPlayback:false
-        };
-        var endData = {
-            player:this,
-            oldPlayState:0,
-            endOfPlayback:true
-        };
-        //done
-        var playState = this.playState;
-        if(!playState){
-            if(loadingString){
-                updateWaitBar.apply(this,[loadingString]); //calling setWait of an empty string hides the wait, we dont want it here
-            //ps: without apply this in updateWait is the dom window
-            }
-            loadData.oldPlayState = playState;
-            playState = this.playState = 1;
-            this.fire('playStateChanged',loadData);
-        }
-
-        var playOptions = {
-
-            position: sPosInMsec,
-            whileplaying: function(){
-
-                var sPos = this.position;
-                var buffering = this.isBuffering || typeof sPos != 'number' || sPos < sPosInMsec;
-
-                //var buffering = this.isBuffering; //this refers to the soundmanager sound obj
-                //Now, what are we doing here below? we could simply check whether is buffering or not..
-                //Unfortunately, when buffering some playState (isBuffering = false) are also fired, randomly
-                //ONCE in a while
-                //the result is a blinking 'isBuffering' 'isPlaying' state in the wait element displaying the state (not so nice),
-                //which is also costly in terms of computation. So, we wait for at least N playstate fired SUBSEQUENTLY, without
-                //NO bufferingState fired between them. N is set to minimumNumberOfSubsequentPlayCall. When this happens, we can start moving the
-                //pointer as a result of a real play state, and we avoid blinking of the wait element
-                switch(buffering){
-                    case true:
-                        switch(playState){
-                            case 2: //do nothing (wait element already displaying)
-                                break;
-                            default: //update the wait element showing it:
-                                bufferData.oldPlayState = playState;
-                                player.playState = playState = 2;
-                                player.fire('playStateChanged',bufferData);
-                                if(bufferingString){
-                                    updateWaitBar.apply(player,[bufferingString]);
-                                }
-                        }
-                        break;
-                    default:
-                        switch(playState){
-                            case 0:
-                            case 1:
-                            case 2:
-                                playData.oldPlayState = playState;
-                                //currentState = isPlayingId; //set state for future subsequent calls of this case
-                                player.playState = playState = 3;
-                                player.fire('playStateChanged',playData);
-                                //update waitbar
-                                updateWaitBar.apply(player,[player.isImgRefreshing ? player.msgs.imgRefreshing : '']);
-                            default: //move pointer
-                                var sPosInSec = toSec(sPos);
-                                player.soundPosition = sPosInSec;
-                                ruler.movePointer(sPosInSec);
-                        }
-                        fireOnMarkerPosition(sPosInSec);
-                }
-
-            },
-            onfinish: function() {
-
-                //whileplaying is NOT called onsinfish. We must update the pointer:
-                //note that for small length sounds (wg, 5 secs) the pointer shifts abruptly from the last
-                //whileplaying position to the end. We tried with a setTimeout function but the visual effect is not
-                //removed. So we leave this small 'bug'
-                endData.oldPlayState = playState;
-                player.playState = playState = 0;
-                player.fire('playStateChanged',endData);
-                ruler.movePointer(player.getSoundDuration());
-                updateWaitBar.apply(player,[player.isImgRefreshing ? player.msgs.imgRefreshing : '']);
-                player.setSoundPosition(0);
-            //player.fire('endReached');
-            }
-        };
-        //attach onload event only if the sound is NOT already loaded:
-        //                /*sound.readyState
-        //                 * Numeric value indicating a sound's current load status
-        //                 * 0 = uninitialised
-        //                 * 1 = loading
-        //                 * 2 = failed/error
-        //                 * 3 = loaded/success
-        //                 */
-        if(sound.readyState !== 3){
-            playOptions.onload = function(success){
-                if(!success){
-                    this.stop();
-                    player.playState = 0;
-                    player.setWait(player.isImgRefreshing ? player.msgs.imgRefreshing : '');
-                    player.soundErrorMsg = 'Error while loading sound: check sound url';
-                    player.showSoundErroMessage();
-                }
-            };
-        }
-        //if the pointer is already at the end of sound, soundmanager does not fire onfinish but starts buffering
-        //forever. Therefore, we must check this case here.
-        //We use a margin of time of 20 milliseconds (.2 seconds) to indicate that inside this margin the sound is at its end
-        if(this.soundPosition + 0.2 >= this.getSoundDuration()){
-            playOptions.onfinish();
-        }else{
-            sound.setVolume(sound.volume); //workaround. Just to be sure. Sometimes it fails when we re-play
-            sound.play(playOptions);
-        //            soundManager.play(sound.sId,{
-        //                onload: function(success){
-        //                    alert(success);
-        //                }
-        //            });
-        }
-
-        return false;
-    },
-
-    msgs : {
-        loading : 'loading',
-        buffering: 'buffering',
-        imgRefreshing : 'refreshing img'
-    },
-    pause: function(){
-        var sound = this.getSound();
-        //we don't check if it's playing, as the stop must really stop anyway
-        //if(sound && this.isPlaying()){
-        if(sound){
-            var v = this.isPlaying();
-            sound.stop();
-            var data = {
-                player:this,
-                oldPlayState:this.playState,
-                endOfPlayback:false
-            };
-            this.playState = 0;
-            this.fire('playStateChanged',data);
-            this.setWait(this.isImgRefreshing ? this.msgs.imgRefreshing : '');
-        }
-        return false;
-    },
-
-    getWaitElement: function(){
-        return this.getContainer().find('.ts-control').find('.ts-wait');
-    },
-
-    setWait: function(msg){
-        var wait = undefined;
-
-        wait = this.getWaitElement();
-        if(!wait || msg === undefined){
-            return;
-        }
-        if(wait.html()!=msg){
-            wait.html(msg);
-        }
-
-        var visible = wait.css('display') != 'none';
-
-        if(msg && !visible){
-            wait.show();
-            this.fire('waitShown');
-        }else if(!msg && visible){
-            wait.hide();
-            this.fire('waitHidden');
-        }
-    },
-
-    /**
-      * sets whether or not window resize resizes also this player. When true, a variable _dynamicResize =setInterval(...) is attached to
-      * this class. When false, if _dynamicResize is in this class, clearInterval(_dynamicResize) is called and then the key is deleted
-      */
-    setDynamicResize: function(value){
-        var key = '_dynamicResize';
-        if(!value && key in this){
-            clearInterval(this[key]);
-            delete this[key];
-            return;
-        }
-        var wdw = this.$J(window);
-        var w = wdw.width();
-        //var h = wdw.height();
-        var me = this;
-        this.dynamicResize = setInterval(function(){
-            var newW = wdw.width();
-            if(w!=newW){
-                w = newW;
-                //still wait a second: are we still adjusting the window? (call resize just once):
-                setTimeout(function(){
-                    if(wdw.width()==newW){
-                        me.resize.apply(me);
-                    }
-                },200);
-            }
-        },100);
-    },
-
-    resize: function() {
-        var height;
-        var container = this.getContainer();
-
-        var wave = container.find('.ts-wave');
-
-        height = wave.height();
-        //        if(!height){
-        //            height = this.minWaveHeight;
-        //            wave.css('height',height+'px');
-        //        }
-        //if (height) {
-        //set image, imagecontainer and canvas (container on imagecontainer for lines and pointer triangles) css
-        var elements = wave.find('.ts-image-container').css('zIndex','0')
-        .add(wave.find('.ts-image-canvas').css('zIndex','1')); //the two children of ts-wave. Set also the zIndex
-        //in order to visualize the canvas OVER the wav image
-        var style = {
-            width: wave.width(),
-            height: height,
-            border: 0,
-            padding:0,
-            margin:0,
-            top:0,
-            left:0
-        };
-        elements.css(style);
-        elements.css('position','absolute');
-        //}
-
-        //refreshing images:
-        this.refreshImage();
-        this.getRuler().resize();
-    },
-    getImageUrl : function(){
-        var image = this.getContainer().find('.ts-image');
-        if(image && image.length){
-            return image.attr('src');
-        }
-        return '';
-    },
-    refreshImage: function(){
-        var container = this.getContainer();
-        var imageC = container.find('.ts-image-container');
-        var image = imageC.find('.ts-image');
-
-
-        var size = this.getImageSize();
-
-        if(!size.width || !size.height){
-            return;
-        }
-        var imgSrc = this.imageCallback(size.width,size.height);
-        var imageNotYetCreated = image.length == 0;
-        if(!imageNotYetCreated && image.attr('src')==imgSrc){
-            return;
-        }
-
-        var player= this;
-
-        if(imageNotYetCreated){
-            image = this.$J('<img/>');
-        }
-
-        //image inside ts-image-container:
-        image.css({
-            'width':'100%',
-            'height':'100%'
-        }); // for IE7. Does not seem to hurt IE8, FF, Chrome
-
-        var updateWait = function(){};
-        var ir = player.msgs.imgRefreshing;
-        var we = player.getWaitElement();
-        if(ir && we){
-            updateWait = function(){
-                if(!player.playState || player.playState==3){
-                    player.setWait('');
-                }
-            }
-        }
-        image.load(function(){
-            image.unbind('load');
-            if(imageNotYetCreated){
-                imageC.append(image.addClass('ts-image'));
-            }
-            updateWait();
-            player.isImgRefreshing = false;
-            player.fire('imgRefreshed');
-        });
-        if(ir && we && (!this.playState || this.playState===3)){ //if loading (1) or buffering (2) do not update wait.
-            //If not playing (undefined or 0) playing (3) update wait
-            this.setWait(ir);
-        }
-        this.isImgRefreshing = true;
-        this.fire('imgRefreshing');
-        image.attr('src', imgSrc);
-
-    },
-    getImageSize: function(){
-        var wave = this.getContainer().find('.ts-wave');
-        return {
-            width: wave.width(),
-            height:wave.height()
-        }
-    },
-
-    setImageSize: function(width,height){
-        var container = this.getContainer();
-        var wave = container.find('.ts-wave');
-        this._setImageSize(width,height,container, wave,true);
-    },
-    //this is intended to be a private method, use setImageSize from outside the player object)
-    _setImageSize: function(width,height,jQueryContainerElement, jQueryWaveElement, resize){
-        if(width || height){
-            var re = /(?:px|ex|em|%)$/;
-            if(width){
-                width+='';
-                width = re.exec(width) ? width : width+'px';
-                jQueryContainerElement.css('width',width);
-            }
-            if(height){
-                height+='';
-                height = re.exec(height) ? height : height+'px';
-                jQueryWaveElement.css('height',height);
-            }
-        }
-        if(resize){
-            this.resize();
-        }
-    },
-
-    getSoundVolume :function(){
-        var s = this.getSound();
-        return s ? s.volume : 0;
-    },
-    //moves the pointer (and sound position) forward till the next marker or the end of sound
-    forward: function() {
-        var map = this.getMarkerMap();
-        var markers = map.toArray();
-        var len = markers.length;
-        var offset =  this.getSoundDuration();
-        var position = this.soundPosition; //parseFloat(this.getSoundPosition());
-        var idx = map.insertionIndex(position);
-        if(idx<0){
-            idx = -idx-1; //cursor is not on a a marker, get the insertion index
-        }else{
-            //cursor is on a marker. As there might be several markers with the same offset
-            //(see MarkerMap.insertionIndex), move to the outmost right
-            while(idx<len  && markers[idx].offset == position){
-                idx++;
-            }
-        }
-
-        if(idx< len){
-            offset = markers[idx].offset;
-        }
-        this.setSoundPosition(offset);
-        return false;
-    },
-    //moves the pointer (and sound position) backward till the previous marker or the start of sound
-    rewind: function() {
-        var map = this.getMarkerMap();
-        var markers = map.toArray();
-        var offset =  0;
-        var position = this.soundPosition; //parseFloat(this.getSoundPosition());
-        var idx = map.insertionIndex(position);
-        if(idx<0){
-            idx = -idx-1; //cursor is not on a a marker, get the insertion index
-        }else{
-            //cursor is on a marker. As there might be several markers with the same offset
-            //(see MarkerMap.insertionIndex), move to the outmost left
-            while(idx>0  && markers[idx-1].offset == position){
-                idx--;
-            }
-        }
-        idx--; //move backward (rewind)
-        if(idx>=0){
-            offset = markers[idx].offset;
-        }
-        this.setSoundPosition(offset);
-        return false;
-    },
-
-    setSoundVolume: function(volume){
-        if(typeof volume != 'number'){ //note: typeof for primitive values, instanceof for the rest
-            //see topic http://stackoverflow.com/questions/472418/why-is-4-not-an-instance-of-number
-            volume = 100;
-        }
-        if(volume<0){
-            volume = 0;
-        }else if(volume>100){
-            volume = 100;
-        }
-        volume = Math.round(volume);
-        var sound = this.getSound();
-        if(sound){
-            sound.setVolume(volume);
-        }
-        var control = this.getContainer().find('.ts-control');
-        var volumeSpeaker = control.find('.ts-volume-speaker');
-        var volumeBarContainer = control.find('.ts-volume-bar-container');
-        var volumeBar = volumeBarContainer.find('.ts-volume-bar');
-        if(volume==0){
-            volumeSpeaker.removeClass('ts-volume-speaker-on').addClass('ts-volume-speaker-off');
-            volumeBar.css('visibility','hidden');
-        }else{
-            volumeSpeaker.removeClass('ts-volume-speaker-off').addClass('ts-volume-speaker-on');
-            volumeBar.css('visibility','visible');
-            volumeBar.css({
-                'height':'100%',
-                'width':volume+'%'
-            });
-        }
-    },
-
-    each: function(){
-        var map = this.getMarkerMap();
-        if(map){
-            map.each.apply(map,arguments);
-        }
-    },
-
-    newMarker: function(offset){
-        return {
-            offset:offset
-        };
-    },
-    addMarker: function(offset){
-        var map = this.getMarkerMap();
-        if(map){
-            map.add(this.newMarker(offset));
-        }
-    },
-
-    removeMarker: function(identifier){ //identifier can be an number (marker index) or a marker (the index will be aearched)
-        //see marlermap.remove
-        var map = this.getMarkerMap();
-        if(map){
-            map.remove(identifier);
-        }
-    },
-
-    moveMarker: function(identifier, newOffset){ //identifier can be an number (marker index) or a marker (the index will be aearched)
-        var map = this.getMarkerMap();
-        if(map){
-            map.move(identifier,newOffset);
-        }
-    },
-
-    getMarker: function(index){
-        var map = this.getMarkerMap();
-        if(map){
-            return map.toArray()[index];
-        }
-        return undefined;
-    },
-
-    setMarkerEditable: function(identifier, value){
-        var map = this.getMarkerMap();
-        if(map){
-            return map.setEditable(identifier,value);
-        }
-        return undefined;
-    },
-
-    //markers is an array of objects with at least the field offset:sconds.milliseconds
-    loadMarkers: function(markers){
-        //ruler.bind('markermoved',this.markerMoved,this);
-        //var $J = this.$J; //reference to jQuery
-
-        var player = this;
-        //initialize the map.
-        var map = this.getMarkerMap();
-        //var mapUI = this.getMarkersUI();
-        var ruler = this.getRuler();
-
-        //TODO: think about if clearing or not: we assign some bindings in the constructor, too:
-        //        map.clear();
-        //        ruler.clear();
-
-        var rulerAdd = ruler.add;
-
-        if(markers){
-            //add markers to the map. No listeners associated to it (for the moment)
-            for(var i =0; i< markers.length; i++){
-                map.add.apply(map,[markers[i]]);
-            }
-            //add markers to ruler and div
-            map.each(function(i,marker){
-                //isEditable and id are added if not present
-                rulerAdd.apply(ruler,[marker.offset, i, marker.isEditable]);
-            });
-        }
-
-        //the function above calls map.add:
-        //add bindings when adding a marker:
-        map.bind('add',function(data){
-            //mapuiAdd.apply(mapUI,[data.marker, data.index,data.isNew]);
-            rulerAdd.apply(ruler,[data.marker.offset, data.index,data.marker.isEditable]);
-            player.fire('markerAdded',data);
-        });
-
-        //2) MOVE
-
-        //add the binding when we move a marker on the ruler:
-        ruler.bind('markermoved',function(data){
-            var soundPos = data.soundPosition;
-            var isPointer = data.isPointer;
-            if(isPointer){
-                player.setSoundPosition(soundPos);
-            }else{
-                map.move(data.markerElement.getIndex(), soundPos);
-            }
-        });
-
-        //and now add a binding to the map when we move a marker:
-
-        map.bind('move', function(data){
-            var from = data.fromIndex;
-            var to = data.toIndex;
-            ruler.move.apply(ruler,[from,to,data.marker.offset]);
-            player.fire('markerMoved',data);
-        });
-
-        //remove
-        map.bind('remove',function(data){
-            ruler.remove.apply(ruler, [data.index]);
-            player.fire('markerRemoved',data);
-        });
-
-        //edit state changed
-        map.bind('markerEditStateChanged',function(data){
-            ruler.setEditable.apply(ruler, [data.index, data.value]);
-            player.fire('markerEditStateChanged',data);
-        });
-    }
-});
diff --git a/timeside/static/timeside/js/ruler.js b/timeside/static/timeside/js/ruler.js
deleted file mode 100644 (file)
index 259d7f3..0000000
+++ /dev/null
@@ -1,475 +0,0 @@
-/*
- * Copyright (C) 2007-2011 Parisson
- * Copyright (c) 2011 Riccardo Zaccarelli <riccardo.zaccarelli@gmail.com>
- * Copyright (c) 2010 Olivier Guilyardi <olivier@samalyse.com>
- *
- * This file is part of TimeSide.
- *
- * TimeSide is free software: you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation, either version 2 of the License, or
- * (at your option) any later version.
- *
- * TimeSide is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
- * GNU General Public License for more details.
- *
- * You should have received a copy of the GNU General Public License
- * along with TimeSide.  If not, see <http://www.gnu.org/licenses/>.
- *
- * Authors: Riccardo Zaccarelli <riccardo.zaccarelli@gmail.com>
- *          Olivier Guilyardi <olivier@samalyse.com>
- */
-
-/**
- * Class representing the ruler (upper part) of the player. Requires jQuery
- * and Raphael
- */
-Timeside.classes.Ruler = Timeside.classes.TimesideArray.extend({
-    //init constructor: soundDuration is IN SECONDS!!! (float)
-    init: function(rulerContainer, waveContainer, soundDuration){
-        this._super();
-        
-        this.getSoundDuration= function(){
-            return soundDuration;
-        };
-
-        this.getWaveContainer =function(){
-            return waveContainer;
-        };
-        
-        this.getContainerWidth =function(){
-            return waveContainer.width();
-        };
-        
-        this.getRulerContainer = function(){
-            return rulerContainer;
-        }
-    },
-    
-    resize : function(){
-        var duration = this.getSoundDuration(); //in seconds
-        if (!duration) {
-            this.debug("ruler.resize: Can't draw ruler with a duration of 0");
-            return;
-        }
-
-        var $J = this.$J;
-        var rulerContainer = this.getRulerContainer();
-       
-        //remove all elements not pointer or marker
-        rulerContainer.find(':not(a.ts-pointer,a.ts-marker,a.ts-pointer>*,a.ts-marker>*)').remove();
-
-        //calculate h with an artifice: create a span (that will be reused later) with the "standard" label
-        var firstSpan = $J('<span/>').css({
-            'display':'block',
-            'position':'absolute'
-        }).html('00000'); //typical timelabel should be '00:00', with '00000' we assure a bit of extra safety space
-        //note also that display and position must be set as below to calculate the proper outerHeight
-        rulerContainer.append(firstSpan); //to calculate height, element must be in the document, append it
-        var verticalMargin = 1;
-        var h = 2*(verticalMargin+firstSpan.outerHeight());
-        //h is the default height of the ruler svg (according to ruler font size)
-        //to accomodate the necessary space for the labels
-        //however, if we set a custom height on the ruler, ie h2 is nonzero:
-        var h2 = rulerContainer.height(); 
-        //then, set the custom height as height for the canvas:
-        //note that, as markers and pointer have position: absolute, they do not affect div height
-        if(h2){
-            h = h2;
-        }
-        var obj = this.calculateRulerElements(rulerContainer.width(),h,firstSpan.outerWidth());
-        this.drawRuler(rulerContainer,h,obj.path);
-        
-        var labels = obj.labels;
-        if(labels && labels.length){
-            for(var i=0; i <labels.length;i++){
-                var span = (i==0 ? firstSpan : $J('<span/>'));
-                span.html(labels[i][0]).css({
-                    'display':'block',
-                    'position':'absolute',
-                    'width':'',
-                    'height':'',
-                    'right':'',
-                    'bottom':'',
-                    'top':'0',
-                    'left':labels[i][1]+'px'
-                });
-                rulerContainer.append(span);
-            }
-        }else{
-            firstSpan.html(this.makeTimeLabel(0));
-        }
-
-        var pointer = undefined;
-        if('getPointer' in this){
-            pointer = this.getPointer();
-        }
-        if(!pointer){
-            pointer = this.add(0,-1);
-            this.getPointer = function(){
-                return pointer;
-            };
-        }else{
-            pointer.refreshPosition();
-            
-        }
-        this.each(function(i,rulermarker){
-            rulermarker.refreshPosition();
-        });
-        
-
-    },
-
-    drawRuler: function(rulerContainer,h,rulerLinesPath){
-        var cssPref = this.cssPrefix;
-        var upperRectClass = cssPref + 'svg-' + 'ruler-upper-rect';
-        var rulerLinesClass = cssPref + 'svg-' + 'ruler-lines';
-
-        var vml = this.$TU.vml;
-        if(vml){
-            //we create each time a new Raphael object. This is not a big performance issue
-            var paper = Raphael(rulerContainer[0], rulerContainer.width(), h);
-            var rect = paper.rect(0,0, rulerContainer.width(), h/2);
-            var path = paper.path(rulerLinesPath);
-            var attr = vml.getVmlAttr;
-            rect.attr(attr(upperRectClass));
-            path.attr(attr(rulerLinesClass));
-            return;
-        }
-        //create svg. Note that elements must be created within a namespace (createElementNS)
-        //and attributes must be set via .setAttributeNS(null,name,value)
-        //in other words, jQuery does not work (maybe in future releases)
-        var $J = this.$J;
-        var svgNS = "http://www.w3.org/2000/svg";
-        var d = document;
-        var svg  = d.createElementNS(svgNS, "svg:svg");
-        svg.setAttributeNS( null, "width", rulerContainer.width()); //TODO: optimize width is called also below
-        svg.setAttributeNS( null, "height", h);
-        rulerContainer.append($J(svg));
-
-        var rect = d.createElementNS(svgNS, "svg:rect");
-        rect.setAttributeNS( null, "x", 0);
-        rect.setAttributeNS( null, "y", 0);
-        rect.setAttributeNS( null, "width", rulerContainer.width());
-        rect.setAttributeNS( null, "height", (h/2));
-        rect.setAttributeNS( null, "class", upperRectClass);
-        svg.appendChild(rect);
-        var lines = d.createElementNS(svgNS, "svg:path");
-        lines.setAttributeNS( null, "d", rulerLinesPath);
-        lines.setAttributeNS( null, "class", rulerLinesClass);
-        svg.appendChild(lines);
-    },
-    /**
-     * returns an object with the following properties:
-     * path: (string) the path of the ruler to be drawn
-     * labels (array) an array of arrays ['text',x,y]
-     */
-    calculateRulerElements: function(w,h,timeLabelWidth){
-        
-        var duration = this.getSoundDuration();
-        
-        var fontLeftMargin = 2; //should be eual or greater to the ruler stroke width, so that
-        //the labels are not overlapping the vertical ruler lines
-        timeLabelWidth+=fontLeftMargin;
-
-        var timeLabelDuration = timeLabelWidth*duration/w;
-        
-        //determine the ticks:
-        var sectionDurations = [1,2,5,10,30,60,120,300,1800,3600,7200,18000,36000];
-        //sectionDurations in seconds. Note that 60=1 minute, 3600=1 hour (so the maximum sectionDuration is 36000=10hours)
-        var i=0;
-        var len = sectionDurations.length;
-        while(i<len && timeLabelDuration>sectionDurations[i]){
-            i++;
-        }
-        var sectionDuration = sectionDurations[i];
-        var sectionNums = parseInt(0.5+(duration/sectionDurations[i])); //ceil
-        var sectionWidth = w*sectionDuration/duration;
-
-
-        var tickCounts = [10,5,2,1];
-        i=0;
-        var tickCount = tickCounts[0];
-        while(i<tickCounts.length-1 && tickCounts[i]*2>sectionWidth){
-            i++;
-        }
-        var tickAtHalfSectionWidthHigher = i==0 || i==2; //draw tick at half section higher if ticks are even
-        tickCount = tickCounts[i];
-        var tickWidth = sectionWidth/tickCount;
-        var makeTimeLabel = this.makeTimeLabel;
-        var h_1 = h-1; //TODO: use line tickness instead of 1
-        var path = new Array(parseInt(0.5+(w/tickWidth)));
-        path[0] = ['M 0 '+h_1];
-        len = path.length;
-        for(i=0;  i < len; i+=tickCount){
-            for(var j=1; j<tickCount+1; j++){
-                var k = i+j;
-                var x = (k*tickWidth);
-                var y = (j==tickCount ? 0 : tickAtHalfSectionWidthHigher && j==(tickCount)/2 ? .5*h : .75*h);
-                var baseline = ' L '+x+' '+h_1;
-                path[k] = baseline;
-                path[k] += ' L '+x+' '+y;
-                path[k] += baseline;
-            }
-        }
-        var labels = new Array(sectionNums);
-        for(i=0; i<sectionNums; i++){
-            labels[i] = [makeTimeLabel(sectionDuration*i),fontLeftMargin+i*sectionWidth];
-        }
-        return {
-            'path': path.join(''),
-            'labels':labels
-        };
-    },
-
-    //overridden: Note that the pointer is NOT cleared!!!!!
-    clear: function(){
-        var markers = this._super();
-        //now remove also the labels in the player ruler:
-        for( var i=0; i<markers.length; i++){
-            markers[i].remove();
-        }
-        return markers;
-    },
-    
-    //overridden 
-    remove: function(index){
-        var rulermarker = this._super(index);
-        rulermarker.remove();
-        this.each(index, function(i,rulermarker){
-            rulermarker.setIndex(i, true);
-        });
-    },
-
-    //overridden: do not call directly this method, use markermap.move
-    move: function(from, to, newOffset){
-        to = this._super(from,to);
-        if(to <0){ //no move (some error)
-            return -1;
-        }
-        //update label if it is the case:
-        var rulermarker = this.toArray()[to];
-        var pixelOffset = this.toPixelOffset(newOffset);
-        if(rulermarker.positionInPixels != pixelOffset){ //should not be the case if this method is called from a mouse event
-            rulermarker.move(pixelOffset);
-        }
-
-        if(to!=from){
-            var i1 = Math.min(from,to);
-            var i2 = Math.max(from,to)+1;
-            this.each(i1,i2, function(index,rulermarker){
-                rulermarker.setIndex(index, true);
-            });
-        }
-        return to;
-    },
-    //overridden
-    //add(offset.-1) adds the pointer, isMovable is ingored
-    //add(offset, index, isMovable) adds a marker, movable if isMovable == true
-    add: function(offset, index, isMovable){
-        var soundPosition;
-        var markerClass;
-
-        if(index<0){
-            soundPosition = offset;
-            isMovable = true;
-            markerClass='pointer';
-        }else{
-            soundPosition = offset;
-            //isMovable = offset.isEditable;
-            markerClass='marker';
-        }
-        
-       
-        var pointerOrMarker = new Timeside.classes.RulerMarker(this,this.getWaveContainer(),markerClass);
-
-        //call super constructor
-        //if it is a pointer, dont add it
-        if(markerClass != 'pointer'){
-            this._super(pointerOrMarker,index); //add at the end
-            //note that setText is called BEFORE move as move must have the proper label width
-            this.each(index, function(i,rulermarker){
-                rulermarker.setIndex(i,i!=index);//update label width only if it is not this marker added
-            });
-        }else{
-            //note that setText is called BEFORE move as move must have the proper label width
-            pointerOrMarker.setText(this.makeTimeLabel(0));
-        }
-        //proceed with events and other stuff: move (called AFTER setText or setText)
-        pointerOrMarker.move(this.toPixelOffset(soundPosition));
-        //set mouse events:
-        var isPointer  = markerClass === 'pointer';
-        this._setEditable(pointerOrMarker, isMovable, isPointer);
-        return pointerOrMarker;
-
-    },
-
-    eventNamespace : 'rulerMouseEvent', //namespace for mouse events
-    mouseEventType : 'rulermarkermouseevent', //event type for fire TO THE PLAYER. The player then fires markerMouseEvent to outside
-
-    setEditable: function(index, value){
-        var a = this.toArray();
-        if(index>=0 && index < a.length){
-            this._setEditable(a[index],value,false);
-        }
-    },
-    //do not call, use setEditable(index,value) instead
-    _setEditable: function(pointerOrMarker, value, isPointer){
-        var eventNamespace = this.eventNamespace;
-        var doc = this.$J(document);
-        var lbl = pointerOrMarker.getLabel();
-        var me = this;
-        var mme = this.mouseEventType;
-
-        
-        lbl.unbind('.'+eventNamespace); //this should delete all previous events
-
-        lbl.bind('mouseenter.'+eventNamespace,function(evt){
-            me.fire(mme,{
-                eventName: 'mouseenter',
-                eventObj: evt,
-                index: isPointer ? -1 : pointerOrMarker.getIndex()
-            });
-            return false;
-        });
-        lbl.bind('mouseleave.'+eventNamespace,function(evt){
-            me.fire(mme,{
-                eventName: 'mouseleave',
-                eventObj: evt,
-                index: isPointer ? -1 : pointerOrMarker.getIndex()
-            });
-            return false;
-        });
-        
-        //to prevent page scrolling after mouseup, as click is also fired
-        lbl.bind('click.'+this.eventNamespace, function(evt){
-            return false;
-        });
-        
-
-        lbl.bind('mousedown.'+eventNamespace,function(evt) {
-            if(evt.which===1){
-                if(value){
-                    pointerOrMarker.isMovedByMouse = true;
-                }
-                
-                var launchDragStart = true;
-
-                var startX = evt.pageX; 
-                var startPos = lbl.position().left+lbl.width()/2;
-
-                evt.stopPropagation(); //dont notify the ruler or other elements;
-                var newPos = startPos;
-                doc.bind('mousemove.'+eventNamespace, function(evt_){
-                    //preventClickFire=true;
-                    if(value){
-                        var x = evt_.pageX;
-                        newPos = startPos+(x-startX);
-                        pointerOrMarker.move(newPos);
-                        //update the text if pointer
-                        if(isPointer){
-                            pointerOrMarker.setText(me.makeTimeLabel(me.toSoundPosition(newPos)));
-                        }
-                    }
-                    if(launchDragStart){
-                        launchDragStart = false;
-                        me.fire(mme,{
-                            eventName: 'dragstart',
-                            eventObj: evt_,
-                            index: isPointer ? -1 : pointerOrMarker.getIndex()
-                        });
-                    }
-                    return false;
-
-                });
-                //to avoid scrolling
-                ////TODO: check IE bug on mouseup on the ruler (pointer is moving too)
-                //TODO: what happens if the user releases the mouse OUTSIDE the browser???? check bug in IE (mouse release)
-                var mouseup = function(evt_){
-                    
-                    doc.unbind('mousemove.'+eventNamespace);
-                    doc.unbind('mouseup.'+eventNamespace);
-                    evt_.stopPropagation();
-                    if(value){
-                        if(newPos !== startPos){
-                        
-                            var data = {
-                                'markerElement':pointerOrMarker,
-                                'soundPosition': me.toSoundPosition.apply(me,[newPos]),
-                                'isPointer':isPointer
-                            };
-                            me.fire('markermoved',data);
-                        }
-                        pointerOrMarker.isMovedByMouse = false;
-                    }
-                    if(evt_.pageX !== startX){
-                        me.fire(mme,{
-                            eventName: 'dragend',
-                            eventObj: evt_,
-                            index: isPointer ? -1 : pointerOrMarker.getIndex()
-                        });
-                    }else{
-                        me.fire(mme,{
-                            eventName: 'click',
-                            eventObj: evt_,
-                            index: isPointer ? -1 : pointerOrMarker.getIndex()
-                        });
-                    }
-                    return false;
-                };
-                doc.bind('mouseup.'+eventNamespace, mouseup);
-            }
-
-            me.fire(mme,{
-                eventName: 'mousedown',
-                eventObj: evt,
-                index: isPointer ? -1 : pointerOrMarker.getIndex()
-            });
-
-
-            return false;
-        });
-    },
-
-    //moves the pointer, does not notify any listener.
-    //soundPosition is in seconds (float)
-    movePointer : function(soundPosition) {
-        var pointer = this.getPointer();
-        if (pointer && !pointer.isMovedByMouse) {
-            var pixelOffset = this.toPixelOffset(soundPosition);
-            //first set text, so the label width is set, then call move:
-            pointer.setText(this.makeTimeLabel(soundPosition));
-            pointer.move(pixelOffset); //does NOT fire any move method
-        }
-        return soundPosition;
-    },
-
-    //soundPosition is in seconds (float)
-    toPixelOffset: function(soundPosition) {
-        var duration = this.getSoundDuration();
-        if (soundPosition < 0){
-            soundPosition = 0;
-        }else if (soundPosition > duration){
-            soundPosition = duration;
-        }
-        var width = this.getContainerWidth();
-        var pixelOffset = (soundPosition / duration) * width;
-        return pixelOffset;
-    },
-
-    //returns the soundPosition is in seconds (float)
-    toSoundPosition: function(pixelOffset) {
-        var width = this.getContainerWidth();
-
-        if (pixelOffset < 0){
-            pixelOffset = 0;
-        }else if (pixelOffset > width){
-            pixelOffset = width;
-        }
-        var duration = this.getSoundDuration();
-        var soundPosition = (pixelOffset / width) *duration;
-        return soundPosition;
-    }
-});
diff --git a/timeside/static/timeside/js/rulermarker.js b/timeside/static/timeside/js/rulermarker.js
deleted file mode 100644 (file)
index e98730c..0000000
+++ /dev/null
@@ -1,259 +0,0 @@
-/*
- * Copyright (C) 2007-2011 Parisson
- * Copyright (c) 2011 Riccardo Zaccarelli <riccardo.zaccarelli@gmail.com>
- * Copyright (c) 2010 Olivier Guilyardi <olivier@samalyse.com>
- *
- * This file is part of TimeSide.
- *
- * TimeSide is free software: you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation, either version 2 of the License, or
- * (at your option) any later version.
- *
- * TimeSide is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
- * GNU General Public License for more details.
- *
- * You should have received a copy of the GNU General Public License
- * along with TimeSide.  If not, see <http://www.gnu.org/licenses/>.
- *
- * Authors: Riccardo Zaccarelli <riccardo.zaccarelli@gmail.com>
- *          Olivier Guilyardi <olivier@samalyse.com>
- */
-
-/**
- * Class representing a RulerMarker in TimesideUI
- * Requires jQuery Raphael and all associated player classes. rulerDiv position MUST be relative
- * (if this class is called from within player, it is)
- */
-
-Timeside.classes.RulerMarker = Timeside.classes.TimesideClass.extend({
-
-    
-    init: function(ruler, waveImgDiv, className) {
-        this._super();
-        var rulerDiv = ruler.getRulerContainer();
-        var $J = this.$J;
-
-        var tooltip = '';
-
-        var cssPref = this.cssPrefix;
-
-        var label = $J('<a/>')
-        .addClass(cssPref + className)
-        .css({
-            display: 'block',
-            textAlign: 'center',
-            position: 'absolute',
-            zIndex: 1000
-        }).append($J('<span/>')).attr('href', '#');
-        
-        if (tooltip){
-            label.attr('title', tooltip);
-        }
-        rulerDiv.append(label);
-
-        //rulerDiv MUST HAVE POSITON relative or absolute (it is relative, see player.resize)
-        if(className != "pointer"){
-            label.css('bottom','0');
-        }else{
-            label.css('top','0');
-        }
-        
-        //set the index,
-        var index = -1;
-        this.setIndex = function(idx, optionalUpdateLabelWidth){
-            index = idx;
-            this.setText(idx+1, optionalUpdateLabelWidth ? true : false);
-        };
-        this.getIndex = function(){
-            return index;
-        };
-
-        //end=======================================================
-        //creating public methods:
-        this.getLabel = function(){
-            return label;
-        };
-
-
-        this.getRulerWidth = function(){
-            return rulerDiv.width();
-        };
-        this.getWaveHeight = function(){
-            return waveImgDiv.height();
-        };
-
-        this.positionInPixels = 0;
-        this.positionAsViewerRatio = 0;
-
-        var arrowBaselineWidth = 9;
-
-        var canvas = undefined;
-        var canvasClass = cssPref + 'svg-'+className+'-line';
-        var vml = this.$TU.vml; //if vml, this class is populated with methods and NOT undefined
-        var round = Math.round;
-        if(!vml){
-            canvas = this.createCanvasSvg(waveImgDiv, arrowBaselineWidth);
-            var path = canvas.childNodes[0]; //note that $J(canvas).find('path') does not work in FF at least 3.5
-            path.setAttributeNS(null,'class',canvasClass);
-            this.moveCanvas = function(pixelOffset){
-                pixelOffset = round(pixelOffset);
-                canvas.setAttributeNS( null, "transform", "translate("+pixelOffset+",0)");
-            };
-            this.jQueryCanvas = $J(canvas);
-        }else{
-            canvas = this.createCanvasVml(waveImgDiv, arrowBaselineWidth);
-            this.jQueryCanvas = $J(canvas.node);
-            var attributes = vml.getVmlAttr(canvasClass);
-            canvas.attr(attributes); //Raphael method
-            this.moveCanvas = function(pixelOffset){
-                pixelOffset = round(pixelOffset);
-                //for some reason, coordinates inside the VML object are stored by raphael with a zoom of 10:
-                this.jQueryCanvas.css('left',(10*pixelOffset)+'px');
-            };
-            //apparently, when resizing the markers loose their attributes. Therefore:
-            var r = this.refreshPosition; //reference to current refreshPosition
-            this.refreshPosition = function(){
-                r.apply(this);
-                canvas.attr(attributes);
-            }
-        }
-    },
-    
-    //sets the text of the marker, if the text changes the marker width and optionalUpdateLabelPosition=true,
-    //re-arranges the marker position to be center-aligned with its vertical line (the one lying on the wav image)
-    setText: function(text, optionalUpdateLabelPosition) {
-        var label = this.getLabel();
-        if (label) {
-            var oldWidth = label.width();
-            label.find('span').html(text);
-            var labelWidth = label.width();
-            if(oldWidth != labelWidth && optionalUpdateLabelPosition){
-                this.refreshLabelPosition();
-            }
-        }
-        return this;
-    },
-    
-    //these methods are executed only if marker is movable (see Ruler.js)
-    move : function(pixelOffset) {
-        var width =  this.getRulerWidth();
-        if (this.positionInPixels != pixelOffset) {
-            if (pixelOffset < 0) {
-                pixelOffset = 0;
-            } else if (pixelOffset >= width) {
-                pixelOffset = width - 1;
-            }
-           //defined in the init method (it depends on wehter the current browser supports SVG or not)
-            this.moveCanvas(pixelOffset);
-           
-            this.positionInPixels = pixelOffset;
-            this.refreshLabelPosition(width);
-            //store relative position (see refreshPosition below)
-            this.positionAsViewerRatio = pixelOffset == width-1 ? 1 : pixelOffset/width;
-        }
-        return this;
-    },
-
-    refreshLabelPosition : function(optionalContainerWidth){
-        if(!(optionalContainerWidth)){
-            optionalContainerWidth = this.getRulerWidth();
-        }
-        var label = this.getLabel();
-        var width = optionalContainerWidth;
-        var pixelOffset = this.positionInPixels;
-        var labelWidth = label.outerWidth(); //consider margins and padding
-        var labelPixelOffset = pixelOffset - labelWidth / 2;
-        if (labelPixelOffset < 0){
-            labelPixelOffset = 0;
-        }else if (labelPixelOffset + labelWidth > width){
-            labelPixelOffset = width - labelWidth;
-        }
-        label.css({
-            left: this.mRound(labelPixelOffset) + 'px'
-        });
-
-    },
-
-    //function called on ruler.resize. Instead of recreating all markers, simply redraw them
-    refreshPosition : function(){
-        var width =  this.getRulerWidth();
-        //store relativePosition:
-        var rp = this.positionAsViewerRatio;
-        this.move(this.mRound(this.positionAsViewerRatio*width));
-        //reset relative position, which does not have to change
-        //but in move might have been rounded:
-        this.positionAsViewerRatio = rp;
-    },
-
-    
-    remove : function() {
-        var label = this.getLabel();
-        label.remove();
-        this.jQueryCanvas.remove(); //defined in the constructor
-        return this;
-    },
-
-
-    createCanvasSvg: function(container, arrowBaseWidth){
-        //create svg. Note that elements must be created within a namespace (createElementNS)
-        //and attributes must be set via .setAttributeNS(null,name,value)
-        //in other words, jQuery does not work (maybe in future releases)
-        var $J = this.$J;
-        var svgNS = "http://www.w3.org/2000/svg";
-        var d = document;
-        var svg = undefined;
-        if(container.children().length>0){
-            svg = container.children().get(0);
-        }else{
-            svg = d.createElementNS(svgNS, "svg:svg");
-            container.append($J(svg));
-        }
-            var group = d.createElementNS(svgNS, "svg:g");
-            group.setAttributeNS( null, "transform", "translate(0,0)");
-
-            var path = d.createElementNS(svgNS, "svg:path");
-            path.setAttributeNS( null, "d", this.createCanvasPath(0,arrowBaseWidth));
-            
-            group.appendChild(path);
-            svg.appendChild(group);
-       
-        return group; //return the group, not the path, as it is the group that will be translated when moving
-    },
-
-    createCanvasVml: function(container, arrowBaseWidth){
-        var vml = this.$TU.vml;
-        var paper = vml.Raphael(container.get(0),container.width(),container.height());
-        var shape = paper.path(this.createCanvasPath(0, arrowBaseWidth));
-        return shape;
-    },
-
-    //w must be odd. Cause the central line must be centered. Example:
-    //
-    //      xxxxx
-    //       xxx
-    //        x
-    //        x
-    //        x
-    //
-    createCanvasPath: function(x,w){
-        var halfW = w >>> 1;
-        //in order to calculate the line height, we could simply set the wave height. However, due to potential
-        //resizing afterwards, the line could not stretch till the bottom (if it overflows it's fine, as the wave div container has 
-        //overflow = hidden). As we do not want to rebuild the canvas on resize,
-        //we assess an height which will 99% overflow the wave height in any case.
-        //We use the wave height and the window height, and take 2 times
-        //the maximum of those heights:
-        var wdwH = this.$J(window).height();
-        var waveH = this.getWaveHeight();
-        var h = 2* (wdwH > waveH ? wdwH : waveH);
-        return 'M '+(x-halfW)+' 0 L '+(x)+' '+(halfW)+' L '+x+' '+h+
-        ' L '+ (x+1)+' '+h+' L '+(x+1)+ ' '+(halfW)+' L '+(x+halfW+1)+' 0 z';
-    },
-
-    //used for faster lookup
-    mRound: Math.round
-
-});
diff --git a/timeside/static/timeside/js/timeside.js b/timeside/static/timeside/js/timeside.js
deleted file mode 100644 (file)
index e274783..0000000
+++ /dev/null
@@ -1,784 +0,0 @@
-/*
- * Copyright (C) 2007-2011 Parisson
- * Copyright (c) 2011 Riccardo Zaccarelli <riccardo.zaccarelli@gmail.com>
- * Copyright (c) 2010 Olivier Guilyardi <olivier@samalyse.com>
- *
- * This file is part of TimeSide.
- *
- * TimeSide is free software: you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation, either version 2 of the License, or
- * (at your option) any later version.
- *
- * TimeSide is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
- * GNU General Public License for more details.
- *
- * You should have received a copy of the GNU General Public License
- * along with TimeSide.  If not, see <http://www.gnu.org/licenses/>.
- *
- * Authors: Riccardo Zaccarelli <riccardo.zaccarelli@gmail.com>
- *          Olivier Guilyardi <olivier@samalyse.com>
- */
-
-/**
- * Root javascript file for TimesideUI, to be manually included in your web page (see online doc)
- */
-
-/**
- *global variable housing all Timeside variables/mathods/classes:
- */
-var Timeside = {
-    Class:undefined,
-    classes:{},
-    player:undefined,
-    config: {
-        /**
-         *set to true to see debug messages on the console (only error or warning messages shown)
-         */
-        debug: false,
-        /*
-         * timeside scripts to be loaded when Timeside.load is called. URL paths are relative to the timeside folder, which
-         * will be determined according to the src attribute of the timeside.js script path (to be included in the <head> of the page)
-         */
-        timesideScripts: ['rulermarker.js','markermap.js', 'player.js', 'ruler.js'],
-        //vml config variables. Used only if svg is NOT supported
-        vml : {
-            /*
-            * raphael script to be loaded when Timeside.load is called and svg is not supported. It will be prepended to the
-            * timesideScripts array defined above in config. URL paths are relative to the timeside folder, which
-            * will be determined according to the src attribute of the timeside.js script path (to be included in the <head> of the page)
-            */
-            raphaelScript : 'libs/raphael-min.js',
-            /*
-             * available attributes which can be converted from css-svg to Raphael attributes (see Raphael.js):
-             */
-            raphaelAttributes : ["clip-rect", "cursor",'fill', "fill-opacity",'opacity', 'stroke', "stroke-dasharray", "stroke-linecap", "stroke-linejoin","stroke-miterlimit","stroke-opacity","stroke-width", "text-anchor"]
-        }
-    },
-    utils:{
-        /**
-         * Returns an uniqid by creating the current local time in millisecond + a random number.
-         * Used for markers in markermap. The method is kind of public in order to be more accessible for other functions
-         * by calling Timeside.utils.uniqid(), in case it is needed
-         */
-        uniqid : function() {
-            var d = new Date();
-            return new String(d.getTime() + '' + Math.floor(Math.random() * 1000000)).substr(0, 18);
-        },
-        /**
-         * vml object which will be populated by vml functions to interface timeside and raphael. See timeside.load.
-         * We could implement functions here for code readability, however,
-         * we delegate Timeside.load so that if svg is supported memory is free from unused vml methods.
-         * IN ANY CASE, svg support can be detected anywhere by calling, eg:
-         *  var svg = !Timeside.utils.vml;
-         */
-        vml: undefined,
-
-        /**
-         * property that will be set to false if soundManager fails to initialize flash
-         */
-        flashFailed : false
-    }
-};
-
-
-/* Simple JavaScript Inheritance
- * By John Resig http://ejohn.org/
- * MIT Licensed.
- * (Inspired by base2 and Prototype)
- */
-
-/*
- * In few words: the lightest and most-comprehensive way to implement inhertance and OOP in javascript. Usages can be found below.
- * Basically,
- * 1) a new Class is instantiated with Class.extend(). This function takes a dictionary
- * of properties/methods which will be put IN THE PROTOTYPE of the class, so that each instance will share the same properties/methods
- * and the latter don't have to be created for each instance separately.
- * 2) If var A = Class.extend({...}) and var B = A.extend({..}), then methods which are found in B will override the same methods in A.
- * In this case, the variable this._super inside the overridden methods will refers to the super-method and can thus be called safely.
- * Consequently, if a _super property/method is implemented in the extend dictionary, it WILL NOT be accessible
- * to the overriding methods of B. Basically, don't use _super as a key of the argument of extend.
- * 3) AFTER the prototype has been populated, the init function, if exists, is called. The latter can be seen as a class constructor in java,
- * with a substantial difference: when executing the init() method the class prototype has already been populated with all inherited methods.
- * Private variable can be declared in the init function, as well as
- * relative getters and setters, if needed. Downside is that the privileged getters and setters can’t be put in the prototype,
- * i.e. they are created for each instance separately, and the _super keyword does not apply to them. Another issue is the overhead of closures in general (basically, write as less as possible
- * in the init function, in particular if the class has to be declared several times)
- * Of course, the this._super keyword of methods implemented in the init constructor does not work
- *
- * EXAMPLE:
- * var MyClass = Class.extend({
- *   init: function(optionalArray){ //constructor
- *       this._super();             //!!!ERROR: Class is the base class and does not have a super construcor
- *       var me = [];               //private variable
- *       this.count = 6;            //set the value of the public property defined below
- *       this.getMe = function(){   //public method
- *           this._super();         //!!!ERROR: methods defined in the init function don't have acces to _super
- *       }
- *       this.alert = function(){   //another public method, !!!WARNING: this will be put in the MyClass scope (NOT in the prototype)
- *           alert('ok');
- *       }
- *   },
- *   count:0,                       //public property
- *   alert: function(){             //public method. !!!WARNING: this method will be put in the prototype BEFORE the init is called,
- *      alert('no');                //  so the alert defined above will be actually called
- *   }
- * });
- * var MyClass2 = MyClass.extend({
- *  init: function(){
- *      this._super();                  //call the super constructor
- *  }
- *  alert: function(){                  //override a method
- *      this._super();                  //call the super method, ie alerts 'no'. WARNING: However, as long as there is an alert written
- *                                      //in the init method of the superclass (see above), THAT method will be called
- *  }
- * });
- *
- */
-
-
-(function(parent){
-
-    var initializing = false, fnTest = /xyz/.test(function(){
-        xyz;
-    }) ? /\b_super\b/ : /.*/;
-
-    /*The xyz test above determines whether the browser can inspect the textual body of a function.
-     *If it can, you can perform an optimization by only wrapping an overridden method if it
-     *actually calls this._super() somewhere in its body.
-     *Since it requires an additional closure and function call overhead to support _super,
-     *it’s nice to skip that step if it isn’t needed.
-     */
-
-    //ADDED BY ME:
-    // before was: this.Class = function(){}, where this here is the DomWindow
-    // In order to chose where to attach the Class object, we added the argument parent (see above):
-    //if parent is undefined, attach Class to the DomWindow (same as before):
-    if(!parent){
-        parent= window;
-    }
-    parent.Class = function(){};
-
-    //from here on, the code is untouched:
-    //
-    //We have the base Class implementation (does nothing)
-    //and we write here below the method extend which returns the Class with inhertance implemented:
-    // Create a new Class that inherits from this class
-    parent.Class.extend = function(prop) {
-        var _super = this.prototype;
-
-        // Instantiate a base class (but only create the instance,
-        // don't run the init constructor)
-        initializing = true;
-        var prototype = new this();
-        initializing = false;
-
-        // Copy the properties over onto the new prototype
-        for (var name in prop) {
-            // Check if we're overwriting an existing function
-            prototype[name] = typeof prop[name] == "function" &&
-            typeof _super[name] == "function" && fnTest.test(prop[name]) ?
-            (function(name, fn){
-                return function() {
-                    var tmp = this._super;
-
-                    // Add a new ._super() method that is the same method
-                    // but on the super-class
-                    this._super = _super[name];
-
-                    // The method only need to be bound temporarily, so we
-                    // remove it when we're done executing
-                    var ret = fn.apply(this, arguments);
-                    this._super = tmp;
-
-                    return ret;
-                };
-            })(name, prop[name]) :
-            prop[name];
-        }
-
-        // The dummy class constructor
-        function Class() {
-            // All construction is actually done in the init method
-            if ( !initializing && this.init ){
-                this.init.apply(this, arguments);
-            }
-        }
-
-        // Populate our constructed prototype object
-        Class.prototype = prototype;
-
-        // Enforce the constructor to be what we expect
-        Class.constructor = Class;
-
-        // And make this class extendable
-        Class.extend = arguments.callee;
-
-        return Class;
-    };
-})(Timeside);
-
-
-
-//Defining the base TimeClass class. Timeside.classes.[Player, Ruler, MarkerMap...] are typical implementations (see js files)
-//Basically we store here static methods which must be accessible in several timside sub-classes
-Timeside.classes.TimesideClass = Timeside.Class.extend({
-    //init constructor. Define the 'bind' and 'fire' (TODO: rename as 'trigger'?) methods
-    //we do it in the init function so that we can set a private variable storing all
-    //listeners. This means we have to re-write all methods
-    init: function(){
-        //the map for listeners. Must be declared in the init as it's private and NOT shared by all instances
-        //(ie, every instance has its own copy)
-        this.listenersMap={};
-    },
-
-    cssPrefix : 'ts-', //actually almost uneuseful, still here for backward compatibility with old code (TODO: remove?)
-    $J : jQuery, //reference to jQuery for faster lookup inside methods
-    $TU : Timeside.utils, //reference to Timeside variable for faster lookup inside methods
-    debugging : false,
-    debug : Timeside.config.debug ? function(message) {
-        var C = console;
-        if (C && C.log) {
-            C.log(message);
-        }
-    } : function(message){},
-
-    /**
-     * 3 methods defining listeners, events fire and bind (aloing the lines of jQuery.bind, unbind and trigger.
-     * the only difference is that 'trigger' is 'fire' here). namespaces are allowed as in jQuery
-     */
-    bind : function(eventType, callback, optionalThisArgInCallback){
-        if(!callback || typeof callback !== 'function'){
-            this.debug('TimesideClass.bind: cannot bind '+eventType+' to callback: the latter is null or not a function');
-            return;
-        }
-        if(!eventType){
-            this.debug('TimesideClass.bind: eventType is empty in bind');
-            return;
-        }
-        var listenersMap = this.listenersMap;
-        if(optionalThisArgInCallback){
-            var cb = callback;
-            callback = function(data){
-                cb.apply(optionalThisArgInCallback,[data]);
-            };
-        }
-
-        if(listenersMap.hasOwnProperty(eventType)){
-            listenersMap[eventType].push(callback);
-        }else{
-            listenersMap[eventType] = [callback];
-        }
-
-        var idx = eventType.indexOf('.');
-        if(idx <= 0 || idx >= eventType.length-1){
-            return;
-        }
-
-        eventType = eventType.substring(0,idx);
-
-
-        if(listenersMap.hasOwnProperty(eventType)){
-            listenersMap[eventType].push(callback);
-        }else{
-            listenersMap[eventType] = [callback];
-        }
-
-    },
-    unbind : function(){
-        var listenersMap = this.listenersMap;
-        var key,keyPlusDot;
-        if(arguments.length>0){
-            key = arguments[0];
-            if(listenersMap.hasOwnProperty(key)){
-                var callbacks = listenersMap[key];
-                var idx = key.indexOf('.');
-                if(idx>0 && idx < key.length-1){
-                    //key is "eventtype.namespace", delete also functions stored in "eventType", if any
-                    var baseKey = key.substring(0,idx);
-                    var baseCallbacks = listenersMap[baseKey];
-                    if(baseCallbacks){
-                        for( var i = baseCallbacks.length; i>-1; i--){
-                            var bc = baseCallbacks[i];
-                            for( var j = callbacks.length; j>-1; j--){
-                                if(bc === callbacks[j]){
-                                    baseCallbacks.splice(i,1);
-                                }
-                            }
-                        }
-                    }
-                }else if(idx<0){
-                    //key is "eventtype", delete also all functions stored in "eventType.namespace", if any
-                    keyPlusDot = key+'.';
-                    for(var k in listenersMap){
-                        if(listenersMap.hasOwnProperty(k) && k.indexOf(keyPlusDot)==0 && k.length > keyPlusDot.length){
-                            delete listenersMap[k];
-                        }
-                    }
-                }
-                delete listenersMap[key];
-            }
-        }else{
-            for(key in listenersMap){
-                if(listenersMap.hasOwnProperty(key)){
-                    delete listenersMap[key];
-                }
-            }
-        }
-    },
-    fire : function(key, dataArgument){
-        var listenersMap = this.listenersMap;
-        if(!(listenersMap.hasOwnProperty(key))){
-            return;
-        }
-        if(arguments.length < 2 || !dataArgument){
-            dataArgument = {};
-        }
-        var callbacks = listenersMap[key];
-        var len = callbacks && callbacks.length ? callbacks.length : 0;
-        for(var i=0; i<len; i++){
-            callbacks[i](dataArgument);
-        }
-    },
-
-    /*
-     *formats (ie returns a string representation of) a time which is in the form seconds,milliseconds (eg 07.6750067)
-     * formatArray is an array of strings which can be:
-     * 'h' hours. Use 'hh' for a zero-padding to 10 (so that 6 hours is rendered as '06')
-     * 'm' hours. Use 'mm' for a zero-padding to 10 (so that 6 minutes is rendered as '06')
-     * 's' hours. Use 'ss' foar a zero-padding to 10 (so that 6 seconds is rendered as '06')
-     * 'D' deciseconds
-     * 'C' centiseconds (it will be padded to 10, so that 5 centiseconds will be rendered as '05')
-     * 'S' milliseconds (it will be padded to 100, so that 5 milliseconds will be rendered as '005')
-     * If formatArray is null or undefined or zero-length, it defaults to ['mm','ss']
-     * 'h','m' and 's' will be prepended the separator ':'. For the others, the prepended separator is '.'
-     * Examples:
-     * makeTimeLabel(607,087)               returns '10:07' (formatArray defaults to ['mm','ss'])
-     * makeTimeLabel(607,087,['m':'s'])     returns '10:7'
-     * makeTimeLabel(607,087,['m':'s','C']) returns '10:7.09'
-     */
-    makeTimeLabel: function(time, formatArray){
-        if(!(formatArray)){
-            formatArray = ['mm','ss'];
-        }
-
-        //marker offset is in float format second.decimalPart
-        var pInt = parseInt;
-        var round = Math.round;
-        var factor = 3600;
-        var hours = pInt(time/factor);
-        time-=hours*factor;
-        factor = 60;
-        var minutes = pInt(time/factor);
-        time-=minutes*factor;
-        var seconds = pInt(time);
-        time-=seconds;
-
-        //here below the function to format a number
-        //ceilAsPowerOfTen is the ceil specifiedas integer indicating the relative power of ten
-        //(0: return the number as it is, 1: format as "0#" and so on)
-        //Examples: format(6) = "6", format(6,1)= "06", format(23,1)= "23"
-
-        //first of all, instantiate the power function once (and not inside the function or function's loop):
-        //note that minimumNumberOfDigits lower to 2 returns integer as it is
-        var mpow = Math.pow; //instantiate mpow once
-        var format = function(integer,minimumNumberOfDigits){
-            var n = ""+integer;
-            var zero = "0"; //instantiating once increases performances???
-            for(var i=1; i< minimumNumberOfDigits; i++){
-                if(integer<mpow(10,i)){
-                    n = zero+n;
-                }
-            }
-            return n;
-        };
-        var ret = [];
-        for(var i =0; i<formatArray.length; i++){
-            var f = formatArray[i];
-            var separator = ":";
-            if(f=='h'){
-                ret[i]=hours;
-            }else if(f=='hh'){
-                ret[i]=format(hours,2);
-            }else if(f=='m'){
-                ret[i]=minutes;
-            }else if(f=='mm'){
-                ret[i]=format(minutes,2);
-            }else if(f=='s'){
-                ret[i]=seconds;
-            }else if(f=='ss'){
-                ret[i]=format(seconds,2);
-            }else if(f=='S'){
-                separator = ".";
-                ret[i]=format(round(time*1000),3);
-            }else if(f=='C'){
-                separator = ".";
-                ret[i]=format(round(time*100),2);
-            }else if(f=='D'){
-                separator = ".";
-                ret[i]= round(time*10);
-            }
-            if(i>0){
-                ret[i] = separator+ret[i];
-            }
-        }
-        return ret.join("");
-    }
-});
-
-/**
- * An Array-like implementation that suits the need of Marker mnanagement
- * Ruler, MarkerMap and MarkerMapDiv implement this class
- */
-Timeside.classes.TimesideArray = Timeside.classes.TimesideClass.extend({
-    init: function(optionalArray){
-        this._super();
-        //here methods that CANNOT be overridden
-        var me= optionalArray ? optionalArray : [];
-        //note that this method written here OVERRIDES the same method written outside init in the children!!!!
-        this.toArray = function(returnACopy){
-            if(returnACopy){
-                var ret = [];
-                for(var i=0; i<me.length; i++){
-                    ret.push(me[i]);
-                }
-                return ret;
-            }
-            return me;
-        };
-        this.length = me.length; //in order to match the javascript array property
-    },
-    //adds at the end of the array. If index is missing the object is appended at the end
-    add : function(object, index){
-        var array = this.toArray();
-        if(arguments.length<2){
-            index = array.length;
-        }
-        array.splice(index,0,object);
-        this.length = array.length; //note that length is a property and must be updated!!!
-        return object;
-    },
-    //removes item at index, returns the removed element
-    remove : function(index){
-        var array = this.toArray();
-        var ret =  array.splice(index,1)[0];
-        this.length = array.length; //note that length is a property and must be updated!!!
-        return ret;
-    },
-    //Iterate over the array, with the same syntax of jQuery.each, ie, executes a function(index,element)
-    //for each element from startIndexInclusive to
-    //endIndexExclusive.
-    //The only required argument is callback:
-    //1) each(callback) iterates over all elements executing callback
-    //2) each(m, callback) iterates over the elements from m executing callback
-    //3) each(m,n,callback) iterates over the elements from m (inclusive) to n-1 (inclusive) executing callback
-
-    //NOTE: writing   each : function(startInclusive, endExclusive, callback) throws an error in chrome, as the last
-    //argument (even if it is a function) is a number. Why?????
-    //Anyway, we write the function arguments as empty
-    each : function(){
-        var startInclusive, endExclusive, callback;
-
-        var arg = arguments;
-        var len = arg.length;
-        var l = this.length;
-        switch(len){
-            case 0:
-                this.debug('TimesideClass.each: each called without arguments!!!');
-                return;
-            case 1:
-                startInclusive = 0;
-                endExclusive = l;
-                break;
-            case 2:
-                if(arg[0] >= l){
-                    return;
-                }
-                startInclusive = arg[0]=== undefined ? 0 : arg[0];
-                endExclusive = l;
-                break;
-            default:
-                startInclusive = arg[0]=== undefined ? 0 : arg[0];
-                endExclusive = arg[1]=== undefined ? l : arg[1];
-        }
-        callback = arg[len-1];
-        if(!(callback instanceof Function)){
-            this.debug('TimesideClass.each: callback NOT a function!!!');
-            return;
-        }
-        var me =this.toArray();
-        for(var i = startInclusive; i<endExclusive; i++){
-            callback(i,me[i]);
-        }
-
-    },
-
-    //clears the array and the events associated to it, ie removes all its elements and calls unbind(). Returns the array of the removed elements
-    clear: function(){
-        this.unbind();
-        var me = this.toArray();
-        var l = me.length;
-        this.length = 0;
-        if(l==0){
-            return [];
-        }
-        return me.splice(0,l);
-    },
-    //moves the element at position from into position to
-    //the element that was at from will be at position to
-    //returns:
-    //-1 if from or to not integers, or from or to not within the array bounds (lower than zero or greater or equal to this.length)
-    //from if from === to (no move)
-    //to otherwise (move succesful)
-    move : function(from, to){
-
-        var pInt = parseInt;
-        if(pInt(from)!==from || pInt(to)!==to){ //just a check
-            return -1;
-        }
-        if(from === to){
-            return from;
-        }
-        var me =this.toArray();
-        var len = me.length;
-        if((from<0 || from>=len)||(to<0 || to>=len)){
-            return -1;
-        }
-        var elm = me.splice(from,1)[0];
-        me.splice(to,0,elm);
-
-        return to;
-    }
-});
-
-
-
-/**
- *Main Timeside method to load player (see Timeside online doc)
- */
-
-Timeside.load =function(config){
-
-    var $J = jQuery;
-    var win = window;
-    var doc = document;
-    //function to be called onready or onerror:
-    var loadAll = function() {
-
-
-        //get the current script path (this file name is timeside.js, or timeside.js?..., or even timeside.js.pagespeed.blah.js)
-        var scripts = $J('script');
-        var thisScriptPath = '';
-        scripts.each(function(i,s){
-            var src = $J(s).attr('src');
-            if(src) {
-                var m = src.match(/^([^?]*\/)timeside.js/);
-                if (m) {
-                    thisScriptPath = m[1];
-                }
-            }
-        });
-
-        var ts = Timeside;
-        var ts_scripts = ts.config.timesideScripts;
-        //detect SVG support and load Raphael in case. Copied from Raphael code v 1.5.2:
-        var svg = (win.SVGAngle || doc.implementation.hasFeature("http://www.w3.org/TR/SVG11/feature#BasicStructure", "1.1"));
-        if(!svg){
-            //add the raphael path. Raphael will be loaded in Timeside.load (see below)
-            ts_scripts.splice(0,0,ts.config.vml.raphaelScript);
-            //populate the vml object with methods to be used in ruler and rulermarker:
-
-            //global private variable:
-            //map to store each class name to the relative dictionary for raphael attr function (VML only)
-            var classToRaphaelAttr = {};
-            //get the raphael attributes for which a conversion css -> raphael_attribute is possible:
-            var availableAttrs = ts.config.vml.raphaelAttributes;
-            //here below we store  Raphael paper objects. var paper = Raphael(htmlElement) is the raphel method to build
-            //a new paper object. Internally, the method builds a div embedding vmls inside htmlElement, retriavable via the
-            //paper.node property.
-            //However, calling again var paper = Raphael(htmlElement) does not use the already created paper,
-            //but creates a new paper with a new paper.node (div). Too bad. The possibility to wrap existing paper node
-            //into a Raphael paper would be a nice and almost necessary feature, which however is not even
-            //planned to be implemented according to raphael developers (see raphael forums).
-            //In case of markers lines, we want to draw a new marker
-            //on the same raphael paper. Therefore, we store here raphael papers in a map htmlElement -> paper
-            var raphael_papers = {};
-            ts.utils.vml = {
-                getVmlAttr: function(className){
-
-                    if(classToRaphaelAttr.hasOwnProperty(className)){
-                        //if(className in classToRaphaelAttr){
-                        return classToRaphaelAttr[className];
-                    }
-                    var d = document;
-                    var dottedclassName = className.replace(/^\.*/,'.'); //add a dot if not present
-                    var ssheets = d.styleSheets;
-                    var len = ssheets.length-1;
-
-                    var attr = {};
-                    for(var i=0; i<len; i++){
-                        var rules = ssheets[i].rules;
-                        var l = rules.length;
-                        for(var j=0; j <l; j++){
-                            var rule = rules[j];
-
-                            if(rule.selectorText === dottedclassName){
-
-                                var style = rule.style;
-                                for(var k =0; k<availableAttrs.length; k++){
-                                    var val = style[availableAttrs[k]];
-                                    if(val){
-                                        attr[availableAttrs[k]] = val;
-                                    }
-                                }
-                            }
-                        }
-                    }
-                    classToRaphaelAttr[className] = attr;
-                    return attr;
-                },
-
-                Raphael: function(element,w,h){
-                    //pass jQueryElm.get(0) as first argument, in case)
-                    if(raphael_papers[element]){
-                        return raphael_papers[element];
-                    }
-                    var paper = Raphael(element,w,h);
-                    raphael_papers[element] = paper;
-                    //paper canvas is a div with weird dimensions. You can check it by printing paper.canvas.outerHTML in IE.
-                    //We set them to 100% so we dont have clipping regions when resizing (maximizing)
-                    paper.canvas.style.width='100%';
-                    paper.canvas.style.height='100%';
-                    paper.canvas.width='100%';
-                    paper.canvas.height='100%';
-                    //apparently, there is also a clip style declaration made by raphael. The following code trhows an error in IE7:
-                    //paper.canvas.style.clip = 'auto';
-                    //however, even leaving the clip style declaration as it is, it seems to work (the div spans the whole width)
-                    return paper;
-                }
-
-            };
-        }
-
-        ts.player = undefined;
-        if(config.onReady && typeof config.onReady === 'function'){
-            var oR = config.onReady;
-            config.onReady = function(player){
-                ts.player = player;
-                oR(player);
-            };
-        }else{
-            config.onReady = function(player){
-                ts.player = player;
-            };
-        }
-
-        //finally,define the error function
-        ts.utils.loadScripts(thisScriptPath,ts_scripts, function() {
-            new ts.classes.Player(config); //do not assign it to any variable, we do it only onready
-        },config.onError);
-    };
-
-
-
-
-    $J(win).ready(function(){
-        var s = soundManager;
-        //grab the case of soundManager init errors:
-        s.onerror = function() {
-            Timeside.utils.flashFailed = true;
-            //end('SoundManager error. If your browser does not support HTML5, Flash player (version '+soundManager.flashVersion+'+) must be installed.\nIf flash is installed, try to:\n - Reload the page\n - Empty the cache (see browser preferences/options/tools) and reload the page\n - Restart the browser');
-
-            //and load all anyway:
-            loadAll();
-        };
-
-        //if soundmanager is ready, the callback is executed immetiately
-        //onready is executed BEFORE onload, it basically queues several onload events.
-        //It it is executed immetiately if soundmanager has already been loaded
-        s.onready(function(){loadAll();});
-    });
-};
-
-/**
-* Loads scripts asynchronously
-* can take up to four arguments:
-* scriptsOptionalRoot (optional): a string specifying the root (such as '/usr/local/'). IF IT IS A NONEMPTY STRING AND
-*                                 DOES NOT END WITH A SLASH, A SLASH WILL B APPENDED
-* scriptArray: a string array of js script filenames, such as ['script1.js','script2.js']
-* optionalOnOkCallback (optional): callback to be executed when ALL scripts are succesfully loaded
-* optionalOnErrorCallback (optional) a callback receiving a string as argument to be called if some script is not found
-* optionalSynchroLoad (optional): if true scripts are loaded in synchronously, ie each script is loaded only once the
-*                                 previous has been loaded. Otherise (including missing argument) an asynchronous load is performed
-*                                 and the optional onOkCallback is executed once ALL scripts are loaded
-*/
-Timeside.utils.loadScripts = function(scriptsOptionalRoot,scriptArray, optionalOnOkCallback, optionalOnErrorCallback, optionalSynchroLoad){
-    //var optionalRoot='', callback=undefined, loadInSeries=false;
-    if(!optionalOnOkCallback || typeof optionalOnOkCallback !== 'function'){
-        optionalOnOkCallback = function(){};
-    }
-    if(!optionalOnErrorCallback || typeof optionalOnErrorCallback !== 'function'){
-        optionalOnErrorCallback = function(msg){};
-    }
-
-    if(!scriptArray || !scriptArray.length){
-        optionalOnOkCallback();
-        return;
-    }
-    var len = scriptArray.length;
-    var i=0;
-    if(scriptsOptionalRoot){
-        scriptsOptionalRoot = scriptsOptionalRoot.replace(/\/*$/,"/"); //add slash at end if not present
-        for(i =0; i<len; i++){
-            scriptArray[i] = scriptsOptionalRoot+scriptArray[i];
-        }
-    }
-
-    var $J = jQuery;
-    //there is a handy getScript function in jQuery, which however does NOT manage the onError case (script load error)
-    //looking at jQuery doc, getScript is the same as the followig ajax request,
-    //to which we added the error property to manage errors:
-    var loadScript = function(url,onSuccess,onError){
-        $J.ajax({
-            url: url,
-            dataType: 'script',
-            success: onSuccess,
-            error: function(a,b,errorThrown){
-                onError('file "'+url+'" error: '+errorThrown);
-            }
-        });
-    };
-    if(optionalSynchroLoad){
-        var load = function(index){
-            if(index<len){
-                loadScript(scriptArray[index],function(){
-                    load(index+1);
-                }, function(msg){
-                    optionalOnErrorCallback(msg);
-                });
-            }else if(index==len){
-                optionalOnOkCallback();
-            }
-        };
-        load(0);
-    }else{
-        var count=0;
-        var s;
-        for(i=0; i <len; i++){
-            s = scriptArray[i];
-            //this means that onError all scripts will be loaded.
-            //However, if everything works fine, asynchornous load (here) should be faster
-            loadScript(s, function(){
-                count++;
-                if(count===len){
-                    optionalOnOkCallback();
-                }
-            },function(msg){
-                count = len+1; //avoid calling optionalOkOnCallback
-                optionalOnErrorCallback(msg);
-            });
-        }
-    }
-};
diff --git a/timeside/static/timeside/skins/classic/img/forward.png b/timeside/static/timeside/skins/classic/img/forward.png
deleted file mode 100644 (file)
index 86485d0..0000000
Binary files a/timeside/static/timeside/skins/classic/img/forward.png and /dev/null differ
diff --git a/timeside/static/timeside/skins/classic/img/pause.png b/timeside/static/timeside/skins/classic/img/pause.png
deleted file mode 100644 (file)
index d09ad51..0000000
Binary files a/timeside/static/timeside/skins/classic/img/pause.png and /dev/null differ
diff --git a/timeside/static/timeside/skins/classic/img/play.png b/timeside/static/timeside/skins/classic/img/play.png
deleted file mode 100644 (file)
index ccb87e8..0000000
Binary files a/timeside/static/timeside/skins/classic/img/play.png and /dev/null differ
diff --git a/timeside/static/timeside/skins/classic/img/player_controlbg.png b/timeside/static/timeside/skins/classic/img/player_controlbg.png
deleted file mode 100644 (file)
index c2b7f47..0000000
Binary files a/timeside/static/timeside/skins/classic/img/player_controlbg.png and /dev/null differ
diff --git a/timeside/static/timeside/skins/classic/img/rewind.png b/timeside/static/timeside/skins/classic/img/rewind.png
deleted file mode 100644 (file)
index ec45b38..0000000
Binary files a/timeside/static/timeside/skins/classic/img/rewind.png and /dev/null differ
diff --git a/timeside/static/timeside/skins/classic/img/setmarker.png b/timeside/static/timeside/skins/classic/img/setmarker.png
deleted file mode 100644 (file)
index b642e82..0000000
Binary files a/timeside/static/timeside/skins/classic/img/setmarker.png and /dev/null differ
diff --git a/timeside/static/timeside/skins/classic/img/volumeoff.png b/timeside/static/timeside/skins/classic/img/volumeoff.png
deleted file mode 100644 (file)
index 5ae7777..0000000
Binary files a/timeside/static/timeside/skins/classic/img/volumeoff.png and /dev/null differ
diff --git a/timeside/static/timeside/skins/classic/img/volumeon.png b/timeside/static/timeside/skins/classic/img/volumeon.png
deleted file mode 100644 (file)
index 71d83a5..0000000
Binary files a/timeside/static/timeside/skins/classic/img/volumeon.png and /dev/null differ
diff --git a/timeside/static/timeside/skins/classic/img/wait.gif b/timeside/static/timeside/skins/classic/img/wait.gif
deleted file mode 100644 (file)
index 5b33f7e..0000000
Binary files a/timeside/static/timeside/skins/classic/img/wait.gif and /dev/null differ
diff --git a/timeside/static/timeside/skins/classic/style.css b/timeside/static/timeside/skins/classic/style.css
deleted file mode 100644 (file)
index 068b72a..0000000
+++ /dev/null
@@ -1,152 +0,0 @@
-/*
-* Style for the timeside player. The player div is supposed to be of class .ts-player. Change if needed
-* For details, see http://code.google.com/p/timeside/wiki/UiGuide?ts=1308677096&updated=UiGuide#CSS_and_skins
-*/
-
-.ts-player {
-    padding: 0;
-    border: solid 1px #ADADAD;
-    margin-top: 2px;
-}
-
-
-.ts-player .ts-ruler{
-    color: #ADADAD;
-    background-color: #F2F2F2;
-    font-size: 10px;
-    line-height: 13px;
-}
-/*svg style, MUST BE A SINGLE SELECTOR. FOR INSTANCE, THIS DOES NOT WORK WHEN SVG IS NOT SUPPORTED:
-  ".ts-player .ts-ruler .ts-svg-ruler-upper-rect" */
-.ts-svg-ruler-upper-rect{
-    fill:  #FFFFFF;
-    stroke-width:0;
-    stroke: #FFFFFF; /*to be sure...*/
-}
-/*svg style, MUST BE A SINGLE SELECTOR. FOR INSTANCE, THIS DOES NOT WORK WHEN SVG IS NOT SUPPORTED:
-  ".ts-player .ts-ruler .ts-svg-ruler-lines"*/
-.ts-svg-ruler-lines{
-    stroke-width:1;
-    stroke: #ADADAD;
-}
-
-/*wave:*/
-.ts-player .ts-wave {
-    height: 130px;
-}
-
-/*.ts-player .ts-viewer .ts-marker {*/
-.ts-player .ts-ruler .ts-marker {
-     padding: 0 0.5em;
-    background: #fff;
-    border: 1px solid #92bdd4;
-    color: #92bdd4;
-    text-decoration: none;
-}
-/*svg style, MUST BE A SINGLE SELECTOR. FOR INSTANCE, THIS DOES NOT WORK WHEN SVG IS NOT SUPPORTED:
-  ".ts-player .ts-wave .ts-image-canvas .ts-svg-marker-line" */
-.ts-svg-marker-line {
-    fill: #92bdd4;
-    stroke-width:0;
-}
-
-/*.ts-player .ts-viewer a.ts-pointer {*/
-.ts-player .ts-ruler a.ts-pointer {
-    color: white ;
-    background-color: #92bde4;
-    padding: 0 0.5em;
-    /*border: solid 1px #92bde4;*/
-
-    text-decoration: none;
-     -moz-border-radius: .3em;
-    -webkit-border-radius: .3em;
-    border-radius: .3em;
-    /*color: #3c4251; #6A0307 !important;*/
-}
-/*svg style, MUST BE A SINGLE SELECTOR. FOR INSTANCE, THIS DOES NOT WORK WHEN SVG IS NOT SUPPORTED:
-  ".ts-player .ts-wave .ts-image-canvas .ts-svg-pointer-line" */
-.ts-svg-pointer-line {
-    fill: #92bde4;
-    stroke-width:0;
-}
-
-.ts-player .ts-wave .ts-image {
-    background: #090e0d ;
-}
-
-.ts-player .ts-control {
-    background: url('img/player_controlbg.png');
-}
-
- /** display (inline-block) and overflow of a is set inside javascript*/
-.ts-player .ts-control .ts-button {
-    background-repeat: no-repeat;
-    margin:4px;
-    height:21px;
-    width:21px;
-   /* background-position: 0px 0px;*/
-}
-.ts-player .ts-control .ts-button:hover {
-    background-position: 0px -21px;
-}
-.ts-player .ts-control .ts-play {
-    background-image: url('img/play.png');
-}
-
-.ts-player .ts-control  .ts-pause {
-    background-image: url('img/pause.png');
-}
-
-.ts-player .ts-control  .ts-rewind {
-    background-image: url('img/rewind.png');
-}
-
-.ts-player .ts-control  .ts-forward {
-    background-image: url('img/forward.png');
-}
-
-.ts-player .ts-control  .ts-set-marker {
-    background-image: url('img/setmarker.png');
-}
-
-.ts-player .ts-control .ts-volume-speaker-on {
-    background-image: url('img/volumeon.png');
-    width:24px;
-}
-.ts-player .ts-control .ts-volume-speaker-off {
-    background-image: url('img/volumeoff.png');
-    width:24px;
-}
-.ts-player .ts-control .ts-volume-bar-container {
-    /*background: url('img/controlbg-inverted.png');
-    background-position: -3px left;
-    background-repeat: repeat-x;*/
-    border: 1px solid #a3a4a7;
-    height:10px;
-    width:42px;
-    margin-top:9px;
-     -moz-border-radius: 5px;
-    -webkit-border-radius: 5px;
-    border-radius: 5px;
-
-}
-.ts-player .ts-control .ts-volume-bar { /*width will be changed inside the code*/
-    background-color: #ccc;
-     -moz-border-radius: 5px;
-    -webkit-border-radius: 5px;
-    border-radius: 5px;
-}
-/*position is set to absolute inside javascript*/
-.ts-player .ts-control .ts-wait {
-    background-repeat: no-repeat;
-    background-image: url('img/wait.gif');
-    text-align: right;
-    right:0;
-    height:28px;
-    line-height:28px;
-    top:0;
-    background-position: right center;
-    padding-right: 30px;
-    font-size: 80%;
-    color: #000;
-}
diff --git a/timeside/static/timeside/skins/lab/img/controlbg-inverted.png b/timeside/static/timeside/skins/lab/img/controlbg-inverted.png
deleted file mode 100644 (file)
index 338a3e1..0000000
Binary files a/timeside/static/timeside/skins/lab/img/controlbg-inverted.png and /dev/null differ
diff --git a/timeside/static/timeside/skins/lab/img/controlbg.png b/timeside/static/timeside/skins/lab/img/controlbg.png
deleted file mode 100644 (file)
index edaf9fc..0000000
Binary files a/timeside/static/timeside/skins/lab/img/controlbg.png and /dev/null differ
diff --git a/timeside/static/timeside/skins/lab/img/empty.png b/timeside/static/timeside/skins/lab/img/empty.png
deleted file mode 100644 (file)
index 120bea9..0000000
Binary files a/timeside/static/timeside/skins/lab/img/empty.png and /dev/null differ
diff --git a/timeside/static/timeside/skins/lab/img/forward.png b/timeside/static/timeside/skins/lab/img/forward.png
deleted file mode 100644 (file)
index f42a3e0..0000000
Binary files a/timeside/static/timeside/skins/lab/img/forward.png and /dev/null differ
diff --git a/timeside/static/timeside/skins/lab/img/pause.png b/timeside/static/timeside/skins/lab/img/pause.png
deleted file mode 100644 (file)
index ca2fbc4..0000000
Binary files a/timeside/static/timeside/skins/lab/img/pause.png and /dev/null differ
diff --git a/timeside/static/timeside/skins/lab/img/play.png b/timeside/static/timeside/skins/lab/img/play.png
deleted file mode 100644 (file)
index 957e628..0000000
Binary files a/timeside/static/timeside/skins/lab/img/play.png and /dev/null differ
diff --git a/timeside/static/timeside/skins/lab/img/rewind.png b/timeside/static/timeside/skins/lab/img/rewind.png
deleted file mode 100644 (file)
index 4058546..0000000
Binary files a/timeside/static/timeside/skins/lab/img/rewind.png and /dev/null differ
diff --git a/timeside/static/timeside/skins/lab/img/setmarker.png b/timeside/static/timeside/skins/lab/img/setmarker.png
deleted file mode 100644 (file)
index badcce7..0000000
Binary files a/timeside/static/timeside/skins/lab/img/setmarker.png and /dev/null differ
diff --git a/timeside/static/timeside/skins/lab/img/volume.png b/timeside/static/timeside/skins/lab/img/volume.png
deleted file mode 100644 (file)
index d741e55..0000000
Binary files a/timeside/static/timeside/skins/lab/img/volume.png and /dev/null differ
diff --git a/timeside/static/timeside/skins/lab/img/volumeoff.png b/timeside/static/timeside/skins/lab/img/volumeoff.png
deleted file mode 100644 (file)
index dc8cc21..0000000
Binary files a/timeside/static/timeside/skins/lab/img/volumeoff.png and /dev/null differ
diff --git a/timeside/static/timeside/skins/lab/img/volumeon.png b/timeside/static/timeside/skins/lab/img/volumeon.png
deleted file mode 100644 (file)
index 93830f5..0000000
Binary files a/timeside/static/timeside/skins/lab/img/volumeon.png and /dev/null differ
diff --git a/timeside/static/timeside/skins/lab/img/wait.gif b/timeside/static/timeside/skins/lab/img/wait.gif
deleted file mode 100644 (file)
index 155c8a5..0000000
Binary files a/timeside/static/timeside/skins/lab/img/wait.gif and /dev/null differ
diff --git a/timeside/static/timeside/skins/lab/img/wait2.gif b/timeside/static/timeside/skins/lab/img/wait2.gif
deleted file mode 100644 (file)
index f2d7273..0000000
Binary files a/timeside/static/timeside/skins/lab/img/wait2.gif and /dev/null differ
diff --git a/timeside/static/timeside/skins/lab/img/wait3.gif b/timeside/static/timeside/skins/lab/img/wait3.gif
deleted file mode 100644 (file)
index bb2f003..0000000
Binary files a/timeside/static/timeside/skins/lab/img/wait3.gif and /dev/null differ
diff --git a/timeside/static/timeside/skins/lab/style.css b/timeside/static/timeside/skins/lab/style.css
deleted file mode 100644 (file)
index 578b4dc..0000000
+++ /dev/null
@@ -1,146 +0,0 @@
-/*
-* Style for the timeside player. The player div is supposed to be of class .ts-player. Change if needed
-* For details, see http://code.google.com/p/timeside/wiki/UiGuide?ts=1308677096&updated=UiGuide#CSS_and_skins
-*/
-
-.ts-player {
-    padding: 0;
-    border: solid 1px #ADADAD;
-    margin-top: 2px;
-}
-
-
-.ts-player .ts-ruler{
-    color: white;
-    background-color: #2E2E2E;
-    font-size: 10px;
-    line-height: 13px;
-}
-/*svg style, MUST BE A SINGLE SELECTOR. FOR INSTANCE, THIS DOES NOT WORK WHEN SVG IS NOT SUPPORTED:
-  ".ts-player .ts-ruler .ts-svg-ruler-upper-rect" */
-.ts-svg-ruler-upper-rect{
-    fill:  #595959;
-    stroke-width:0;
-    stroke: #595959; /*to be sure...*/
-}
-/*svg style, MUST BE A SINGLE SELECTOR. FOR INSTANCE, THIS DOES NOT WORK WHEN SVG IS NOT SUPPORTED:
-  ".ts-player .ts-ruler .ts-svg-ruler-lines"*/
-.ts-svg-ruler-lines{
-    stroke-width:1;
-    stroke: #ADADAD;
-}
-
-/*wave:*/
-.ts-player .ts-wave {
-    height: 130px;
-}
-
-/*.ts-player .ts-viewer .ts-marker {*/
-.ts-player .ts-ruler .ts-marker {
-     padding: 0 0.5em;
-    background: #e65911;
-    color: #FFF;
-    text-decoration: none;
-}
-/*svg style, MUST BE A SINGLE SELECTOR. FOR INSTANCE, THIS DOES NOT WORK WHEN SVG IS NOT SUPPORTED:
-  ".ts-player .ts-wave .ts-image-canvas .ts-svg-marker-line" */
-.ts-svg-marker-line {
-    fill: #e65911;
-    stroke-width:0;
-}
-
-/*.ts-player .ts-viewer a.ts-pointer {*/
-.ts-player .ts-ruler a.ts-pointer {
-    color: #BB0000;
-    background-color: white;
-    padding: 0 0.5em;
-    border: solid 1px #BB0000;
-
-    text-decoration: none;
-     -moz-border-radius: .3em;
-    -webkit-border-radius: .3em;
-    border-radius: .3em;
-    /*color: #3c4251; #6A0307 !important;*/
-}
-/*svg style, MUST BE A SINGLE SELECTOR. FOR INSTANCE, THIS DOES NOT WORK WHEN SVG IS NOT SUPPORTED:
-  ".ts-player .ts-wave .ts-image-canvas .ts-svg-pointer-line" */
-.ts-svg-pointer-line {
-    fill: #BB0000;
-    stroke-width:0;
-}
-
-.ts-player .ts-wave .ts-image {
-    background: #090e0d ;
-}
-
-.ts-player .ts-control {
-    background: url('img/controlbg.png');
-    font-size: 90%;
-}
-
- /** display (inline-block) and overflow of a is set inside javascript*/
-.ts-player .ts-control .ts-button {
-    background-repeat: no-repeat;
-    height:28px;
-    width:28px;
-}
-.ts-player .ts-control .ts-play {
-    background-image: url('img/play.png');
-}
-
-.ts-player .ts-control  .ts-pause {
-    background-image: url('img/pause.png');
-}
-
-.ts-player .ts-control  .ts-rewind {
-    background-image: url('img/rewind.png');
-}
-
-.ts-player .ts-control  .ts-forward {
-    background-image: url('img/forward.png');
-}
-
-.ts-player .ts-control  .ts-set-marker {
-    background-image: url('img/setmarker.png');
-}
-
-.ts-player .ts-control .ts-volume-speaker-on {
-    background-image: url('img/volumeon.png');
-    width:24px;
-}
-.ts-player .ts-control .ts-volume-speaker-off {
-    background-image: url('img/volumeoff.png');
-    width:24px;
-}
-.ts-player .ts-control .ts-volume-bar-container { 
-    background: url('img/controlbg-inverted.png');
-    background-position: -3px left;
-    background-repeat: repeat-x;
-    height:10px;
-    width:42px;
-    margin-top:9px;
-     -moz-border-radius: 5px;
-    -webkit-border-radius: 5px;
-    border-radius: 5px;
-    
-}
-.ts-player .ts-control .ts-volume-bar { /*width will be changed inside the code*/
-    background-color: #e4eaf1;
-     -moz-border-radius: 5px;
-    -webkit-border-radius: 5px;
-    border-radius: 5px;
-}
-/*position is set to absolute inside javascript*/
-.ts-player .ts-control .ts-wait {
-    background-repeat: no-repeat;
-    background-image: url('img/wait3.gif');
-    text-align: right;
-    right:0;
-    height:28px;
-    line-height:28px;
-    top:0;
-    background-position: right center;
-    padding-right: 60px;
-    font-size: 80%;
-    color:white;
-}
\ No newline at end of file
diff --git a/timeside/static/timeside/swf/soundmanager2.swf b/timeside/static/timeside/swf/soundmanager2.swf
deleted file mode 100644 (file)
index c835734..0000000
Binary files a/timeside/static/timeside/swf/soundmanager2.swf and /dev/null differ
diff --git a/timeside/static/timeside/swf/soundmanager2_debug.swf b/timeside/static/timeside/swf/soundmanager2_debug.swf
deleted file mode 100644 (file)
index 8f7ae84..0000000
Binary files a/timeside/static/timeside/swf/soundmanager2_debug.swf and /dev/null differ
diff --git a/timeside/static/timeside/swf/soundmanager2_flash9.swf b/timeside/static/timeside/swf/soundmanager2_flash9.swf
deleted file mode 100644 (file)
index 3099659..0000000
Binary files a/timeside/static/timeside/swf/soundmanager2_flash9.swf and /dev/null differ
diff --git a/timeside/static/timeside/swf/soundmanager2_flash9_debug.swf b/timeside/static/timeside/swf/soundmanager2_flash9_debug.swf
deleted file mode 100644 (file)
index 4e9bf2f..0000000
Binary files a/timeside/static/timeside/swf/soundmanager2_flash9_debug.swf and /dev/null differ
diff --git a/timeside/static/timeside/swf/soundmanager2_flash_xdomain.zip b/timeside/static/timeside/swf/soundmanager2_flash_xdomain.zip
deleted file mode 100644 (file)
index b745e64..0000000
Binary files a/timeside/static/timeside/swf/soundmanager2_flash_xdomain.zip and /dev/null differ
diff --git a/timeside/templates/timeside/base.html b/timeside/templates/timeside/base.html
deleted file mode 100644 (file)
index 372c79f..0000000
+++ /dev/null
@@ -1,40 +0,0 @@
-<!DOCTYPE html>
-{% load i18n %}
-{% get_current_language as LANGUAGE_CODE %}
-{% get_available_languages as LANGUAGES %}
-<html lang="{{ LANGUAGE_CODE }}" xml:lang="{{ LANGUAGE_CODE }}" {% if LANGUAGE_BIDI %}dir="rtl"{% endif %}>
-
-<head>
-<meta http-equiv="Content-type" content="text/html;charset=UTF-8" />
-<title></title>
-
-{% block stylesheets %}
-{% endblock %}
-
-{% block extra_stylesheets %}{% endblock %}
-
-{% block javascript %}
-    <script src="{{ STATIC_URL }}timeside/js/libs/soundmanager2-nodebug-jsmin.js" type="text/javascript"></script>
-    <script src="{{ STATIC_URL }}timeside/js/timeside.js" type="text/javascript"></script>
-    <script src="{{ STATIC_URL }}telemeta/js/playerLoader.js" type="text/javascript"></script>
-    <script src="{{ STATIC_URL }}telemeta/js/divmarker.js" type="text/javascript"></script>
-{% endblock %}
-
-{% block extra_javascript %}{% endblock %}
-</head>
-
-<body>
-{% block layout %}
-<div id="layout">
-
-{% block content %}
-{% endblock content %}
-
-</div>
-{% endblock layout %}
-
-{% block analytics %}
-{% endblock analytics %}
-
-</body>
-</html>
diff --git a/timeside/templates/timeside/index.html b/timeside/templates/timeside/index.html
deleted file mode 100644 (file)
index 9e67fd7..0000000
+++ /dev/null
@@ -1,12 +0,0 @@
-{% extends "timeside/base.html" %}
-{% load i18n %}
-
-{% block content %}
-
-<ul>
- {% for item in object_list %}
-  <li>{{ item.title }}</li>
- {% endfor %}
-</ul>
-
-{% endblock content %}
diff --git a/timeside/urls.py b/timeside/urls.py
deleted file mode 100644 (file)
index 3f76c35..0000000
+++ /dev/null
@@ -1,25 +0,0 @@
-# -*- coding: utf-8 -*-
-
-from django.conf.urls import patterns, include, url
-from django.contrib import admin
-from rest_framework import routers
-from timeside import views
-
-admin.autodiscover()
-
-api_router = routers.DefaultRouter()
-api_router.register(r'selections', views.SelectionViewSet)
-api_router.register(r'items', views.ItemViewSet)
-api_router.register(r'experiences', views.ExperienceViewSet)
-api_router.register(r'processors', views.ProcessorViewSet)
-api_router.register(r'results', views.ResultViewSet)
-api_router.register(r'presets', views.PresetViewSet)
-api_router.register(r'tasks', views.TaskViewSet)
-api_router.register(r'users', views.UserViewSet)
-
-urlpatterns = patterns('',
-    url(r'^admin/', include(admin.site.urls)),
-    url(r'^api/', include(api_router.urls)),
-    url(r'^$', views.IndexView.as_view(), name="timeside-index"),
-    url(r'^results/(?P<pk>.*)/json/$', views.ResultAnalyzerView.as_view(), name="timeside-result-json"),
-)
diff --git a/timeside/views.py b/timeside/views.py
deleted file mode 100644 (file)
index cc4653d..0000000
+++ /dev/null
@@ -1,82 +0,0 @@
-# -*- coding: utf-8 -*-
-
-from django.views.generic import *
-from django.http import HttpResponse, HttpResponseRedirect
-
-from rest_framework import viewsets
-
-import timeside
-from timeside.models import *
-from timeside.serializers import *
-
-
-class SelectionViewSet(viewsets.ModelViewSet):
-    
-    model = Selection
-    serializer_class = SelectionSerializer
-
-
-class ItemViewSet(viewsets.ModelViewSet):
-    
-    model = Item
-    serializer_class = ItemSerializer
-
-
-class ExperienceViewSet(viewsets.ModelViewSet):
-    
-    model = Experience
-    serializer_class = ExperienceSerializer
-
-
-class ProcessorViewSet(viewsets.ModelViewSet):
-    
-    model = Processor
-    serializer_class = ProcessorSerializer
-
-
-class ResultViewSet(viewsets.ModelViewSet):
-    
-    model = Result
-    serializer_class = ResultSerializer
-
-
-class PresetViewSet(viewsets.ModelViewSet):
-    
-    model = Preset
-    serializer_class = PresetSerializer
-
-
-class TaskViewSet(viewsets.ModelViewSet):
-    
-    model = Task
-    serializer_class = TaskSerializer
-
-
-class UserViewSet(viewsets.ModelViewSet):
-    
-    model = User
-    serializer_class = UserSerializer
-
-
-class IndexView(ListView):
-
-    model = Item
-    template_name='timeside/index.html'
-
-    def get_context_data(self, **kwargs):
-        context = super(IndexView, self).get_context_data(**kwargs)
-        return context
-
-    def dispatch(self, *args, **kwargs):
-        return super(IndexView, self).dispatch(*args, **kwargs)
-
-
-class ResultAnalyzerView(View):
-    
-    model = Result
-
-    def get(self, request, *args, **kwargs):
-        result = Result.objects.get(pk=kwargs['pk'])
-        container = AnalyzerResultContainer()
-        return HttpResponse(container.from_hdf5(result.hdf5.path).to_json(), mimetype='application/json')
-    
\ No newline at end of file