Improve details of emoji/chan/nick/command autocompletion
- Make dropdown items match context menu items - Disable transparency on dropdown item links - Clean up help page additions - Better align help page autocompletion characters - Use ES6 features (`const`, arrow functions, method definition shorthands) - Use `Array#filter` instead of `$.map` - Do not display `@` in nick completion *when* only one `@` is used (to be less confusing and more consistent)
This commit is contained in:
parent
29d8bc9d3d
commit
e000ba45df
@ -1338,8 +1338,7 @@ kbd {
|
|||||||
|
|
||||||
#help .help-item .subject {
|
#help .help-item .subject {
|
||||||
white-space: nowrap;
|
white-space: nowrap;
|
||||||
padding-right: 10px;
|
padding-right: 15px;
|
||||||
min-width: 150px;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#help .help-item .description p {
|
#help .help-item .description p {
|
||||||
@ -1528,19 +1527,14 @@ kbd {
|
|||||||
display: inline-block;
|
display: inline-block;
|
||||||
}
|
}
|
||||||
|
|
||||||
.textcomplete-item {
|
|
||||||
border-bottom-color: rgba(0, 0, 0, .1);
|
|
||||||
border-bottom-style: solid;
|
|
||||||
border-bottom-width: 1px;
|
|
||||||
margin-top: 0;
|
|
||||||
margin-bottom: 0;
|
|
||||||
padding: 10px 8px;
|
|
||||||
}
|
|
||||||
|
|
||||||
.textcomplete-item a {
|
.textcomplete-item a {
|
||||||
color: #333;
|
color: #333;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.textcomplete-item a:hover {
|
||||||
|
opacity: 1;
|
||||||
|
}
|
||||||
|
|
||||||
.textcomplete-item .emoji {
|
.textcomplete-item .emoji {
|
||||||
margin-right: 8px;
|
margin-right: 8px;
|
||||||
width: 16px;
|
width: 16px;
|
||||||
|
@ -534,8 +534,10 @@
|
|||||||
|
|
||||||
<h2>Autocompletion</h2>
|
<h2>Autocompletion</h2>
|
||||||
|
|
||||||
<p> Start typing the following characters followed by any letter to
|
<p>
|
||||||
trigger the autocompletion dropdown:</p>
|
Start typing the following characters followed by any letter to
|
||||||
|
trigger the autocompletion dropdown:
|
||||||
|
</p>
|
||||||
|
|
||||||
<div class="help-item">
|
<div class="help-item">
|
||||||
<div class="subject">
|
<div class="subject">
|
||||||
@ -551,7 +553,7 @@
|
|||||||
<code>#</code>
|
<code>#</code>
|
||||||
</div>
|
</div>
|
||||||
<div class="description">
|
<div class="description">
|
||||||
<p> Chan </p>
|
<p>Channel</p>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
@ -573,7 +575,6 @@
|
|||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
|
||||||
<h2>Commands</h2>
|
<h2>Commands</h2>
|
||||||
|
|
||||||
<p>All commands can be autocompleted with <kbd>tab</kbd>.</p>
|
<p>All commands can be autocompleted with <kbd>tab</kbd>.</p>
|
||||||
|
@ -45,73 +45,66 @@ $(function() {
|
|||||||
|
|
||||||
// Autocompletion Strategies
|
// Autocompletion Strategies
|
||||||
|
|
||||||
var emojiStrategy = {
|
const emojiStrategy = {
|
||||||
id: "emoji",
|
id: "emoji",
|
||||||
match: /\B:([-+\w]*)$/,
|
match: /\B:([-+\w]*)$/,
|
||||||
search: function(term, callback) {
|
search(term, callback) {
|
||||||
callback($.map(Object.keys(emojiMap), function(e) {
|
callback(Object.keys(emojiMap).filter(name => name.indexOf(term) === 0));
|
||||||
return e.indexOf(term) === 0 ? e : null;
|
|
||||||
}));
|
|
||||||
},
|
},
|
||||||
template: function(value) {
|
template(value) {
|
||||||
return `<span class="emoji">${emojiMap[value]}</span> ${value}`;
|
return `<span class="emoji">${emojiMap[value]}</span> ${value}`;
|
||||||
},
|
},
|
||||||
replace: function(value) {
|
replace(value) {
|
||||||
return emojiMap[value];
|
return emojiMap[value];
|
||||||
},
|
},
|
||||||
index: 1
|
index: 1
|
||||||
};
|
};
|
||||||
|
|
||||||
var nicksStrategy = {
|
const nicksStrategy = {
|
||||||
id: "nicks",
|
id: "nicks",
|
||||||
match: /\B(@([a-zA-Z_[\]\\^{}|`@][a-zA-Z0-9_[\]\\^{}|`-]*)?)$/,
|
match: /\B(@([a-zA-Z_[\]\\^{}|`@][a-zA-Z0-9_[\]\\^{}|`-]*)?)$/,
|
||||||
search: function(term, callback) {
|
search(term, callback) {
|
||||||
term = term.slice(1);
|
term = term.slice(1);
|
||||||
if (term[0] === "@") {
|
if (term[0] === "@") {
|
||||||
callback(completeNicks(term.slice(1)).map(function(val) {
|
callback(completeNicks(term.slice(1)).map(val => "@" + val));
|
||||||
return "@" + val;
|
|
||||||
}));
|
|
||||||
} else {
|
} else {
|
||||||
callback(completeNicks(term));
|
callback(completeNicks(term));
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
template: function(value) {
|
template(value) {
|
||||||
if (value[0] === "@") {
|
|
||||||
return value;
|
return value;
|
||||||
}
|
|
||||||
return "@" + value;
|
|
||||||
},
|
},
|
||||||
replace: function(value) {
|
replace(value) {
|
||||||
return value;
|
return value;
|
||||||
},
|
},
|
||||||
index: 1
|
index: 1
|
||||||
};
|
};
|
||||||
|
|
||||||
var chanStrategy = {
|
const chanStrategy = {
|
||||||
id: "chans",
|
id: "chans",
|
||||||
match: /\B((#|\+|&|![A-Z0-9]{5})([^\x00\x0A\x0D\x20\x2C\x3A]+(:[^\x00\x0A\x0D\x20\x2C\x3A]*)?)?)$/,
|
match: /\B((#|\+|&|![A-Z0-9]{5})([^\x00\x0A\x0D\x20\x2C\x3A]+(:[^\x00\x0A\x0D\x20\x2C\x3A]*)?)?)$/,
|
||||||
search: function(term, callback, match) {
|
search(term, callback, match) {
|
||||||
callback(completeChans(match[0]));
|
callback(completeChans(match[0]));
|
||||||
},
|
},
|
||||||
template: function(value) {
|
template(value) {
|
||||||
return value;
|
return value;
|
||||||
},
|
},
|
||||||
replace: function(value) {
|
replace(value) {
|
||||||
return value;
|
return value;
|
||||||
},
|
},
|
||||||
index: 1
|
index: 1
|
||||||
};
|
};
|
||||||
|
|
||||||
var commandStrategy = {
|
const commandStrategy = {
|
||||||
id: "commands",
|
id: "commands",
|
||||||
match: /^\/(\w*)$/,
|
match: /^\/(\w*)$/,
|
||||||
search: function(term, callback) {
|
search(term, callback) {
|
||||||
callback(completeCommands("/" + term));
|
callback(completeCommands("/" + term));
|
||||||
},
|
},
|
||||||
template: function(value) {
|
template(value) {
|
||||||
return value;
|
return value;
|
||||||
},
|
},
|
||||||
replace: function(value) {
|
replace(value) {
|
||||||
return value;
|
return value;
|
||||||
},
|
},
|
||||||
index: 1
|
index: 1
|
||||||
@ -1360,34 +1353,30 @@ $(function() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
function completeNicks(word) {
|
function completeNicks(word) {
|
||||||
var users = chat.find(".active").find(".users");
|
const users = chat.find(".active").find(".users");
|
||||||
var words = users.data("nicks");
|
const words = users.data("nicks");
|
||||||
|
|
||||||
return $.grep(
|
return $.grep(
|
||||||
words,
|
words,
|
||||||
function(w) {
|
w => !w.toLowerCase().indexOf(word.toLowerCase())
|
||||||
return !w.toLowerCase().indexOf(word.toLowerCase());
|
|
||||||
}
|
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
function completeCommands(word) {
|
function completeCommands(word) {
|
||||||
var words = constants.commands.slice();
|
const words = constants.commands.slice();
|
||||||
|
|
||||||
return $.grep(
|
return $.grep(
|
||||||
words,
|
words,
|
||||||
function(w) {
|
w => !w.toLowerCase().indexOf(word.toLowerCase())
|
||||||
return !w.toLowerCase().indexOf(word.toLowerCase());
|
|
||||||
}
|
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
function completeChans(word) {
|
function completeChans(word) {
|
||||||
var words = [];
|
const words = [];
|
||||||
|
|
||||||
sidebar.find(".chan")
|
sidebar.find(".chan")
|
||||||
.each(function() {
|
.each(function() {
|
||||||
var self = $(this);
|
const self = $(this);
|
||||||
if (!self.hasClass("lobby")) {
|
if (!self.hasClass("lobby")) {
|
||||||
words.push(self.data("title"));
|
words.push(self.data("title"));
|
||||||
}
|
}
|
||||||
@ -1395,9 +1384,7 @@ $(function() {
|
|||||||
|
|
||||||
return $.grep(
|
return $.grep(
|
||||||
words,
|
words,
|
||||||
function(w) {
|
w => !w.toLowerCase().indexOf(word.toLowerCase())
|
||||||
return !w.toLowerCase().indexOf(word.toLowerCase());
|
|
||||||
}
|
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user