#6942 improve invoiceIn #220

Merged
jorgep merged 63 commits from 6942-improveInvoceIn into dev 2024-05-29 07:03:46 +00:00
3 changed files with 21 additions and 17 deletions
Showing only changes of commit c6477af493 - Show all commits

View File

@ -109,7 +109,7 @@ const defaultButtons = computed(() => ({
})); }));
onMounted(async () => { onMounted(async () => {
Review

Lo he pasado aquí para que todos los hooks estén agrupados.

Lo he pasado aquí para que todos los hooks estén agrupados.
originalData.value = $props.formInitialData; originalData.value = JSON.parse(JSON.stringify($props.formInitialData ?? {}));
Review

Hay que hacerlo así para que se haga una copia, si no, se hace una referencia al mismo objeto.

Hay que hacerlo así para que se haga una copia, si no, se hace una referencia al mismo objeto.
Review

Se podría poner el comentario en código?

Se podría poner el comentario en código?
nextTick(() => (componentIsRendered.value = true)); nextTick(() => (componentIsRendered.value = true));
@ -124,7 +124,9 @@ onMounted(async () => {
() => formData.value, () => formData.value,
(newVal, oldVal) => { (newVal, oldVal) => {
if (!oldVal) return; if (!oldVal) return;
hasChanges.value = !isResetting.value && newVal; hasChanges.value =
!isResetting.value &&
JSON.stringify(newVal) !== JSON.stringify(originalData.value);
Review

Para ver si hay cambios comparamos el obj actual con el original. Con la lógica anterior, no funcionaba bien si se usa una store, ya que al emitir este valor se 'actualiza'. Así se hace la comprobación correcta.

Para ver si hay cambios comparamos el obj actual con el original. Con la lógica anterior, no funcionaba bien si se usa una store, ya que al emitir este valor se 'actualiza'. Así se hace la comprobación correcta.
Review

Se podría poner el comentario en código?

Se podría poner el comentario en código?
Review

yo lo veo bien sin comentarios. lo que diga @jgallego

yo lo veo bien sin comentarios. lo que diga @jgallego
Review

Yo no pondría comentarios, pero si en otros sitios está implementado distinto yo lo cambiaría para que quien venga detrás coja siempre una buena implementación

Yo no pondría comentarios, pero si en otros sitios está implementado distinto yo lo cambiaría para que quien venga detrás coja siempre una buena implementación
isResetting.value = false; isResetting.value = false;
}, },
{ deep: true } { deep: true }
@ -145,6 +147,7 @@ watch(formUrl, async () => {
}); });
onBeforeRouteLeave((to, from, next) => { onBeforeRouteLeave((to, from, next) => {
Review

Agrupado con el resto de hooks

Agrupado con el resto de hooks
console.log('entro aqui antes');
if (hasChanges.value && $props.observeFormChanges) if (hasChanges.value && $props.observeFormChanges)
quasar.dialog({ quasar.dialog({
component: VnConfirm, component: VnConfirm,
@ -177,7 +180,7 @@ async function fetch() {
} }
} }
async function save() { async function save(emit = true) {
if ($props.observeFormChanges && !hasChanges.value) if ($props.observeFormChanges && !hasChanges.value)
return notify('globals.noChanges', 'negative'); return notify('globals.noChanges', 'negative');
@ -194,18 +197,18 @@ async function save() {
if ($props.urlCreate) notify('globals.dataCreated', 'positive'); if ($props.urlCreate) notify('globals.dataCreated', 'positive');
updateAndEmit(response?.data, 'onDataSaved');
hasChanges.value = false; hasChanges.value = false;
isLoading.value = false;
if (emit) updateAndEmit(response?.data, 'onDataSaved');
} catch (err) { } catch (err) {
console.error(err); console.error(err);
notify('errors.writeRequest', 'negative'); notify('errors.writeRequest', 'negative');
} finally {
isLoading.value = false;
} }
} }
async function saveAndGo() { async function saveAndGo() {
await save(); await save(null);
push({ path: $props.goTo }); push({ path: $props.goTo });
} }
@ -240,7 +243,7 @@ function updateAndEmit(val, evt) {
emit(evt, state.get($props.model)); emit(evt, state.get($props.model));
} }
defineExpose({ save, isLoading, hasChanges }); defineExpose({ save, saveAndGo, isLoading, hasChanges });
</script> </script>
<template> <template>
<div class="column items-center full-width"> <div class="column items-center full-width">

View File

@ -4,7 +4,7 @@ import { useI18n } from 'vue-i18n';
import { useRoute, useRouter } from 'vue-router'; import { useRoute, useRouter } from 'vue-router';
import FormModel from 'components/FormModel.vue'; import FormModel from 'components/FormModel.vue';
import VnRow from 'components/ui/VnRow.vue'; import VnRow from 'components/ui/VnRow.vue';
import VnSelectFilter from 'src/components/common/VnSelectFilter.vue'; import VnSelect from 'src/components/common/VnSelect.vue';
import FetchData from 'components/FetchData.vue'; import FetchData from 'components/FetchData.vue';
import VnSubToolbar from 'src/components/ui/VnSubToolbar.vue'; import VnSubToolbar from 'src/components/ui/VnSubToolbar.vue';
import VnSearchbar from 'src/components/ui/VnSearchbar.vue'; import VnSearchbar from 'src/components/ui/VnSearchbar.vue';
@ -29,8 +29,9 @@ const newInvoiceIn = reactive({
const suppliersOptions = ref([]); const suppliersOptions = ref([]);
const companiesOptions = ref([]); const companiesOptions = ref([]);
const redirectToInvoiceInBasicData = (_, { id }) => const redirectToInvoiceInBasicData = ({ id }) => {
router.push({ name: 'InvoiceInBasicData', params: { id } }); router.push({ name: 'InvoiceInBasicData', params: { id } });
};
</script> </script>
<template> <template>
@ -61,13 +62,13 @@ const redirectToInvoiceInBasicData = (_, { id }) =>
<VnSubToolbar /> <VnSubToolbar />
<FormModel <FormModel
url-create="InvoiceIns" url-create="InvoiceIns"
model="Invoice" model="InvoiceIn"
:form-initial-data="newInvoiceIn" :form-initial-data="newInvoiceIn"
@on-data-saved="redirectToInvoiceInBasicData" @on-data-saved="redirectToInvoiceInBasicData"
> >
<template #form="{ data, validate }"> <template #form="{ data, validate }">
<VnRow> <VnRow>
<VnSelectFilter <VnSelect
:label="t('Supplier')" :label="t('Supplier')"
v-model="data.supplierFk" v-model="data.supplierFk"
:options="suppliersOptions" :options="suppliersOptions"
@ -87,14 +88,14 @@ const redirectToInvoiceInBasicData = (_, { id }) =>
</QItemSection> </QItemSection>
</QItem> </QItem>
</template> </template>
</VnSelectFilter> </VnSelect>
<VnInput <VnInput
:label="t('invoiceIn.summary.supplierRef')" :label="t('invoiceIn.summary.supplierRef')"
v-model="data.supplierRef" v-model="data.supplierRef"
/> />
</VnRow> </VnRow>
<VnRow> <VnRow>
<VnSelectFilter <VnSelect
:label="t('Company')" :label="t('Company')"
v-model="data.companyFk" v-model="data.companyFk"
:options="companiesOptions" :options="companiesOptions"

View File

@ -39,10 +39,10 @@ export default {
}, },
{ {
path: 'create', path: 'create',
name: 'InvoiceInCreate', name: 'InvoiceInCreare',
meta: { meta: {
title: 'create', title: 'invoiceInCreate',
icon: 'vn:settings', icon: 'create',
}, },
component: () => import('src/pages/InvoiceIn/InvoiceInCreate.vue'), component: () => import('src/pages/InvoiceIn/InvoiceInCreate.vue'),
}, },