ProductCreate.vue 1.6KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273
  1. <script setup>
  2. import { onMounted } from 'vue'
  3. import { Inertia } from '@inertiajs/inertia'
  4. import { useForm, usePage } from '@inertiajs/inertia-vue3'
  5. import { useFormErrorReset } from '@/components/useFormErrorReset'
  6. import AppInputText from '@/components/AppInputText.vue'
  7. const getProductNumber = () => {
  8. Inertia.reload({ only: ['productNumber'] })
  9. }
  10. onMounted(() => getProductNumber())
  11. const form = useForm({
  12. name: null,
  13. unit: null,
  14. })
  15. useFormErrorReset(form)
  16. const onSubmit = () => {
  17. form
  18. .transform((data) => ({
  19. number: usePage().props.value.productNumber,
  20. ...data,
  21. }))
  22. .post(route('products.store'), {
  23. onSuccess: () => form.reset(),
  24. onFinish: () => getProductNumber(),
  25. })
  26. }
  27. </script>
  28. <template>
  29. <div class="grid">
  30. <div class="col-12 md:col-6">
  31. <AppInputText
  32. disabled
  33. label="Nomor Produk"
  34. placeholder="nomor produk"
  35. v-model="$page.props.productNumber"
  36. />
  37. </div>
  38. <div class="col-12 md:col-6">
  39. <AppInputText
  40. label="Nama"
  41. placeholder="nama"
  42. :error="form.errors.name"
  43. v-model="form.name"
  44. />
  45. </div>
  46. <div class="col-12 md:col-6">
  47. <AppInputText
  48. label="Satuan"
  49. placeholder="satuan"
  50. :error="form.errors.unit"
  51. v-model="form.unit"
  52. />
  53. </div>
  54. </div>
  55. <div class="flex flex-column md:flex-row justify-content-end">
  56. <Button
  57. label="Simpan"
  58. icon="pi pi-check"
  59. class="p-button-outlined"
  60. :disabled="form.processing"
  61. @click="onSubmit"
  62. />
  63. </div>
  64. </template>