aboutsummaryrefslogtreecommitdiff
path: root/src/plugins/spotifyControls
diff options
context:
space:
mode:
authorDominik <dominik.buettner1711@gmail.com>2023-01-23 22:25:00 +0100
committerGitHub <noreply@github.com>2023-01-23 22:25:00 +0100
commitcb4c50842f36a1d23a18618741b787dc3dafdc68 (patch)
tree8e1f0449006070907509294c418d1423cf7f330c /src/plugins/spotifyControls
parent83757b19be30811f54a4d31adecb741a343be345 (diff)
downloadVencord-cb4c50842f36a1d23a18618741b787dc3dafdc68.tar.gz
Vencord-cb4c50842f36a1d23a18618741b787dc3dafdc68.tar.bz2
Vencord-cb4c50842f36a1d23a18618741b787dc3dafdc68.zip
[SpotifyControls] Add option to show Controls on hover (#352)
Co-authored-by: Dominik <domi@bambus.me> Co-authored-by: Ven <vendicated@riseup.net>
Diffstat (limited to 'src/plugins/spotifyControls')
-rw-r--r--src/plugins/spotifyControls/index.tsx26
1 files changed, 24 insertions, 2 deletions
diff --git a/src/plugins/spotifyControls/index.tsx b/src/plugins/spotifyControls/index.tsx
index 7ab1e37..86e187e 100644
--- a/src/plugins/spotifyControls/index.tsx
+++ b/src/plugins/spotifyControls/index.tsx
@@ -16,16 +16,38 @@
* along with this program. If not, see <https://www.gnu.org/licenses/>.
*/
+import { Settings } from "@api/settings";
import { Devs } from "@utils/constants";
-import definePlugin from "@utils/types";
+import definePlugin, { OptionType } from "@utils/types";
import { Player } from "./PlayerComponent";
+function toggleHoverControls(value: boolean) {
+ document.getElementById("vc-spotify-hover-controls")?.remove();
+ if (value) {
+ const style = document.createElement("style");
+ style.id = "vc-spotify-hover-controls";
+ style.textContent = `
+.vc-spotify-button-row { height: 0; opacity: 0; will-change: height, opacity; transition: height .2s, opacity .05s; }
+#vc-spotify-player:hover .vc-spotify-button-row { opacity: 1; height: 32px; }
+`;
+ document.head.appendChild(style);
+ }
+}
+
export default definePlugin({
name: "SpotifyControls",
description: "Spotify Controls",
authors: [Devs.Ven, Devs.afn, Devs.KraXen72],
dependencies: ["MenuItemDeobfuscatorAPI"],
+ options: {
+ hoverControls: {
+ description: "Show controls on hover",
+ type: OptionType.BOOLEAN,
+ default: false,
+ onChange: v => toggleHoverControls(v)
+ },
+ },
patches: [
{
find: "showTaglessAccountPanel:",
@@ -53,6 +75,6 @@ export default definePlugin({
}
}
],
-
+ start: () => toggleHoverControls(Settings.plugins.SpotifyControls.hoverControls),
renderPlayer: () => <Player />
});