rDrama/chat/src/features/emoji/EmojiMods.tsx

56 lines
1.6 KiB
TypeScript
Raw Normal View History

[DO NOT MERGE] Chat restructure (#360) * Create new subdirectory for chat-related stuff * Gitignore * Have new code show up on chat * Have new code show up on chat * Fix config issue * More script stuff * Create UserInput components * More chat changes * More updates to chat * Add chat:watch script * Move up state and pass down * Match up existing functionality entirely * Match up existing functionality entirely * Send a message when hitting Enter * feature based directories * First crack at emoji drawer * Leave everything in a fucked up state ugh * Leave it in a better state * Stop for the night * Decouple by abstract chat functionality to provider * Wait a minute... * Small chat restructure * Prepare for notifications * Add root context * Flash number of messages * Read this and u die * Add quote functionality * Couple tweaks * Shallowenize the features dir/ * Add activity list * Ch-ch-ch-ch-ch-changes * Enable moving drawer * Hover style on activities * UserList changes * Add emoji processing logic * Duhhhh * Scroll to top when changing query * Put the emoji in the drawer * Improve emoji drawer * Add emoji genres * Do not show activities * Add feature flag technology * Fix issue where own messages were triggering notifications * Adjust startup scripts * Responsive part 1 * Styling changes for emoji genres * More emoji drawer styling * Add QuickEmojis * Re-add classnames * Set version * Modify build script * Modify build script * Mild renaming * Lots of styling changes * Leggo.
2022-09-24 03:49:40 +00:00
import React, { useCallback, useRef } from "react";
interface Props {
selection: EmojiModSelection;
onChangeSelection(selection: EmojiModSelection): void;
}
export function EmojiMods({ selection, onChangeSelection }: Props) {
const largeOption = useRef<HTMLInputElement>(null);
const mirrorOption = useRef<HTMLInputElement>(null);
const patOption = useRef<HTMLInputElement>(null);
const handleChangeSelection = useCallback(() => {
onChangeSelection({
large: largeOption.current.checked,
mirror: mirrorOption.current.checked,
pat: patOption.current.checked,
});
}, []);
return (
<div className="EmojiMods">
<input
type="checkbox"
id="largeOption"
ref={largeOption}
onChange={handleChangeSelection}
checked={selection.large}
style={{ marginLeft: "1rem", marginRight: "0.5rem" }}
></input>
<label htmlFor="largeOption" style={{ marginRight: "1rem" }}>
Large
</label>
<input
type="checkbox"
id="mirrorOption"
ref={mirrorOption}
onChange={handleChangeSelection}
checked={selection.mirror}
style={{ marginRight: "0.5rem" }}
></input>
<label htmlFor="mirrorOption" style={{ marginRight: "1rem" }}>
Mirror
</label>
<input
type="checkbox"
id="patOption"
ref={patOption}
onChange={handleChangeSelection}
checked={selection.pat}
style={{ marginRight: "0.5rem" }}
></input>
<label htmlFor="patOption">Pat</label>
</div>
);
}