The frontend component of PuffPastry, meant to interface with the backend, which in turn interfaces with the smart contract.
Du kannst nicht mehr als 25 Themen auswählen Themen müssen entweder mit einem Buchstaben oder einer Ziffer beginnen. Sie können Bindestriche („-“) enthalten und bis zu 35 Zeichen lang sein.

IssueModal.vue 1.3 KiB

vor 8 Monaten
vor 8 Monaten
vor 8 Monaten
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748
  1. <template>
  2. <Modal header="New Issue" @submitted="submit">
  3. <slot>
  4. <div class="my-3">
  5. <input type="text" class="w-full border-gray-300 border border-solid py-2 px-2.5" placeholder="Title" aria-label="Title" v-model="title" />
  6. </div>
  7. <div class="my-3">
  8. <PostBuilder @text-change="assignDescription" />
  9. </div>
  10. </slot>
  11. </Modal>
  12. </template>
  13. <script setup lang="ts" generic="T extends ContentModal">
  14. import { useFetch } from "../../composables/useFetch.ts";
  15. import { useSession } from "../../composables/useSession.ts";
  16. import Modal from "./Modal.vue";
  17. import { ref } from "vue";
  18. import { AddIssueRequest, AddIssueResponse } from "../../types/issue.ts";
  19. import PostBuilder from "../PostBuilder.vue";
  20. import { ContentModal } from "../../composables/useModal.ts";
  21. const title = ref('');
  22. const description = ref<string[]>(['']);
  23. const { post } = useFetch();
  24. const submit = async () => {
  25. const { getSessionId } = useSession();
  26. const sessionId = getSessionId();
  27. if (sessionId) {
  28. await post<AddIssueRequest, AddIssueResponse>('/issues/create', {
  29. title: title.value,
  30. paragraphs: description.value
  31. });
  32. }
  33. }
  34. const assignDescription = (paragraphs: string[]) => {
  35. description.value = paragraphs;
  36. }
  37. </script>
  38. <style scoped>
  39. </style>