ClickableRoleDot -> BetterRoleDot; now allows using both role colour styles at once

This commit is contained in:
Vendicated 2022-11-14 21:42:02 +01:00
parent 82e444e196
commit b49ac6b541
No known key found for this signature in database
GPG key ID: EC781ADFB93EFFA3

View file

@ -16,36 +16,47 @@
* along with this program. If not, see <https://www.gnu.org/licenses/>. * along with this program. If not, see <https://www.gnu.org/licenses/>.
*/ */
import { migratePluginSettings, Settings } from "../api/settings";
import { Devs } from "../utils/constants"; import { Devs } from "../utils/constants";
import definePlugin from "../utils/types"; import definePlugin, { OptionType } from "../utils/types";
import { Toasts } from "../webpack/common"; import { Clipboard, Toasts } from "../webpack/common";
migratePluginSettings("BetterRoleDot", "ClickableRoleDot");
export default definePlugin({ export default definePlugin({
name: "ClickableRoleDot", name: "BetterRoleDot",
authors: [Devs.Ven], authors: [Devs.Ven],
description: description:
"Makes RoleDots (Accessibility Feature) copy colour to clipboard on click", "Copy role colour on RoleDot (accessibility setting) click. Also allows using both RoleDot and coloured names simultaneously",
patches: [ patches: [
{ {
find: "M0 4C0 1.79086 1.79086 0 4 0H16C18.2091 0 20 1.79086 20 4V16C20 18.2091 18.2091 20 16 20H4C1.79086 20 0 18.2091 0 16V4Z", find: "M0 4C0 1.79086 1.79086 0 4 0H16C18.2091 0 20 1.79086 20 4V16C20 18.2091 18.2091 20 16 20H4C1.79086 20 0 18.2091 0 16V4Z",
replacement: { replacement: {
match: /(viewBox:"0 0 20 20")/, match: /viewBox:"0 0 20 20"/,
replace: "$1,onClick:()=>Vencord.Plugins.plugins.ClickableRoleDot.copyToClipBoard(e.color)", replace: "$&,onClick:()=>Vencord.Plugins.plugins.BetterRoleDot.copyToClipBoard(e.color),style:{cursor:'pointer'}",
},
},
{
find: '"username"===',
all: true,
predicate: () => Settings.plugins.BetterRoleDot.bothStyles,
replacement: {
match: /"(?:username|dot)"===\w\b/g,
replace: "true",
}, },
}, },
], ],
copyToClipBoard(color: string) { options: {
if (IS_WEB) { bothStyles: {
navigator.clipboard.writeText(color) type: OptionType.BOOLEAN,
.then(() => this.notifySuccess); description: "Show both role dot and coloured names",
} else { default: false,
DiscordNative.clipboard.copy(color);
this.notifySuccess();
} }
}, },
notifySuccess() { copyToClipBoard(color: string) {
Clipboard.copy(color);
Toasts.show({ Toasts.show({
message: "Copied to Clipboard!", message: "Copied to Clipboard!",
type: Toasts.Type.SUCCESS, type: Toasts.Type.SUCCESS,
@ -55,5 +66,5 @@ export default definePlugin({
position: Toasts.Position.BOTTOM position: Toasts.Position.BOTTOM
} }
}); });
} },
}); });