Files
habitica/website/client/mixins/groupsUtilities.js
Keith Holliday a317b351be Sept 23 fixes (#9074)
* 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
2017-09-25 13:02:12 -05:00

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;
},
},
};