aboutsummaryrefslogtreecommitdiffstats
path: root/view/js
diff options
context:
space:
mode:
authorMario Vavti <mario@mariovavti.com>2018-04-26 12:38:25 +0200
committerMario Vavti <mario@mariovavti.com>2018-04-26 12:38:25 +0200
commitfe4defe752a7a22e7d59483fde75b779ee78c3a4 (patch)
treec6c6bf906bde12334dae9f57608fd7717e238e3d /view/js
parent09666ae8e9d7195c4b839abd9b10ae23ff783558 (diff)
downloadvolse-hubzilla-fe4defe752a7a22e7d59483fde75b779ee78c3a4.tar.gz
volse-hubzilla-fe4defe752a7a22e7d59483fde75b779ee78c3a4.tar.bz2
volse-hubzilla-fe4defe752a7a22e7d59483fde75b779ee78c3a4.zip
upgrade to textcomplete (jquery.textcomplete is discontinued), enable built-in cache and unify to start lookup after 3 characters
Diffstat (limited to 'view/js')
-rw-r--r--view/js/autocomplete.js70
1 files changed, 53 insertions, 17 deletions
diff --git a/view/js/autocomplete.js b/view/js/autocomplete.js
index 0a440aa90..53c0e540f 100644
--- a/view/js/autocomplete.js
+++ b/view/js/autocomplete.js
@@ -184,8 +184,9 @@ function string2bb(element) {
// Autocomplete contacts
contacts = {
- match: /(^|\s)(@\!*)([^ \n]+)$/,
+ match: /(^|\s)(@\!*)([^ \n]{3,})$/,
index: 3,
+ cache: true,
search: function(term, callback) { contact_search(term, callback, backend_url, 'c', extra_channels, spinelement=false); },
replace: editor_replace,
template: contact_format
@@ -193,8 +194,9 @@ function string2bb(element) {
// Autocomplete forums
forums = {
- match: /(^|\s)(\!\!*)([^ \n]+)$/,
+ match: /(^|\s)(\!\!*)([^ \n]{3,})$/,
index: 3,
+ cache: true,
search: function(term, callback) { contact_search(term, callback, backend_url, 'f', extra_channels, spinelement=false); },
replace: editor_replace,
template: contact_format
@@ -203,8 +205,9 @@ function string2bb(element) {
// Autocomplete hashtags
tags = {
- match: /(^|\s)(\#)([^ \n]{2,})$/,
+ match: /(^|\s)(\#)([^ \n]{3,})$/,
index: 3,
+ cache: true,
search: function(term, callback) { $.getJSON('/hashtags/' + '$f=&t=' + term).done(function(data) { callback($.map(data, function(entry) { return entry.text.toLowerCase().indexOf(term.toLowerCase()) === 0 ? entry : null; })); }); },
replace: function(item) { return "$1$2" + item.text + ' '; },
context: function(text) { return text.toLowerCase(); },
@@ -215,13 +218,20 @@ function string2bb(element) {
smilies = {
match: /(^|\s)(:[a-z_:]{2,})$/,
index: 2,
+ cache: true,
search: function(term, callback) { $.getJSON('/smilies/json').done(function(data) { callback($.map(data, function(entry) { return entry.text.indexOf(term) === 0 ? entry : null; })); }); },
//template: function(item) { return item.icon + item.text; },
replace: function(item) { return "$1" + item.text + ' '; },
template: smiley_format
};
this.attr('autocomplete','off');
- this.textcomplete([contacts,forums,smilies,tags], {className:'acpopup', zIndex:1020});
+
+ var Textarea = Textcomplete.editors.Textarea;
+ var editor = new Textarea(this[0]);
+ var textcomplete = new Textcomplete(editor);
+
+ textcomplete.register([contacts,forums,smilies,tags], {className:'acpopup', zIndex:1020});
+
};
})( jQuery );
@@ -234,6 +244,7 @@ function string2bb(element) {
contacts = {
match: /(^@)([^\n]{3,})$/,
index: 2,
+ cache: true,
search: function(term, callback) { contact_search(term, callback, backend_url, 'x', [], spinelement='#nav-search-spinner'); },
replace: basic_replace,
template: contact_format,
@@ -243,6 +254,7 @@ function string2bb(element) {
forums = {
match: /(^\!)([^\n]{3,})$/,
index: 2,
+ cache: true,
search: function(term, callback) { contact_search(term, callback, backend_url, 'f', [], spinelement='#nav-search-spinner'); },
replace: basic_replace,
template: contact_format
@@ -252,6 +264,7 @@ function string2bb(element) {
tags = {
match: /(^\#)([^ \n]{3,})$/,
index: 2,
+ cache: true,
search: function(term, callback) { $.getJSON('/hashtags/' + '$f=&t=' + term).done(function(data) { callback($.map(data, function(entry) { return entry.text.toLowerCase().indexOf(term.toLowerCase()) === 0 ? entry : null; })); }); },
replace: function(item) { return "$1" + item.text + ' '; },
context: function(text) { return text.toLowerCase(); },
@@ -259,8 +272,14 @@ function string2bb(element) {
};
this.attr('autocomplete', 'off');
- var a = this.textcomplete([contacts,forums,tags], {className:'acpopup', maxCount:100, zIndex: 1020, appendTo:'nav'});
- a.on('textComplete:select', function(e, value, strategy) { submit_form(this); });
+
+ var Textarea = Textcomplete.editors.Textarea;
+ var editor = new Textarea(this[0]);
+ var textcomplete = new Textcomplete(editor);
+
+ textcomplete.register([contacts,forums,tags], {className:'acpopup', maxCount:100, zIndex: 1020, appendTo:'nav'});
+
+ this.on('textComplete:select', function(e, value, strategy) { submit_form(this); });
};
})( jQuery );
@@ -271,21 +290,27 @@ function string2bb(element) {
// Autocomplete contacts
contacts = {
- match: /(^)([^\n]+)$/,
+ match: /(^)([^\n]{3,})$/,
index: 2,
+ cache: true,
search: function(term, callback) { contact_search(term, callback, backend_url, typ,[], spinelement=false); },
replace: basic_replace,
template: contact_format,
};
this.attr('autocomplete','off');
- var a = this.textcomplete([contacts], {className:'acpopup', zIndex:1020});
+
+ var Textarea = Textcomplete.editors.Textarea;
+ var editor = new Textarea(this[0]);
+ var textcomplete = new Textcomplete(editor);
+
+ textcomplete.register([contacts], {className:'acpopup', zIndex:1020});
if(autosubmit)
- a.on('textComplete:select', function(e,value,strategy) { submit_form(this); });
+ this.on('textComplete:select', function(e,value,strategy) { submit_form(this); });
if(typeof onselect !== 'undefined')
- a.on('textComplete:select', function(e, value, strategy) { onselect(value); });
+ this.on('textComplete:select', function(e, value, strategy) { onselect(value); });
};
})( jQuery );
@@ -297,21 +322,27 @@ function string2bb(element) {
// Autocomplete contacts
names = {
- match: /(^)([^\n]+)$/,
+ match: /(^)([^\n]{3,})$/,
index: 2,
+ cache: true,
search: function(term, callback) { contact_search(term, callback, backend_url, typ,[], spinelement=false); },
replace: trim_replace,
template: contact_format,
};
this.attr('autocomplete','off');
- var a = this.textcomplete([names], {className:'acpopup', zIndex:1020});
+
+ var Textarea = Textcomplete.editors.Textarea;
+ var editor = new Textarea(this[0]);
+ var textcomplete = new Textcomplete(editor);
+
+ textcomplete.register([names], {className:'acpopup', zIndex:1020});
if(autosubmit)
- a.on('textComplete:select', function(e,value,strategy) { submit_form(this); });
+ this.on('textComplete:select', function(e,value,strategy) { submit_form(this); });
if(typeof onselect !== 'undefined')
- a.on('textComplete:select', function(e, value, strategy) { onselect(value); });
+ this.on('textComplete:select', function(e, value, strategy) { onselect(value); });
};
})( jQuery );
@@ -375,11 +406,16 @@ function string2bb(element) {
};
this.attr('autocomplete','off');
- var a = this.textcomplete([bbco], {className:'acpopup', zIndex:1020});
- a.on('textComplete:select', function(e, value, strategy) { value; });
+ var Textarea = Textcomplete.editors.Textarea;
+ var editor = new Textarea(this[0]);
+ var textcomplete = new Textcomplete(editor);
+
+ textcomplete.register([bbco], {className:'acpopup', zIndex:1020});
+
+ this.on('textComplete:select', function(e, value, strategy) { value; });
- a.keypress(function(e){
+ this.keypress(function(e){
if (e.keyCode == 13) {
var x = listNewLineAutocomplete(this.id);
if(x) {