mirror of
https://github.com/revoltchat/revite.git
synced 2024-11-10 01:03:36 -05:00
feat: handle nsfw flag & added monospace font (#258)
This commit is contained in:
parent
3b843dbfad
commit
c4881db86c
4 changed files with 30 additions and 3 deletions
|
@ -65,6 +65,7 @@
|
||||||
"@fontsource/space-mono": "^4.4.5",
|
"@fontsource/space-mono": "^4.4.5",
|
||||||
"@fontsource/ubuntu": "^4.4.5",
|
"@fontsource/ubuntu": "^4.4.5",
|
||||||
"@fontsource/ubuntu-mono": "^4.4.5",
|
"@fontsource/ubuntu-mono": "^4.4.5",
|
||||||
|
"@fontsource/jetbrains-mono": "^4.4.5",
|
||||||
"@hcaptcha/react-hcaptcha": "^0.3.6",
|
"@hcaptcha/react-hcaptcha": "^0.3.6",
|
||||||
"@preact/preset-vite": "^2.0.0",
|
"@preact/preset-vite": "^2.0.0",
|
||||||
"@rollup/plugin-replace": "^2.4.2",
|
"@rollup/plugin-replace": "^2.4.2",
|
||||||
|
|
|
@ -62,7 +62,8 @@ export type MonospaceFonts =
|
||||||
| "Roboto Mono"
|
| "Roboto Mono"
|
||||||
| "Source Code Pro"
|
| "Source Code Pro"
|
||||||
| "Space Mono"
|
| "Space Mono"
|
||||||
| "Ubuntu Mono";
|
| "Ubuntu Mono"
|
||||||
|
| "JetBrains Mono";
|
||||||
|
|
||||||
export type Theme = {
|
export type Theme = {
|
||||||
[variable in Variables]: string;
|
[variable in Variables]: string;
|
||||||
|
@ -211,6 +212,10 @@ export const MONOSPACE_FONTS: Record<
|
||||||
name: "Ubuntu Mono",
|
name: "Ubuntu Mono",
|
||||||
load: () => import("@fontsource/ubuntu-mono/400.css"),
|
load: () => import("@fontsource/ubuntu-mono/400.css"),
|
||||||
},
|
},
|
||||||
|
"JetBrains Mono": {
|
||||||
|
name: "JetBrains Mono",
|
||||||
|
load: () => import("@fontsource/jetbrains-mono/400.css"),
|
||||||
|
},
|
||||||
};
|
};
|
||||||
|
|
||||||
export const FONT_KEYS = Object.keys(FONTS).sort();
|
export const FONT_KEYS = Object.keys(FONTS).sort();
|
||||||
|
|
|
@ -103,7 +103,7 @@ const TextChannel = observer(({ channel }: { channel: ChannelI }) => {
|
||||||
!!(
|
!!(
|
||||||
(channel.channel_type === "TextChannel" ||
|
(channel.channel_type === "TextChannel" ||
|
||||||
channel.channel_type === "Group") &&
|
channel.channel_type === "Group") &&
|
||||||
channel.name?.includes("nsfw")
|
channel.nsfw
|
||||||
)
|
)
|
||||||
}>
|
}>
|
||||||
<ChannelHeader
|
<ChannelHeader
|
||||||
|
|
|
@ -11,6 +11,7 @@ import { FileUploader } from "../../../context/revoltjs/FileUploads";
|
||||||
|
|
||||||
import Button from "../../../components/ui/Button";
|
import Button from "../../../components/ui/Button";
|
||||||
import InputBox from "../../../components/ui/InputBox";
|
import InputBox from "../../../components/ui/InputBox";
|
||||||
|
import Checkbox from "../../../components/ui/Checkbox";
|
||||||
|
|
||||||
interface Props {
|
interface Props {
|
||||||
channel: Channel;
|
channel: Channel;
|
||||||
|
@ -32,19 +33,26 @@ const Row = styled.div`
|
||||||
export default observer(({ channel }: Props) => {
|
export default observer(({ channel }: Props) => {
|
||||||
const [name, setName] = useState(channel.name ?? undefined);
|
const [name, setName] = useState(channel.name ?? undefined);
|
||||||
const [description, setDescription] = useState(channel.description ?? "");
|
const [description, setDescription] = useState(channel.description ?? "");
|
||||||
|
const [nsfw, setNSFW] = useState(channel.nsfw ?? false);
|
||||||
|
|
||||||
useEffect(() => setName(channel.name ?? undefined), [channel.name]);
|
useEffect(() => setName(channel.name ?? undefined), [channel.name]);
|
||||||
useEffect(
|
useEffect(
|
||||||
() => setDescription(channel.description ?? ""),
|
() => setDescription(channel.description ?? ""),
|
||||||
[channel.description],
|
[channel.description],
|
||||||
);
|
);
|
||||||
|
useEffect(
|
||||||
|
() => setNSFW(channel.nsfw ?? false),
|
||||||
|
[channel.nsfw],
|
||||||
|
);
|
||||||
|
|
||||||
const [changed, setChanged] = useState(false);
|
const [changed, setChanged] = useState(false);
|
||||||
function save() {
|
function save() {
|
||||||
const changes: Record<string, string | undefined> = {};
|
const changes: Record<string, string | boolean | undefined> = {};
|
||||||
if (name !== channel.name) changes.name = name;
|
if (name !== channel.name) changes.name = name;
|
||||||
if (description !== channel.description)
|
if (description !== channel.description)
|
||||||
changes.description = description;
|
changes.description = description;
|
||||||
|
if (nsfw !== channel.nsfw)
|
||||||
|
changes.nsfw = nsfw;
|
||||||
|
|
||||||
channel.edit(changes);
|
channel.edit(changes);
|
||||||
setChanged(false);
|
setChanged(false);
|
||||||
|
@ -110,6 +118,19 @@ export default observer(({ channel }: Props) => {
|
||||||
if (!changed) setChanged(true);
|
if (!changed) setChanged(true);
|
||||||
}}
|
}}
|
||||||
/>
|
/>
|
||||||
|
{channel.channel_type === "VoiceChannel" ? '' : (
|
||||||
|
<Checkbox
|
||||||
|
checked={nsfw ?? false}
|
||||||
|
onChange={
|
||||||
|
(nsfwchange) => {
|
||||||
|
setNSFW(nsfwchange);
|
||||||
|
if (!changed) setChanged(true);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
description="Set this channel to NSFW.">
|
||||||
|
NSFW
|
||||||
|
</Checkbox>
|
||||||
|
)}
|
||||||
<p>
|
<p>
|
||||||
<Button onClick={save} contrast disabled={!changed}>
|
<Button onClick={save} contrast disabled={!changed}>
|
||||||
<Text id="app.special.modals.actions.save" />
|
<Text id="app.special.modals.actions.save" />
|
||||||
|
|
Loading…
Reference in a new issue