| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136 |
- <template>
- <q-dialog ref="dialogRef" @hide="onDialogHide">
- <q-card class="q-dialog-plugin overflow-hidden" style="width: 800px">
- <DefaultDialogHeader :title="title" @close="onDialogCancel" />
- <q-form ref="formRef" @submit="onOKClick">
- <q-card-section class="row q-col-gutter-sm q-pt-none">
- <DefaultInput
- v-model="form.name"
- v-model:error="validationErrors.name"
- :label="$t('common.terms.name')"
- :placeholder="'Nome completo do pais'"
- :rules="[inputRules.required]"
- class="col-md-6 col-12"
- />
- <DefaultInput
- v-model="form.code"
- v-model:error="validationErrors.code"
- :label="$t('common.terms.code')"
- :placeholder="'Ex. BR, PT...'"
- :rules="[inputRules.required]"
- class="col-md-6 col-12"
- />
- <DefaultSelect
- v-model="selectedStatus"
- v-model:error="validationErrors.status"
- :options="statusOptions"
- :rules="[inputRules.required]"
- :label="$t('common.terms.status')"
- :placeholder="$t('common.terms.status')"
- class="col-md-6 col-12"
- />
- </q-card-section>
- <q-card-actions>
- <q-space />
- <q-btn
- outline
- color="negative"
- :label="$t('common.actions.cancel')"
- @click="onDialogCancel"
- />
- <q-btn
- color="primary"
- :label="
- country ? $t('common.actions.save') : $t('common.actions.add')
- "
- :type="'submit'"
- :loading="loading"
- :disable="!hasUpdatedFields"
- />
- </q-card-actions>
- </q-form>
- </q-card>
- </q-dialog>
- </template>
- <script setup>
- import { ref, useTemplateRef, onMounted, watch } from "vue";
- import { useInputRules } from "src/composables/useInputRules";
- import { useDialogPluginComponent } from "quasar";
- import { useI18n } from "vue-i18n";
- import { createCountry, updateCountry } from "src/api/country";
- import { useFormUpdateTracker } from "src/composables/useFormUpdateTracker";
- import { useSubmitHandler } from "src/composables/useSubmitHandler";
- import DefaultDialogHeader from "src/components/defaults/DefaultDialogHeader.vue";
- import DefaultInput from "src/components/defaults/DefaultInput.vue";
- import DefaultSelect from "src/components/defaults/DefaultSelect.vue";
- defineEmits([
- // REQUIRED; need to specify some events that your
- // component will emit through useDialogPluginComponent()
- ...useDialogPluginComponent.emits,
- ]);
- const { country, title } = defineProps({
- country: {
- type: Object,
- default: null,
- },
- title: {
- type: Function,
- default: () => useI18n().t("common.terms.title"),
- },
- });
- const { t } = useI18n();
- const { inputRules } = useInputRules();
- const { dialogRef, onDialogHide, onDialogOK, onDialogCancel } =
- useDialogPluginComponent();
- const formRef = useTemplateRef("formRef");
- const { form, getUpdatedFields, hasUpdatedFields } = useFormUpdateTracker({
- name: country ? country?.name : "",
- code: country ? country?.code : "",
- status: country ? country?.status : "ACTIVE",
- });
- const {
- loading,
- validationErrors,
- execute: submitForm,
- } = useSubmitHandler({
- onSuccess: () => onDialogOK(true),
- formRef: formRef,
- });
- const selectedStatus = ref({
- label: t("common.status.active"),
- value: "ACTIVE",
- });
- const statusOptions = ref([
- { label: t("common.status.active"), value: "ACTIVE" },
- { label: t("common.status.inactive"), value: "INACTIVE" },
- ]);
- const onOKClick = async () => {
- if (country) {
- await submitForm(() => updateCountry(getUpdatedFields.value, country.id));
- } else {
- await submitForm(() => createCountry({ ...form }));
- }
- };
- watch(selectedStatus, () => {
- form.status = selectedStatus.value.value;
- });
- onMounted(() => {
- if (country) {
- selectedStatus.value = statusOptions.value.find(
- (status) => status.value === country.status,
- );
- }
- });
- </script>
|