From 30ac25607023752031aa98060cbf8a736109992d Mon Sep 17 00:00:00 2001 From: V Date: Sun, 24 Sep 2023 16:02:18 +0200 Subject: migrate all plugins to folders --- src/plugins/blurNsfw/index.ts | 77 +++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 77 insertions(+) create mode 100644 src/plugins/blurNsfw/index.ts (limited to 'src/plugins/blurNsfw/index.ts') diff --git a/src/plugins/blurNsfw/index.ts b/src/plugins/blurNsfw/index.ts new file mode 100644 index 0000000..54b1e49 --- /dev/null +++ b/src/plugins/blurNsfw/index.ts @@ -0,0 +1,77 @@ +/* + * Vencord, a modification for Discord's desktop app + * Copyright (c) 2022 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 . +*/ + +import { Settings } from "@api/Settings"; +import { Devs } from "@utils/constants"; +import definePlugin, { OptionType } from "@utils/types"; + +let style: HTMLStyleElement; + +function setCss() { + style.textContent = ` + .vc-nsfw-img [class^=imageWrapper] img, + .vc-nsfw-img [class^=wrapperPaused] video { + filter: blur(${Settings.plugins.BlurNSFW.blurAmount}px); + transition: filter 0.2s; + } + .vc-nsfw-img [class^=imageWrapper]:hover img, + .vc-nsfw-img [class^=wrapperPaused]:hover video { + filter: unset; + } + `; +} + +export default definePlugin({ + name: "BlurNSFW", + description: "Blur attachments in NSFW channels until hovered", + authors: [Devs.Ven], + + patches: [ + { + find: ".embedWrapper,embed", + replacement: [{ + match: /(\.renderEmbed=.+?(.)=.\.props)(.+?\.embedWrapper)/g, + replace: "$1,vcProps=$2$3+(vcProps.channel.nsfw?' vc-nsfw-img':'')" + }, { + match: /(\.renderAttachments=.+?(.)=this\.props)(.+?\.embedWrapper)/g, + replace: "$1,vcProps=$2$3+(vcProps.nsfw?' vc-nsfw-img':'')" + }] + } + ], + + options: { + blurAmount: { + type: OptionType.NUMBER, + description: "Blur Amount", + default: 10, + onChange: setCss + } + }, + + start() { + style = document.createElement("style"); + style.id = "VcBlurNsfw"; + document.head.appendChild(style); + + setCss(); + }, + + stop() { + style?.remove(); + } +}); -- cgit