mirror of https://github.com/calzoneman/sync.git
Add emote search, sort toggle
This commit is contained in:
parent
d3e2433ee6
commit
8927613da7
|
@ -180,6 +180,13 @@ html(lang="en")
|
||||||
button.close(data-dismiss="modal", aria-hidden="true") ×
|
button.close(data-dismiss="modal", aria-hidden="true") ×
|
||||||
h4 Emote List
|
h4 Emote List
|
||||||
.modal-body
|
.modal-body
|
||||||
|
form.form-inline(action="javascript:void(0)")
|
||||||
|
.form-group
|
||||||
|
input#emotelist-search.form-control(type="text", placeholder="Search")
|
||||||
|
.checkbox
|
||||||
|
label
|
||||||
|
input#emotelist-alphabetical(type="checkbox")
|
||||||
|
| Sort alphabetically
|
||||||
#emotelist-paginator-container
|
#emotelist-paginator-container
|
||||||
table
|
table
|
||||||
tbody
|
tbody
|
||||||
|
|
|
@ -39,13 +39,22 @@ input.form-control[type="email"], textarea.form-control {
|
||||||
background-color: rgba(65, 69, 74, 0.7) !important;
|
background-color: rgba(65, 69, 74, 0.7) !important;
|
||||||
}
|
}
|
||||||
|
|
||||||
.profile-box, .user-dropdown, #emotelist td {
|
.profile-box, .user-dropdown {
|
||||||
color: #c8c8c8;
|
color: #c8c8c8;
|
||||||
background-color: rgba(28, 30, 34, 0.95);
|
background-color: rgba(28, 30, 34, 0.95);
|
||||||
border: 1px solid #000000 !important;
|
border: 1px solid #000000 !important;
|
||||||
border-radius: 0px !important;
|
border-radius: 0px !important;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#emotelist table {
|
||||||
|
background-color: #2a2d30;
|
||||||
|
}
|
||||||
|
|
||||||
|
#emotelist td {
|
||||||
|
background-color: rgba(28, 30, 34, 0.95);
|
||||||
|
border: none;
|
||||||
|
}
|
||||||
|
|
||||||
.profile-image {
|
.profile-image {
|
||||||
border-radius: 0px;
|
border-radius: 0px;
|
||||||
border: solid 1px #000000 !important;
|
border: solid 1px #000000 !important;
|
||||||
|
|
|
@ -114,7 +114,8 @@ var USEROPTS = {
|
||||||
default_quality : getOrDefault("default_quality", ""),
|
default_quality : getOrDefault("default_quality", ""),
|
||||||
boop : getOrDefault("boop", "never"),
|
boop : getOrDefault("boop", "never"),
|
||||||
secure_connection : getOrDefault("secure_connection", false),
|
secure_connection : getOrDefault("secure_connection", false),
|
||||||
show_shadowchat : getOrDefault("show_shadowchat", false)
|
show_shadowchat : getOrDefault("show_shadowchat", false),
|
||||||
|
emotelist_sort : getOrDefault("emotelist_sort", true)
|
||||||
};
|
};
|
||||||
|
|
||||||
/* Backwards compatibility check */
|
/* Backwards compatibility check */
|
||||||
|
|
|
@ -161,6 +161,7 @@ NewPaginator.prototype.loadButtons = function (page) {
|
||||||
}
|
}
|
||||||
|
|
||||||
var numPages = Math.ceil(this.numItems / this.itemsPerPage);
|
var numPages = Math.ceil(this.numItems / this.itemsPerPage);
|
||||||
|
numPages = Math.max(numPages, 1);
|
||||||
var numBtns = Math.min(this.btnBefore + this.btnAfter + 1, numPages);
|
var numBtns = Math.min(this.btnBefore + this.btnAfter + 1, numPages);
|
||||||
var start;
|
var start;
|
||||||
if (page < this.btnBefore) {
|
if (page < this.btnBefore) {
|
||||||
|
|
21
www/js/ui.js
21
www/js/ui.js
|
@ -766,3 +766,24 @@ applyOpts();
|
||||||
$("#emotelistbtn").click(function () {
|
$("#emotelistbtn").click(function () {
|
||||||
EMOTELIST.show();
|
EMOTELIST.show();
|
||||||
});
|
});
|
||||||
|
|
||||||
|
$("#emotelist-search").keyup(function () {
|
||||||
|
var value = this.value.toLowerCase();
|
||||||
|
if (value) {
|
||||||
|
EMOTELIST.filter = function (emote) {
|
||||||
|
return emote.name.toLowerCase().indexOf(value) >= 0;
|
||||||
|
};
|
||||||
|
} else {
|
||||||
|
EMOTELIST.filter = null;
|
||||||
|
}
|
||||||
|
EMOTELIST.handleChange();
|
||||||
|
EMOTELIST.loadPage(0);
|
||||||
|
});
|
||||||
|
|
||||||
|
$("#emotelist-alphabetical").prop("checked", USEROPTS.emotelist_sort);
|
||||||
|
$("#emotelist-alphabetical").change(function () {
|
||||||
|
USEROPTS.emotelist_sort = this.checked;
|
||||||
|
setOpt("emotelist_sort", USEROPTS.emotelist_sort);
|
||||||
|
EMOTELIST.handleChange();
|
||||||
|
EMOTELIST.loadPage(0);
|
||||||
|
});
|
||||||
|
|
|
@ -2858,9 +2858,10 @@ function EmoteList() {
|
||||||
this.page = 0;
|
this.page = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
EmoteList.prototype.show = function () {
|
EmoteList.prototype.handleChange = function () {
|
||||||
if (this.emoteListChanged) {
|
this.emotes = CHANNEL.emotes.slice();
|
||||||
this.emotes = CHANNEL.emotes.slice().sort(function (a, b) {
|
if (USEROPTS.emotelist_sort) {
|
||||||
|
this.emotes.sort(function (a, b) {
|
||||||
var x = a.name.toLowerCase();
|
var x = a.name.toLowerCase();
|
||||||
var y = b.name.toLowerCase();
|
var y = b.name.toLowerCase();
|
||||||
|
|
||||||
|
@ -2872,6 +2873,12 @@ EmoteList.prototype.show = function () {
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
if (this.filter) {
|
||||||
|
this.emotes = this.emotes.filter(this.filter);
|
||||||
|
}
|
||||||
|
|
||||||
this.paginator = new NewPaginator(this.emotes.length, this.itemsPerPage,
|
this.paginator = new NewPaginator(this.emotes.length, this.itemsPerPage,
|
||||||
this.loadPage.bind(this));
|
this.loadPage.bind(this));
|
||||||
var container = document.getElementById("emotelist-paginator-container");
|
var container = document.getElementById("emotelist-paginator-container");
|
||||||
|
@ -2879,6 +2886,11 @@ EmoteList.prototype.show = function () {
|
||||||
container.appendChild(this.paginator.elem);
|
container.appendChild(this.paginator.elem);
|
||||||
this.paginator.loadPage(this.page);
|
this.paginator.loadPage(this.page);
|
||||||
this.emoteListChanged = false;
|
this.emoteListChanged = false;
|
||||||
|
};
|
||||||
|
|
||||||
|
EmoteList.prototype.show = function () {
|
||||||
|
if (this.emoteListChanged) {
|
||||||
|
this.handleChange();
|
||||||
}
|
}
|
||||||
|
|
||||||
this.modal.modal();
|
this.modal.modal();
|
||||||
|
@ -2891,7 +2903,7 @@ EmoteList.prototype.loadPage = function (page) {
|
||||||
var row;
|
var row;
|
||||||
var start = page * this.itemsPerPage;
|
var start = page * this.itemsPerPage;
|
||||||
if (start >= this.emotes.length) return;
|
if (start >= this.emotes.length) return;
|
||||||
var end = Math.min(start + this.itemsPerPage, this.emotes.length - 1);
|
var end = Math.min(start + this.itemsPerPage, this.emotes.length);
|
||||||
var _this = this;
|
var _this = this;
|
||||||
|
|
||||||
for (var i = start; i < end; i++) {
|
for (var i = start; i < end; i++) {
|
||||||
|
|
Loading…
Reference in New Issue