CustomerCreate.vue 1.5KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172
  1. <script setup>
  2. import { useForm } from '@inertiajs/inertia-vue3'
  3. import { useFormErrorReset } from '@/components/useFormErrorReset'
  4. import AppInputText from '@/components/AppInputText.vue'
  5. const form = useForm({
  6. name: null,
  7. address: null,
  8. phone: null,
  9. npwp: null,
  10. })
  11. useFormErrorReset(form)
  12. const onSubmit = () => {
  13. form.post(route('customers.store'), {
  14. onSuccess: () => form.reset(),
  15. })
  16. }
  17. </script>
  18. <template>
  19. <div class="grid">
  20. <div class="col-12 md:col-6">
  21. <AppInputText
  22. label="Nama"
  23. placeholder="nama"
  24. :error="form.errors.name"
  25. v-model="form.name"
  26. />
  27. </div>
  28. <div class="col-12 md:col-6">
  29. <AppInputText
  30. label="Alamat"
  31. placeholder="alamat"
  32. :error="form.errors.address"
  33. v-model="form.address"
  34. />
  35. </div>
  36. <div class="col-12 md:col-6">
  37. <AppInputText
  38. label="No HP"
  39. placeholder="no hp"
  40. type="number"
  41. :error="form.errors.phone"
  42. v-model="form.phone"
  43. />
  44. </div>
  45. <div class="col-12 md:col-6">
  46. <AppInputText
  47. label="NPWP"
  48. placeholder="npwp"
  49. type="number"
  50. :error="form.errors.npwp"
  51. v-model="form.npwp"
  52. />
  53. </div>
  54. </div>
  55. <div class="flex flex-column md:flex-row justify-content-end">
  56. <Button
  57. label="Simpan"
  58. icon="pi pi-check"
  59. class="p-button-outlined"
  60. :disabled="form.processing"
  61. @click="onSubmit"
  62. />
  63. </div>
  64. </template>