d6c43986fd
Co-authored-by: Justice Almanzar <superdash993@gmail.com> Co-authored-by: Nuckyz <61953774+Nuckyz@users.noreply.github.com> Co-authored-by: V <vendicated@riseup.net>
78 lines
2.6 KiB
TypeScript
78 lines
2.6 KiB
TypeScript
/*
|
|
* Vencord, a modification for Discord's desktop app
|
|
* Copyright (c) 2023 Vendicated and contributors
|
|
*
|
|
* This program is free software: you can redistribute it and/or modify
|
|
* it under the terms of the GNU General Public License as published by
|
|
* the Free Software Foundation, either version 3 of the License, or
|
|
* (at your option) any later version.
|
|
*
|
|
* This program is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU General Public License
|
|
* along with this program. If not, see <https://www.gnu.org/licenses/>.
|
|
*/
|
|
|
|
import "./addonCard.css";
|
|
|
|
import { classNameFactory } from "@api/Styles";
|
|
import { Badge } from "@components/Badge";
|
|
import { Switch } from "@components/Switch";
|
|
import { Text } from "@webpack/common";
|
|
import type { MouseEventHandler, ReactNode } from "react";
|
|
|
|
const cl = classNameFactory("vc-addon-");
|
|
|
|
interface Props {
|
|
name: ReactNode;
|
|
description: ReactNode;
|
|
enabled: boolean;
|
|
setEnabled: (enabled: boolean) => void;
|
|
disabled?: boolean;
|
|
isNew?: boolean;
|
|
onMouseEnter?: MouseEventHandler<HTMLDivElement>;
|
|
onMouseLeave?: MouseEventHandler<HTMLDivElement>;
|
|
|
|
infoButton?: ReactNode;
|
|
footer?: ReactNode;
|
|
author?: ReactNode;
|
|
}
|
|
|
|
export function AddonCard({ disabled, isNew, name, infoButton, footer, author, enabled, setEnabled, description, onMouseEnter, onMouseLeave }: Props) {
|
|
return (
|
|
<div
|
|
className={cl("card", { "card-disabled": disabled })}
|
|
onMouseEnter={onMouseEnter}
|
|
onMouseLeave={onMouseLeave}
|
|
>
|
|
<div className={cl("header")}>
|
|
<div className={cl("name-author")}>
|
|
<Text variant="text-md/bold" className={cl("name")}>
|
|
{name}{isNew && <Badge text="NEW" color="#ED4245" />}
|
|
</Text>
|
|
{!!author && (
|
|
<Text variant="text-md/normal" className={cl("author")}>
|
|
{author}
|
|
</Text>
|
|
)}
|
|
</div>
|
|
|
|
{infoButton}
|
|
|
|
<Switch
|
|
checked={enabled}
|
|
onChange={setEnabled}
|
|
disabled={disabled}
|
|
/>
|
|
</div>
|
|
|
|
<Text className={cl("note")} variant="text-sm/normal">{description}</Text>
|
|
|
|
{footer}
|
|
</div>
|
|
);
|
|
}
|