diff options
author | Friendika <info@friendika.com> | 2011-11-04 01:52:33 -0700 |
---|---|---|
committer | Friendika <info@friendika.com> | 2011-11-04 01:52:33 -0700 |
commit | 2765b0ba4145dd58e49caa74b780dd6c19d7551c (patch) | |
tree | 675bf71f2d008e8cec5271f0b77e1dd83c9a1a1f /js/fk.autocomplete.js | |
parent | 0130052b2cfde6ca888506807c1b5e7e61209151 (diff) | |
parent | 51b0f583b0b4f9e9f7a2fcfdf27332c905cc1011 (diff) | |
download | volse-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.js | 53 |
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); } |