fix: refs #6942 fix emit on data saved
gitea/salix-front/pipeline/pr-test This commit looks good Details

This commit is contained in:
Jorge Penadés 2024-06-06 09:53:48 +02:00
parent e532f0d167
commit 97dc299cfe
2 changed files with 8 additions and 8 deletions

View File

@ -117,7 +117,7 @@ onMounted(async () => {
state.set($props.model, $props.formInitialData);
if ($props.autoLoad && !$props.formInitialData && $props.url) await fetch();
else if (arrayData.store.data) updateAndEmit(arrayData.store.data, 'onFetch');
else if (arrayData.store.data) updateAndEmit('onFetch', arrayData.store.data);
if ($props.observeFormChanges) {
watch(
@ -137,7 +137,7 @@ onMounted(async () => {
if (!$props.url)
watch(
() => arrayData.store.data,
(val) => updateAndEmit(val, 'onFetch')
(val) => updateAndEmit('onFetch', val)
);
watch(formUrl, async () => {
@ -172,8 +172,8 @@ async function fetch() {
});
if (Array.isArray(data)) data = data[0] ?? {};
updateAndEmit(data, 'onFetch');
} catch (error) {
updateAndEmit('onFetch', data);
} catch (e) {
state.set($props.model, {});
originalData.value = {};
}
@ -199,7 +199,7 @@ async function save() {
hasChanges.value = false;
isLoading.value = false;
updateAndEmit(response?.data, 'onDataSaved');
updateAndEmit('onDataSaved', formData.value, response?.data);
} catch (err) {
console.error(err);
notify('errors.writeRequest', 'negative');
@ -234,12 +234,12 @@ function filter(value, update, filterOptions) {
);
}
function updateAndEmit(val, evt) {
function updateAndEmit(evt, val, res) {
state.set($props.model, val);
originalData.value = val && JSON.parse(JSON.stringify(val));
if (!$props.url) arrayData.store.data = val;
emit(evt, state.get($props.model));
emit(evt, state.get($props.model), res);
}
defineExpose({ save, isLoading, hasChanges });

View File

@ -29,7 +29,7 @@ const newInvoiceIn = reactive({
const suppliersOptions = ref([]);
const companiesOptions = ref([]);
const redirectToInvoiceInBasicData = ({ id }) => {
const redirectToInvoiceInBasicData = (__, { id }) => {
router.push({ name: 'InvoiceInBasicData', params: { id } });
};
</script>