1
0
Fork 1
mirror of https://github.com/Vendicated/Vencord.git synced 2025-01-25 00:36:23 +00:00

Unhardcode PluginSettings styles

This commit is contained in:
Vendicated 2023-01-09 16:23:40 +01:00
parent 95df164e44
commit da2d317555
No known key found for this signature in database
GPG key ID: A1DC0CFB5615D905
2 changed files with 58 additions and 41 deletions

View file

@ -20,7 +20,7 @@ import "./styles.css";
import * as DataStore from "@api/DataStore"; import * as DataStore from "@api/DataStore";
import { showNotice } from "@api/Notices"; import { showNotice } from "@api/Notices";
import { Settings, useSettings } from "@api/settings"; import { useSettings } from "@api/settings";
import { classNameFactory } from "@api/Styles"; import { classNameFactory } from "@api/Styles";
import ErrorBoundary from "@components/ErrorBoundary"; import ErrorBoundary from "@components/ErrorBoundary";
import { ErrorCard } from "@components/ErrorCard"; import { ErrorCard } from "@components/ErrorCard";
@ -71,8 +71,8 @@ function ReloadRequiredCard({ plugins, ...props }: ReloadRequiredCardProps) {
const pluginSuffix = plugins.length === 1 ? " requires a reload to apply changes." : "."; const pluginSuffix = plugins.length === 1 ? " requires a reload to apply changes." : ".";
return ( return (
<ErrorCard {...props} style={{ padding: "1em", display: "grid", gridTemplateColumns: "1fr auto", gap: 8, ...props.style }}> <ErrorCard {...props} className={cl("reload-card")}>
<span style={{ margin: "auto 0" }}> <span className={cl("dep-text")}>
{pluginPrefix} <code>{plugins.join(", ")}</code>{pluginSuffix} {pluginPrefix} <code>{plugins.join(", ")}</code>{pluginSuffix}
</span> </span>
<Button look={Button.Looks.INVERTED} onClick={() => location.reload()}>Reload</Button> <Button look={Button.Looks.INVERTED} onClick={() => location.reload()}>Reload</Button>
@ -91,8 +91,6 @@ function PluginCard({ plugin, disabled, onRestartNeeded, onMouseEnter, onMouseLe
const settings = useSettings(); const settings = useSettings();
const pluginSettings = settings.plugins[plugin.name]; const pluginSettings = settings.plugins[plugin.name];
const [iconHover, setIconHover] = React.useState(false);
function isEnabled() { function isEnabled() {
return pluginSettings?.enabled || plugin.started; return pluginSettings?.enabled || plugin.started;
} }
@ -154,43 +152,20 @@ function PluginCard({ plugin, disabled, onRestartNeeded, onMouseEnter, onMouseLe
onChange={toggleEnabled} onChange={toggleEnabled}
disabled={disabled} disabled={disabled}
value={isEnabled()} value={isEnabled()}
note={<Text variant="text-md/normal" style={{ note={<Text className={cl("note")} variant="text-md/normal">{plugin.description}</Text>}
height: 40,
overflow: "hidden",
// mfw css is so bad you need whatever this is to get multi line overflow ellipsis to work
textOverflow: "ellipsis",
display: "-webkit-box", // firefox users will cope (it doesn't support it)
WebkitLineClamp: 2,
lineClamp: 2,
WebkitBoxOrient: "vertical",
boxOrient: "vertical"
}}>
{plugin.description}
</Text>}
hideBorder={true} hideBorder={true}
> >
<Flex style={{ marginTop: "auto", width: "100%", height: "100%", alignItems: "center", gap: "8px" }}> <Flex className={cl("flex")}>
<Text <Text
variant="text-md/bold" variant="text-md/bold"
style={{ className={cl("name")}
display: "flex", width: "100%", alignItems: "center", flexGrow: "1", gap: "8px"
}}
> >
{plugin.name}{(isNew) && <Badge text="NEW" color="#ED4245" />} {plugin.name}{isNew && <Badge text="NEW" color="#ED4245" />}
</Text> </Text>
<button role="switch" onClick={() => openModal()} className={classes("button-12Fmur", cl("info-button"))}> <button role="switch" onClick={() => openModal()} className={classes("button-12Fmur", cl("info-button"))}>
{plugin.options {plugin.options
? <CogWheel ? <CogWheel />
style={{ color: iconHover ? "" : "var(--text-muted)" }} : <InfoIcon width="24" height="24" />}
onMouseEnter={() => setIconHover(true)}
onMouseLeave={() => setIconHover(false)}
/>
: <InfoIcon
width="24" height="24"
style={{ color: iconHover ? "" : "var(--text-muted)" }}
onMouseEnter={() => setIconHover(true)}
onMouseLeave={() => setIconHover(false)}
/>}
</button> </button>
</Flex> </Flex>
</Switch> </Switch>
@ -287,7 +262,7 @@ export default ErrorBoundary.wrap(function PluginSettings() {
for (const p of sortedPlugins) { for (const p of sortedPlugins) {
if (!pluginFilter(p)) continue; if (!pluginFilter(p)) continue;
const isRequired = p.required || depMap[p.name]?.some(d => Settings.plugins[d].enabled); const isRequired = p.required || depMap[p.name]?.some(d => settings.plugins[d].enabled);
if (isRequired) { if (isRequired) {
const tooltipText = p.required const tooltipText = p.required
@ -330,10 +305,10 @@ export default ErrorBoundary.wrap(function PluginSettings() {
Filters Filters
</Forms.FormTitle> </Forms.FormTitle>
<ReloadRequiredCard plugins={[...changes.getChanges()]} style={{ marginBottom: 16 }} /> <ReloadRequiredCard plugins={[...changes.getChanges()]} className={Margins.marginBottom20} />
<div className={cl("filter-controls")}> <div className={cl("filter-controls")}>
<TextInput autoFocus value={searchValue.value} placeholder="Search for a plugin..." onChange={onSearch} style={{ marginBottom: 24 }} /> <TextInput autoFocus value={searchValue.value} placeholder="Search for a plugin..." onChange={onSearch} className={Margins.marginBottom20} />
<div className={InputStyles.inputWrapper}> <div className={InputStyles.inputWrapper}>
<Select <Select
className={InputStyles.inputDefault} className={InputStyles.inputDefault}
@ -373,7 +348,7 @@ function makeDependencyList(deps: string[]) {
return ( return (
<React.Fragment> <React.Fragment>
<Forms.FormText>This plugin is required by:</Forms.FormText> <Forms.FormText>This plugin is required by:</Forms.FormText>
{deps.map((dep: string) => <Forms.FormText style={{ margin: "0 auto" }}>{dep}</Forms.FormText>)} {deps.map((dep: string) => <Forms.FormText className={cl("dep-text")}>{dep}</Forms.FormText>)}
</React.Fragment> </React.Fragment>
); );
} }

View file

@ -27,14 +27,13 @@
background-color: var(--background-modifier-selected); background-color: var(--background-modifier-selected);
color: var(--interactive-active); color: var(--interactive-active);
border-radius: 3px; border-radius: 3px;
cursor: pointer;
display: block; display: block;
height: 100%; height: 100%;
padding: 10px; padding: 10px;
width: 100% width: 100%;
} }
.vc-plugins-card .vc-plugins-info-button { .vc-plugins-info-button {
height: 24px; height: 24px;
width: 24px; width: 24px;
padding: 0; padding: 0;
@ -58,4 +57,47 @@
font-size: 12px; font-size: 12px;
line-height: 16px; line-height: 16px;
color: var(--white-500); color: var(--white-500);
text-align: center;
}
.vc-plugins-note {
height: 40px;
overflow: hidden;
text-overflow: ellipsis;
display: -webkit-box;
-webkit-line-clamp: 2;
line-clamp: 2;
-webkit-box-orient: vertical;
box-orient: vertical;
}
.vc-plugins-name {
display: flex;
width: 100%;
align-items: center;
flex-grow: 1;
gap: 8px;
}
.vc-plugins-flex {
margin-top: auto;
width: 100%;
height: 100%;
align-items: center;
gap: 8px;
}
.vc-plugins-dep-name {
margin: 0 auto;
}
.vc-plugins-reload-card {
padding: 1em;
display: grid;
grid-template-columns: 1fr auto;
gap: 1em;
}
.vc-plugins-info-button svg:not(:hover):not(:focus) {
color: var(--text-muted);
} }