diff --git a/src/components/CreateNewPostcodeForm.vue b/src/components/CreateNewPostcodeForm.vue index e6247226e..a426ac2b4 100644 --- a/src/components/CreateNewPostcodeForm.vue +++ b/src/components/CreateNewPostcodeForm.vue @@ -45,6 +45,7 @@ function onDataSaved(formData) { } async function onCityCreated(newTown, formData) { + await provincesFetchDataRef.value.fetch(); newTown.province = provincesOptions.value.find( (province) => province.id === newTown.provinceFk ); diff --git a/src/components/ItemsFilterPanel.vue b/src/components/ItemsFilterPanel.vue index 94adfe0ff..743c2c9d1 100644 --- a/src/components/ItemsFilterPanel.vue +++ b/src/components/ItemsFilterPanel.vue @@ -112,6 +112,7 @@ const getCategoryClass = (category, params) => { const getSelectedTagValues = async (tag) => { try { + if (!tag?.selectedTag?.id) return; tag.value = null; const filter = { fields: ['value'], diff --git a/src/components/common/VnLog.vue b/src/components/common/VnLog.vue index 19765b1f7..6e656dbe8 100644 --- a/src/components/common/VnLog.vue +++ b/src/components/common/VnLog.vue @@ -1,7 +1,7 @@ diff --git a/src/pages/Customer/components/CustomerNewPayment.vue b/src/pages/Customer/components/CustomerNewPayment.vue index 877a2c353..16dd28767 100644 --- a/src/pages/Customer/components/CustomerNewPayment.vue +++ b/src/pages/Customer/components/CustomerNewPayment.vue @@ -2,18 +2,24 @@ import { onBeforeMount, reactive, ref } from 'vue'; import { useI18n } from 'vue-i18n'; import { useRoute } from 'vue-router'; +import axios from 'axios'; import { useDialogPluginComponent } from 'quasar'; +import { usePrintService } from 'composables/usePrintService'; +import useNotify from 'src/composables/useNotify.js'; import FetchData from 'components/FetchData.vue'; import FormModel from 'components/FormModel.vue'; import VnRow from 'components/ui/VnRow.vue'; import VnInputDate from 'components/common/VnInputDate.vue'; +import VnInputNumber from 'components/common/VnInputNumber.vue'; import VnSelect from 'src/components/common/VnSelect.vue'; import VnInput from 'src/components/common/VnInput.vue'; const { t } = useI18n(); const route = useRoute(); +const { notify } = useNotify(); +const { sendEmail, openReport } = usePrintService(); const { dialogRef } = useDialogPluginComponent(); const $props = defineProps({ @@ -27,7 +33,7 @@ const $props = defineProps({ }, promise: { type: Function, - required: true, + default: null, }, }); @@ -36,11 +42,12 @@ const urlCreate = ref([]); const companyOptions = ref([]); const bankOptions = ref([]); const clientFindOne = ref([]); -const deliveredAmount = ref(null); -const amountToReturn = ref(null); const viewReceipt = ref(); -const sendEmail = ref(false); -const isLoading = ref(false); +const shouldSendEmail = ref(false); +const maxAmount = ref(); +const accountingType = ref({}); +const isCash = ref(false); +const formModelRef = ref(false); const filterBanks = { fields: ['id', 'bank', 'accountingTypeFk'], @@ -67,87 +74,123 @@ onBeforeMount(() => { urlCreate.value = `Clients/${route.params.id}/createReceipt`; }); -const setPaymentType = (value) => { - // if (id === 1) initialData.description = 'Credit card'; - // if (id === 2) initialData.description = 'Cash'; - // if (id === 3 || id === 3117) initialData.description = ''; - // if (id === 4) initialData.description = 'Transfer'; - // const CASH_CODE = 2; - // // const CASH_CODE = 2 - // if (!value) return; - // const accountingType = CASH_CODE; - // initialData.description = ''; - // viewReceipt.value = value == CASH_CODE; - // if (accountingType.code == 'compensation') this.receipt.description = ''; - // else { - // if ( - // accountingType.receiptDescription != null && - // accountingType.receiptDescription != '' - // ) - // this.receipt.description.push(accountingType.receiptDescription); - // if (this.originalDescription) - // this.receipt.description.push(this.originalDescription); - // this.receipt.description = this.receipt.description.join(', '); - // } - // this.maxAmount = accountingType && accountingType.maxAmount; - // this.receipt.payed = Date.vnNew(); - // if (accountingType.daysInFuture) - // this.receipt.payed.setDate( - // this.receipt.payed.getDate() + accountingType.daysInFuture - // ); -}; +function setPaymentType(accounting) { + if (!accounting) return; + accountingType.value = accounting.accountingType; + + initialData.description = []; + initialData.payed = Date.vnNew(); + isCash.value = accountingType.value.code == 'cash'; + viewReceipt.value = isCash.value; + if (accountingType.value.daysInFuture) + initialData.payed.setDate( + initialData.payed.getDate() + accountingType.value.daysInFuture + ); + maxAmount.value = accountingType.value && accountingType.value.maxAmount; + + if (accountingType.value.code == 'compensation') + return (initialData.description = ''); + if (accountingType.value.receiptDescription) + initialData.description.push(accountingType.value.receiptDescription); + if (initialData.description) initialData.description.push(initialData.description); + + initialData.description = initialData.description.join(', '); +} const calculateFromAmount = (event) => { - amountToReturn.value = parseFloat(event) * -1 + parseFloat(deliveredAmount.value); + initialData.amountToReturn = + parseFloat(initialData.deliveredAmount) + parseFloat(event) * -1; }; const calculateFromDeliveredAmount = (event) => { - amountToReturn.value = parseFloat($props.totalCredit) * -1 + parseFloat(event); + initialData.amountToReturn = parseFloat(event) - initialData.amountPaid; }; -const setClientEmail = (data) => { - initialData.email = data.email; -}; +function onBeforeSave(data) { + const exceededAmount = data.amountPaid > maxAmount.value; + if (isCash.value && exceededAmount) + return notify(t('Amount exceeded', { maxAmount: maxAmount.value }), 'negative'); -const onDataSaved = async () => { - isLoading.value = true; - if ($props.promise) { - try { - await $props.promise(); - } finally { - isLoading.value = false; - if (closeButton.value) closeButton.value.click(); - } + if (isCash.value && shouldSendEmail.value && !data.email) + return notify(t('There is no assigned email for this client'), 'negative'); + + data.bankFk = data.bankFk.id; + return data; +} + +async function onDataSaved(formData, { id }) { + try { + if (shouldSendEmail.value && isCash.value) + await sendEmail(`Receipts/${id}/receipt-email`, { + recipient: formData.email, + }); + + if (viewReceipt.value) openReport(`Receipts/${id}/receipt-pdf`); + } finally { + if ($props.promise) $props.promise(); + if (closeButton.value) closeButton.value.click(); } -}; +} + +async function accountShortToStandard({ target: { value } }) { + if (!value) return (initialData.description = ''); + initialData.compensationAccount = value.replace('.', '0'.repeat(11 - value.length)); + const params = { bankAccount: initialData.compensationAccount }; + const { data } = await axios(`Clients/getClientOrSupplierReference`, { params }); + if (!data.clientId) { + initialData.description = t('Supplier Compensation Reference', { + supplierId: data.supplierId, + supplierName: data.supplierName, + }); + return; + } + initialData.description = t('Client Compensation Reference', { + clientId: data.clientId, + clientName: data.clientName, + }); +} + +async function getAmountPaid() { + const filter = { + where: { + clientFk: route.params.id, + companyFk: initialData.companyFk, + }, + }; + + const { data } = await axios(`ClientRisks`, { + params: { filter: JSON.stringify(filter) }, + }); + initialData.amountPaid = (data?.length && data[0].amount) || undefined; +}