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