|
|
|
define([
|
|
|
|
'/customize/DecorateToolbar.js',
|
|
|
|
'/common/cryptpad-common.js',
|
|
|
|
'/bower_components/lil-uri/uri.min.js',
|
|
|
|
'/bower_components/jquery/dist/jquery.min.js',
|
|
|
|
], function (DecorateToolbar, Cryptpad, LilUri) {
|
|
|
|
var $ = window.$;
|
|
|
|
DecorateToolbar.main($('#bottom-bar'));
|
|
|
|
Cryptpad.styleAlerts();
|
|
|
|
|
|
|
|
var $table = $('table.scroll');
|
|
|
|
var $tbody = $table.find('tbody');
|
|
|
|
var $tryit = $('#tryit');
|
|
|
|
var now = new Date();
|
|
|
|
var hasRecent = false;
|
|
|
|
|
|
|
|
var memorySpan = Cryptpad.timeframe; // thirty days
|
|
|
|
|
|
|
|
var forgetPad = Cryptpad.forgetPad;
|
|
|
|
|
|
|
|
var padTypes = {
|
|
|
|
'/pad/': 'Pad',
|
|
|
|
'/code/': 'Code'
|
|
|
|
};
|
|
|
|
|
|
|
|
var truncateTitle = function (title, len) {
|
|
|
|
if (typeof(title) === 'string' && title.length > len) {
|
|
|
|
return title.slice(0, len) + '…';
|
|
|
|
}
|
|
|
|
return title;
|
|
|
|
};
|
|
|
|
|
|
|
|
var recentPads = Cryptpad.getRecentPads();
|
|
|
|
recentPads.sort(Cryptpad.mostRecent);
|
|
|
|
|
|
|
|
var fixHTML = function (html) {
|
|
|
|
return html.replace(/</g, '<');
|
|
|
|
};
|
|
|
|
|
|
|
|
var makeRecentPadsTable = function () {
|
|
|
|
if (!recentPads.length) { return; }
|
|
|
|
recentPads.some(function (pad, index) {
|
|
|
|
if (!pad) { return; }
|
|
|
|
|
|
|
|
//console.log(pad);
|
|
|
|
|
|
|
|
// don't link to old pads
|
|
|
|
if (now.getTime() - new Date(pad.atime).getTime() > memorySpan) { return true; }
|
|
|
|
|
|
|
|
hasRecent = true;
|
|
|
|
|
|
|
|
// split up the uri
|
|
|
|
var uri = LilUri(pad.href);
|
|
|
|
|
|
|
|
// derive the name
|
|
|
|
var name = padTypes[uri.path()];
|
|
|
|
|
|
|
|
var title = pad.title || uri.parts.hash.slice(0,8);
|
|
|
|
var shortTitle = truncateTitle(pad.title, 48);
|
|
|
|
|
|
|
|
var date = new Date(pad.atime).toLocaleDateString();
|
|
|
|
var created = new Date(pad.ctime).toLocaleDateString();
|
|
|
|
|
|
|
|
if (date === now.toLocaleDateString()) {
|
|
|
|
date = new Date(pad.atime).toLocaleTimeString().replace(/ /g, '');
|
|
|
|
}
|
|
|
|
|
|
|
|
var id = 'pad-'+index;
|
|
|
|
|
|
|
|
var $row = $('<tr>', {
|
|
|
|
id: id
|
|
|
|
});
|
|
|
|
|
|
|
|
var $remove = $('<td>', {
|
|
|
|
'class': 'remove',
|
|
|
|
title: "forget '"+shortTitle + "'"
|
|
|
|
}).text('✖').click(function () {
|
|
|
|
Cryptpad.confirm(fixHTML("Are you sure you'd like to forget this pad (" + shortTitle + ")?"), function (yes) {
|
|
|
|
if (!yes) { return; }
|
|
|
|
forgetPad(pad.href);
|
|
|
|
$row.fadeOut(750, function () {
|
|
|
|
$row.remove();
|
|
|
|
if (!$table.find('tr').find('td').length) {
|
|
|
|
$table.remove();
|
|
|
|
$tryit.text("Try it out!");
|
|
|
|
}
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
$row
|
|
|
|
.append($('<td>').text(name))
|
|
|
|
.append($('<td>').append($('<a>', {
|
|
|
|
href: pad.href,
|
|
|
|
title: pad.title,
|
|
|
|
}).text(shortTitle)))
|
|
|
|
.append($('<td>').text(created))
|
|
|
|
.append($('<td>').text(date))
|
|
|
|
.append($remove);
|
|
|
|
$tbody.append($row);
|
|
|
|
});
|
|
|
|
};
|
|
|
|
|
|
|
|
if (recentPads.length) {
|
|
|
|
recentPads.sort(Cryptpad.mostRecent);
|
|
|
|
makeRecentPadsTable();
|
|
|
|
}
|
|
|
|
if (hasRecent) {
|
|
|
|
$('table').attr('style', '');
|
|
|
|
$tryit.text('Your Recent pads (stored only in browser)');
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|