forked from mirrors/Vencord
feat: switch in plugin settings (#140)
This commit is contained in:
parent
a3b0556a9a
commit
934a89add0
2 changed files with 28 additions and 19 deletions
|
@ -25,7 +25,7 @@ import { ChangeList } from "../../utils/ChangeList";
|
||||||
import { classes, lazyWebpack } from "../../utils/misc";
|
import { classes, lazyWebpack } from "../../utils/misc";
|
||||||
import { Plugin } from "../../utils/types";
|
import { Plugin } from "../../utils/types";
|
||||||
import { filters } from "../../webpack";
|
import { filters } from "../../webpack";
|
||||||
import { Alerts, Button, Forms, Margins, Parser, React, Text, TextInput, Toasts, Tooltip } from "../../webpack/common";
|
import { Alerts, Button, Forms, Margins, Parser, React, Switch, Text, TextInput, Toasts, Tooltip } from "../../webpack/common";
|
||||||
import ErrorBoundary from "../ErrorBoundary";
|
import ErrorBoundary from "../ErrorBoundary";
|
||||||
import { Flex } from "../Flex";
|
import { Flex } from "../Flex";
|
||||||
import PluginModal from "./PluginModal";
|
import PluginModal from "./PluginModal";
|
||||||
|
@ -34,6 +34,9 @@ import * as styles from "./styles";
|
||||||
const Select = lazyWebpack(filters.byCode("optionClassName", "popoutPosition", "autoFocus", "maxVisibleItems"));
|
const Select = lazyWebpack(filters.byCode("optionClassName", "popoutPosition", "autoFocus", "maxVisibleItems"));
|
||||||
const InputStyles = lazyWebpack(filters.byProps(["inputDefault", "inputWrapper"]));
|
const InputStyles = lazyWebpack(filters.byProps(["inputDefault", "inputWrapper"]));
|
||||||
|
|
||||||
|
const CogWheel = lazyWebpack(filters.byCode("18.564C15.797 19.099 14.932 19.498 14 19.738V22H10V19.738C9.069"));
|
||||||
|
const InfoIcon = lazyWebpack(filters.byCode("4.4408921e-16 C4.4771525,-1.77635684e-15 4.4408921e-16"));
|
||||||
|
|
||||||
function showErrorToast(message: string) {
|
function showErrorToast(message: string) {
|
||||||
Toasts.show({
|
Toasts.show({
|
||||||
message,
|
message,
|
||||||
|
@ -79,23 +82,21 @@ function PluginCard({ plugin, disabled, onRestartNeeded, onMouseEnter, onMouseLe
|
||||||
}
|
}
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<Flex style={styles.PluginsGridItem} flexDirection="column" onClick={() => openModal()} onMouseEnter={onMouseEnter} onMouseLeave={onMouseLeave}>
|
<Flex style={styles.PluginsGridItem} flexDirection="column" onMouseEnter={onMouseEnter} onMouseLeave={onMouseLeave}>
|
||||||
<Text variant="text-md/bold">{plugin.name}</Text>
|
<Switch
|
||||||
<Text variant="text-md/normal" style={{ height: 40, overflow: "hidden" }}>{plugin.description}</Text>
|
onChange={toggleEnabled}
|
||||||
<Flex flexDirection="row-reverse" style={{ marginTop: "auto", width: "100%", justifyContent: "space-between" }}>
|
disabled={disabled}
|
||||||
<Button
|
value={isEnabled()}
|
||||||
onClick={e => {
|
note={<Text variant="text-md/normal" style={{ height: 40, overflow: "hidden" }}>{plugin.description}</Text>}
|
||||||
e.preventDefault();
|
hideBorder={true}
|
||||||
e.stopPropagation();
|
>
|
||||||
toggleEnabled();
|
<Flex style={{ marginTop: "auto", width: "100%", height: "100%", alignItems: "center" }}>
|
||||||
}}
|
<Text variant="text-md/bold" style={{ flexGrow: "1" }}>{plugin.name}</Text>
|
||||||
disabled={disabled}
|
<button role="switch" onClick={() => openModal()} style={styles.SettingsIcon} className="button-12Fmur">
|
||||||
color={isEnabled() ? Button.Colors.RED : Button.Colors.GREEN}
|
{plugin.options ? <CogWheel /> : <InfoIcon width="24" height="24" />}
|
||||||
>
|
</button>
|
||||||
{isEnabled() ? "Disable" : "Enable"}
|
</Flex>
|
||||||
</Button>
|
</Switch>
|
||||||
{plugin.options && <Forms.FormText style={{ cursor: "pointer", margin: "auto 0 auto 10px" }}>Click to configure</Forms.FormText>}
|
|
||||||
</Flex>
|
|
||||||
</Flex>
|
</Flex>
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
|
@ -29,7 +29,7 @@ export const PluginsGridItem: React.CSSProperties = {
|
||||||
borderRadius: 3,
|
borderRadius: 3,
|
||||||
cursor: "pointer",
|
cursor: "pointer",
|
||||||
display: "block",
|
display: "block",
|
||||||
height: 150,
|
height: "min-content",
|
||||||
padding: 10,
|
padding: 10,
|
||||||
width: "100%",
|
width: "100%",
|
||||||
};
|
};
|
||||||
|
@ -40,3 +40,11 @@ export const FiltersBar: React.CSSProperties = {
|
||||||
gridTemplateColumns: "1fr 150px",
|
gridTemplateColumns: "1fr 150px",
|
||||||
display: "grid"
|
display: "grid"
|
||||||
};
|
};
|
||||||
|
|
||||||
|
export const SettingsIcon: React.CSSProperties = {
|
||||||
|
height: "24px",
|
||||||
|
width: "24px",
|
||||||
|
padding: "0",
|
||||||
|
background: "transparent",
|
||||||
|
marginRight: 8
|
||||||
|
};
|
||||||
|
|
Loading…
Reference in a new issue