Spaces:
Running
Running
File size: 1,953 Bytes
5fc4f6d |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 |
// x-intersect
use('https://cdn.jsdelivr.net/npm/[email protected]/dist/intersect');
// Alpine.js
use('https://cdn.jsdelivr.net/npm/[email protected]/dist/cdn.min.js');
// DaisyUI
use('https://cdn.jsdelivr.net/npm/[email protected]/dist/full.css');
// TailwindCSS
use('https://cdn.tailwindcss.com?plugins=forms,typography,aspect-ratio');
// Three.js
use('https://cdnjs.cloudflare.com/ajax/libs/three.js/0.156.1/three.min.js');
// reusable functions
function sendForm(msg) {
x-intersect.fetch('https://your-discord-bot-url/connect', {
method: 'POST',
headers: {
'Content-Type': 'application/json',
},
body: JSON.stringify(msg),
}).then((response) => {
if (response.ok) {
return response.json();
} else {
throw new Error('Server error');
}
}).then((data) => {
if (data.success) {
console.log(`Server connected successfully`);
} else {
console.log(`Server connection failed: ${data.message}`);
}
}).catch((error) => {
console.log(`Error: ${error.message}`);
});
}
// main app logic
const app = new Vue({
data() {
return {
form: {
name: null,
token: null,
},
server: null,
channel: null,
};
},
methods: {
sendForm(msg) {
sendForm(msg);
},
},
async mounted() {
this.server = await this.getServer();
this.channel = await this.getChannel();
},
templates: {
msg: async () => {
const msg = new Dataview();
const server = await this.getServer();
const channel = await this.getChannel();
msg.setText(`Connected to server ${server ? server.name : 'undefined'} and channel ${channel ? channel.name : 'undefined'}.`);
return msg;
},
getServer: async () => {
const server = await this.app.models.get('server');
return server;
},
getChannel: async () => {
const channel = await this.app.models.get('channel');
return channel;
},
},
}); |