1
0
mirror of https://github.com/SuperBFG7/ympd synced 2025-01-10 17:30:35 +00:00

added sammy.js app routing

This commit is contained in:
Andrew Karpow 2013-11-07 13:47:31 +01:00
parent 931e975d4e
commit 9a82b44ea9
4 changed files with 2217 additions and 34 deletions

View File

@ -32,14 +32,14 @@
<span class="icon-bar"></span> <span class="icon-bar"></span>
<span class="icon-bar"></span> <span class="icon-bar"></span>
</button> </button>
<a class="navbar-brand" href="#">ympd</a> <a class="navbar-brand" href="/">ympd</a>
</div> </div>
<div class="collapse navbar-collapse"> <div class="collapse navbar-collapse">
<ul id="nav_links" class="nav navbar-nav"> <ul id="nav_links" class="nav navbar-nav">
<li><a href="#">Playlist</a></li> <li id="nav_playlist"><a href="#">Playlist</a></li>
<li><a href="#browse">Browse database</a></li> <li id="nav_browse"><a href="#/browse/">Browse database</a></li>
<li><a href="#about">About</a></li> <li id="nav_about"><a href="#/about/">About</a></li>
</ul> </ul>
<form class="navbar-form navbar-right" role="search"> <form class="navbar-form navbar-right" role="search">
@ -146,6 +146,7 @@
<script src="js/jquery-1.10.2.min.js"></script> <script src="js/jquery-1.10.2.min.js"></script>
<script src="js/bootstrap.min.js"></script> <script src="js/bootstrap.min.js"></script>
<script src="js/bootstrap-slider.js"></script> <script src="js/bootstrap-slider.js"></script>
<script src="js/sammy.js"></script>
<script src="js/mpd.js"></script> <script src="js/mpd.js"></script>
</body> </body>
</html> </html>

View File

@ -1,34 +1,73 @@
var socket; var socket;
var last_state; var last_state;
var current_app;
$('#volumeslider').slider().on('slide', function(event) { $('#volumeslider').slider().on('slide', function(event) {
socket.send("MPD_API_SET_VOLUME,"+event.value); socket.send("MPD_API_SET_VOLUME,"+event.value);
}); });
$(window).bind('hashchange', function(e) { $('#nav_links > li').on('click', function(e) {
$('#nav_links > li').each(function(value) { //$('#nav_links > li:contains(' + History.getState().title + ')').removeClass('active');
if(window.location.hash === $(this).children().attr('href')) //History.pushState({state:$(this).attr('id')}, $(this).text(), '?' + $(this).attr('id'));
$(this).addClass('active');
else
$(this).removeClass('active');
});
switch(window.location.hash) {
case "#browse":
$('#panel-heading').text("Browse database");
socket.send('MPD_API_GET_BROWSE,/');
break;
case "#about":
$('#panel-heading').text("About");
break;
default:
$('#panel-heading').text("Playlist");
$('#nav_links > li:first-child').addClass('active');
socket.send("MPD_API_GET_PLAYLIST");
}
socket.send("MPD_API_GET_TRACK_INFO");
}); });
var app = $.sammy(function() {
this.before('/', function(e, data) {
socket.send("MPD_API_GET_TRACK_INFO");
});
this.get('#/', function() {
current_app = 'playlist';
$('#salamisandwich').find("tr:gt(0)").remove();
socket.send("MPD_API_GET_PLAYLIST");
$('#panel-heading').text("Playlist");
});
this.get(/\#\/browse\/(.*)/, function() {
current_app = 'browse';
$('#salamisandwich').find("tr:gt(0)").remove();
var path = this.params['splat'];
if(path == '')
path = "/";
socket.send("MPD_API_GET_BROWSE,"+path);
$('#panel-heading').text("Browse database: "+path+"");
});
this.get('#/about', function() {
current_app = 'about';
$('#panel-heading').text("About");
});
this.get("/", function(context) {
context.redirect("#/");
});
});
/*
History.Adapter.bind(window,'statechange',function(){ // Note: We are using statechange instead of popstate
if(!State.data.state) {
//$('#' + State.data).
}
$('#panel-heading').text(State.title);
switch(State.data.state) {
case "nav_browse":
socket.send('MPD_API_GET_BROWSE,/');
break;
case "nav_about":
break;
case "nav_playlist":
default:
}
$(this).addClass('active');
console.log(" Browser State: ");
console.log(State);
socket.send("MPD_API_GET_TRACK_INFO");
});
*/
$(document).ready(function(){ $(document).ready(function(){
webSocketConnect(); webSocketConnect();
}); });
@ -45,7 +84,10 @@ function webSocketConnect() {
try { try {
socket.onopen = function() { socket.onopen = function() {
console.log("Connected"); console.log("Connected");
$(window).trigger( 'hashchange' ); app.run();
/* Push Initial state on first visit */
//$(window).trigger("statechange")
} }
socket.onmessage =function got_packet(msg) { socket.onmessage =function got_packet(msg) {
@ -55,10 +97,11 @@ function webSocketConnect() {
var obj = JSON.parse(msg.data); var obj = JSON.parse(msg.data);
switch (obj.type) { switch (obj.type) {
case "playlist": case "playlist":
if(window.location.hash) //if(state.data.state !== 'nav_playlist')
// break;
if(current_app !== 'playlist')
break; break;
$('#salamisandwich').find("tr:gt(0)").remove();
for (var song in obj.data) { for (var song in obj.data) {
var minutes = Math.floor(obj.data[song].duration / 60); var minutes = Math.floor(obj.data[song].duration / 60);
var seconds = obj.data[song].duration - minutes * 60; var seconds = obj.data[song].duration - minutes * 60;
@ -71,16 +114,18 @@ function webSocketConnect() {
} }
break; break;
case "browse": case "browse":
if(window.location.hash !== '#browse') //if(state.data.state !== 'nav_browse')
// break;
if(current_app !== 'browse')
break; break;
$('#salamisandwich').find("tr:gt(0)").remove(); console.log(app);
for (var item in obj.data) { for (var item in obj.data) {
switch(obj.data[item].type) { switch(obj.data[item].type) {
case "directory": case "directory":
$('#salamisandwich tr:last').after( $('#salamisandwich tr:last').after(
"<tr><td><span class=\"glyphicon glyphicon-folder-open\"></span></td>" + "<tr><td><span class=\"glyphicon glyphicon-folder-open\"></span></td>" +
"<td><a href=\"#browse\">" + obj.data[item].dir +"</a></td>" + "<td><a href=\"#/browse/"+ obj.data[item].dir +"\">" + obj.data[item].dir +"</a></td>" +
"<td></td></tr>"); "<td></td></tr>");
break; break;
case "song": case "song":
@ -89,7 +134,7 @@ function webSocketConnect() {
$('#salamisandwich tr:last').after( $('#salamisandwich tr:last').after(
"<tr><td><span class=\"glyphicon glyphicon-music\"></span></td>" + "<tr><td><span class=\"glyphicon glyphicon-music\"></span></td>" +
"<td><a href=\"#browse\">" + obj.data[item].title +"</a></td>" + "<td><a href=\"#\">" + obj.data[item].title +"</a></td>" +
"<td>"+ minutes + ":" + (seconds < 10 ? '0' : '') + seconds +"</td></tr>"); "<td>"+ minutes + ":" + (seconds < 10 ? '0' : '') + seconds +"</td></tr>");
break; break;
case "playlist": case "playlist":
@ -97,7 +142,8 @@ function webSocketConnect() {
} }
} }
$('#salamisandwich td:eq(1)').click(function(){ $('#salamisandwich td:eq(1)').click(function(){
socket.send('MPD_API_GET_BROWSE,'+$(this).text()); console.log($(this).children().attr("path"));
//socket.send('MPD_API_GET_BROWSE,'+;
}); });
break; break;

2135
htdocs/js/sammy.js Normal file

File diff suppressed because it is too large Load Diff

View File

@ -21,6 +21,7 @@ static const struct serveable whitelist[] = {
{ "/js/mpd.js", "text/javascript" }, { "/js/mpd.js", "text/javascript" },
{ "/js/jquery-1.10.2.min.js", "text/javascript" }, { "/js/jquery-1.10.2.min.js", "text/javascript" },
{ "/js/bootstrap-slider.js", "text/javascript" }, { "/js/bootstrap-slider.js", "text/javascript" },
{ "/js/sammy.js", "text/javascript" },
{ "/fonts/glyphicons-halflings-regular.woff", "application/x-font-woff"}, { "/fonts/glyphicons-halflings-regular.woff", "application/x-font-woff"},
{ "/fonts/glyphicons-halflings-regular.svg", "image/svg+xml"}, { "/fonts/glyphicons-halflings-regular.svg", "image/svg+xml"},