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;
    },
 },
});