Create.vue 2.1KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576
  1. <script setup>
  2. import { useForm, Head } from '@inertiajs/inertia-vue3'
  3. import { useFormErrorReset } from '@/components/useFormErrorReset'
  4. import AppInputText from '@/components/AppInputText.vue'
  5. import AppDropdown from '@/components/AppDropdown.vue'
  6. import DashboardLayout from '@/layouts/DashboardLayout.vue'
  7. defineProps({
  8. roles: Array,
  9. })
  10. const form = useForm({
  11. name: null,
  12. phone: null,
  13. email: null,
  14. role_id: null,
  15. })
  16. useFormErrorReset(form)
  17. const onSubmit = () => {
  18. form.post(route('users.store'), { onSuccess: () => form.reset() })
  19. }
  20. </script>
  21. <template>
  22. <Head title="Tambah User" />
  23. <DashboardLayout>
  24. <div class="grid">
  25. <div class="col-12 lg:col-8">
  26. <Card>
  27. <template #title> Tambah User </template>
  28. <template #content>
  29. <div class="grid">
  30. <div class="col-12 md:col-6">
  31. <AppInputText label="Nama" placeholder="nama" :error="form.errors.name" v-model="form.name" />
  32. </div>
  33. <div class="col-12 md:col-6">
  34. <AppInputText label="Nomor HP" placeholder="nomor hp" :error="form.errors.phone" v-model="form.phone" />
  35. </div>
  36. <div class="col-12 md:col-6">
  37. <AppInputText label="Email" placeholder="email" :error="form.errors.email" v-model="form.email" />
  38. </div>
  39. <div class="col-12 md:col-6">
  40. <AppDropdown
  41. label="Hak Akses"
  42. placeholder="pilih satu"
  43. v-model="form.role_id"
  44. :options="roles"
  45. :error="form.errors.role_id"
  46. />
  47. </div>
  48. </div>
  49. </template>
  50. <template #footer>
  51. <div class="flex flex-column md:flex-row justify-content-end">
  52. <Button
  53. label="Simpan"
  54. icon="pi pi-check"
  55. class="p-button-outlined"
  56. :disabled="form.processing"
  57. @click="onSubmit"
  58. />
  59. </div>
  60. </template>
  61. </Card>
  62. </div>
  63. </div>
  64. </DashboardLayout>
  65. </template>