friendica-github/view/theme/frost/js/theme.js

679 lines
18 KiB
JavaScript
Raw Normal View History

$(document).ready(function() {
2012-07-24 09:15:57 -06:00
window.navMenuTimeout = {
'#network-menu-list-timeout': null,
'#contacts-menu-list-timeout': null,
'#system-menu-list-timeout': null,
'#network-menu-list-opening': false,
'#contacts-menu-list-opening': false,
'#system-menu-list-opening': false,
'#network-menu-list-closing': false,
'#contacts-menu-list-closing': false,
'#system-menu-list-closing': false
};
2017-01-26 22:54:32 -05:00
/* enable editor on focus and click */
$("#profile-jot-text").focus(enableOnUser);
$("#profile-jot-text").click(enableOnUser);
$('.nav-menu-list, .nav-menu-icon').hover(function() {
showNavMenu($(this).attr('point'));
2012-07-24 09:15:57 -06:00
}, function() {
hideNavMenu($(this).attr('point'));
2012-07-24 09:15:57 -06:00
});
$('.group-edit-icon').hover(
2012-07-24 09:15:57 -06:00
function() {
$(this).addClass('icon'); $(this).removeClass('iconspacer');},
2012-07-24 09:15:57 -06:00
function() {
$(this).removeClass('icon'); $(this).addClass('iconspacer');}
2012-07-24 09:15:57 -06:00
);
$('.sidebar-group-element').hover(
2012-07-24 09:15:57 -06:00
function() {
id = $(this).attr('id');
$('#edit-' + id).addClass('icon'); $('#edit-' + id).removeClass('iconspacer');},
2012-07-24 09:15:57 -06:00
function() {
id = $(this).attr('id');
$('#edit-' + id).removeClass('icon');$('#edit-' + id).addClass('iconspacer');}
2012-07-24 09:15:57 -06:00
);
$('.savedsearchdrop').hover(
2012-07-24 09:15:57 -06:00
function() {
$(this).addClass('drop'); $(this).addClass('icon'); $(this).removeClass('iconspacer');},
2012-07-24 09:15:57 -06:00
function() {
$(this).removeClass('drop'); $(this).removeClass('icon'); $(this).addClass('iconspacer');}
2012-07-24 09:15:57 -06:00
);
$('.savedsearchterm').hover(
2012-07-24 09:15:57 -06:00
function() {
id = $(this).attr('id');
$('#drop-' + id).addClass('icon'); $('#drop-' + id).addClass('drophide'); $('#drop-' + id).removeClass('iconspacer');},
2012-07-24 09:15:57 -06:00
function() {
id = $(this).attr('id');
$('#drop-' + id).removeClass('icon');$('#drop-' + id).removeClass('drophide'); $('#drop-' + id).addClass('iconspacer');}
2012-07-24 09:15:57 -06:00
);
$('#id_share').change(function() {
2013-02-10 14:57:44 -07:00
if ($('#id_share').is(':checked')) {
$('#acl-wrapper').show();
} else {
$('#acl-wrapper').hide();
2013-02-10 14:57:44 -07:00
}
}).trigger('change');
if (typeof window.AjaxUpload != "undefined") {
2013-02-10 14:57:44 -07:00
var uploader = new window.AjaxUpload(
window.imageUploadButton,
{ action: 'wall_upload/'+window.nickname,
name: 'userfile',
onSubmit: function(file,ext) { $('#profile-rotator').show(); },
2013-02-10 14:57:44 -07:00
onComplete: function(file,response) {
addeditortext(window.jotId, response);
$('#profile-rotator').hide();
}
2013-02-10 14:57:44 -07:00
}
);
if ($('#wall-file-upload').length) {
2013-02-10 14:57:44 -07:00
var file_uploader = new window.AjaxUpload(
'wall-file-upload',
{ action: 'wall_attach/'+window.nickname,
name: 'userfile',
onSubmit: function(file,ext) { $('#profile-rotator').show(); },
2013-02-10 14:57:44 -07:00
onComplete: function(file,response) {
addeditortext(window.jotId, response);
$('#profile-rotator').hide();
}
2013-02-10 14:57:44 -07:00
}
);
}
}
if (typeof window.aclInit !="undefined" && typeof acl=="undefined") {
2013-02-10 14:57:44 -07:00
acl = new ACL(
baseurl+"/acl",
[ window.allowCID,window.allowGID,window.denyCID,window.denyGID ]
);
}
if (window.aclType == "settings-head" || window.aclType == "photos_head" || window.aclType == "event_head") {
$('#contact_allow, #contact_deny, #group_allow, #group_deny').change(function() {
2013-02-10 14:57:44 -07:00
var selstr;
$('#contact_allow option:selected, #contact_deny option:selected, #group_allow option:selected, #group_deny option:selected').each( function() {
selstr = $(this).text();
$('#jot-perms-icon').removeClass('unlock').addClass('lock');
$('#jot-public').hide();
2013-02-10 14:57:44 -07:00
});
if (selstr == null) {
$('#jot-perms-icon').removeClass('lock').addClass('unlock');
$('#jot-public').show();
2013-02-10 14:57:44 -07:00
}
}).trigger('change');
}
if (window.aclType == "event_head") {
$('#events-calendar').fullCalendar({
events: baseurl + window.eventModuleUrl +'/json/',
header: {
left: 'prev,next today',
center: 'title',
right: 'month,agendaWeek,agendaDay'
},
timeFormat: 'H(:mm)',
eventClick: function(calEvent, jsEvent, view) {
showEvent(calEvent.id);
},
loading: function(isLoading, view) {
if (!isLoading) {
$('td.fc-day').dblclick(function() { window.location.href='/events/new?start='+$(this).data('date'); });
}
},
eventRender: function(event, element, view) {
//console.log(view.name);
if (event.item['author-name']==null) return;
switch(view.name) {
case "month":
element.find(".fc-title").html(
"<img src='{0}' style='height:10px;width:10px'>{1} : {2}".format(
event.item['author-avatar'],
event.item['author-name'],
event.title
));
break;
case "agendaWeek":
element.find(".fc-title").html(
"<img src='{0}' style='height:12px; width:12px'>{1}<p>{2}</p><p>{3}</p>".format(
event.item['author-avatar'],
event.item['author-name'],
event.item.desc,
event.item.location
));
break;
case "agendaDay":
element.find(".fc-title").html(
"<img src='{0}' style='height:24px;width:24px'>{1}<p>{2}</p><p>{3}</p>".format(
event.item['author-avatar'],
event.item['author-name'],
event.item.desc,
event.item.location
));
break;
}
}
});
// center on date
var args=location.href.replace(baseurl,"").split("/");
if (args.length>=5 && window.eventModeParams == 2) {
$("#events-calendar").fullCalendar('gotoDate',args[3] , args[4]-1);
} else if (args.length>=4 && window.eventModeParams == 1) {
$("#events-calendar").fullCalendar('gotoDate',args[2] , args[3]-1);
}
// show event popup
var hash = location.hash.split("-")
if (hash.length==2 && hash[0]=="#link") showEvent(hash[1]);
}
switch(window.autocompleteType) {
case 'msg-header':
$("#recip").name_autocomplete(baseurl + '/acl', '', false, function(data) {
$("#recip-complete").val(data.id);
});
break;
case 'contacts-head':
$("#contacts-search").contact_autocomplete(baseurl + '/acl', 'a', true);
$("#contacts-search").keyup(function(event) {
if (event.keyCode == 13) {
$("#contacts-search").click();
}
});
$(".autocomplete-w1 .selected").keyup(function(event) {
if (event.keyCode == 13) {
$("#contacts-search").click();
}
});
break;
2013-02-10 14:57:44 -07:00
case 'display-head':
2016-01-21 13:28:29 +01:00
$(".comment-wwedit-wrapper textarea").editor_autocomplete(baseurl+"/acl");
2013-02-10 14:57:44 -07:00
break;
default:
break;
}
2013-02-10 14:57:44 -07:00
// Add Colorbox for viewing Network page images
//var cBoxClasses = new Array();
$(".wall-item-body a img").each(function() {
var aElem = $(this).parent();
2013-02-10 14:57:44 -07:00
var imgHref = aElem.attr("href");
// We need to make sure we only put a Colorbox on links to Friendica images
// We'll try to do this by looking for links of the form
// .../photo/ab803d8eg08daf85023adfec08 (with nothing more following), in hopes
// that that will be unique enough
if (imgHref.match(/\/photo\/[a-fA-F0-9]+(-[0-9]\.[\w]+?)?$/)) {
2013-02-10 14:57:44 -07:00
// Add a unique class to all the images of a certain post, to allow scrolling through
var cBoxClass = $(this).closest(".wall-item-body").attr("id") + "-lightbox";
$(this).addClass(cBoxClass);
2013-02-10 14:57:44 -07:00
aElem.colorbox({
maxHeight: '90%',
photo: true, // Colorbox doesn't recognize a URL that don't end in .jpg, etc. as a photo
rel: cBoxClass //$(this).attr("class").match(/wall-item-body-[\d]+-lightbox/)[0]
2013-02-10 14:57:44 -07:00
});
}
2013-02-10 14:57:44 -07:00
});
2012-07-24 09:15:57 -06:00
});
// update pending count //
$(function() {
$("nav").bind('nav-update', function(e,data) {
var elm = $('#pending-update');
var register = $(data).find('register').text();
if (register=="0") { register=""; elm.hide();} else { elm.show(); }
elm.html(register);
});
});
$(function() {
$("#cnftheme").click(function() {
2013-02-04 18:06:43 -07:00
$.colorbox({
width: 800,
height: '90%',
2013-02-10 14:57:44 -07:00
href: baseurl + "/admin/themes/" + $("#id_theme :selected").val(),
onComplete: function() {
$("div#fancybox-content form").submit(function(e) {
var url = $(this).attr('action');
2013-02-04 18:06:43 -07:00
// can't get .serialize() to work...
var data={};
$(this).find("input").each(function() {
data[$(this).attr('name')] = $(this).val();
2013-02-04 18:06:43 -07:00
});
$(this).find("select").each(function() {
data[$(this).attr('name')] = $(this).children(":selected").val();
2013-02-04 18:06:43 -07:00
});
console.log(":)", url, data);
$.post(url, data, function(data) {
if (timer) {
clearTimeout(timer);
}
2013-02-04 18:06:43 -07:00
NavUpdate();
$.colorbox.close();
2013-02-04 18:06:43 -07:00
})
2013-02-04 18:06:43 -07:00
return false;
});
2013-02-04 18:06:43 -07:00
}
});
return false;
});
});
2012-07-24 09:15:57 -06:00
2012-12-27 12:20:47 -07:00
function homeRedirect() {
$('html').fadeOut('slow', function() {
2012-12-27 12:20:47 -07:00
window.location = baseurl + "/login";
});
}
if (typeof window.photoEdit != 'undefined') {
$(document).keydown(function(event) {
if (window.prevLink != '') { if (event.ctrlKey && event.keyCode == 37) { event.preventDefault(); window.location.href = window.prevLink; }}
if (window.nextLink != '') { if (event.ctrlKey && event.keyCode == 39) { event.preventDefault(); window.location.href = window.nextLink; }}
});
2012-07-24 09:15:57 -06:00
}
function showEvent(eventid) {
$.get(
baseurl + window.eventModuleUrl + '/?id=' + eventid,
function(data) {
$.colorbox({html:data});
$.colorbox.resize();
}
);
}
2015-05-23 19:23:32 +02:00
function doEventPreview() {
$('#event-edit-preview').val(1);
$.post('events',$('#event-edit-form').serialize(), function(data) {
$.colorbox({ html: data });
});
$('#event-edit-preview').val(0);
}
function initCrop() {
function onEndCrop( coords, dimensions ) {
$PR( 'x1' ).value = coords.x1;
$PR( 'y1' ).value = coords.y1;
$PR( 'x2' ).value = coords.x2;
$PR( 'y2' ).value = coords.y2;
$PR( 'width' ).value = dimensions.width;
$PR( 'height' ).value = dimensions.height;
}
Event.observe( window, 'load', function() {
new Cropper.ImgWithPreview(
'croppa',
{
previewWrap: 'previewWrap',
minWidth: 175,
minHeight: 175,
maxWidth: 640,
maxHeight: 640,
ratioDim: { x: 100, y:100 },
displayOnInit: true,
onEndCrop: onEndCrop
});
});
2012-07-24 09:15:57 -06:00
}
function showNavMenu(menuID) {
if (window.navMenuTimeout[menuID + '-closing']) {
2012-07-24 09:15:57 -06:00
window.navMenuTimeout[menuID + '-closing'] = false;
clearTimeout(window.navMenuTimeout[menuID + '-timeout']);
} else {
2012-07-24 09:15:57 -06:00
window.navMenuTimeout[menuID + '-opening'] = true;
2012-07-24 09:15:57 -06:00
window.navMenuTimeout[menuID + '-timeout'] = setTimeout( function () {
$(menuID).slideDown('fast').show();
2012-07-24 09:15:57 -06:00
window.navMenuTimeout[menuID + '-opening'] = false;
}, 200);
}
}
function hideNavMenu(menuID) {
if (window.navMenuTimeout[menuID + '-opening']) {
2012-07-24 09:15:57 -06:00
window.navMenuTimeout[menuID + '-opening'] = false;
clearTimeout(window.navMenuTimeout[menuID + '-timeout']);
} else {
2012-07-24 09:15:57 -06:00
window.navMenuTimeout[menuID + '-closing'] = true;
2012-07-24 09:15:57 -06:00
window.navMenuTimeout[menuID + '-timeout'] = setTimeout( function () {
$(menuID).slideUp('fast');
2012-07-24 09:15:57 -06:00
window.navMenuTimeout[menuID + '-closing'] = false;
}, 500);
}
}
2013-02-10 14:57:44 -07:00
/*
2017-01-26 22:54:32 -05:00
* Editor
2013-02-10 14:57:44 -07:00
*/
2013-02-10 14:57:44 -07:00
var editor = false;
var textlen = 0;
2017-01-26 22:54:32 -05:00
function initEditor(callback) {
if(editor == false) {
$("#profile-jot-text-loading").show();
2017-01-26 22:54:32 -05:00
$("#profile-jot-text-loading").hide();
$("#profile-jot-text").css({ 'height': 200, 'color': '#000' });
$("#profile-jot-text").editor_autocomplete(baseurl+"/acl");
$(".jothidden").show();
// setup acl popup
$("a#jot-perms-icon").colorbox({
2013-02-04 18:06:43 -07:00
'inline' : true,
'transition' : 'elastic'
});
2017-01-26 22:54:32 -05:00
editor = true;
2013-02-10 14:57:44 -07:00
}
2017-01-26 22:54:32 -05:00
if (typeof callback != "undefined") {
callback();
}
}
function enableOnUser() {
2017-01-26 22:54:32 -05:00
if (editor) {
return;
2013-02-10 14:57:44 -07:00
}
$(this).val("");
2013-02-10 14:57:44 -07:00
initEditor();
}
function msgInitEditor() {
2017-01-26 22:54:32 -05:00
$("#prvmail-text").editor_autocomplete(baseurl+"/acl");
}
2013-02-10 14:57:44 -07:00
/*
* Jot
*/
function addeditortext(textElem, data) {
2017-01-26 22:54:32 -05:00
var currentText = $(textElem).val();
$(textElem).val(currentText + data);
}
function jotVideoURL() {
reply = prompt(window.vidURL);
if (reply && reply.length) {
2013-02-10 14:57:44 -07:00
addeditortext("#profile-jot-text", '[video]' + reply + '[/video]');
}
}
function jotAudioURL() {
reply = prompt(window.audURL);
if (reply && reply.length) {
2013-02-10 14:57:44 -07:00
addeditortext("#profile-jot-text", '[audio]' + reply + '[/audio]');
}
}
function jotGetLocation() {
reply = prompt(window.whereAreU, $('#jot-location').val());
if (reply && reply.length) {
$('#jot-location').val(reply);
}
}
function jotShare(id) {
if ($('#jot-popup').length != 0) $('#jot-popup').show();
$('#like-rotator-' + id).show();
$.get('share/' + id, function(data) {
if (!editor) $("#profile-jot-text").val("");
initEditor(function() {
2013-02-10 14:57:44 -07:00
addeditortext("#profile-jot-text", data);
$('#like-rotator-' + id).hide();
$(window).scrollTop(0);
});
});
}
2013-02-10 14:57:44 -07:00
function jotClearLocation() {
$('#jot-coord').val('');
$('#profile-nolocation-wrapper').hide();
2013-02-10 14:57:44 -07:00
}
function jotGetLink() {
reply = prompt(window.linkURL);
if (reply && reply.length) {
2013-02-10 14:57:44 -07:00
reply = bin2hex(reply);
$('#profile-rotator').show();
$.get('parse_url?binurl=' + reply, function(data) {
2013-02-10 14:57:44 -07:00
addeditortext(window.jotId, data);
$('#profile-rotator').hide();
2013-02-10 14:57:44 -07:00
});
}
}
function linkdropper(event) {
var linkFound = event.dataTransfer.types.contains("text/uri-list");
if (linkFound)
event.preventDefault();
}
2013-02-10 14:57:44 -07:00
function linkdrop(event) {
var reply = event.dataTransfer.getData("text/uri-list");
event.preventDefault();
if (reply && reply.length) {
2013-02-10 14:57:44 -07:00
reply = bin2hex(reply);
$('#profile-rotator').show();
$.get('parse_url?binurl=' + reply, function(data) {
2013-02-10 14:57:44 -07:00
addeditortext(window.jotId, data);
$('#profile-rotator').hide();
2013-02-10 14:57:44 -07:00
});
}
}
if (typeof window.geoTag === 'function') window.geoTag();
2013-02-10 14:57:44 -07:00
/*
* Items
*/
function confirmDelete() { return confirm(window.delItem); }
function deleteCheckedItems(delID) {
if (confirm(window.delItems)) {
2013-02-10 14:57:44 -07:00
var checkedstr = '';
$(delID).hide();
$(delID + '-rotator').show();
$('.item-select').each( function() {
if ($(this).is(':checked')) {
if (checkedstr.length != 0) {
checkedstr = checkedstr + ',' + $(this).val();
} else {
checkedstr = $(this).val();
2013-02-10 14:57:44 -07:00
}
}
2013-02-10 14:57:44 -07:00
});
$.post('item', { dropitems: checkedstr }, function(data) {
2013-02-10 14:57:44 -07:00
window.location.reload();
});
}
}
function itemTag(id) {
reply = prompt(window.term);
if (reply && reply.length) {
reply = reply.replace('#','');
if (reply.length) {
commentBusy = true;
$('body').css('cursor', 'wait');
$.get('tagger/' + id + '?term=' + reply, NavUpdate);
liking = 1;
}
}
}
function itemFiler(id) {
var bordercolor = $("input").css("border-color");
$.get('filer/', function(data) {
$.colorbox({html:data});
$.colorbox.resize();
$("#id_term").keypress(function() {
$(this).css("border-color",bordercolor);
})
$("#select_term").change(function() {
$("#id_term").css("border-color",bordercolor);
})
$("#filer_save").click(function(e) {
e.preventDefault();
reply = $("#id_term").val();
if (reply && reply.length) {
commentBusy = true;
$('body').css('cursor', 'wait');
$.get('filer/' + id + '?term=' + reply, NavUpdate);
liking = 1;
$.colorbox.close();
} else {
$("#id_term").css("border-color","#FF0000");
}
return false;
});
});
}
2013-02-10 14:57:44 -07:00
/*
* Comments
*/
function insertFormatting(BBcode, id) {
var tmpStr = $("#comment-edit-text-" + id).val();
if (tmpStr == "") {
$("#comment-edit-text-" + id).addClass("comment-edit-text-full");
$("#comment-edit-text-" + id).removeClass("comment-edit-text-empty");
2013-02-10 14:57:44 -07:00
openMenu("comment-edit-submit-wrapper-" + id);
}
textarea = document.getElementById("comment-edit-text-" +id);
if (document.selection) {
textarea.focus();
selected = document.selection.createRange();
if (BBcode == "url") {
2013-02-10 14:57:44 -07:00
selected.text = "["+BBcode+"=http://]" + selected.text + "[/"+BBcode+"]";
} else {
selected.text = "["+BBcode+"]" + selected.text + "[/"+BBcode+"]";
}
2013-02-10 14:57:44 -07:00
} else if (textarea.selectionStart || textarea.selectionStart == "0") {
var start = textarea.selectionStart;
var end = textarea.selectionEnd;
if (BBcode == "url") {
2013-02-10 14:57:44 -07:00
textarea.value = textarea.value.substring(0, start) + "["+BBcode+"=http://]" + textarea.value.substring(start, end) + "[/"+BBcode+"]" + textarea.value.substring(end, textarea.value.length);
} else {
textarea.value = textarea.value.substring(0, start) + "["+BBcode+"]" + textarea.value.substring(start, end) + "[/"+BBcode+"]" + textarea.value.substring(end, textarea.value.length);
}
2013-02-10 14:57:44 -07:00
}
2013-02-10 14:57:44 -07:00
return true;
}
function cmtBbOpen(id) {
$("#comment-edit-bb-" + id).show();
2013-02-10 14:57:44 -07:00
}
function cmtBbClose(id) {
$("#comment-edit-bb-" + id).hide();
}
2013-02-10 14:57:44 -07:00
function commentOpen(obj,id) {
if (obj.value == "") {
$("#comment-edit-text-" + id).addClass("comment-edit-text-full");
$("#comment-edit-text-" + id).removeClass("comment-edit-text-empty");
$("#mod-cmnt-wrap-" + id).show();
2013-02-10 14:57:44 -07:00
openMenu("comment-edit-submit-wrapper-" + id);
}
}
function commentClose(obj,id) {
if (obj.value == "") {
$("#comment-edit-text-" + id).removeClass("comment-edit-text-full");
$("#comment-edit-text-" + id).addClass("comment-edit-text-empty");
$("#mod-cmnt-wrap-" + id).hide();
2013-02-10 14:57:44 -07:00
closeMenu("comment-edit-submit-wrapper-" + id);
}
}
2013-02-10 14:57:44 -07:00
function commentInsert(obj,id) {
var tmpStr = $("#comment-edit-text-" + id).val();
if (tmpStr == "") {
$("#comment-edit-text-" + id).addClass("comment-edit-text-full");
$("#comment-edit-text-" + id).removeClass("comment-edit-text-empty");
2013-02-10 14:57:44 -07:00
openMenu("comment-edit-submit-wrapper-" + id);
}
var ins = $(obj).html();
2013-02-10 14:57:44 -07:00
ins = ins.replace("&lt;","<");
ins = ins.replace("&gt;",">");
ins = ins.replace("&amp;","&");
ins = ins.replace("&quot;",'"');
$("#comment-edit-text-" + id).val(tmpStr + ins);
2013-02-10 14:57:44 -07:00
}
function qCommentInsert(obj,id) {
var tmpStr = $("#comment-edit-text-" + id).val();
if (tmpStr == "") {
$("#comment-edit-text-" + id).addClass("comment-edit-text-full");
$("#comment-edit-text-" + id).removeClass("comment-edit-text-empty");
2013-02-10 14:57:44 -07:00
openMenu("comment-edit-submit-wrapper-" + id);
}
var ins = $(obj).val();
2013-02-10 14:57:44 -07:00
ins = ins.replace("&lt;","<");
ins = ins.replace("&gt;",">");
ins = ins.replace("&amp;","&");
ins = ins.replace("&quot;",'"');
$("#comment-edit-text-" + id).val(tmpStr + ins);
$(obj).val("");
2013-02-10 14:57:44 -07:00
}