Edit.vue 2.3KB

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