mirror of
https://github.com/stoatchat/for-legacy-web.git
synced 2026-03-07 17:35:28 +00:00
Prevent granting permissions you don't have
This commit is contained in:
committed by
Paul Makles
parent
629da8ec8c
commit
0bfdf15c02
@@ -6,7 +6,7 @@ import { Server } from "revolt.js/dist/maps/Servers";
|
|||||||
|
|
||||||
import styles from "./Panes.module.scss";
|
import styles from "./Panes.module.scss";
|
||||||
import { Text } from "preact-i18n";
|
import { Text } from "preact-i18n";
|
||||||
import { useCallback, useEffect, useMemo, useState } from "preact/hooks";
|
import {useCallback, useContext, useEffect, useMemo, useState} from "preact/hooks";
|
||||||
|
|
||||||
import { useIntermediate } from "../../../context/intermediate/Intermediate";
|
import { useIntermediate } from "../../../context/intermediate/Intermediate";
|
||||||
|
|
||||||
@@ -17,6 +17,7 @@ import InputBox from "../../../components/ui/InputBox";
|
|||||||
import Overline from "../../../components/ui/Overline";
|
import Overline from "../../../components/ui/Overline";
|
||||||
|
|
||||||
import ButtonItem from "../../../components/navigation/items/ButtonItem";
|
import ButtonItem from "../../../components/navigation/items/ButtonItem";
|
||||||
|
import {AppContext} from "../../../context/revoltjs/RevoltClient";
|
||||||
|
|
||||||
interface Props {
|
interface Props {
|
||||||
server: Server;
|
server: Server;
|
||||||
@@ -26,6 +27,7 @@ const I32ToU32 = (arr: number[]) => arr.map((x) => x >>> 0);
|
|||||||
|
|
||||||
// ! FIXME: bad code :)
|
// ! FIXME: bad code :)
|
||||||
export const Roles = observer(({ server }: Props) => {
|
export const Roles = observer(({ server }: Props) => {
|
||||||
|
const client = useContext(AppContext);
|
||||||
const [role, setRole] = useState("default");
|
const [role, setRole] = useState("default");
|
||||||
const { openScreen } = useIntermediate();
|
const { openScreen } = useIntermediate();
|
||||||
const roles = useMemo(() => server.roles ?? {}, [server]);
|
const roles = useMemo(() => server.roles ?? {}, [server]);
|
||||||
@@ -35,6 +37,8 @@ export const Roles = observer(({ server }: Props) => {
|
|||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
const clientPermissions = client.servers.get(server._id)!.permission;
|
||||||
|
|
||||||
const {
|
const {
|
||||||
name: roleName,
|
name: roleName,
|
||||||
colour: roleColour,
|
colour: roleColour,
|
||||||
@@ -207,6 +211,7 @@ export const Roles = observer(({ server }: Props) => {
|
|||||||
onChange={() =>
|
onChange={() =>
|
||||||
setPerm([perm[0] ^ value, perm[1]])
|
setPerm([perm[0] ^ value, perm[1]])
|
||||||
}
|
}
|
||||||
|
disabled={!(clientPermissions & value)}
|
||||||
description={
|
description={
|
||||||
<Text id={`permissions.server.${key}.d`} />
|
<Text id={`permissions.server.${key}.d`} />
|
||||||
}>
|
}>
|
||||||
@@ -233,7 +238,7 @@ export const Roles = observer(({ server }: Props) => {
|
|||||||
onChange={() =>
|
onChange={() =>
|
||||||
setPerm([perm[0], perm[1] ^ value])
|
setPerm([perm[0], perm[1] ^ value])
|
||||||
}
|
}
|
||||||
disabled={key === "View"}
|
disabled={key === "View" || (!(clientPermissions & value))}
|
||||||
description={
|
description={
|
||||||
<Text id={`permissions.channel.${key}.d`} />
|
<Text id={`permissions.channel.${key}.d`} />
|
||||||
}>
|
}>
|
||||||
|
|||||||
Reference in New Issue
Block a user