am amy!!!!!
This commit is contained in:
parent
0024187d2d
commit
0a80079600
8 changed files with 1238 additions and 54 deletions
38
README.md
38
README.md
|
|
@ -1,37 +1 @@
|
||||||
# [Your name here]'s shelter plugins
|
meow
|
||||||
If you're reading this you should either change this README,
|
|
||||||
or you should run `npx degit uwu/shelter-template shelter-plugins`!
|
|
||||||
|
|
||||||
## Getting started
|
|
||||||
You should be using [pnpm](https://pnpm.io/) with this template ideally.
|
|
||||||
|
|
||||||
To install the dependencies and debug `hello-world` run:
|
|
||||||
```sh
|
|
||||||
pnpm i
|
|
||||||
pnpm lune dev plugins/hello-world
|
|
||||||
```
|
|
||||||
|
|
||||||
Ensure that Lune Dev Mode is enabled in Discord so that lune can connect to it.
|
|
||||||
|
|
||||||
Now you can start debugging. The plugin will automatically reload after every change.
|
|
||||||
|
|
||||||
## Installing
|
|
||||||
To then install your finished plugin in shelter you can either rely on GitHub pages and it's workflow or you can build and host them here temporarily.
|
|
||||||
|
|
||||||
### Building locally
|
|
||||||
To build and host your plugins locally run:
|
|
||||||
```sh
|
|
||||||
pnpm lune ci
|
|
||||||
npx http-server dist/ --cors
|
|
||||||
```
|
|
||||||
Then you can install your plugin in shelter with this URL `http://localhost:8080/hello-world`.
|
|
||||||
|
|
||||||
### Publishing via GitHub
|
|
||||||
If you have published this repo on GitHub the plugins will be built after every commit.
|
|
||||||
|
|
||||||
For the GitHub action to run flawlessly, make sure you have the following setting enabled:
|
|
||||||
`Repo settings > Actions > General > Workflow permissions > Read and write permissions`
|
|
||||||
|
|
||||||
And for it to be hosted correctly you need to configure the `gh-pages` branch after its been created by the GitHub action. You can do this in `Repo settings > Pages > Branch`.
|
|
||||||
|
|
||||||
If this worked, you will be able to install the plugin via `https://<username>.github.io/<repo>/hello-world`.
|
|
||||||
|
|
@ -1,12 +0,0 @@
|
||||||
const {
|
|
||||||
util: { log }
|
|
||||||
} = shelter;
|
|
||||||
|
|
||||||
export function onLoad() {
|
|
||||||
// you can safely run onLoad actions at the top level!
|
|
||||||
log("Hello, World from shelter!")
|
|
||||||
}
|
|
||||||
|
|
||||||
export function onUnload() {
|
|
||||||
log("Goodbye, World from shelter!")
|
|
||||||
}
|
|
||||||
|
|
@ -1,5 +0,0 @@
|
||||||
{
|
|
||||||
"name": "hello-world",
|
|
||||||
"author": "Your name here",
|
|
||||||
"description": "An example shelter plugin"
|
|
||||||
}
|
|
||||||
58
plugins/show raw message/index.jsx
Normal file
58
plugins/show raw message/index.jsx
Normal file
|
|
@ -0,0 +1,58 @@
|
||||||
|
const {
|
||||||
|
util: { getFiber, reactFiberWalker },
|
||||||
|
flux: { dispatcher, stores },
|
||||||
|
observeDom: observeDom,
|
||||||
|
ui: {
|
||||||
|
Button,
|
||||||
|
openModal,
|
||||||
|
ModalBody,
|
||||||
|
ModalFooter,
|
||||||
|
ModalRoot,
|
||||||
|
ModalHeader,
|
||||||
|
ModalSizes,
|
||||||
|
},
|
||||||
|
} = shelter;
|
||||||
|
|
||||||
|
dispatcher.subscribe("CONTEXT_MENU_OPEN", handler);
|
||||||
|
|
||||||
|
function handler(dispatch) {
|
||||||
|
const unObserve = observeDom("[id^=message-copy-link]", (elem) => {
|
||||||
|
const messageId = reactFiberWalker(getFiber(elem), "message", true)
|
||||||
|
.pendingProps.message.id;
|
||||||
|
elem.insertAdjacentElement(
|
||||||
|
"afterend",
|
||||||
|
<Button
|
||||||
|
size={"MEDIUM"}
|
||||||
|
onClick={clicked.bind(null, getMessageObject(messageId))}
|
||||||
|
>
|
||||||
|
show raw message object
|
||||||
|
</Button>
|
||||||
|
);
|
||||||
|
unObserve();
|
||||||
|
});
|
||||||
|
setTimeout(unObserve, 500);
|
||||||
|
}
|
||||||
|
|
||||||
|
function clicked(a) {
|
||||||
|
const remove = openModal((p) => (
|
||||||
|
<ModalRoot size={ModalSizes.SMALL}>
|
||||||
|
<code style={{ overflowX: "scroll", overflowY: "scroll" }}>
|
||||||
|
{JSON.stringify(a, null, 2)}
|
||||||
|
</code>
|
||||||
|
</ModalRoot>
|
||||||
|
));
|
||||||
|
|
||||||
|
dispatcher.dispatch({ type: "CONTEXT_MENU_CLOSE" });
|
||||||
|
}
|
||||||
|
|
||||||
|
function getMessageObject(messageId) {
|
||||||
|
const fluxMessages = stores.MessageStore.getMessages(
|
||||||
|
stores.SelectedChannelStore.getChannelId()
|
||||||
|
);
|
||||||
|
return fluxMessages._map[messageId];
|
||||||
|
}
|
||||||
|
|
||||||
|
export function onUnload() {
|
||||||
|
dispatcher.unsubscribe("CONTEXT_MENU_OPEN", handler);
|
||||||
|
}
|
||||||
|
|
||||||
5
plugins/show raw message/plugin.json
Normal file
5
plugins/show raw message/plugin.json
Normal file
|
|
@ -0,0 +1,5 @@
|
||||||
|
{
|
||||||
|
"name": "show raw messages",
|
||||||
|
"author": "amy",
|
||||||
|
"description": "see the raw message object (beta, looks like shit)"
|
||||||
|
}
|
||||||
122
plugins/uwuifier/index.jsx
Normal file
122
plugins/uwuifier/index.jsx
Normal file
|
|
@ -0,0 +1,122 @@
|
||||||
|
const {
|
||||||
|
http: { intercept },
|
||||||
|
util: { log }
|
||||||
|
} = shelter;
|
||||||
|
|
||||||
|
|
||||||
|
const endings = [
|
||||||
|
"rawr x3",
|
||||||
|
"OwO",
|
||||||
|
"UwU",
|
||||||
|
"o.O",
|
||||||
|
"-.-",
|
||||||
|
">w<",
|
||||||
|
"(⑅˘꒳˘)",
|
||||||
|
"(ꈍᴗꈍ)",
|
||||||
|
"(˘ω˘)",
|
||||||
|
"(U ᵕ U❁)",
|
||||||
|
"σωσ",
|
||||||
|
"òωó",
|
||||||
|
"(///ˬ///✿)",
|
||||||
|
"(U ﹏ U)",
|
||||||
|
"( ͡o ω ͡o )",
|
||||||
|
"ʘwʘ",
|
||||||
|
":3",
|
||||||
|
":3", // important enough to have twice
|
||||||
|
":3", // important enough to have thrice
|
||||||
|
"XD",
|
||||||
|
"nyaa~~",
|
||||||
|
"mya",
|
||||||
|
">_<",
|
||||||
|
"😳",
|
||||||
|
"🥺",
|
||||||
|
"😳😳😳",
|
||||||
|
"rawr",
|
||||||
|
"^^",
|
||||||
|
"^^;;",
|
||||||
|
"(ˆ ﻌ ˆ)♡",
|
||||||
|
"^•ﻌ•^",
|
||||||
|
"/(^•ω•^)",
|
||||||
|
"(✿oωo)"
|
||||||
|
];
|
||||||
|
|
||||||
|
const replacements = [
|
||||||
|
["small", "smol"],
|
||||||
|
["cute", "kawaii"],
|
||||||
|
["fluff", "floof"],
|
||||||
|
["love", "luv"],
|
||||||
|
["stupid", "baka"],
|
||||||
|
["what", "nani"],
|
||||||
|
["meow", "nya"],
|
||||||
|
["hello", "hewwo"],
|
||||||
|
];
|
||||||
|
|
||||||
|
function selectRandomElement(arr) {
|
||||||
|
const randomIndex = Math.floor(Math.random() * arr.length);
|
||||||
|
return arr[randomIndex];
|
||||||
|
}
|
||||||
|
// returns true if all characters in the string are the same
|
||||||
|
// "aaaaaaaaaaaaa" -> true
|
||||||
|
// "aaaaaaaaaaaab" -> false
|
||||||
|
const isOneCharacterString = (str) => {
|
||||||
|
return str.split('').every((char) => char === str[0]);
|
||||||
|
};
|
||||||
|
|
||||||
|
function replaceString(inputString) {
|
||||||
|
let replaced = false;
|
||||||
|
for (const replacement of replacements) {
|
||||||
|
const regex = new RegExp(`\\b${replacement[0]}\\b`, "gi");
|
||||||
|
if (regex.test(inputString)) {
|
||||||
|
inputString = inputString.replace(regex, replacement[1]);
|
||||||
|
replaced = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return replaced ? inputString : false;
|
||||||
|
}
|
||||||
|
|
||||||
|
function uwuify(message) {
|
||||||
|
const rule = /\S+|\s+/g;
|
||||||
|
const words = message.match(rule);
|
||||||
|
let answer = "";
|
||||||
|
|
||||||
|
if (words === null) return "";
|
||||||
|
|
||||||
|
for (let i = 0; i < words.length; i++) {
|
||||||
|
if (isOneCharacterString(words[i]) || words[i].startsWith("https://")) {
|
||||||
|
answer += words[i];
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!replaceString(words[i])) {
|
||||||
|
answer += words[i]
|
||||||
|
.replace(/n(?=[aeo])/g, "ny")
|
||||||
|
.replace(/l|r/g, "w");
|
||||||
|
} else answer += replaceString(words[i]);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
answer += " " + selectRandomElement(endings);
|
||||||
|
return answer;
|
||||||
|
}
|
||||||
|
|
||||||
|
const unintercept = intercept(
|
||||||
|
"post",
|
||||||
|
/\/channels\/\d+\/messages/,
|
||||||
|
(req, send) => {
|
||||||
|
let newContent = req?.body?.content;
|
||||||
|
log(newContent);
|
||||||
|
if (!newContent) {
|
||||||
|
return send(req);
|
||||||
|
}
|
||||||
|
if (newContent.startsWith("!u ")) {
|
||||||
|
newContent = newContent.replace("!u ", "", 1)
|
||||||
|
req.body.content = uwuify(newContent.toLowerCase());
|
||||||
|
}
|
||||||
|
return send(req);
|
||||||
|
}
|
||||||
|
);
|
||||||
|
|
||||||
|
export function onUnload() {
|
||||||
|
log("Goodbye, Wowwd fwom shewtew! ^^;;")
|
||||||
|
unintercept()
|
||||||
|
}
|
||||||
5
plugins/uwuifier/plugin.json
Normal file
5
plugins/uwuifier/plugin.json
Normal file
|
|
@ -0,0 +1,5 @@
|
||||||
|
{
|
||||||
|
"name": "uwuifier",
|
||||||
|
"author": "amy",
|
||||||
|
"description": "become kawaii"
|
||||||
|
}
|
||||||
1047
pnpm-lock.yaml
generated
Normal file
1047
pnpm-lock.yaml
generated
Normal file
File diff suppressed because it is too large
Load diff
Loading…
Add table
Add a link
Reference in a new issue