Edit.vue 2.7KB

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