2015-05-15 12:58:13 +08:00
|
|
|
var options = {
|
2015-10-22 17:09:55 +08:00
|
|
|
valueNames: ['id', 'text', 'timestamp', 'fromNow', 'time', 'tags', 'pinned'],
|
2015-05-15 12:58:13 +08:00
|
|
|
item: '<li class="col-xs-12 col-sm-6 col-md-6 col-lg-4">\
|
|
|
|
<span class="id" style="display:none;"></span>\
|
|
|
|
<a href="#">\
|
|
|
|
<div class="item">\
|
2015-10-22 17:09:55 +08:00
|
|
|
<div class="ui-history-pin fa fa-thumb-tack fa-fw"></div>\
|
2015-07-02 00:10:20 +08:00
|
|
|
<div class="ui-history-close fa fa-close fa-fw" data-toggle="modal" data-target=".delete-modal"></div>\
|
|
|
|
<div class="content">\
|
|
|
|
<h4 class="text"></h4>\
|
|
|
|
<p>\
|
2015-09-24 11:55:56 +08:00
|
|
|
<i><i class="fa fa-clock-o"></i> visited </i><i class="fromNow"></i>\
|
2015-07-02 00:10:20 +08:00
|
|
|
<br>\
|
|
|
|
<i class="timestamp" style="display:none;"></i>\
|
|
|
|
<i class="time"></i>\
|
|
|
|
</p>\
|
|
|
|
<p class="tags"></p>\
|
|
|
|
</div>\
|
2015-05-15 12:58:13 +08:00
|
|
|
</div>\
|
|
|
|
</a>\
|
|
|
|
</li>'
|
|
|
|
};
|
|
|
|
var historyList = new List('history', options);
|
|
|
|
|
|
|
|
migrateHistoryFromTempCallback = pageInit;
|
|
|
|
loginStateChangeEvent = pageInit;
|
|
|
|
pageInit();
|
|
|
|
|
|
|
|
function pageInit() {
|
|
|
|
checkIfAuth(
|
|
|
|
function (data) {
|
|
|
|
$('.ui-signin').hide();
|
|
|
|
$('.ui-or').hide();
|
|
|
|
$('.ui-welcome').show();
|
2016-05-16 13:47:35 +08:00
|
|
|
if (data.photo) $('.ui-avatar').prop('src', data.photo).show();
|
|
|
|
else $('.ui-avatar').prop('src', '').hide();
|
2015-05-15 12:58:13 +08:00
|
|
|
$('.ui-name').html(data.name);
|
|
|
|
$('.ui-signout').show();
|
|
|
|
$(".ui-history").click();
|
|
|
|
parseServerToHistory(historyList, parseHistoryCallback);
|
|
|
|
},
|
|
|
|
function () {
|
|
|
|
$('.ui-signin').slideDown();
|
|
|
|
$('.ui-or').slideDown();
|
|
|
|
$('.ui-welcome').hide();
|
2016-05-16 13:47:35 +08:00
|
|
|
$('.ui-avatar').prop('src', '').hide();
|
2015-05-15 12:58:13 +08:00
|
|
|
$('.ui-name').html('');
|
|
|
|
$('.ui-signout').hide();
|
|
|
|
parseStorageToHistory(historyList, parseHistoryCallback);
|
|
|
|
}
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2015-05-04 15:53:29 +08:00
|
|
|
$(".masthead-nav li").click(function () {
|
|
|
|
$(this).siblings().removeClass("active");
|
|
|
|
$(this).addClass("active");
|
|
|
|
});
|
|
|
|
|
|
|
|
$(".ui-home").click(function () {
|
|
|
|
$(".section").hide();
|
|
|
|
$("#home").fadeIn();
|
|
|
|
});
|
|
|
|
|
|
|
|
$(".ui-history").click(function () {
|
|
|
|
$(".section").hide();
|
|
|
|
$("#history").fadeIn();
|
|
|
|
});
|
|
|
|
|
|
|
|
$(".ui-releasenotes").click(function () {
|
|
|
|
$(".section").hide();
|
|
|
|
$("#releasenotes").fadeIn();
|
|
|
|
});
|
|
|
|
|
|
|
|
function checkHistoryList() {
|
2015-05-15 12:58:13 +08:00
|
|
|
if ($("#history-list").children().length > 0) {
|
2015-05-04 15:53:29 +08:00
|
|
|
$(".ui-nohistory").hide();
|
2015-05-15 12:58:13 +08:00
|
|
|
$(".ui-import-from-browser").hide();
|
|
|
|
} else if ($("#history-list").children().length == 0) {
|
2015-05-04 15:53:29 +08:00
|
|
|
$(".ui-nohistory").slideDown();
|
2015-05-15 12:58:13 +08:00
|
|
|
getStorageHistory(function (data) {
|
|
|
|
if (data && data.length > 0 && getLoginState() && historyList.items.length == 0) {
|
|
|
|
$(".ui-import-from-browser").slideDown();
|
|
|
|
}
|
|
|
|
});
|
2015-05-04 15:53:29 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2015-05-15 12:58:13 +08:00
|
|
|
function parseHistoryCallback(list, notehistory) {
|
2015-05-04 15:53:29 +08:00
|
|
|
checkHistoryList();
|
2015-10-22 17:09:55 +08:00
|
|
|
//sort by pinned then timestamp
|
|
|
|
list.sort('', {
|
|
|
|
sortFunction: function (a, b) {
|
|
|
|
var notea = a.values();
|
|
|
|
var noteb = b.values();
|
|
|
|
if (notea.pinned && !noteb.pinned) {
|
|
|
|
return -1;
|
|
|
|
} else if (!notea.pinned && noteb.pinned) {
|
|
|
|
return 1;
|
|
|
|
} else {
|
|
|
|
if (notea.timestamp > noteb.timestamp) {
|
|
|
|
return -1;
|
|
|
|
} else if (notea.timestamp < noteb.timestamp) {
|
|
|
|
return 1;
|
|
|
|
} else {
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
});
|
2015-05-15 12:58:13 +08:00
|
|
|
var filtertags = [];
|
|
|
|
$(".item").each(function (key, value) {
|
|
|
|
var a = $(this).closest("a");
|
2015-10-22 17:09:55 +08:00
|
|
|
var pin = $(this).find(".ui-history-pin");
|
2015-05-15 12:58:13 +08:00
|
|
|
var id = a.siblings("span").html();
|
|
|
|
var tagsEl = $(this).find(".tags");
|
|
|
|
var item = historyList.get('id', id);
|
|
|
|
if (item.length > 0 && item[0]) {
|
|
|
|
var values = item[0].values();
|
2015-10-22 17:09:55 +08:00
|
|
|
//parse pinned
|
|
|
|
if (values.pinned) {
|
|
|
|
pin.addClass('active');
|
|
|
|
} else {
|
|
|
|
pin.removeClass('active');
|
|
|
|
}
|
2015-05-15 12:58:13 +08:00
|
|
|
//parse link to element a
|
2016-02-16 20:08:44 -08:00
|
|
|
a.attr('href', serverurl + '/' + values.id);
|
2015-05-15 12:58:13 +08:00
|
|
|
//parse tags
|
|
|
|
if (values.tags) {
|
|
|
|
var tags = values.tags;
|
|
|
|
if (tags.length > 0) {
|
|
|
|
var labels = [];
|
|
|
|
for (var j = 0; j < tags.length; j++) {
|
|
|
|
//push info filtertags if not found
|
|
|
|
var found = false;
|
|
|
|
if (filtertags.indexOf(tags[j]) != -1)
|
|
|
|
found = true;
|
|
|
|
if (!found)
|
|
|
|
filtertags.push(tags[j]);
|
|
|
|
//push into the item label
|
|
|
|
labels.push("<span class='label label-default'>" + tags[j] + "</span>");
|
|
|
|
}
|
|
|
|
tagsEl.html(labels.join(' '));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
});
|
2015-05-04 15:53:29 +08:00
|
|
|
$(".ui-history-close").click(function (e) {
|
|
|
|
e.preventDefault();
|
2015-05-15 12:58:13 +08:00
|
|
|
var id = $(this).closest("a").siblings("span").html();
|
2015-07-02 00:10:20 +08:00
|
|
|
var value = list.get('id', id)[0].values();
|
|
|
|
$('.ui-delete-modal-msg').text('Do you really want to delete below history?');
|
|
|
|
$('.ui-delete-modal-item').html('<i class="fa fa-file-text"></i> ' + value.text + '<br><i class="fa fa-clock-o"></i> ' + value.time);
|
|
|
|
clearHistory = false;
|
|
|
|
deleteId = id;
|
2015-10-22 17:09:55 +08:00
|
|
|
});
|
|
|
|
$(".ui-history-pin").click(function (e) {
|
|
|
|
e.preventDefault();
|
|
|
|
var $this = $(this);
|
|
|
|
var id = $this.closest("a").siblings("span").html();
|
|
|
|
var item = list.get('id', id)[0];
|
|
|
|
var values = item.values();
|
|
|
|
var pinned = values.pinned;
|
|
|
|
if (!values.pinned) {
|
|
|
|
pinned = true;
|
|
|
|
item._values.pinned = true;
|
|
|
|
} else {
|
|
|
|
pinned = false;
|
|
|
|
item._values.pinned = false;
|
|
|
|
}
|
|
|
|
getHistory(function (notehistory) {
|
|
|
|
for(var i = 0; i < notehistory.length; i++) {
|
|
|
|
if (notehistory[i].id == id) {
|
|
|
|
notehistory[i].pinned = pinned;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
saveHistory(notehistory);
|
|
|
|
if (pinned)
|
|
|
|
$this.addClass('active');
|
|
|
|
else
|
|
|
|
$this.removeClass('active');
|
|
|
|
});
|
2015-07-02 00:10:20 +08:00
|
|
|
});
|
|
|
|
buildTagsFilter(filtertags);
|
|
|
|
}
|
|
|
|
|
|
|
|
//auto update item fromNow every minutes
|
|
|
|
setInterval(updateItemFromNow, 60000);
|
|
|
|
|
|
|
|
function updateItemFromNow() {
|
|
|
|
var items = $('.item').toArray();
|
|
|
|
for (var i = 0; i < items.length; i++) {
|
|
|
|
var item = $(items[i]);
|
|
|
|
var timestamp = parseInt(item.find('.timestamp').text());
|
|
|
|
item.find('.fromNow').text(moment(timestamp).fromNow());
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
var clearHistory = false;
|
|
|
|
var deleteId = null;
|
|
|
|
|
|
|
|
function deleteHistory() {
|
|
|
|
if (clearHistory) {
|
|
|
|
saveHistory([]);
|
|
|
|
historyList.clear();
|
|
|
|
checkHistoryList();
|
2015-09-24 11:55:56 +08:00
|
|
|
deleteId = null;
|
2015-07-02 00:10:20 +08:00
|
|
|
} else {
|
|
|
|
if (!deleteId) return;
|
2015-05-04 15:53:29 +08:00
|
|
|
getHistory(function (notehistory) {
|
2015-07-02 00:10:20 +08:00
|
|
|
var newnotehistory = removeHistory(deleteId, notehistory);
|
2015-05-04 15:53:29 +08:00
|
|
|
saveHistory(newnotehistory);
|
2015-09-24 11:55:56 +08:00
|
|
|
historyList.remove('id', deleteId);
|
|
|
|
checkHistoryList();
|
|
|
|
deleteId = null;
|
2015-05-04 15:53:29 +08:00
|
|
|
});
|
2015-07-02 00:10:20 +08:00
|
|
|
}
|
|
|
|
$('.delete-modal').modal('hide');
|
|
|
|
clearHistory = false;
|
2015-05-04 15:53:29 +08:00
|
|
|
}
|
|
|
|
|
2015-07-02 00:10:20 +08:00
|
|
|
$(".ui-delete-modal-confirm").click(function () {
|
|
|
|
deleteHistory();
|
|
|
|
});
|
|
|
|
|
2015-05-15 12:58:13 +08:00
|
|
|
$(".ui-import-from-browser").click(function () {
|
|
|
|
saveStorageHistoryToServer(function () {
|
|
|
|
parseStorageToHistory(historyList, parseHistoryCallback);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
$(".ui-save-history").click(function () {
|
|
|
|
getHistory(function (data) {
|
|
|
|
var history = JSON.stringify(data);
|
|
|
|
var blob = new Blob([history], {
|
|
|
|
type: "application/json;charset=utf-8"
|
|
|
|
});
|
|
|
|
saveAs(blob, 'hackmd_history_' + moment().format('YYYYMMDDHHmmss'));
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
$(".ui-open-history").bind("change", function (e) {
|
|
|
|
var files = e.target.files || e.dataTransfer.files;
|
|
|
|
var file = files[0];
|
|
|
|
var reader = new FileReader();
|
|
|
|
reader.onload = function () {
|
|
|
|
var notehistory = JSON.parse(reader.result);
|
|
|
|
//console.log(notehistory);
|
|
|
|
if (!reader.result) return;
|
|
|
|
getHistory(function (data) {
|
|
|
|
var mergedata = data.concat(notehistory);
|
|
|
|
mergedata = clearDuplicatedHistory(mergedata);
|
|
|
|
saveHistory(mergedata);
|
|
|
|
parseHistory(historyList, parseHistoryCallback);
|
|
|
|
});
|
|
|
|
$(".ui-open-history").replaceWith($(".ui-open-history").val('').clone(true));
|
|
|
|
};
|
|
|
|
reader.readAsText(file);
|
|
|
|
});
|
|
|
|
|
|
|
|
$(".ui-clear-history").click(function () {
|
2015-07-02 00:10:20 +08:00
|
|
|
$('.ui-delete-modal-msg').text('Do you really want to clear all history?');
|
|
|
|
$('.ui-delete-modal-item').html('There is no turning back.');
|
|
|
|
clearHistory = true;
|
|
|
|
deleteId = null;
|
2015-05-15 12:58:13 +08:00
|
|
|
});
|
|
|
|
|
|
|
|
$(".ui-refresh-history").click(function () {
|
|
|
|
resetCheckAuth();
|
|
|
|
historyList.clear();
|
|
|
|
parseHistory(historyList, parseHistoryCallback);
|
|
|
|
});
|
|
|
|
|
|
|
|
$(".ui-logout").click(function () {
|
|
|
|
clearLoginState();
|
2016-03-04 23:11:32 +08:00
|
|
|
location.href = serverurl + '/logout';
|
2015-05-15 12:58:13 +08:00
|
|
|
});
|
|
|
|
|
|
|
|
var filtertags = [];
|
|
|
|
$(".ui-use-tags").select2({
|
|
|
|
placeholder: 'Use tags...',
|
|
|
|
multiple: true,
|
|
|
|
data: function () {
|
|
|
|
return {
|
|
|
|
results: filtertags
|
|
|
|
};
|
2015-05-04 15:53:29 +08:00
|
|
|
}
|
2015-05-15 12:58:13 +08:00
|
|
|
});
|
|
|
|
$('.select2-input').css('width', 'inherit');
|
|
|
|
buildTagsFilter([]);
|
2015-05-04 15:53:29 +08:00
|
|
|
|
2015-05-15 12:58:13 +08:00
|
|
|
function buildTagsFilter(tags) {
|
|
|
|
for (var i = 0; i < tags.length; i++)
|
|
|
|
tags[i] = {
|
|
|
|
id: i,
|
|
|
|
text: tags[i]
|
|
|
|
};
|
|
|
|
filtertags = tags;
|
|
|
|
}
|
|
|
|
$(".ui-use-tags").on('change', function () {
|
|
|
|
var tags = [];
|
|
|
|
var data = $(this).select2('data');
|
|
|
|
for (var i = 0; i < data.length; i++)
|
|
|
|
tags.push(data[i].text);
|
|
|
|
if (tags.length > 0) {
|
|
|
|
historyList.filter(function (item) {
|
|
|
|
var values = item.values();
|
|
|
|
if (!values.tags) return false;
|
|
|
|
var found = false;
|
|
|
|
for (var i = 0; i < tags.length; i++) {
|
|
|
|
if (values.tags.indexOf(tags[i]) != -1) {
|
|
|
|
found = true;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return found;
|
|
|
|
});
|
|
|
|
} else {
|
|
|
|
historyList.filter();
|
|
|
|
}
|
|
|
|
checkHistoryList();
|
|
|
|
});
|
2015-05-04 15:53:29 +08:00
|
|
|
|
2015-05-15 12:58:13 +08:00
|
|
|
$('.search').keyup(function () {
|
|
|
|
checkHistoryList();
|
2016-05-30 12:45:13 +08:00
|
|
|
});
|