From 934a89add0f68e9a0c8a28bf182e773bc6f93b2a Mon Sep 17 00:00:00 2001
From: KraXen72 <DPELECH1@GMAil.com>
Date: Sat, 22 Oct 2022 23:38:48 +0200
Subject: [PATCH] feat: switch in plugin settings (#140)

---
 src/components/PluginSettings/index.tsx | 37 +++++++++++++------------
 src/components/PluginSettings/styles.ts | 10 ++++++-
 2 files changed, 28 insertions(+), 19 deletions(-)

diff --git a/src/components/PluginSettings/index.tsx b/src/components/PluginSettings/index.tsx
index 552f9fd1..dbb51619 100644
--- a/src/components/PluginSettings/index.tsx
+++ b/src/components/PluginSettings/index.tsx
@@ -25,7 +25,7 @@ import { ChangeList } from "../../utils/ChangeList";
 import { classes, lazyWebpack } from "../../utils/misc";
 import { Plugin } from "../../utils/types";
 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 { Flex } from "../Flex";
 import PluginModal from "./PluginModal";
@@ -34,6 +34,9 @@ import * as styles from "./styles";
 const Select = lazyWebpack(filters.byCode("optionClassName", "popoutPosition", "autoFocus", "maxVisibleItems"));
 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) {
     Toasts.show({
         message,
@@ -79,23 +82,21 @@ function PluginCard({ plugin, disabled, onRestartNeeded, onMouseEnter, onMouseLe
     }
 
     return (
-        <Flex style={styles.PluginsGridItem} flexDirection="column" onClick={() => openModal()} onMouseEnter={onMouseEnter} onMouseLeave={onMouseLeave}>
-            <Text variant="text-md/bold">{plugin.name}</Text>
-            <Text variant="text-md/normal" style={{ height: 40, overflow: "hidden" }}>{plugin.description}</Text>
-            <Flex flexDirection="row-reverse" style={{ marginTop: "auto", width: "100%", justifyContent: "space-between" }}>
-                <Button
-                    onClick={e => {
-                        e.preventDefault();
-                        e.stopPropagation();
-                        toggleEnabled();
-                    }}
-                    disabled={disabled}
-                    color={isEnabled() ? Button.Colors.RED : Button.Colors.GREEN}
-                >
-                    {isEnabled() ? "Disable" : "Enable"}
-                </Button>
-                {plugin.options && <Forms.FormText style={{ cursor: "pointer", margin: "auto 0 auto 10px" }}>Click to configure</Forms.FormText>}
-            </Flex>
+        <Flex style={styles.PluginsGridItem} flexDirection="column" onMouseEnter={onMouseEnter} onMouseLeave={onMouseLeave}>
+            <Switch
+                onChange={toggleEnabled}
+                disabled={disabled}
+                value={isEnabled()}
+                note={<Text variant="text-md/normal" style={{ height: 40, overflow: "hidden" }}>{plugin.description}</Text>}
+                hideBorder={true}
+            >
+                <Flex style={{ marginTop: "auto", width: "100%", height: "100%", alignItems: "center" }}>
+                    <Text variant="text-md/bold" style={{ flexGrow: "1" }}>{plugin.name}</Text>
+                    <button role="switch" onClick={() => openModal()} style={styles.SettingsIcon} className="button-12Fmur">
+                        {plugin.options ? <CogWheel /> : <InfoIcon width="24" height="24" />}
+                    </button>
+                </Flex>
+            </Switch>
         </Flex>
     );
 }
diff --git a/src/components/PluginSettings/styles.ts b/src/components/PluginSettings/styles.ts
index 767fb639..703c579c 100644
--- a/src/components/PluginSettings/styles.ts
+++ b/src/components/PluginSettings/styles.ts
@@ -29,7 +29,7 @@ export const PluginsGridItem: React.CSSProperties = {
     borderRadius: 3,
     cursor: "pointer",
     display: "block",
-    height: 150,
+    height: "min-content",
     padding: 10,
     width: "100%",
 };
@@ -40,3 +40,11 @@ export const FiltersBar: React.CSSProperties = {
     gridTemplateColumns: "1fr 150px",
     display: "grid"
 };
+
+export const SettingsIcon: React.CSSProperties = {
+    height: "24px",
+    width: "24px",
+    padding: "0",
+    background: "transparent",
+    marginRight: 8
+};