aboutsummaryrefslogtreecommitdiffstats
path: root/js/fk.autocomplete.js
diff options
context:
space:
mode:
authorFriendika <info@friendika.com>2011-11-04 01:52:33 -0700
committerFriendika <info@friendika.com>2011-11-04 01:52:33 -0700
commit2765b0ba4145dd58e49caa74b780dd6c19d7551c (patch)
tree675bf71f2d008e8cec5271f0b77e1dd83c9a1a1f /js/fk.autocomplete.js
parent0130052b2cfde6ca888506807c1b5e7e61209151 (diff)
parent51b0f583b0b4f9e9f7a2fcfdf27332c905cc1011 (diff)
downloadvolse-hubzilla-2765b0ba4145dd58e49caa74b780dd6c19d7551c.tar.gz
volse-hubzilla-2765b0ba4145dd58e49caa74b780dd6c19d7551c.tar.bz2
volse-hubzilla-2765b0ba4145dd58e49caa74b780dd6c19d7551c.zip
Merge branch 'atcomplete'
Diffstat (limited to 'js/fk.autocomplete.js')
-rw-r--r--js/fk.autocomplete.js53
1 files changed, 35 insertions, 18 deletions
diff --git a/js/fk.autocomplete.js b/js/fk.autocomplete.js
index c17d61fc5..3f73c6fbb 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 = $(elm.container).offset();
+ w = elm.container.offsetWidth;
+ h = elm.container.offsetHeight;
+ }
+
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>");
@@ -65,7 +73,7 @@ ACPopup.prototype._search = function(){
that.cont.show();
$(data.items).each(function(){
html = "<img src='{0}' height='16px' width='16px'>{1} ({2})".format(this.photo, this.name, this.nick)
- that.add(html, this.nick + '+' + this.id + ' - ' + this.link);
+ that.add(html, this.nick + '+' + this.id + ' - ' + this.link);
});
} else {
that.cont.hide();
@@ -74,16 +82,25 @@ ACPopup.prototype._search = function(){
});
}
-ACPopup.prototype.add = function(label, value){
+ ACPopup.prototype.add = function(label, value){
var that=this;
var elm = $("<div class='acpopupitem' title='"+value+"'>"+label+"</div>");
elm.click(function(e){
- t = $(this).attr('title').replace(new RegExp(' \- .*'),'');
- el=$(that.element);
- sel = el.getSelection();
- sel.start = sel.start- that.searchText.length;
- el.setSelection(sel.start,sel.end).replaceSelectedText(t).collapseSelection(false);
- that.close();
+ t = $(this).attr('title').replace(new RegExp(' \- .*'),'');
+ if(typeof(that.element.container) === "undefined") {
+ el=$(that.element);
+ sel = el.getSelection();
+ sel.start = sel.start- that.searchText.length;
+ el.setSelection(sel.start,sel.end).replaceSelectedText(t+' ').collapseSelection(false);
+ that.close();
+ }
+ else {
+ txt = tinyMCE.activeEditor.getContent();
+ newtxt = txt.replace(that.searchText,t+' ');
+ tinyMCE.activeEditor.setContent(newtxt);
+ tinyMCE.activeEditor.focus();
+ that.close();
+ }
});
$(this.cont).append(elm);
}