ClickableRoleDot -> BetterRoleDot; now allows using both role colour styles at once
This commit is contained in:
parent
82e444e196
commit
b49ac6b541
1 changed files with 26 additions and 15 deletions
|
@ -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
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
}
|
},
|
||||||
});
|
});
|
Loading…
Reference in a new issue