1
0
Fork 1
mirror of https://github.com/Vendicated/Vencord.git synced 2025-01-25 16:56:23 +00:00

adding the api

This commit is contained in:
programminglaboratorys 2024-04-26 14:46:13 +03:00
parent 4fce88fa8f
commit 955232f4d6
4 changed files with 101 additions and 0 deletions

67
src/api/Tablist.tsx Normal file
View file

@ -0,0 +1,67 @@
import { Channel } from "discord-types/general";
//import { Logger } from "@utils/Logger";
//const logger = new Logger("Tablist"); useless
export interface ExpressionMate {
CHAT_INPUT_BUTTON_CLASSNAME: string;
expressionPickerViewType: object;
expressionPickerWidths: { MIN: "min", MAX: "max"; };
MIN_EXPRESSION_PICKER_WIDTH: number; // what's really matter here
}
export interface TablistButtonProps {
id?: string;
"aria-controls": string;
"aria-selected": boolean;
isActive: boolean;
viewType: string;
children: string | JSX.Element;
autoFocus?: boolean;
[key: string]: any;
}
export interface TablistPanelProps {
selectedTab: string;
channel: Channel;
expressionMate: ExpressionMate;
}
export type TablistButtonComponent = (props: TablistButtonProps) => JSX.Element | null;
export type TablistPanelComponent = (props: TablistPanelProps) => JSX.Element | null;
export interface TablistItem {
tab: string,
Component: TablistPanelComponent;
autoFocus?: boolean;
}
const TablistComponents = new Map<string, TablistItem>();
export const addTablistButton = (id: string, tab: string, PanelComponent: TablistPanelComponent, autoFocus?: boolean) => TablistComponents.set(id, { tab: tab, Component: PanelComponent, autoFocus: autoFocus });
export const removeTablistButton = (id: string) => TablistComponents.delete(id);
export function* RenderButtons(TablistButtonComponent: TablistButtonComponent, selectedTab: string, expressionMate: ExpressionMate) {
for (const tab in TablistComponents) {
yield (<TablistButtonComponent
id={tab + "-picker-tab"}
aria-controls={tab + "-picker-tab-panel"}
aria-selected={tab === selectedTab}
viewType={tab}
isActive={tab === selectedTab}
expressionMate={expressionMate}
>{TablistComponents[tab].tab}
</TablistButtonComponent>);
}
}
export function* TabPanels(selectedTab: string, expressionMate: ExpressionMate, channel: Channel) {
for (const tab in TablistComponents) {
if (tab !== selectedTab) { continue; }
let PanelComponent: TablistPanelComponent = TablistComponents[tab].Component;
yield (<PanelComponent selectedTab={selectedTab} channel={channel} expressionMate={expressionMate} />);
}
}

View file

@ -31,6 +31,7 @@ import * as $Notifications from "./Notifications";
import * as $ServerList from "./ServerList";
import * as $Settings from "./Settings";
import * as $Styles from "./Styles";
import * as $Tablist from "./Tablist";
/**
* An API allowing you to listen to Message Clicks or run your own logic
@ -110,3 +111,8 @@ export const ContextMenu = $ContextMenu;
* An API allowing you to add buttons to the chat input
*/
export const ChatButtons = $ChatButtons;
/**
* An API allowing you to add panels to the expression picker
*/
export const Tablist = $Tablist;

View file

@ -0,0 +1,24 @@
import definePlugin from "@utils/types";
import { Devs } from "@utils/constants";
export default definePlugin({
name: "TablistApi",
description: "API to add panels to the expression picker",
authors: [Devs.iamme],
patches: [
{
find: ".EXPRESSION_PICKER_CATEGORIES_A11Y_LABEL",
replacement: [
{
match: /\.jsx)\((\i),\{id:\i\.\i,.+?,"aria-selected":(\i)===.+?,viewType:(\i).+?\}\)/,//\]
replace: "$&,...Vencord.Api.Tablist.RenderButtons($1, $2, $3)"
},
{
match: /null,(\i)===(\i)\.ExpressionPickerViewType\.EMOJI\?.{0,55}channel:(\i),.+?\):null/,
replace: "$&,...Vencord.Api.Tablist.TabPanels($1, $2, $3)"
}
]
}
]
});

View file

@ -438,6 +438,10 @@ export const Devs = /* #__PURE__*/ Object.freeze({
name: "Sqaaakoi",
id: 259558259491340288n
},
iamme: {
name: "i am me",
id: 984392761929256980n
},
Byron: {
name: "byeoon",
id: 1167275288036655133n