improvement!: remove "color" attribute for users and instead let the clients decide

This commit is contained in:
hippoz 2021-10-21 22:22:35 +03:00
parent c101db1de6
commit 80ed58c856
No known key found for this signature in database
GPG key ID: 7C52899193467641
3 changed files with 4 additions and 39 deletions

View file

@ -87,8 +87,7 @@ app.post("/account/create", [
username, username,
email, email,
password: hashedPassword, password: hashedPassword,
role: startingRole, role: startingRole
color: User.generateColorFromUsername(username)
}); });
const userObject = await user.getPublicObject(); const userObject = await user.getPublicObject();

View file

@ -7,7 +7,6 @@ const userSchema = new mongoose.Schema({
password: String, password: String,
email: String, email: String,
role: String, role: String,
color: String
}); });
userSchema.method("getPublicObject", function() { userSchema.method("getPublicObject", function() {
@ -15,7 +14,6 @@ userSchema.method("getPublicObject", function() {
username: this.username, username: this.username,
permissionLevel: config.roleMap[this.role], permissionLevel: config.roleMap[this.role],
role: this.role, role: this.role,
color: this.color,
_id: this._id _id: this._id
}; };
}); });
@ -27,51 +25,20 @@ userSchema.method("getFullObject", function() {
email: this.email, email: this.email,
permissionLevel: config.roleMap[this.role], permissionLevel: config.roleMap[this.role],
role: this.role, role: this.role,
color: this.color,
_id: this._id _id: this._id
}; };
}); });
const User = mongoose.model("User", userSchema); const User = mongoose.model("User", userSchema);
// NOTE(hippoz): These are all actually material design colors, taken from https://material-ui.com/customization/color/#playground
const colors = [
"#f44336",
"#e91e63",
"#9c27b0",
"#673ab7",
"#3f51b5",
"#2196f3",
"#03a9f4",
"#00bcd4",
"#009688",
"#4caf50",
"#8bc34a",
"#cddc39",
"#ffeb3b",
"#ffc107",
"#ff9800",
"#ff5722"
];
User.generateColorFromUsername = function(username) {
let sum = 0;
for (let i in username) {
sum += username.charCodeAt(i);
}
const colorIndex = sum % colors.length;
return colors[colorIndex];
};
User.findByUsername = async function(username) { User.findByUsername = async function(username) {
return await User.findOne({ username }).exec(); return await User.findOne({ username }).exec();
}; };
User.getPulicFields = function(isPartial=false) { User.getPulicFields = function(isPartial=false) {
if (isPartial) { if (isPartial)
return "username _id color"; return "username _id";
} return "username role _id";
return "username role _id color";
}; };
module.exports = User; module.exports = User;

View file

@ -223,7 +223,6 @@ Used mostly for messages.
| - | - | | - | - |
| _id | The id of the user | | _id | The id of the user |
| name | The name of the user | | name | The name of the user |
| color | A hex color that represents that user |
## Message author object ## Message author object