From 17c3496542adc9ddfe46e3bc73c0fe7776c30f78 Mon Sep 17 00:00:00 2001 From: fawn Date: Sun, 19 Mar 2023 08:13:17 +0000 Subject: [PATCH] feat(typingIndicator): Option to not show indicator for blocked users (#513) --- src/components/PatchHelper.tsx | 3 ++- src/plugins/typingIndicator.tsx | 13 +++++++++---- src/utils/patches.ts | 4 +--- src/utils/types.ts | 4 ++-- 4 files changed, 14 insertions(+), 10 deletions(-) diff --git a/src/components/PatchHelper.tsx b/src/components/PatchHelper.tsx index 65245283..f1fe22c0 100644 --- a/src/components/PatchHelper.tsx +++ b/src/components/PatchHelper.tsx @@ -19,7 +19,8 @@ import { debounce } from "@utils/debounce"; import { Margins } from "@utils/margins"; import { makeCodeblock } from "@utils/misc"; -import { canonicalizeMatch, canonicalizeReplace, ReplaceFn } from "@utils/patches"; +import { canonicalizeMatch, canonicalizeReplace } from "@utils/patches"; +import { ReplaceFn } from "@utils/types"; import { search } from "@webpack"; import { Button, Clipboard, Forms, Parser, React, Switch, Text, TextInput } from "@webpack/common"; diff --git a/src/plugins/typingIndicator.tsx b/src/plugins/typingIndicator.tsx index 9af09bca..4b0d1622 100644 --- a/src/plugins/typingIndicator.tsx +++ b/src/plugins/typingIndicator.tsx @@ -22,7 +22,7 @@ import { Devs } from "@utils/constants"; import { LazyComponent } from "@utils/misc"; import definePlugin, { OptionType } from "@utils/types"; import { find, findLazy, findStoreLazy } from "@webpack"; -import { ChannelStore, GuildMemberStore, Tooltip, UserStore, useStateFromStores } from "@webpack/common"; +import { ChannelStore, GuildMemberStore, RelationshipStore, Tooltip, UserStore, useStateFromStores } from "@webpack/common"; import { buildSeveralUsers } from "./typingTweaks"; @@ -57,9 +57,9 @@ function TypingIndicator({ channelId }: { channelId: string; }) { if (isChannelMuted) return null; } - delete typingUsers[UserStore.getCurrentUser().id]; + const myId = UserStore.getCurrentUser().id; - const typingUsersArray = Object.keys(typingUsers); + const typingUsersArray = Object.keys(typingUsers).filter(id => id !== myId && !(RelationshipStore.isBlocked(id) && !settings.store.includeBlockedUsers)); let tooltipText: string; switch (typingUsersArray.length) { @@ -108,13 +108,18 @@ const settings = definePluginSettings({ type: OptionType.BOOLEAN, description: "Whether to show the typing indicator for muted channels.", default: false + }, + includeBlockedUsers: { + type: OptionType.BOOLEAN, + description: "Whether to show the typing indicator for blocked users.", + default: false } }); export default definePlugin({ name: "TypingIndicator", description: "Adds an indicator if someone is typing on a channel.", - authors: [Devs.Nuckyz], + authors: [Devs.Nuckyz, Devs.obscurity], settings, patches: [ diff --git a/src/utils/patches.ts b/src/utils/patches.ts index 0f83d400..c30f7b17 100644 --- a/src/utils/patches.ts +++ b/src/utils/patches.ts @@ -16,9 +16,7 @@ * along with this program. If not, see . */ -import { PatchReplacement } from "./types"; - -export type ReplaceFn = (match: string, ...groups: string[]) => string; +import { PatchReplacement, ReplaceFn } from "./types"; export function canonicalizeMatch(match: RegExp | string) { if (typeof match === "string") return match; diff --git a/src/utils/types.ts b/src/utils/types.ts index 76a3d740..54c9674b 100644 --- a/src/utils/types.ts +++ b/src/utils/types.ts @@ -19,13 +19,13 @@ import { Command } from "@api/Commands"; import { Promisable } from "type-fest"; -import type { ReplaceFn } from "./patches"; - // exists to export default definePlugin({...}) export default function definePlugin

(p: P & Record) { return p; } +export type ReplaceFn = (match: string, ...groups: string[]) => string; + export interface PatchReplacement { match: string | RegExp; replace: string | ReplaceFn;