Edit.vue 2.0KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475
  1. <script setup>
  2. import { useForm } from '@/components/useForm'
  3. import AppInputText from '@/components/AppInputText.vue'
  4. import DashboardLayout from '@/layouts/Dashboard/DashboardLayout.vue'
  5. const props = defineProps({
  6. product: Object,
  7. })
  8. const form = useForm({
  9. number: props.product.number,
  10. name: props.product.name,
  11. unit: props.product.unit,
  12. })
  13. const onSubmit = () => {
  14. form.put(route('products.update', props.product.id))
  15. }
  16. </script>
  17. <template>
  18. <DashboardLayout title="Ubah Produk">
  19. <div class="grid">
  20. <div class="col-12 lg:col-8">
  21. <Card>
  22. <template #title> Ubah Produk </template>
  23. <template #content>
  24. <div class="grid">
  25. <div class="col-12 md:col-6">
  26. <AppInputText
  27. disabled
  28. label="Nomor Produk"
  29. placeholder="nomor produk"
  30. :error="form.errors.number"
  31. v-model="form.number"
  32. />
  33. </div>
  34. <div class="col-12 md:col-6">
  35. <AppInputText
  36. label="Nama"
  37. placeholder="nama"
  38. :error="form.errors.name"
  39. v-model="form.name"
  40. />
  41. </div>
  42. <div class="col-12 md:col-6">
  43. <AppInputText
  44. label="Satuan"
  45. placeholder="satuan"
  46. :error="form.errors.unit"
  47. v-model="form.unit"
  48. />
  49. </div>
  50. </div>
  51. </template>
  52. <template #footer>
  53. <div class="flex flex-column md:flex-row justify-content-end">
  54. <Button
  55. label="Simpan"
  56. icon="pi pi-check"
  57. class="p-button-outlined"
  58. :disabled="form.processing"
  59. @click="onSubmit"
  60. />
  61. </div>
  62. </template>
  63. </Card>
  64. </div>
  65. </div>
  66. </DashboardLayout>
  67. </template>