Edit.vue 2.4KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990
  1. <script setup>
  2. import { useForm } from '@/composables/useForm'
  3. import AppInputText from '@/components/AppInputText.vue'
  4. import DashboardLayout from '@/layouts/Dashboard/DashboardLayout.vue'
  5. const props = defineProps({
  6. customer: Object,
  7. })
  8. const form = useForm({
  9. name: props.customer.name,
  10. address: props.customer.address,
  11. phone: props.customer.phone,
  12. npwp: props.customer.npwp,
  13. })
  14. const onSubmit = () => {
  15. form.put(route('customers.update', props.customer.id))
  16. }
  17. </script>
  18. <template>
  19. <DashboardLayout title="Ubah Pelanggan">
  20. <div class="grid">
  21. <div class="col-12">
  22. <Card>
  23. <template #title> Ubah Pelanggan </template>
  24. <template #content>
  25. <div class="grid">
  26. <div class="col-12 md:col-6">
  27. <AppInputText
  28. label="Nama"
  29. placeholder="nama"
  30. :error="form.errors.name"
  31. v-model="form.name"
  32. />
  33. </div>
  34. <div class="col-12 md:col-6">
  35. <AppInputText
  36. label="Alamat"
  37. placeholder="alamat"
  38. :error="form.errors.address"
  39. v-model="form.address"
  40. />
  41. </div>
  42. <div class="col-12 md:col-6">
  43. <AppInputText
  44. label="No HP"
  45. placeholder="no hp"
  46. type="number"
  47. :error="form.errors.phone"
  48. v-model="form.phone"
  49. />
  50. </div>
  51. <div class="col-12 md:col-6">
  52. <AppInputText
  53. label="NPWP"
  54. placeholder="npwp"
  55. type="number"
  56. :error="form.errors.npwp"
  57. v-model="form.npwp"
  58. />
  59. </div>
  60. </div>
  61. </template>
  62. <template #footer>
  63. <div class="grid">
  64. <div
  65. class="col-12 flex flex-column md:flex-row justify-content-end"
  66. >
  67. <Button
  68. label="Simpan"
  69. icon="pi pi-check"
  70. class="p-button-outlined"
  71. :disabled="form.processing"
  72. @click="onSubmit"
  73. />
  74. </div>
  75. </div>
  76. </template>
  77. </Card>
  78. </div>
  79. </div>
  80. </DashboardLayout>
  81. </template>