list options via cookieArray

admin

Administrator
Staff member
I have been working on a project that will create a playlist of MP3,wav,midi, or au files and play them through the bgSound.src attribute. The script grabs the file path and filename of the audio file and saves it as the option value in the playlist and also grabs only the filename and uses it as the corresponding text for the option. Everything works great except that I can not figure out how to save the list and reload it. The entire [relevant] code is below - saveThe(playList) and loadThe(playList) are the functions that do not work. Please help!

function Play() {
playList = document.amp.playlist;
for(var i = 0; i < playList.options.length; i++) {
document.all.sound.src = playList.options.value;
}
}

function Stop() {
document.all.sound.src = "";
}

function getCookie (name) {
var dcookie = document.cookie;
var cname = name + "=";
var clen = dcookie.length;
var cbegin = 0;
while (cbegin < clen) {
var vbegin = cbegin + cname.length;
if (dcookie.substring(cbegin, vbegin) == cname) {
var vend = dcookie.indexOf (";", vbegin);
if (vend == -1) vend = clen;
return unescape(dcookie.substring(vbegin, vend));
}
cbegin = dcookie.indexOf(" ", cbegin) + 1;
if (cbegin == 0) break;
}
return null;
}

function setCookie (name, value, expires) {
if (!expires) expires = new Date();
document.cookie = name + "=" + escape (value) +
"; expires=" + expires.toGMTString() + "; path=/";
}

function setCookieArray(name){
this.length = setCookieArray.arguments.length - 1;
for (var i = 0; i < this.length; i++) {
this[i + 1] = setCookieArray.arguments[i + 1]
setCookie (name + i, this[i + 1], expdate);
}
}

function getCookieArray(name){
var i = 0;
while (getCookie(name + i) != null) {
this[i + 1] = getCookie(name + i);
i++; this.length = i;
}
}

var expdate = new Date();
expdate.setTime (expdate.getTime() + (24 * 60 * 60 * 1000 * 365));

function addTitle() {
title = document.Asound.file.value;
title = title.toLowerCase();
tl = title;
char = unescape("%5C");
while(tl.indexOf(char) != -1) {
pos = tl.indexOf(char);
tl = tl.substring(pos + 1, tl.length);
}
document.amp.title.value = tl;
}

var soundFile;
var songName;
var playList;
function move(soundFile,songName) {
soundFile = document.Asound.file.value;
songName = document.amp.title.value;
playList = document.amp.playlist;
var i = 0;
if(soundFile.value != "") {
var no = new Option();
no.value = soundFile;
no.text = document.amp.title.value;
playList.options[playList.options.length] = no;
document.amp.title.value = "";
}
}
function remove(playList) {
playList = document.amp.playlist;
for(var i=0; i<playList.options.length; i++) {
if(playList.options.selected && playList.options != "") {
playList.options.value = "";
playList.options.text = "";
}
}
BumpUp(playList);
}
function BumpUp(playList) {
for(var i = 0; i < playList.options.length; i++) {
if(playList.options.value == "") {
for(var j = i; j < playList.options.length - 1; j++) {
playList.options[j].value = playList.options[j + 1].value;
playList.options[j].text = playList.options[j + 1].text;
}
var ln = i;
break;
}
}
if(ln < playList.options.length) {
playList.options.length -= 1;
BumpUp(playList);
}
}
function Moveup(playList) {
playList = document.amp.playlist;
for(var i = 0; i < playList.options.length; i++) {
if (playList.options.selected && playList.options != ""
&& playList.options != playList.options[0]) {
var tmpval = playList.options.value;
var tmpval2 = playList.options.text;
playList.options.value = playList.options[i - 1].value;
playList.options.text = playList.options[i - 1].text
playList.options[i-1].value = tmpval;
playList.options[i-1].text = tmpval2;
}
}
}
function Movedown(playList) {
playList = document.amp.playlist;
for(var i = 0; i < playList.options.length; i++) {
if (playList.options.selected && playList.options != ""
&& playList.options[i+1] != playList.options[playList.options.length]) {
var tmpval = playList.options.value;
var tmpval2 = playList.options.text;
playList.options.value = playList.options[i+1].value;
playList.options.text = playList.options[i+1].text
playList.options[i+1].value = tmpval;
playList.options[i+1].text = tmpval2;
}
}
}

function saveThe(playList) {
playList = document.amp.playlist;
for(var i = 0; i < playList.options.length; i++) {
newVal = new Array;
newVal = playList.options;
var listArray = new setCookieArray("TheList", // cookie name
newVal);

var listArray = new getCookieArray("TheList");
}
}

function loadThe(playList) {
reSET();
getCookie("TheList");
var i, j;
playList = document.amp.playlist;
listArray = new getCookieArray("TheList");
if (listArray != null) {
for (i = 0; i < listArray.length; i++) {
playList.options[j] = new Option(listArray);
j++;
}
}
}

function reSET() {
listArray = null;
newVal = null;
}

<form name="amp">
<select name="playlist" size="19" class="plst"></select>

<input type="text" name="title" size="35">

<input type="button" value=http://www.webdeveloper.com/forum/archive/index.php/"Add" onclick="move(soundFile,playList)">
<input type="button" value="Remove" onclick="remove(playList)">
<input type="button" value="Up" onclick="Moveup(playList)">
<input type="button" value="Down" onclick="Movedown(playList)">
<input type="button" value="Save" onclick="saveThe(playList)">
<input type="button" value="Play" onclick="Play()">
<input type="button" value="Stop" onclick="Stop()">
<input type="button" value="Load" onclick="loadThe(playList)">
</form>

<form name="Asound">
<input type="file" name="file" onBlur='addTitle()'>
</form>

:confused:
 
Back
Top