Create.vue 1.6KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859
  1. <script setup>
  2. import { watch, computed } from 'vue'
  3. import { Head, useForm, usePage } from '@inertiajs/inertia-vue3'
  4. import AppButton from '@/components/AppButton.vue'
  5. import AppInputNumber from '@/components/AppInputNumber.vue'
  6. import AppInputText from '@/components/AppInputText.vue'
  7. import AppLayout from '@/layouts/AppLayout.vue'
  8. const errors = computed(() => usePage().props.value.errors)
  9. watch(errors, () => {
  10. form.clearErrors()
  11. })
  12. const form = useForm({
  13. name: null,
  14. price: null,
  15. unit: null,
  16. })
  17. const submit = () => {
  18. form.post(route('products.store'), { onSuccess: () => form.reset() })
  19. }
  20. </script>
  21. <template>
  22. <Head title="Tambah Product" />
  23. <AppLayout>
  24. <div class="grid">
  25. <div class="col-12 lg:col-8">
  26. <Card>
  27. <template #content>
  28. <div class="grid">
  29. <div class="col-12 md:col-6">
  30. <AppInputText label="Nama" placeholder="nama" :error="form.errors.name" v-model="form.name" />
  31. </div>
  32. <div class="col-12 md:col-6">
  33. <AppInputNumber label="Harga" placeholder="harga" :error="form.errors.price" v-model="form.price" />
  34. </div>
  35. <div class="col-12 md:col-6">
  36. <AppInputText label="Satuan" placeholder="satuan" :error="form.errors.unit" v-model="form.unit" />
  37. </div>
  38. </div>
  39. </template>
  40. <template #footer>
  41. <div class="flex justify-content-end">
  42. <AppButton @click="submit" label="Simpan" icon="pi pi-check" class="p-button-text" />
  43. </div>
  44. </template>
  45. </Card>
  46. </div>
  47. </div>
  48. </AppLayout>
  49. </template>