1
0
mirror of https://github.com/owncloud/bookmarks.git synced 2025-01-21 17:52:10 +01:00

394 lines
9.9 KiB
JavaScript
Raw Normal View History

2011-08-15 22:05:07 +02:00
var bookmarks_page = 0;
var bookmarks_loading = false;
2012-08-13 19:58:46 +00:00
var dialog;
2011-08-25 12:55:13 +02:00
var bookmarks_sorting = 'bookmarks_sorting_recent';
var fullTags = [];
$(document).ready(function() {
watchUrlField();
$('#bm_import').change(attachSettingEvent);
$('#add_url').on('keydown keyup change click', watchUrlField);
$('#settingsbtn').on('click keydown', toggleSettings);
$('#bm_export').click(exportBm);
$('#firstrun_setting').click(function(){
if(! $('#bookmark_settings').hasClass('open')){
$('#settingsbtn').click();
}
});
$('.bookmarks_list').scroll(updateOnBottom).empty();
2012-06-28 11:40:42 +02:00
$('#tag_filter input').tagit({
allowSpaces: true,
availableTags: fullTags,
onTagFinishRemoved: filterTagsChanged,
2014-06-12 18:20:16 +02:00
placeholderText: t('bookmarks', 'Filter by tag')
2012-06-28 11:40:42 +02:00
}).tagit('option', 'onTagAdded', filterTagsChanged);
2011-08-15 22:05:07 +02:00
getBookmarks();
});
2012-07-31 20:48:11 +00:00
var formatString = (function() {
var replacer = function(context) {
return function(s, name) {
return context[name];
};
};
return function(input, context) {
return input.replace(/\{(\w+)\}/g, replacer(context));
};
})();
function watchClickInSetting(e){
if($('#bookmark_settings').find($(e.target)).length == 0){
toggleSettings();
}
}
function checkURL(url) {
if(url.substring(0, 3) === "htt") {
return url;
}
return "http://"+url;
}
function toggleSettings() {
if( $('#bookmark_settings').hasClass('open')) { //Close
$('#bookmark_settings').switchClass( "open", "" );
$('body').unbind('click', watchClickInSetting);
}
else {
$('#bookmark_settings').switchClass( "", "open");
$('body').bind('click',watchClickInSetting);
}
}
2012-06-29 14:12:29 +02:00
function addFilterTag(event) {
event.preventDefault();
$('#tag_filter input').tagit('createTag', $(this).text());
2012-06-28 11:40:42 +02:00
}
2012-06-27 22:43:11 +00:00
function updateTagsList(tag) {
html = tmpl("tag_tmpl", tag);
$('.tag_list').append(html);
2012-06-27 22:43:11 +00:00
}
2012-06-28 11:40:42 +02:00
function filterTagsChanged()
{
$('#bookmarkFilterTag').val($('#tag_filter input:hidden').val());
$('.bookmarks_list').empty();
bookmarks_page = 0;
2012-06-28 11:40:42 +02:00
getBookmarks();
}
2011-08-15 22:05:07 +02:00
function getBookmarks() {
if(bookmarks_loading) {
//have patience :)
return;
}
bookmarks_loading = true;
//Update Rel Tags if first page
if(bookmarks_page == 0) {
$.ajax({
type: 'GET',
2012-10-29 20:17:17 +00:00
url: OC.filePath('bookmarks', 'ajax', 'updateList.php'),
data: { type:'rel_tags', tag: $('#bookmarkFilterTag').val(), page:bookmarks_page, sort:bookmarks_sorting },
success: function(tags){
$('.tag_list').empty();
for(var i in tags.data) {
updateTagsList(tags.data[i]);
}
$('.tag_list .tag_edit').click(renameTag);
$('.tag_list .tag_delete').click(deleteTag);
$('.tag_list a.tag').click(addFilterTag);
}
});
}
2011-08-15 22:05:07 +02:00
$.ajax({
type: 'GET',
2012-10-29 20:17:17 +00:00
url: OC.filePath('bookmarks', 'ajax', 'updateList.php'),
data: { type:'bookmark', tag: $('#bookmarkFilterTag').val(), page:bookmarks_page, sort:bookmarks_sorting },
2011-08-15 22:05:07 +02:00
success: function(bookmarks){
if (bookmarks.data.length) {
bookmarks_page += 1;
}
2011-08-15 22:05:07 +02:00
$('.bookmark_link').unbind('click', recordClick);
$('.bookmark_delete').unbind('click', delBookmark);
2012-06-29 14:12:29 +02:00
$('.bookmark_edit').unbind('click', editBookmark);
2011-08-15 22:05:07 +02:00
for(var i in bookmarks.data) {
updateBookmarksList(bookmarks.data[i]);
}
checkEmpty();
2011-08-15 22:05:07 +02:00
$('.bookmark_link').click(recordClick);
$('.bookmark_delete').click(delBookmark);
2012-06-29 14:12:29 +02:00
$('.bookmark_edit').click(editBookmark);
2011-08-15 22:05:07 +02:00
bookmarks_loading = false;
if (bookmarks.data.length) {
updateOnBottom()
}
2011-08-15 22:05:07 +02:00
}
});
2011-08-15 22:05:07 +02:00
}
2011-09-13 15:38:11 +04:30
2012-06-29 14:12:29 +02:00
function createEditDialog(record){
2012-08-13 20:32:52 +00:00
var oc_dialog= $('#edit_dialog form').clone().dialog({
width : 620,
height: 350,
2014-06-12 18:20:16 +02:00
title: t('bookmarks', 'Edit bookmark'),
modal: true,
close : function(event, ui) {
$(this).dialog('destroy').remove();
}
});
$('.ui-dialog').bookmark_dialog({
2012-06-29 14:12:29 +02:00
on_success: function(){
2012-08-13 20:32:52 +00:00
oc_dialog.dialog('destroy').remove();
filterTagsChanged();
2012-06-29 14:12:29 +02:00
},
record: record
});
2012-06-29 14:12:29 +02:00
}
function watchUrlField(){
var form = $('#add_form');
var el = $('#add_url');
var button = $('#bookmark_add_submit');
form.unbind('submit');
if(! acceptUrl(el.val()) ) {
form.bind('submit',function(e){e.preventDefault()});
button.addClass('disabled');
}
else{
button.removeClass('disabled');
form.bind('submit',addBookmark);
}
}
function acceptUrl(url) {
return url.replace(/^\s+/g,'').replace(/\s+$/g,'') != '';
}
2012-06-29 14:12:29 +02:00
function addBookmark(event) {
event.preventDefault();
2012-08-13 19:58:46 +00:00
url = $('#add_url').val();
//If trim is empty
if(! acceptUrl(url) ) {
return;
}
2012-08-13 19:58:46 +00:00
$('#add_url').val('');
bookmark = { url: url, description:'', title:'', from_own: '1', added_date: new Date()};
2012-08-13 19:58:46 +00:00
$.ajax({
type: 'POST',
url: OC.filePath('bookmarks', 'ajax', 'editBookmark.php'),
data: bookmark,
2012-08-13 19:58:46 +00:00
success: function(data){
if (data.status == 'success') {
// First remove old BM if exists
$('.bookmark_single').filterAttr('data-id', data.item.id).remove();
bookmark = $.extend({}, bookmark, data.item);
updateBookmarksList(bookmark, 'prepend');
checkEmpty();
watchUrlField();
2012-08-13 19:58:46 +00:00
}
}
});
2011-08-15 22:05:07 +02:00
}
function delBookmark(event) {
var record = $(this).parent().parent();
2011-08-15 22:05:07 +02:00
$.ajax({
2012-06-10 23:38:26 +02:00
type: 'POST',
2012-04-25 21:20:06 +02:00
url: OC.filePath('bookmarks', 'ajax', 'delBookmark.php'),
data: { id: record.data('id') },
success: function(data){
if (data.status == 'success') {
record.remove();
checkEmpty();
}
}
2011-08-15 22:05:07 +02:00
});
}
function checkEmpty() {
2013-02-07 00:33:47 +01:00
if($('.bookmarks_list').children().length == 0) {
$("#firstrun").show();
$("#bm_export").addClass('disabled');
2013-02-07 00:33:47 +01:00
$('.bookmarks_list').hide();
} else {
$("#firstrun").hide();
$("#bm_export").removeClass('disabled');
2013-02-07 00:33:47 +01:00
$('.bookmarks_list').show();
}
}
2012-06-29 14:12:29 +02:00
function editBookmark(event) {
2012-09-02 15:53:33 +00:00
if($('.bookmark_single_form').length){
$('.bookmark_single_form .reset').click();
}
2011-09-13 15:38:11 +04:30
var record = $(this).parent().parent();
2012-06-29 14:12:29 +02:00
bookmark = record.data('record');
html = tmpl("item_form_tmpl", bookmark);
record.after(html);
record.hide();
rec_form = record.next().find('form');
rec_form.find('.bookmark_form_tags ul').tagit({
allowSpaces: true,
availableTags: fullTags,
2014-06-12 18:20:16 +02:00
placeholderText: t('bookmarks', 'Tags')
});
rec_form.bind('submit',submitBookmark);
rec_form.find('.reset').bind('click',cancelBookmark);
2011-09-13 15:38:11 +04:30
}
function cancelBookmark(event) {
event.preventDefault();
rec_form = $(this).closest('form').parent();
rec_form.prev().show();
rec_form.remove();
}
function submitBookmark(event) {
event.preventDefault();
form_values = $(this).serialize();
$.ajax({
type: 'POST',
url: $(this).attr('action'),
data: form_values,
success: function(data){
if(data.status == 'success'){
//@TODO : do better reaction than reloading the page
filterTagsChanged();
} else { // On failure
//@TODO : show error message?
}
}
});
}
2012-10-11 19:45:05 +00:00
function updateBookmarksList(bookmark, position) {
position = typeof position !== 'undefined' ? position : 'append';
bookmark = $.extend({title:'', description:'', added_date: new Date('now'), tags:[] }, bookmark);
tags = bookmark.tags;
var taglist = '';
2011-08-15 22:05:07 +02:00
for ( var i=0, len=tags.length; i<len; ++i ){
2012-02-01 22:02:06 +01:00
if(tags[i] != '')
taglist = taglist + '<a class="bookmark_tag" href="#">' + escapeHTML(tags[i]) + '</a> ';
2011-08-15 22:05:07 +02:00
}
if(!hasProtocol(bookmark.url)) {
bookmark.url = 'http://' + bookmark.url;
}
if(bookmark.added) {
bookmark.added_date.setTime(parseInt(bookmark.added)*1000);
}
if(! bookmark.title)
bookmark.title ='';
html = tmpl("item_tmpl", bookmark);
if(position == "prepend") {
$('.bookmarks_list').prepend(html);
} else {
$('.bookmarks_list').append(html);
}
line = $('div[data-id="'+ bookmark.id +'"]');
line.data('record', bookmark);
if(taglist != '') {
line.append('<p class="bookmark_tags">' + taglist + '</p>');
2012-02-01 22:02:06 +01:00
}
line.find('a.bookmark_tag').bind('click', addFilterTag);
line.find('.bookmark_link').click(recordClick);
line.find('.bookmark_delete').click(delBookmark);
line.find('.bookmark_edit').click(editBookmark);
2011-08-15 22:05:07 +02:00
}
function updateOnBottom() {
//check wether user is on bottom of the page
var top = $('.bookmarks_list>:last-child').position().top;
var height = $('.bookmarks_list').height();
// use a bit of margin to begin loading before we are really at the
// bottom
if (top < height * 1.2) {
2012-07-01 21:08:41 +00:00
getBookmarks();
2011-08-15 22:05:07 +02:00
}
}
function recordClick(event) {
$.ajax({
2012-06-10 23:38:26 +02:00
type: 'POST',
2012-04-25 21:20:06 +02:00
url: OC.filePath('bookmarks', 'ajax', 'recordClick.php'),
data: 'url=' + encodeURIComponent($(this).attr('href'))
});
2011-08-15 22:05:07 +02:00
}
function hasProtocol(url) {
var regexp = /(ftp|http|https|sftp)/;
return regexp.test(url);
}
function renameTag(event) {
if($('input[name="tag_new_name"]').length) return; // Do nothing if a tag is currenlty edited
tag_el = $(this).closest('li');
tag_el.append('<form><input name="tag_new_name" type="text"></form>');
var form = tag_el.find('form');
tag_el.find('.tags_actions').hide();
tag_name = tag_el.find('.tag').hide().text();
tag_el.find('input').val(tag_name).focus().bind('blur',function() {
form.trigger('submit');
});
form.bind('submit',submitTagName);
}
function submitTagName(event) {
event.preventDefault();
tag_el = $(this).closest('li')
new_tag_name = tag_el.find('input').val();
old_tag_name = tag_el.find('.tag').show().text();
tag_el.find('.tag_edit').show();
tag_el.find('.tags_actions').show();
tag_el.find('input').unbind('blur');
tag_el.find('form').unbind('submit').remove();
if(new_tag_name != old_tag_name && new_tag_name != '') {
//submit
$.ajax({
type: 'POST',
url: OC.filePath('bookmarks', 'ajax', 'renameTag.php'),
data: { old_name: old_tag_name, new_name: new_tag_name},
success: function(bookmarks){
if (bookmarks.status =='success') {
filterTagsChanged();
}
}
});
}
}
function deleteTag(event){
tag_el = $(this).closest('li');
var old_tag_name = tag_el.find('.tag').show().text();
2012-08-13 17:24:34 +00:00
OC.dialogs.confirm(t('bookmarks', 'Are you sure you want to remove this tag from every entry?'),
t('bookmarks', 'Warning'), function(answer) {
if(answer) {
$.ajax({
type: 'POST',
url: OC.filePath('bookmarks', 'ajax', 'delTag.php'),
data: { old_name: old_tag_name},
success: function(bookmarks){
if (bookmarks.status =='success') {
filterTagsChanged();
}
}
});
}
});
2012-07-31 20:48:11 +00:00
}