2012-04-11 18:07:19 +02:00
|
|
|
$(document).ready(function () {
|
2012-04-29 19:54:38 +02:00
|
|
|
|
|
|
|
var socket,
|
|
|
|
loc = document.location,
|
|
|
|
port = loc.port == "" ? (loc.protocol == "https:" ? 443 : 80) : loc.port,
|
|
|
|
url = loc.protocol + "//" + loc.hostname + ":" + port + "/",
|
|
|
|
pathComponents = location.pathname.split('/'),
|
2012-04-29 20:12:15 +02:00
|
|
|
// Strip admin/plugins
|
|
|
|
baseURL = pathComponents.slice(0,pathComponents.length-2).join('/') + '/',
|
2012-04-29 19:54:38 +02:00
|
|
|
resource = baseURL.substring(1) + "socket.io";
|
|
|
|
|
|
|
|
//connect
|
2014-11-18 15:08:44 +01:00
|
|
|
var room = url + "pluginfw/installer";
|
|
|
|
socket = io.connect(room, {resource : resource});
|
2012-04-11 18:07:19 +02:00
|
|
|
|
2013-03-25 23:09:03 +01:00
|
|
|
function search(searchTerm, limit) {
|
2013-03-25 17:20:10 +01:00
|
|
|
if(search.searchTerm != searchTerm) {
|
|
|
|
search.offset = 0
|
|
|
|
search.results = []
|
|
|
|
search.end = false
|
|
|
|
}
|
2013-03-25 23:09:03 +01:00
|
|
|
limit = limit? limit : search.limit
|
2013-03-25 17:20:10 +01:00
|
|
|
search.searchTerm = searchTerm;
|
2013-03-25 23:09:03 +01:00
|
|
|
socket.emit("search", {searchTerm: searchTerm, offset:search.offset, limit: limit, sortBy: search.sortBy, sortDir: search.sortDir});
|
|
|
|
search.offset += limit;
|
2013-09-12 16:37:37 +02:00
|
|
|
|
2013-03-26 11:19:36 +01:00
|
|
|
$('#search-progress').show()
|
2013-09-12 16:37:37 +02:00
|
|
|
search.messages.show('fetching')
|
|
|
|
storeScrollPosition()
|
|
|
|
search.searching = true
|
2013-03-25 17:20:10 +01:00
|
|
|
}
|
2013-09-12 16:37:37 +02:00
|
|
|
search.searching = false;
|
2013-03-25 23:09:03 +01:00
|
|
|
search.offset = 0;
|
2013-09-12 16:37:37 +02:00
|
|
|
search.limit = 25;
|
2013-03-25 23:09:03 +01:00
|
|
|
search.results = [];
|
|
|
|
search.sortBy = 'name';
|
|
|
|
search.sortDir = /*DESC?*/true;
|
|
|
|
search.end = true;// have we received all results already?
|
2013-03-26 21:04:21 +01:00
|
|
|
search.messages = {
|
|
|
|
show: function(msg) {
|
2013-09-12 16:37:37 +02:00
|
|
|
//$('.search-results .messages').show()
|
2013-03-26 21:04:21 +01:00
|
|
|
$('.search-results .messages .'+msg+'').show()
|
2013-09-12 16:37:37 +02:00
|
|
|
$('.search-results .messages .'+msg+' *').show()
|
2013-03-26 21:04:21 +01:00
|
|
|
},
|
|
|
|
hide: function(msg) {
|
2013-09-12 16:37:37 +02:00
|
|
|
//$('.search-results .messages').hide()
|
2013-03-26 21:04:21 +01:00
|
|
|
$('.search-results .messages .'+msg+'').hide()
|
2013-09-12 16:37:37 +02:00
|
|
|
$('.search-results .messages .'+msg+' *').hide()
|
2013-03-26 21:04:21 +01:00
|
|
|
}
|
|
|
|
}
|
2013-03-25 17:20:10 +01:00
|
|
|
|
2013-03-26 15:11:30 +01:00
|
|
|
var installed = {
|
|
|
|
progress: {
|
|
|
|
show: function(plugin, msg) {
|
2013-03-26 21:04:21 +01:00
|
|
|
$('.installed-results .'+plugin+' .progress').show()
|
|
|
|
$('.installed-results .'+plugin+' .progress .message').text(msg)
|
2013-03-27 12:20:50 +01:00
|
|
|
if($(window).scrollTop() > $('.'+plugin).offset().top)$(window).scrollTop($('.'+plugin).offset().top-100)
|
2013-03-26 15:11:30 +01:00
|
|
|
},
|
|
|
|
hide: function(plugin) {
|
2013-03-26 21:04:21 +01:00
|
|
|
$('.installed-results .'+plugin+' .progress').hide()
|
|
|
|
$('.installed-results .'+plugin+' .progress .message').text('')
|
|
|
|
}
|
|
|
|
},
|
|
|
|
messages: {
|
|
|
|
show: function(msg) {
|
|
|
|
$('.installed-results .messages').show()
|
|
|
|
$('.installed-results .messages .'+msg+'').show()
|
|
|
|
},
|
|
|
|
hide: function(msg) {
|
|
|
|
$('.installed-results .messages').hide()
|
|
|
|
$('.installed-results .messages .'+msg+'').hide()
|
2013-03-26 15:11:30 +01:00
|
|
|
}
|
|
|
|
},
|
|
|
|
list: []
|
|
|
|
}
|
|
|
|
|
2013-03-25 17:20:10 +01:00
|
|
|
function displayPluginList(plugins, container, template) {
|
|
|
|
plugins.forEach(function(plugin) {
|
|
|
|
var row = template.clone();
|
|
|
|
|
|
|
|
for (attr in plugin) {
|
|
|
|
if(attr == "name"){ // Hack to rewrite URLS into name
|
2013-03-27 12:28:54 +01:00
|
|
|
row.find(".name").html("<a target='_blank' title='Plugin details' href='https://npmjs.org/package/"+plugin['name']+"'>"+plugin['name'].substr(3)+"</a>"); // remove 'ep_'
|
2013-03-25 17:20:10 +01:00
|
|
|
}else{
|
2014-02-17 17:40:30 +01:00
|
|
|
row.find("." + attr).text(plugin[attr]);
|
2013-03-25 17:20:10 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
row.find(".version").html( plugin.version );
|
2013-03-26 15:11:30 +01:00
|
|
|
row.addClass(plugin.name)
|
2013-03-26 18:39:46 +01:00
|
|
|
row.data('plugin', plugin.name)
|
2013-03-25 17:20:10 +01:00
|
|
|
container.append(row);
|
|
|
|
})
|
|
|
|
updateHandlers();
|
2012-04-18 13:43:34 +02:00
|
|
|
}
|
2013-03-25 23:09:03 +01:00
|
|
|
|
|
|
|
function sortPluginList(plugins, property, /*ASC?*/dir) {
|
|
|
|
return plugins.sort(function(a, b) {
|
|
|
|
if (a[property] < b[property])
|
|
|
|
return dir? -1 : 1;
|
|
|
|
if (a[property] > b[property])
|
|
|
|
return dir? 1 : -1;
|
|
|
|
// a must be equal to b
|
|
|
|
return 0;
|
|
|
|
})
|
|
|
|
}
|
2012-04-18 13:43:34 +02:00
|
|
|
|
2013-03-26 19:32:15 +01:00
|
|
|
// Infinite scroll
|
2013-09-12 16:37:37 +02:00
|
|
|
var scrollPosition
|
|
|
|
function storeScrollPosition() {
|
|
|
|
scrollPosition = $(window).scrollTop()
|
|
|
|
}
|
|
|
|
function restoreScrollPosition() {
|
|
|
|
setTimeout(function() {
|
|
|
|
$(window).scrollTop(scrollPosition)
|
|
|
|
}, 0)
|
|
|
|
}
|
|
|
|
|
2013-03-26 19:32:15 +01:00
|
|
|
$(window).scroll(checkInfiniteScroll)
|
|
|
|
function checkInfiniteScroll() {
|
2013-09-12 16:37:37 +02:00
|
|
|
if(search.end || search.searching) return;// don't keep requesting if there are no more results
|
|
|
|
setTimeout(function() {
|
|
|
|
try{
|
|
|
|
var top = $('.results>tr:last').offset().top
|
|
|
|
if($(window).scrollTop()+$(window).height() > top) search(search.searchTerm)
|
|
|
|
}catch(e){}
|
|
|
|
}, 1)
|
2013-03-26 19:32:15 +01:00
|
|
|
}
|
|
|
|
|
2012-04-11 18:07:19 +02:00
|
|
|
function updateHandlers() {
|
2013-03-25 17:20:10 +01:00
|
|
|
// Search
|
2013-01-24 22:39:52 +01:00
|
|
|
$("#search-query").unbind('keyup').keyup(function () {
|
2013-03-25 17:20:10 +01:00
|
|
|
search($("#search-query").val());
|
2012-04-11 18:07:19 +02:00
|
|
|
});
|
2015-01-18 12:15:41 +01:00
|
|
|
|
|
|
|
// Prevent form submit
|
|
|
|
$('#search-query').parent().bind('submit', function() {
|
|
|
|
return false;
|
|
|
|
});
|
2012-04-11 18:07:19 +02:00
|
|
|
|
2013-03-25 17:20:10 +01:00
|
|
|
// update & install
|
2013-01-26 22:15:19 +01:00
|
|
|
$(".do-install, .do-update").unbind('click').click(function (e) {
|
2013-03-26 11:58:31 +01:00
|
|
|
var $row = $(e.target).closest("tr")
|
2013-03-26 18:39:46 +01:00
|
|
|
, plugin = $row.data('plugin');
|
2013-03-27 12:02:19 +01:00
|
|
|
if($(this).hasClass('do-install')) {
|
|
|
|
$row.remove().appendTo('#installed-plugins')
|
|
|
|
installed.progress.show(plugin, 'Installing')
|
|
|
|
}else{
|
|
|
|
installed.progress.show(plugin, 'Updating')
|
|
|
|
}
|
2013-03-26 11:19:36 +01:00
|
|
|
socket.emit("install", plugin);
|
2013-03-26 21:04:21 +01:00
|
|
|
installed.messages.hide("nothing-installed")
|
2012-04-11 18:07:19 +02:00
|
|
|
});
|
|
|
|
|
2013-03-25 17:20:10 +01:00
|
|
|
// uninstall
|
2012-04-11 18:07:19 +02:00
|
|
|
$(".do-uninstall").unbind('click').click(function (e) {
|
2013-03-26 11:58:31 +01:00
|
|
|
var $row = $(e.target).closest("tr")
|
2013-03-26 18:39:46 +01:00
|
|
|
, pluginName = $row.data('plugin');
|
2013-03-26 15:11:30 +01:00
|
|
|
socket.emit("uninstall", pluginName);
|
|
|
|
installed.progress.show(pluginName, 'Uninstalling')
|
|
|
|
installed.list = installed.list.filter(function(plugin) {
|
|
|
|
return plugin.name != pluginName
|
|
|
|
})
|
2012-04-11 18:07:19 +02:00
|
|
|
});
|
2012-04-18 13:43:34 +02:00
|
|
|
|
2013-03-25 23:09:03 +01:00
|
|
|
// Sort
|
|
|
|
$('.sort.up').unbind('click').click(function() {
|
|
|
|
search.sortBy = $(this).text().toLowerCase();
|
|
|
|
search.sortDir = false;
|
|
|
|
search.offset = 0;
|
|
|
|
search(search.searchTerm, search.results.length);
|
2013-03-26 11:38:51 +01:00
|
|
|
search.results = [];
|
2013-03-25 23:09:03 +01:00
|
|
|
})
|
|
|
|
$('.sort.down, .sort.none').unbind('click').click(function() {
|
|
|
|
search.sortBy = $(this).text().toLowerCase();
|
|
|
|
search.sortDir = true;
|
|
|
|
search.offset = 0;
|
2013-03-26 11:38:51 +01:00
|
|
|
search(search.searchTerm, search.results.length);
|
2013-03-25 23:09:03 +01:00
|
|
|
search.results = [];
|
|
|
|
})
|
2012-04-11 18:07:19 +02:00
|
|
|
}
|
|
|
|
|
2013-03-25 17:20:10 +01:00
|
|
|
socket.on('results:search', function (data) {
|
|
|
|
if(!data.results.length) search.end = true;
|
2015-01-18 13:56:30 +01:00
|
|
|
if(data.query.offset == 0) search.results = [];
|
2013-03-26 21:04:21 +01:00
|
|
|
search.messages.hide('nothing-found')
|
|
|
|
search.messages.hide('fetching')
|
2013-03-26 19:22:04 +01:00
|
|
|
$("#search-query").removeAttr('disabled')
|
2013-01-24 22:39:52 +01:00
|
|
|
|
2013-03-25 23:09:03 +01:00
|
|
|
console.log('got search results', data)
|
|
|
|
|
|
|
|
// add to results
|
|
|
|
search.results = search.results.concat(data.results);
|
|
|
|
|
|
|
|
// Update sorting head
|
|
|
|
$('.sort')
|
|
|
|
.removeClass('up down')
|
|
|
|
.addClass('none');
|
|
|
|
$('.search-results thead th[data-label='+data.query.sortBy+']')
|
|
|
|
.removeClass('none')
|
|
|
|
.addClass(data.query.sortDir? 'up' : 'down');
|
|
|
|
|
|
|
|
// re-render search results
|
2013-03-25 17:20:10 +01:00
|
|
|
var searchWidget = $(".search-results");
|
|
|
|
searchWidget.find(".results *").remove();
|
2013-03-26 16:23:47 +01:00
|
|
|
if(search.results.length > 0) {
|
|
|
|
displayPluginList(search.results, searchWidget.find(".results"), searchWidget.find(".template tr"))
|
|
|
|
}else {
|
2013-03-26 21:04:21 +01:00
|
|
|
search.messages.show('nothing-found')
|
2013-03-26 16:23:47 +01:00
|
|
|
}
|
2013-09-12 16:37:37 +02:00
|
|
|
search.messages.hide('fetching')
|
2013-03-26 11:19:36 +01:00
|
|
|
$('#search-progress').hide()
|
2013-09-12 16:37:37 +02:00
|
|
|
restoreScrollPosition()
|
2013-03-26 19:32:15 +01:00
|
|
|
checkInfiniteScroll()
|
2013-09-12 16:37:37 +02:00
|
|
|
search.searching = false
|
2012-04-11 18:07:19 +02:00
|
|
|
});
|
|
|
|
|
2013-03-25 17:20:10 +01:00
|
|
|
socket.on('results:installed', function (data) {
|
2013-03-26 21:04:21 +01:00
|
|
|
installed.messages.hide("fetching")
|
|
|
|
installed.messages.hide("nothing-installed")
|
2013-03-26 16:23:47 +01:00
|
|
|
|
2013-03-26 15:11:30 +01:00
|
|
|
installed.list = data.installed
|
|
|
|
sortPluginList(installed.list, 'name', /*ASC?*/true);
|
2013-03-25 23:09:03 +01:00
|
|
|
|
2013-03-26 15:11:30 +01:00
|
|
|
// filter out epl
|
|
|
|
installed.list = installed.list.filter(function(plugin) {
|
2013-03-25 23:52:10 +01:00
|
|
|
return plugin.name != 'ep_etherpad-lite'
|
|
|
|
})
|
2013-01-26 22:15:19 +01:00
|
|
|
|
2013-03-26 16:23:47 +01:00
|
|
|
// remove all installed plugins (leave plugins that are still being installed)
|
2013-03-26 15:11:30 +01:00
|
|
|
installed.list.forEach(function(plugin) {
|
|
|
|
$('#installed-plugins .'+plugin.name).remove()
|
|
|
|
})
|
2013-03-26 16:23:47 +01:00
|
|
|
|
|
|
|
if(installed.list.length > 0) {
|
|
|
|
displayPluginList(installed.list, $("#installed-plugins"), $("#installed-plugin-template"));
|
2013-03-27 12:02:19 +01:00
|
|
|
socket.emit('checkUpdates');
|
2013-03-26 16:23:47 +01:00
|
|
|
}else {
|
2013-03-26 21:04:21 +01:00
|
|
|
installed.messages.show("nothing-installed")
|
2013-03-26 16:23:47 +01:00
|
|
|
}
|
2012-04-11 18:07:19 +02:00
|
|
|
});
|
2013-01-26 22:15:19 +01:00
|
|
|
|
2013-03-25 17:20:10 +01:00
|
|
|
socket.on('results:updatable', function(data) {
|
2013-03-27 12:02:19 +01:00
|
|
|
data.updatable.forEach(function(pluginName) {
|
|
|
|
var $row = $('#installed-plugins > tr.'+pluginName)
|
|
|
|
, actions = $row.find('.actions')
|
|
|
|
actions.append('<input class="do-update" type="button" value="Update" />')
|
2013-01-26 22:15:19 +01:00
|
|
|
})
|
|
|
|
updateHandlers();
|
|
|
|
})
|
2012-04-11 18:07:19 +02:00
|
|
|
|
2013-03-26 11:19:36 +01:00
|
|
|
socket.on('finished:install', function(data) {
|
2013-03-26 15:11:30 +01:00
|
|
|
if(data.error) {
|
|
|
|
alert('An error occured while installing '+data.plugin+' \n'+data.error)
|
|
|
|
$('#installed-plugins .'+data.plugin).remove()
|
|
|
|
}
|
|
|
|
|
2013-03-26 11:19:36 +01:00
|
|
|
socket.emit("getInstalled");
|
2013-03-26 11:58:31 +01:00
|
|
|
|
|
|
|
// update search results
|
|
|
|
search.offset = 0;
|
|
|
|
search(search.searchTerm, search.results.length);
|
|
|
|
search.results = [];
|
2013-03-26 11:19:36 +01:00
|
|
|
})
|
|
|
|
|
|
|
|
socket.on('finished:uninstall', function(data) {
|
2013-03-26 15:11:30 +01:00
|
|
|
if(data.error) alert('An error occured while uninstalling the '+data.plugin+' \n'+data.error)
|
|
|
|
|
|
|
|
// remove plugin from installed list
|
|
|
|
$('#installed-plugins .'+data.plugin).remove()
|
2013-03-26 11:58:31 +01:00
|
|
|
|
2013-03-26 15:11:30 +01:00
|
|
|
socket.emit("getInstalled");
|
|
|
|
|
2013-03-26 11:58:31 +01:00
|
|
|
// update search results
|
|
|
|
search.offset = 0;
|
|
|
|
search(search.searchTerm, search.results.length);
|
|
|
|
search.results = [];
|
2013-03-26 11:19:36 +01:00
|
|
|
})
|
|
|
|
|
2013-03-25 17:20:10 +01:00
|
|
|
// init
|
|
|
|
updateHandlers();
|
|
|
|
socket.emit("getInstalled");
|
|
|
|
search('');
|
2013-03-26 15:11:30 +01:00
|
|
|
|
2013-03-27 12:02:19 +01:00
|
|
|
// check for updates every 5mins
|
2013-03-26 15:11:30 +01:00
|
|
|
setInterval(function() {
|
|
|
|
socket.emit('checkUpdates');
|
2013-03-27 12:02:19 +01:00
|
|
|
}, 1000*60*5)
|
2012-04-11 18:07:19 +02:00
|
|
|
});
|