Edit.vue 2.6KB

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