Merge pull request #664 from Xaekai/emote.rename

Emote renaming
This commit is contained in:
Calvin Montgomery 2017-05-18 22:02:50 -07:00 committed by GitHub
commit 02587dbb5c
3 changed files with 179 additions and 3 deletions

View file

@ -20,6 +20,30 @@ EmoteList.prototype = {
this.emotes = Array.prototype.slice.call(emotes); this.emotes = Array.prototype.slice.call(emotes);
}, },
emoteExists: function (emote){
if(this.emotes.filter((item)=>{ return item.name === emote.name }).length){
return true;
}
return false;
},
renameEmote: function (emote) {
var found = false;
for (var i = 0; i < this.emotes.length; i++) {
if (this.emotes[i].name === emote.old) {
found = true;
this.emotes[i] = emote;
delete this.emotes[i].old;
break;
}
}
if(found){
return true;
}
return false;
},
updateEmote: function (emote) { updateEmote: function (emote) {
var found = false; var found = false;
for (var i = 0; i < this.emotes.length; i++) { for (var i = 0; i < this.emotes.length; i++) {
@ -118,6 +142,7 @@ EmoteModule.prototype.packInfo = function (data, isAdmin) {
}; };
EmoteModule.prototype.onUserPostJoin = function (user) { EmoteModule.prototype.onUserPostJoin = function (user) {
user.socket.on("renameEmote", this.handleRenameEmote.bind(this, user));
user.socket.on("updateEmote", this.handleUpdateEmote.bind(this, user)); user.socket.on("updateEmote", this.handleUpdateEmote.bind(this, user));
user.socket.on("importEmotes", this.handleImportEmotes.bind(this, user)); user.socket.on("importEmotes", this.handleImportEmotes.bind(this, user));
user.socket.on("moveEmote", this.handleMoveEmote.bind(this, user)); user.socket.on("moveEmote", this.handleMoveEmote.bind(this, user));
@ -133,6 +158,51 @@ EmoteModule.prototype.sendEmotes = function (users) {
}); });
}; };
EmoteModule.prototype.handleRenameEmote = function (user, data) {
if (typeof data !== "object") {
return;
}
/*
** This shouldn't be able to happen,
** but we have idiots that like to send handcrafted frames to fuck with shit
*/
if (typeof data.old !== "string"){
return;
}
if (!this.channel.modules.permissions.canEditEmotes(user)) {
return;
}
var e = this.emotes.emoteExists(data);
var f = validateEmote(data);
if (!f || e) {
var message = "Unable to rename emote '" + JSON.stringify(data) + "'. " +
"Please contact an administrator for assistance.";
if (!data.image || !data.name) {
message = "Emote names and images must not be blank.";
}
if (e) {
message = "Emote already exists.";
}
user.socket.emit("errorMsg", {
msg: message,
alert: true
});
return;
}
// See comment above
var success = this.emotes.renameEmote(Object.assign({}, f));
if(!success){ return; }
var chan = this.channel;
chan.broadcastAll("renameEmote", f);
chan.logger.log(`[mod] ${user.getName()} renamed emote: ${f.old} -> ${f.name}`);
};
EmoteModule.prototype.handleUpdateEmote = function (user, data) { EmoteModule.prototype.handleUpdateEmote = function (user, data) {
if (typeof data !== "object") { if (typeof data !== "object") {
return; return;

View file

@ -1019,6 +1019,58 @@ Callbacks = {
CSEMOTELIST.handleChange(); CSEMOTELIST.handleChange();
}, },
renameEmote: function (data) {
var badBefore = /\s/g.test(data.old);
var badAfter = /\s/g.test(data.name);
var oldName = data.old;
delete data.old;
data.regex = new RegExp(data.source, "gi");
for (var i = 0; i < CHANNEL.emotes.length; i++) {
if (CHANNEL.emotes[i].name === oldName) {
CHANNEL.emotes[i] = data;
break;
}
}
// Now bad
if(badAfter){
// But wasn't bad before: Add it to bad list
if(!badBefore){
CHANNEL.badEmotes.push(data);
delete CHANNEL.emoteMap[oldName];
}
// Was bad before too: Update
else {
for (var i = 0; i < CHANNEL.badEmotes.length; i++) {
if (CHANNEL.badEmotes[i].name === oldName) {
CHANNEL.badEmotes[i] = data;
break;
}
}
}
}
// Not bad now
else {
// But was bad before: Drop from list
if(badBefore){
for (var i = 0; i < CHANNEL.badEmotes.length; i++) {
if (CHANNEL.badEmotes[i].name === oldName) {
CHANNEL.badEmotes.splice(i, 1);
break;
}
}
} else {
delete CHANNEL.emoteMap[oldName];
}
CHANNEL.emoteMap[data.name] = data;
}
EMOTELIST.handleChange();
CSEMOTELIST.handleChange();
},
removeEmote: function (data) { removeEmote: function (data) {
var found = -1; var found = -1;
for (var i = 0; i < CHANNEL.emotes.length; i++) { for (var i = 0; i < CHANNEL.emotes.length; i++) {

View file

@ -3103,7 +3103,7 @@ CSEmoteList.prototype.loadPage = function (page) {
var row = document.createElement("tr"); var row = document.createElement("tr");
tbody.appendChild(row); tbody.appendChild(row);
(function (emote) { (function (emote, row) {
// Add delete button // Add delete button
var tdDelete = document.createElement("td"); var tdDelete = document.createElement("td");
var btnDelete = document.createElement("button"); var btnDelete = document.createElement("button");
@ -3121,13 +3121,67 @@ CSEmoteList.prototype.loadPage = function (page) {
}; };
// Add emote name // Add emote name
// TODO: editable
var tdName = document.createElement("td"); var tdName = document.createElement("td");
var nameDisplay = document.createElement("code"); var nameDisplay = document.createElement("code");
nameDisplay.textContent = emote.name; nameDisplay.textContent = emote.name;
tdName.appendChild(nameDisplay); tdName.appendChild(nameDisplay);
row.appendChild(tdName); row.appendChild(tdName);
var $nameDisplay = $(nameDisplay);
$nameDisplay.click(function (clickEvent) {
$nameDisplay.detach();
var editInput = document.createElement("input");
editInput.className = "form-control";
editInput.type = "text";
editInput.value = emote.name;
tdName.appendChild(editInput);
editInput.focus();
function save() {
var val = editInput.value;
tdName.removeChild(editInput);
tdName.appendChild(nameDisplay);
// Nothing was changed
if(val === emote.name){ return }
// Emote name already exists
if( CHANNEL.emotes.filter(function(emote){ return emote.name === val }).length ){
/*
* Since we are already in a modal
* and Bootstrap doesn't have supermodals
* we will make a self destructing warning
* as a row in the table
*/
var wrow = document.createElement("tr");
var tdBlankDel = document.createElement("td"); wrow.appendChild(tdBlankDel);
var tdWarnMess = document.createElement("td"); wrow.appendChild(tdWarnMess);
var warnSpan = document.createElement("p"); tdWarnMess.appendChild(warnSpan);
warnSpan.className = "text-warning";
warnSpan.textContent = "An emote of that name already exists.";
tdWarnMess.colSpan = "2";
row.insertAdjacentElement("beforebegin", wrow)
$(wrow).delay(2500).fadeOut('slow', function(){ $(this).remove() });
return;
}
socket.emit("renameEmote", {
old: emote.name,
image: emote.image,
name: val
});
}
editInput.onblur = save;
editInput.onkeyup = function (event) {
if (event.keyCode === 13) {
save();
}
};
});
// Add emote image // Add emote image
var tdImage = document.createElement("td"); var tdImage = document.createElement("td");
var urlDisplay = document.createElement("code"); var urlDisplay = document.createElement("code");
@ -3173,7 +3227,7 @@ CSEmoteList.prototype.loadPage = function (page) {
} }
}; };
}); });
})(this.emotes[i]); })(this.emotes[i], row);
} }
}; };