Homepage.vue 809 B

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152
  1. <template>
  2. <div>
  3. <h1>Sites</h1>
  4. <form>
  5. <field
  6. v-for="field in fields"
  7. :name="field.name"
  8. :minEntries="field.minEntries"
  9. :maxEntries="field.maxEntries"
  10. :initialEntries="[]"
  11. :fieldTypes="field.fieldTypes"/>
  12. </form>
  13. </div>
  14. </template>
  15. <script>
  16. import Field from '../components/Field.vue';
  17. import io from "../../io.js";
  18. export default {
  19. components: { Field },
  20. data: () => {
  21. return {
  22. fields: [],
  23. accounts: []
  24. }
  25. },
  26. methods: {
  27. },
  28. mounted() {
  29. io.getSocket(socket => {
  30. this.socket = socket;
  31. socket.emit("getAccountSchema", res => {
  32. this.fields = res.schema.versions[0].fields;
  33. });
  34. socket.emit("getAccounts", res => {
  35. this.accounts = res.accounts;
  36. });
  37. });
  38. }
  39. };
  40. </script>
  41. <style lang="scss" scoped>
  42. form {
  43. width: 400px;
  44. }
  45. </style>