aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorFriendika <info@friendika.com>2011-11-03 20:40:56 -0700
committerFriendika <info@friendika.com>2011-11-03 20:40:56 -0700
commite19b5971804f0e07d7f3e4ad6d7b71e05ff49ed5 (patch)
treef121a8086601cc30521ff59970393f5908b57129
parent5f531aa53734818aebb602a8833ea76ec33db90d (diff)
downloadvolse-hubzilla-e19b5971804f0e07d7f3e4ad6d7b71e05ff49ed5.tar.gz
volse-hubzilla-e19b5971804f0e07d7f3e4ad6d7b71e05ff49ed5.tar.bz2
volse-hubzilla-e19b5971804f0e07d7f3e4ad6d7b71e05ff49ed5.zip
tinymce tag complete stuff
-rw-r--r--js/fk.autocomplete.js28
-rw-r--r--view/jot-header.tpl25
2 files changed, 40 insertions, 13 deletions
diff --git a/js/fk.autocomplete.js b/js/fk.autocomplete.js
index c17d61fc5..45de0cb2d 100644
--- a/js/fk.autocomplete.js
+++ b/js/fk.autocomplete.js
@@ -13,20 +13,28 @@ function ACPopup(elm,backend_url){
this.ready=true;
this.kp_timer = false;
this.url = backend_url;
-
- style = $(elm).offset();
- w = $(elm).width();
- h = $(elm).height();
+
+ if(typeof elm.editorId == "undefined") {
+ style = $(elm).offset();
+ w = $(elm).width();
+ h = $(elm).height();
+ }
+ else {
+ style = $('.profile-jot-text').offset();
+ w = 300;
+ h = 150;
+
+ }
style.top=style.top+h;
style.width = w;
style.position = 'absolute';
-/* style['max-height'] = '150px';
- style.border = '1px solid red';
- style.background = '#cccccc';
+ /* style['max-height'] = '150px';
+ style.border = '1px solid red';
+ style.background = '#cccccc';
- style.overflow = 'auto';
- style['z-index'] = '100000';
-*/
+ style.overflow = 'auto';
+ style['z-index'] = '100000';
+ */
style.display = 'none';
this.cont = $("<div class='acpopup'></div>");
diff --git a/view/jot-header.tpl b/view/jot-header.tpl
index ecf27e1b1..9ded3e9b4 100644
--- a/view/jot-header.tpl
+++ b/view/jot-header.tpl
@@ -30,9 +30,26 @@ function initEditor(cb){
content_css: "$baseurl/view/custom_tinymce.css",
theme_advanced_path : false,
setup : function(ed) {
- //Character count
+ cPopup = null;
+ ed.onKeyDown.add(function(ed,e) {
+ if(cPopup !== null)
+ cPopup.onkey(e);
+ });
+
ed.onKeyUp.add(function(ed, e) {
var txt = tinyMCE.activeEditor.getContent();
+ match = txt.match(/@([^ \n]+)$/);
+ if(match!==null) {
+ if(cPopup === null) {
+ cPopup = new ACPopup(this,baseurl+"/acl");
+ }
+ if(cPopup.ready && match[1]!==cPopup.searchText) cPopup.search(match[1]);
+ if(! cPopup.ready) cPopup = null;
+ }
+ else {
+ if(cPopup !== null) { cPopup.close(); cPopup = null; }
+ }
+
textlen = txt.length;
if(textlen != 0 && $('#jot-perms-icon').is('.unlock')) {
$('#profile-jot-desc').html(ispublic);
@@ -41,6 +58,8 @@ function initEditor(cb){
$('#profile-jot-desc').html('&nbsp;');
}
+ //Character count
+
if(textlen <= 140) {
$('#character-counter').removeClass('red');
$('#character-counter').removeClass('orange');
@@ -71,8 +90,8 @@ function initEditor(cb){
editor = true;
// setup acl popup
$("a#jot-perms-icon").fancybox({
- 'transitionIn' : 'none',
- 'transitionOut' : 'none'
+ 'transitionIn' : 'elastic',
+ 'transitionOut' : 'elastic'
});
} else {
if (typeof cb!="undefined") cb();