mirror of
https://github.com/HabitRPG/habitica.git
synced 2025-12-16 14:17:22 +01:00
* Discover challenges * Fixed hero loading * Moved add task button * Fixed bailey showing * Added logs for bad sub data * Fixed blurb editing * Added confirmation for deleteing message * Reset invite modals on invite * fixed group member sorting * Fixed chat time styles * Fixed hover on liked * Fixed like count * Added reverse * Fixed editing party * Added leader conditions * Added search * Added loading * Reset members when leaving party * Rounded pending * Fixed overflow on collecting quests * Added to invite friends * Hid summary from party * Fixed button styles * Fixed button class * Removed okay button * Fixed renav for profile modal * Added subscription back to menu * Fixed static link * Added daily due setting * Added local auth adding * Fixed centering of text * Removed message locally * Added count for new message * Added style fix for profile pet * Fixed achievement popovers * Fixed white boxes * Added plain color backgrounds * fixed challenge mutability * Fixed challenge editing * Added notation for large numbers * Add color text to guild sizes * Removed membership filters from discover challenges * Added invites to group * Cmd + enter send message * Made leader clickable * Updated group validation * Added cancelling autocomplete * Added mention icon * Added removing member * Removed extra string
93 lines
2.9 KiB
JavaScript
93 lines
2.9 KiB
JavaScript
import intersection from 'lodash/intersection';
|
|
|
|
export default {
|
|
filters: {
|
|
// https://stackoverflow.com/questions/2685911/is-there-a-way-to-round-numbers-into-a-reader-friendly-format-e-g-1-1k
|
|
abbrNum: (number) => {
|
|
let decPlaces = 2;
|
|
decPlaces = Math.pow(10, decPlaces);
|
|
|
|
let abbrev = ['k', 'm', 'b', 't'];
|
|
for (let i = abbrev.length - 1; i >= 0; i--) {
|
|
let size = Math.pow(10, (i + 1) * 3);
|
|
|
|
if (size <= number) {
|
|
number = Math.round(number * decPlaces / size) / decPlaces;
|
|
|
|
if (number === 1000 && i < abbrev.length - 1) {
|
|
number = 1;
|
|
i++;
|
|
}
|
|
|
|
number += abbrev[i];
|
|
break;
|
|
}
|
|
}
|
|
|
|
return number;
|
|
},
|
|
},
|
|
methods: {
|
|
isMemberOfGroup (user, group) {
|
|
if (group._id === this.$store.state.constants.TAVERN_ID) return true;
|
|
|
|
// If the group is a guild, just check for an intersection with the
|
|
// current user's guilds, rather than checking the members of the group.
|
|
if (group.type === 'guild') {
|
|
return user.guilds.indexOf(group._id) !== -1;
|
|
}
|
|
|
|
// Similarly, if we're dealing with the user's current party, return true.
|
|
if (group.type === 'party') {
|
|
return user.party._id === group._id;
|
|
}
|
|
|
|
return false;
|
|
},
|
|
isLeaderOfGroup (user, group) {
|
|
return user._id === group.leader || user._id === group.leader._id;
|
|
},
|
|
filterGuild (group, filters, search, user) {
|
|
let passedSearch = true;
|
|
let hasCategories = true;
|
|
let isMember = true;
|
|
let isLeader = true;
|
|
let correctSize = true;
|
|
|
|
if (group._id === this.$store.state.constants.TAVERN_ID || group._id === 'habitrpg') return false;
|
|
|
|
if (search) {
|
|
passedSearch = group.name.toLowerCase().indexOf(search.toLowerCase()) >= 0;
|
|
}
|
|
|
|
if (filters.categories && filters.categories.length > 0) {
|
|
let intersectingCats = intersection(filters.categories, group.categorySlugs);
|
|
hasCategories = intersectingCats.length > 0;
|
|
}
|
|
|
|
let filteringRole = filters.roles && filters.roles.length > 0;
|
|
if (filteringRole && filters.roles.indexOf('member') !== -1) {
|
|
isMember = this.isMemberOfGroup(user, group);
|
|
}
|
|
|
|
if (filteringRole && filters.roles.indexOf('guild_leader') !== -1) {
|
|
isLeader = this.isLeaderOfGroup(user, group);
|
|
}
|
|
|
|
if (filters.guildSize && filters.guildSize.indexOf('gold_tier') !== -1) {
|
|
correctSize = group.memberCount > 1000;
|
|
}
|
|
|
|
if (filters.guildSize && filters.guildSize.indexOf('silver_tier') !== -1) {
|
|
correctSize = group.memberCount > 100 && group.memberCount < 999;
|
|
}
|
|
|
|
if (filters.guildSize && filters.guildSize.indexOf('bronze_tier') !== -1) {
|
|
correctSize = group.memberCount < 99;
|
|
}
|
|
|
|
return passedSearch && hasCategories && isMember && isLeader && correctSize;
|
|
},
|
|
},
|
|
};
|