Create.vue 2.0KB

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