aboutsummaryrefslogtreecommitdiff
path: root/webAO/packets/handlers/handleMC.ts
diff options
context:
space:
mode:
authorstonedDiscord <Tukz@gmx.de>2022-08-30 22:39:43 +0200
committerGitHub <noreply@github.com>2022-08-30 22:39:43 +0200
commitcced5e71d9004eaf34156935d214eac82204ab4b (patch)
treeaf3481664cebef9e0f1afbfe74629084c897ec40 /webAO/packets/handlers/handleMC.ts
parent325aa41d1216facbb7228743930a8ad21afec7aa (diff)
parent3d6e61c6b0962cea539c6d780d68a7ad0b64bee1 (diff)
Merge pull request #155 from caleb-mabry/move-two-packets
Move three packets
Diffstat (limited to 'webAO/packets/handlers/handleMC.ts')
-rw-r--r--webAO/packets/handlers/handleMC.ts41
1 files changed, 41 insertions, 0 deletions
diff --git a/webAO/packets/handlers/handleMC.ts b/webAO/packets/handlers/handleMC.ts
new file mode 100644
index 0000000..28254ba
--- /dev/null
+++ b/webAO/packets/handlers/handleMC.ts
@@ -0,0 +1,41 @@
+import { prepChat } from "../../encoding";
+import { AO_HOST, appendICLog, client } from '../../client'
+
+/**
+ * Handles a music change to an arbitrary resource.
+ * @param {Array} args packet arguments
+ */
+export const handleMC = (args: string[]) => {
+ const track = prepChat(args[1]);
+ let charID = Number(args[2]);
+ const showname = args[3] || "";
+ const looping = Boolean(args[4]);
+ const channel = Number(args[5]) || 0;
+ // const fading = Number(args[6]) || 0; // unused in web
+
+ const music = client.viewport.music[channel];
+ let musicname;
+ music.pause();
+ if (track.startsWith("http")) {
+ music.src = track;
+ } else {
+ music.src = `${AO_HOST}sounds/music/${encodeURI(track.toLowerCase())}`;
+ }
+ music.loop = looping;
+ music.play();
+
+ try {
+ musicname = client.chars[charID].name;
+ } catch (e) {
+ charID = -1;
+ }
+
+ if (charID >= 0) {
+ musicname = client.chars[charID].name;
+ appendICLog(`${musicname} changed music to ${track}`);
+ } else {
+ appendICLog(`The music was changed to ${track}`);
+ }
+
+ document.getElementById("client_trackstatustext")!.innerText = track;
+} \ No newline at end of file