preserve file refs on sort (crc32 instead of idx)
This commit is contained in:
		
							parent
							
								
									b4acb24f6a
								
							
						
					
					
						commit
						7aace470c5
					
				| @ -6,22 +6,19 @@ function dbg(msg) { | |||||||
| 	ebi('path').innerHTML = msg; | 	ebi('path').innerHTML = msg; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| makeSortable(ebi('files'), reload_mp); |  | ||||||
| 
 |  | ||||||
| 
 | 
 | ||||||
| // extract songs + add play column
 | // extract songs + add play column
 | ||||||
| function init_mp() { | function MPlayer() { | ||||||
| 	var tracks = []; | 	this.id = new Date().getTime(); | ||||||
| 	var ret = { | 	this.au = null; | ||||||
| 		'au': null, | 	this.au_native = null; | ||||||
| 		'au_native': null, | 	this.au_ogvjs = null; | ||||||
| 		'au_ogvjs': null, | 	this.cover_url = ''; | ||||||
| 		'tracks': tracks, | 	this.tracks = {}; | ||||||
| 		'cover_url': '' | 	this.order = []; | ||||||
| 	}; |  | ||||||
| 	var re_audio = /\.(opus|ogg|m4a|aac|mp3|wav|flac)$/i; |  | ||||||
| 
 | 
 | ||||||
| 	var trs = ebi('files').getElementsByTagName('tbody')[0].getElementsByTagName('tr'); | 	var re_audio = /\.(opus|ogg|m4a|aac|mp3|wav|flac)$/i; | ||||||
|  | 	var trs = document.querySelectorAll('#files tbody tr'); | ||||||
| 	for (var a = 0, aa = trs.length; a < aa; a++) { | 	for (var a = 0, aa = trs.length; a < aa; a++) { | ||||||
| 		var tds = trs[a].getElementsByTagName('td'); | 		var tds = trs[a].getElementsByTagName('td'); | ||||||
| 		var link = tds[1].getElementsByTagName('a'); | 		var link = tds[1].getElementsByTagName('a'); | ||||||
| @ -30,37 +27,48 @@ function init_mp() { | |||||||
| 
 | 
 | ||||||
| 		var m = re_audio.exec(url); | 		var m = re_audio.exec(url); | ||||||
| 		if (m) { | 		if (m) { | ||||||
| 			var ntrack = tracks.length; | 			var tid = link.getAttribute('id'); | ||||||
| 			tracks.push(url); | 			this.order.push(tid); | ||||||
| 
 | 			this.tracks[tid] = url; | ||||||
| 			tds[0].innerHTML = '<a id="trk' + ntrack + '" href="#trk' + ntrack + '" class="play">play</a></td>'; | 			tds[0].innerHTML = '<a id="a' + tid + '" href="#a' + tid + '" class="play">play</a></td>'; | ||||||
|  | 			ebi('a' + tid).onclick = ev_play; | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	for (var a = 0, aa = tracks.length; a < aa; a++) | 	this.vol = sread('vol'); | ||||||
| 		ebi('trk' + a).onclick = ev_play; | 	if (this.vol !== null) | ||||||
| 
 | 		this.vol = parseFloat(this.vol); | ||||||
| 	ret.vol = sread('vol'); |  | ||||||
| 	if (ret.vol !== null) |  | ||||||
| 		ret.vol = parseFloat(ret.vol); |  | ||||||
| 	else | 	else | ||||||
| 		ret.vol = 0.5; | 		this.vol = 0.5; | ||||||
| 
 | 
 | ||||||
| 	ret.expvol = function () { | 	this.expvol = function () { | ||||||
| 		return 0.5 * ret.vol + 0.5 * ret.vol * ret.vol; | 		return 0.5 * this.vol + 0.5 * this.vol * this.vol; | ||||||
| 	}; | 	}; | ||||||
| 
 | 
 | ||||||
| 	ret.setvol = function (vol) { | 	this.setvol = function (vol) { | ||||||
| 		ret.vol = Math.max(Math.min(vol, 1), 0); | 		this.vol = Math.max(Math.min(vol, 1), 0); | ||||||
| 		swrite('vol', vol); | 		swrite('vol', vol); | ||||||
| 
 | 
 | ||||||
| 		if (ret.au) | 		if (this.au) | ||||||
| 			ret.au.volume = ret.expvol(); | 			this.au.volume = this.expvol(); | ||||||
| 	}; | 	}; | ||||||
| 
 | 
 | ||||||
| 	return ret; | 	this.read_order = function () { | ||||||
|  | 		var order = []; | ||||||
|  | 		var links = document.querySelectorAll('#files>tbody>tr>td:nth-child(1)>a'); | ||||||
|  | 		for (var a = 0, aa = links.length; a < aa; a++) { | ||||||
|  | 			var tid = links[a].getAttribute('id'); | ||||||
|  | 			if (tid.indexOf('af-') !== 0) | ||||||
|  | 				continue; | ||||||
|  | 
 | ||||||
|  | 			order.push(tid.slice(1)); | ||||||
| 		} | 		} | ||||||
| var mp = init_mp(); | 		this.order = order; | ||||||
|  | 	}; | ||||||
|  | } | ||||||
|  | addcrc(); | ||||||
|  | var mp = new MPlayer(); | ||||||
|  | makeSortable(ebi('files'), mp.read_order.bind(mp)); | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| // toggle player widget
 | // toggle player widget
 | ||||||
| @ -300,9 +308,9 @@ function song_skip(n) { | |||||||
| 		tid = mp.au.tid; | 		tid = mp.au.tid; | ||||||
| 
 | 
 | ||||||
| 	if (tid !== null) | 	if (tid !== null) | ||||||
| 		play(tid + n); | 		play(mp.order.indexOf(tid) + n); | ||||||
| 	else | 	else | ||||||
| 		play(0); | 		play(mp.order[0]); | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| @ -329,7 +337,6 @@ function song_skip(n) { | |||||||
| 	}; | 	}; | ||||||
| 	ebi('barpos').onclick = function (e) { | 	ebi('barpos').onclick = function (e) { | ||||||
| 		if (!mp.au) { | 		if (!mp.au) { | ||||||
| 			//dbg((new Date()).getTime());
 |  | ||||||
| 			return play(0); | 			return play(0); | ||||||
| 		} | 		} | ||||||
| 
 | 
 | ||||||
| @ -368,7 +375,7 @@ function song_skip(n) { | |||||||
| 				var len = mp.au.duration; | 				var len = mp.au.duration; | ||||||
| 				if (pos > 0 && pos > len - 0.1) { | 				if (pos > 0 && pos > len - 0.1) { | ||||||
| 					last_skip_url = mp.au.src; | 					last_skip_url = mp.au.src; | ||||||
| 					play(mp.au.tid + 1); | 					song_skip(1); | ||||||
| 				} | 				} | ||||||
| 			} | 			} | ||||||
| 		} | 		} | ||||||
| @ -381,7 +388,7 @@ function song_skip(n) { | |||||||
| // event from play button next to a file in the list
 | // event from play button next to a file in the list
 | ||||||
| function ev_play(e) { | function ev_play(e) { | ||||||
| 	ev(e); | 	ev(e); | ||||||
| 	play(parseInt(this.getAttribute('id').substr(3))); | 	play(this.getAttribute('id').slice(1)); | ||||||
| 	return false; | 	return false; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| @ -403,18 +410,24 @@ catch (ex) { } | |||||||
| 
 | 
 | ||||||
| // plays the tid'th audio file on the page
 | // plays the tid'th audio file on the page
 | ||||||
| function play(tid, call_depth) { | function play(tid, call_depth) { | ||||||
| 	if (mp.tracks.length == 0) | 	if (mp.order.length == 0) | ||||||
| 		return alert('no audio found wait what'); | 		return alert('no audio found wait what'); | ||||||
| 
 | 
 | ||||||
| 	while (tid >= mp.tracks.length) | 	var tn = tid; | ||||||
| 		tid -= mp.tracks.length; | 	if ((tn + '').indexOf('f-') === 0) | ||||||
|  | 		tn = mp.order.indexOf(tn); | ||||||
| 
 | 
 | ||||||
| 	while (tid < 0) | 	while (tn >= mp.order.length) | ||||||
| 		tid += mp.tracks.length; | 		tn -= mp.order.length; | ||||||
|  | 
 | ||||||
|  | 	while (tn < 0) | ||||||
|  | 		tn += mp.order.length; | ||||||
|  | 
 | ||||||
|  | 	tid = mp.order[tn]; | ||||||
| 
 | 
 | ||||||
| 	if (mp.au) { | 	if (mp.au) { | ||||||
| 		mp.au.pause(); | 		mp.au.pause(); | ||||||
| 		setclass('trk' + mp.au.tid, 'play'); | 		setclass('a' + mp.au.tid, 'play'); | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	// ogv.js breaks on .play() unless directly user-triggered
 | 	// ogv.js breaks on .play() unless directly user-triggered
 | ||||||
| @ -458,7 +471,7 @@ function play(tid, call_depth) { | |||||||
| 	mp.au.tid = tid; | 	mp.au.tid = tid; | ||||||
| 	mp.au.src = url; | 	mp.au.src = url; | ||||||
| 	mp.au.volume = mp.expvol(); | 	mp.au.volume = mp.expvol(); | ||||||
| 	var oid = 'trk' + tid; | 	var oid = 'a' + tid; | ||||||
| 	setclass(oid, 'play act'); | 	setclass(oid, 'play act'); | ||||||
| 	var trs = ebi('files').getElementsByTagName('tbody')[0].getElementsByTagName('tr'); | 	var trs = ebi('files').getElementsByTagName('tbody')[0].getElementsByTagName('tr'); | ||||||
| 	for (var a = 0, aa = trs.length; a < aa; a++) { | 	for (var a = 0, aa = trs.length; a < aa; a++) { | ||||||
| @ -489,8 +502,8 @@ function play(tid, call_depth) { | |||||||
| 	catch (ex) { | 	catch (ex) { | ||||||
| 		alert('playback failed: ' + ex); | 		alert('playback failed: ' + ex); | ||||||
| 	} | 	} | ||||||
| 	setclass('trk' + mp.au.tid, 'play'); | 	setclass(oid, 'play'); | ||||||
| 	setTimeout('play(' + (mp.au.tid + 1) + ');', 500); | 	setTimeout('song_skip(1));', 500); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| @ -569,8 +582,8 @@ function autoplay_blocked() { | |||||||
| // autoplay linked track
 | // autoplay linked track
 | ||||||
| (function () { | (function () { | ||||||
| 	var v = location.hash; | 	var v = location.hash; | ||||||
| 	if (v && v.length > 4 && v.indexOf('#trk') === 0) | 	if (v && v.length == 12 && v.indexOf('#af-') === 0) | ||||||
| 		play(parseInt(v.substr(4))); | 		play(v.slice(2)); | ||||||
| })(); | })(); | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| @ -1447,6 +1460,14 @@ var mukey = (function () { | |||||||
| })(); | })(); | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|  | function addcrc() { | ||||||
|  | 	var links = document.querySelectorAll('#files>tbody>tr>td:nth-child(2)>a'); | ||||||
|  | 	for (var a = 0, aa = links.length; a < aa; a++) { | ||||||
|  | 		links[a].setAttribute('id', 'f-' + crc32(links[a].textContent)); | ||||||
|  | 	} | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
| (function () { | (function () { | ||||||
| 	function set_tooltip(e) { | 	function set_tooltip(e) { | ||||||
| 		ev(e); | 		ev(e); | ||||||
| @ -1471,13 +1492,12 @@ function reload_mp() { | |||||||
| 		mp.au = null; | 		mp.au = null; | ||||||
| 	} | 	} | ||||||
| 	widget.close(); | 	widget.close(); | ||||||
| 	mp = init_mp(); | 	mp = new MPlayer(); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| function reload_browser(not_mp) { | function reload_browser(not_mp) { | ||||||
| 	filecols.set_style(); | 	filecols.set_style(); | ||||||
| 	makeSortable(ebi('files'), reload_mp); |  | ||||||
| 
 | 
 | ||||||
| 	var parts = get_evpath().split('/'); | 	var parts = get_evpath().split('/'); | ||||||
| 	var rm = document.querySelectorAll('#path>a+a+a'); | 	var rm = document.querySelectorAll('#path>a+a+a'); | ||||||
| @ -1501,8 +1521,11 @@ function reload_browser(not_mp) { | |||||||
| 		oo[a].textContent = hsz; | 		oo[a].textContent = hsz; | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	if (!not_mp) | 	if (!not_mp) { | ||||||
|  | 		addcrc(); | ||||||
| 		reload_mp(); | 		reload_mp(); | ||||||
|  | 		makeSortable(ebi('files'), mp.read_order.bind(mp)); | ||||||
|  | 	} | ||||||
| 
 | 
 | ||||||
| 	if (window['up2k']) | 	if (window['up2k']) | ||||||
| 		up2k.set_fsearch(); | 		up2k.set_fsearch(); | ||||||
|  | |||||||
| @ -91,7 +91,29 @@ function import_js(url, cb) { | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| function sortTable(table, col) { | var crctab = (function () { | ||||||
|  |     var c, tab = []; | ||||||
|  |     for (var n = 0; n < 256; n++) { | ||||||
|  |         c = n; | ||||||
|  |         for (var k = 0; k < 8; k++) { | ||||||
|  |             c = ((c & 1) ? (0xEDB88320 ^ (c >>> 1)) : (c >>> 1)); | ||||||
|  |         } | ||||||
|  |         tab[n] = c; | ||||||
|  |     } | ||||||
|  |     return tab; | ||||||
|  | })(); | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | function crc32(str) { | ||||||
|  |     var crc = 0 ^ (-1); | ||||||
|  |     for (var i = 0; i < str.length; i++) { | ||||||
|  |         crc = (crc >>> 8) ^ crctab[(crc ^ str.charCodeAt(i)) & 0xFF]; | ||||||
|  |     } | ||||||
|  |     return ((crc ^ (-1)) >>> 0).toString(16); | ||||||
|  | }; | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | function sortTable(table, col, cb) { | ||||||
|     var tb = table.tBodies[0], |     var tb = table.tBodies[0], | ||||||
|         th = table.tHead.rows[0].cells, |         th = table.tHead.rows[0].cells, | ||||||
|         tr = Array.prototype.slice.call(tb.rows, 0), |         tr = Array.prototype.slice.call(tb.rows, 0), | ||||||
| @ -148,6 +170,7 @@ function sortTable(table, col) { | |||||||
|         return reverse * (a.localeCompare(b)); |         return reverse * (a.localeCompare(b)); | ||||||
|     }); |     }); | ||||||
|     for (i = 0; i < tr.length; ++i) tb.appendChild(tr[vl[i][1]]); |     for (i = 0; i < tr.length; ++i) tb.appendChild(tr[vl[i][1]]); | ||||||
|  |     if (cb) cb(); | ||||||
| } | } | ||||||
| function makeSortable(table, cb) { | function makeSortable(table, cb) { | ||||||
|     var th = table.tHead, i; |     var th = table.tHead, i; | ||||||
| @ -157,9 +180,7 @@ function makeSortable(table, cb) { | |||||||
|     while (--i >= 0) (function (i) { |     while (--i >= 0) (function (i) { | ||||||
|         th[i].onclick = function (e) { |         th[i].onclick = function (e) { | ||||||
|             ev(e); |             ev(e); | ||||||
|             sortTable(table, i); |             sortTable(table, i, cb); | ||||||
|             if (cb) |  | ||||||
|                 cb(); |  | ||||||
|         }; |         }; | ||||||
|     }(i)); |     }(i)); | ||||||
| } | } | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 ed
						ed