add tableflip and unflip commands (#2075)
Some checks failed
Deploy to Netlify (dev) / Deploy to Netlify (push) Has been cancelled

This commit is contained in:
Rein Fernhout 2024-12-13 05:32:25 +01:00 committed by GitHub
parent a142630ff9
commit 00d5553bcb
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
2 changed files with 21 additions and 1 deletions

View file

@ -103,7 +103,7 @@ import {
} from '../../utils/room'; } from '../../utils/room';
import { sanitizeText } from '../../utils/sanitize'; import { sanitizeText } from '../../utils/sanitize';
import { CommandAutocomplete } from './CommandAutocomplete'; import { CommandAutocomplete } from './CommandAutocomplete';
import { Command, SHRUG, useCommands } from '../../hooks/useCommands'; import { Command, SHRUG, TABLEFLIP, UNFLIP, useCommands } from '../../hooks/useCommands';
import { mobileOrTablet } from '../../utils/user-agent'; import { mobileOrTablet } from '../../utils/user-agent';
import { useElementSizeObserver } from '../../hooks/useElementSizeObserver'; import { useElementSizeObserver } from '../../hooks/useElementSizeObserver';
import { ReplyLayout, ThreadIndicator } from '../../components/message'; import { ReplyLayout, ThreadIndicator } from '../../components/message';
@ -270,6 +270,12 @@ export const RoomInput = forwardRef<HTMLDivElement, RoomInputProps>(
} else if (commandName === Command.Shrug) { } else if (commandName === Command.Shrug) {
plainText = `${SHRUG} ${plainText}`; plainText = `${SHRUG} ${plainText}`;
customHtml = `${SHRUG} ${customHtml}`; customHtml = `${SHRUG} ${customHtml}`;
} else if (commandName === Command.TableFlip) {
plainText = `${TABLEFLIP} ${plainText}`;
customHtml = `${TABLEFLIP} ${customHtml}`;
} else if (commandName === Command.UnFlip) {
plainText = `${UNFLIP} ${plainText}`;
customHtml = `${UNFLIP} ${customHtml}`;
} else if (commandName) { } else if (commandName) {
const commandContent = commands[commandName as Command]; const commandContent = commands[commandName as Command];
if (commandContent) { if (commandContent) {

View file

@ -6,6 +6,8 @@ import * as roomActions from '../../client/action/room';
import { useRoomNavigate } from './useRoomNavigate'; import { useRoomNavigate } from './useRoomNavigate';
export const SHRUG = '¯\\_(ツ)_/¯'; export const SHRUG = '¯\\_(ツ)_/¯';
export const TABLEFLIP = '(╯°□°)╯︵ ┻━┻';
export const UNFLIP = '┬─┬ノ( º_º)';
export function parseUsersAndReason(payload: string): { export function parseUsersAndReason(payload: string): {
users: string[]; users: string[];
@ -48,6 +50,8 @@ export enum Command {
MyRoomAvatar = 'myroomavatar', MyRoomAvatar = 'myroomavatar',
ConvertToDm = 'converttodm', ConvertToDm = 'converttodm',
ConvertToRoom = 'converttoroom', ConvertToRoom = 'converttoroom',
TableFlip = 'tableflip',
UnFlip = 'unflip',
} }
export type CommandContent = { export type CommandContent = {
@ -78,6 +82,16 @@ export const useCommands = (mx: MatrixClient, room: Room): CommandRecord => {
description: 'Send ¯\\_(ツ)_/¯ as message', description: 'Send ¯\\_(ツ)_/¯ as message',
exe: async () => undefined, exe: async () => undefined,
}, },
[Command.TableFlip]: {
name: Command.TableFlip,
description: `Send ${TABLEFLIP} as message`,
exe: async () => undefined,
},
[Command.UnFlip]: {
name: Command.UnFlip,
description: `Send ${UNFLIP} as message`,
exe: async () => undefined,
},
[Command.StartDm]: { [Command.StartDm]: {
name: Command.StartDm, name: Command.StartDm,
description: 'Start direct message with user. Example: /startdm userId1', description: 'Start direct message with user. Example: /startdm userId1',