Create.vue 1.7KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162
  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 props = defineProps({
  8. outlet_number: String,
  9. })
  10. const errors = computed(() => usePage().props.value.errors)
  11. watch(errors, () => {
  12. form.clearErrors()
  13. })
  14. const form = useForm({
  15. name: '',
  16. phone: '',
  17. address: '',
  18. })
  19. const submit = () => {
  20. form.post(route('outlets.store'), { onSuccess: () => form.reset() })
  21. }
  22. </script>
  23. <template>
  24. <Head title="Tambah Outlet" />
  25. <AppLayout>
  26. <div class="grid">
  27. <div class="col-12 lg:col-8">
  28. <Card>
  29. <template #content>
  30. <div class="grid">
  31. <div class="col-12 md:col-6">
  32. <AppInputText label="Nama" placeholder="nama" :error="form.errors.name" v-model="form.name" />
  33. </div>
  34. <div class="col-12 md:col-6">
  35. <AppInputText label="Nomor HP" placeholder="nomor hp" :error="form.errors.phone" v-model="form.phone" />
  36. </div>
  37. <div class="col-12 md:col-6">
  38. <AppInputText label="Alamat" placeholder="alamat" :error="form.errors.address" v-model="form.address" />
  39. </div>
  40. </div>
  41. </template>
  42. <template #footer>
  43. <div class="flex flex-column md:flex-row justify-content-end">
  44. <Button label="Simpan" icon="pi pi-check" class="p-button-outlined" @click="submit" />
  45. </div>
  46. </template>
  47. </Card>
  48. </div>
  49. </div>
  50. </AppLayout>
  51. </template>