This commit is contained in:
Mirco Wittrien 2020-08-29 08:55:29 +02:00
parent 279ae7f302
commit 12fffaeb3b
3 changed files with 39 additions and 11 deletions

View File

@ -1744,6 +1744,7 @@
DiscordObjects.Invite = BDFDB.ModuleUtils.findByPrototypes("getExpiresAt", "isExpired"); DiscordObjects.Invite = BDFDB.ModuleUtils.findByPrototypes("getExpiresAt", "isExpired");
DiscordObjects.Message = BDFDB.ModuleUtils.findByPrototypes("getReaction", "getAuthorName", "getChannelId"); DiscordObjects.Message = BDFDB.ModuleUtils.findByPrototypes("getReaction", "getAuthorName", "getChannelId");
DiscordObjects.Messages = BDFDB.ModuleUtils.findByPrototypes("jumpToMessage", "hasAfterCached", "forEach"); DiscordObjects.Messages = BDFDB.ModuleUtils.findByPrototypes("jumpToMessage", "hasAfterCached", "forEach");
DiscordObjects.Relationship = BDFDB.ModuleUtils.find(m => m.prototype && m.prototype.comparator && Array.isArray(m.prototype.comparator));
DiscordObjects.Timestamp = BDFDB.ModuleUtils.findByPrototypes("add", "dayOfYear", "hasAlignedHourOffset"); DiscordObjects.Timestamp = BDFDB.ModuleUtils.findByPrototypes("add", "dayOfYear", "hasAlignedHourOffset");
DiscordObjects.User = BDFDB.ModuleUtils.findByPrototypes("hasFlag", "isLocalBot", "isClaimed"); DiscordObjects.User = BDFDB.ModuleUtils.findByPrototypes("hasFlag", "isLocalBot", "isClaimed");
BDFDB.DiscordObjects = Object.assign({}, DiscordObjects); BDFDB.DiscordObjects = Object.assign({}, DiscordObjects);

File diff suppressed because one or more lines are too long

View File

@ -3,6 +3,9 @@
var BetterFriendList = (_ => { var BetterFriendList = (_ => {
var rerenderTimeout, sortKey, sortReversed, searchQuery, searchTimeout; var rerenderTimeout, sortKey, sortReversed, searchQuery, searchTimeout;
var settings = {}; var settings = {};
const placeHolderId = "PLACEHOLDER_BETTERFRIENDLIST";
const statusSortOrder = { const statusSortOrder = {
online: 0, online: 0,
streaming: 1, streaming: 1,
@ -16,7 +19,7 @@ var BetterFriendList = (_ => {
return class BetterFriendList { return class BetterFriendList {
getName () {return "BetterFriendList";} getName () {return "BetterFriendList";}
getVersion () {return "1.2.8";} getVersion () {return "1.2.9";}
getAuthor () {return "DevilBro";} getAuthor () {return "DevilBro";}
@ -59,6 +62,7 @@ var BetterFriendList = (_ => {
constructor () { constructor () {
this.changelog = { this.changelog = {
"progress":[["New Features & Name","Name was changed from BetterFriendCount to BetterFriendList and new features were added"]], "progress":[["New Features & Name","Name was changed from BetterFriendCount to BetterFriendList and new features were added"]],
"fixed":[["Empty Search","Empty search no longer stops the friend list from being displayed"]],
"improved":[["Settings","You can now disable the single features of this plugin"]], "improved":[["Settings","You can now disable the single features of this plugin"]],
"added":[["Mutual Servers","Mutual servers are now displayed in the friend list again"]] "added":[["Mutual Servers","Mutual servers are now displayed in the friend list again"]]
}; };
@ -69,6 +73,7 @@ var BetterFriendList = (_ => {
}, },
after: { after: {
TabBar: "render", TabBar: "render",
PeopleListSectionedLazy: "default",
FriendRow: "render", FriendRow: "render",
PendingRow: "default", PendingRow: "default",
BlockedRow: "render", BlockedRow: "render",
@ -189,17 +194,36 @@ var BetterFriendList = (_ => {
newSection = BDFDB.ArrayUtils.keySort(newSection.map(user => Object.assign({}, user, {statusIndex: statusSortOrder[user.status]})), sortKey); newSection = BDFDB.ArrayUtils.keySort(newSection.map(user => Object.assign({}, user, {statusIndex: statusSortOrder[user.status]})), sortKey);
if (sortReversed) newSection.reverse(); if (sortReversed) newSection.reverse();
} }
if (!newSection.length) {
let placeholder = new BDFDB.DiscordObjects.User({
id: placeHolderId,
username: placeHolderId
});
if (placeholder) newSection.push(new BDFDB.DiscordObjects.Relationship({
activities: [],
applicationStream: null,
isMobile: false,
key: placeHolderId,
mutualGuilds: [],
mutualGuildsLength: 0,
status: "offline",
type: BDFDB.DiscordConstants.RelationshipTypes.NONE,
user: placeholder,
usernameLower: placeholder.usernameNormalized
}));
}
return newSection; return newSection;
}); });
} }
let getSectionTitle = e.instance.props.getSectionTitle; let getSectionTitle = e.instance.props.getSectionTitle;
e.instance.props.getSectionTitle = (...args) => { e.instance.props.getSectionTitle = (...args) => {
let users = e.instance.props.statusSections.flat(10);
return BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.Flex, { return BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.Flex, {
align: BDFDB.LibraryComponents.Flex.Align.CENTER, align: BDFDB.LibraryComponents.Flex.Align.CENTER,
children: [ children: [
BDFDB.ReactUtils.createElement("div", { BDFDB.ReactUtils.createElement("div", {
className: BDFDB.disCN._betterfriendlisttitle, className: BDFDB.disCN._betterfriendlisttitle,
children: getSectionTitle(...args) children: getSectionTitle(...args).replace(users.length, users.filter(u => u && u.key != placeHolderId).length)
}), }),
settings.addSortOptions && [ settings.addSortOptions && [
{key: "usernameLower", label: BDFDB.LanguageUtils.LanguageStrings.FRIENDS_COLUMN_NAME}, {key: "usernameLower", label: BDFDB.LanguageUtils.LanguageStrings.FRIENDS_COLUMN_NAME},
@ -269,14 +293,17 @@ var BetterFriendList = (_ => {
BDFDB.TimeUtils.clear(rerenderTimeout); BDFDB.TimeUtils.clear(rerenderTimeout);
rerenderTimeout = BDFDB.TimeUtils.timeout(_ => {BDFDB.ModuleUtils.forceAllUpdates(this, "TabBar");}, 1000); rerenderTimeout = BDFDB.TimeUtils.timeout(_ => {BDFDB.ModuleUtils.forceAllUpdates(this, "TabBar");}, 1000);
} }
else if (settings.addMutualGuild && e.instance.props.mutualGuilds && e.instance.props.mutualGuilds.length) { else {
let [children, index] = BDFDB.ReactUtils.findParent(e.returnvalue, {name: "UserInfo"}); if (e.instance.props.user.id == placeHolderId) return null;
if (index > -1) children.splice(index + 1, 0, BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.GuildSummaryItem, { else if (settings.addMutualGuild && e.instance.props.mutualGuilds && e.instance.props.mutualGuilds.length) {
className: BDFDB.disCN._betterfriendlistmutualguilds, let [children, index] = BDFDB.ReactUtils.findParent(e.returnvalue, {name: "UserInfo"});
guilds: e.instance.props.mutualGuilds, if (index > -1) children.splice(index + 1, 0, BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.GuildSummaryItem, {
tooltip: true, className: BDFDB.disCN._betterfriendlistmutualguilds,
max: 10 guilds: e.instance.props.mutualGuilds,
}, true)); tooltip: true,
max: 10
}, true));
}
} }
} }