7729-devToTest_2430 #554
|
@ -1,41 +1,20 @@
|
|||
<script setup>
|
||||
import { computed, ref, onBeforeMount } from 'vue';
|
||||
import { computed, ref } from 'vue';
|
||||
import { useI18n } from 'vue-i18n';
|
||||
import VnSubToolbar from 'src/components/ui/VnSubToolbar.vue';
|
||||
import { toCurrency } from 'src/filters';
|
||||
import VnTable from 'src/components/VnTable/VnTable.vue';
|
||||
import { useInvoiceOutGlobalStore } from 'src/stores/invoiceOutGlobal.js';
|
||||
import { useArrayData } from 'src/composables/useArrayData';
|
||||
// import useStateStore from 'src/stores/useStateStore';
|
||||
|
||||
const { t } = useI18n();
|
||||
const tableRef = ref();
|
||||
// const userFrom = Date.vnFirstDayOfMonth().toISOString();
|
||||
// const userTo = Date.vnLastDayOfMonth().toISOString();
|
||||
const invoiceOutGlobalStore = useInvoiceOutGlobalStore();
|
||||
// const stateStore = useStateStore();
|
||||
const arrayData = useArrayData('InvoiceOutNegative', {
|
||||
url: 'InvoiceOuts/negativeBases',
|
||||
limit: 0,
|
||||
userParams: {
|
||||
from: Date.vnFirstDayOfMonth().toISOString(),
|
||||
to: Date.vnLastDayOfMonth().toISOString(),
|
||||
},
|
||||
exprBuilder: (param, value) => {
|
||||
switch (param) {
|
||||
case 'from':
|
||||
case 'to':
|
||||
return;
|
||||
default:
|
||||
return { [param]: value };
|
||||
}
|
||||
},
|
||||
});
|
||||
|
||||
onBeforeMount(async () => {
|
||||
await arrayData.fetch({ append: false });
|
||||
// stateStore.rightDrawer = true;
|
||||
});
|
||||
const userParams = {
|
||||
from: Date.vnFirstDayOfMonth().toISOString(),
|
||||
to: Date.vnLastDayOfMonth().toISOString(),
|
||||
};
|
||||
useArrayData('InvoiceOutNegative', { userParams });
|
||||
|
||||
const columns = computed(() => [
|
||||
{
|
||||
|
@ -51,7 +30,7 @@ const columns = computed(() => [
|
|||
},
|
||||
columnField: {
|
||||
component: null,
|
||||
}
|
||||
},
|
||||
},
|
||||
{
|
||||
align: 'left',
|
||||
|
@ -65,7 +44,7 @@ const columns = computed(() => [
|
|||
},
|
||||
columnField: {
|
||||
component: null,
|
||||
}
|
||||
},
|
||||
},
|
||||
{
|
||||
align: 'left',
|
||||
|
@ -86,7 +65,7 @@ const columns = computed(() => [
|
|||
},
|
||||
columnField: {
|
||||
component: null,
|
||||
}
|
||||
},
|
||||
},
|
||||
{
|
||||
align: 'left',
|
||||
|
@ -139,8 +118,6 @@ const columns = computed(() => [
|
|||
]);
|
||||
|
||||
const downloadCSV = async () => {
|
||||
console.log('arrayData from: ', arrayData.store.userParams.from);
|
||||
console.log('arrayData to: ', arrayData.store.userParams.to);
|
||||
const filterParams = {
|
||||
limit: 20,
|
||||
where: {
|
||||
|
@ -148,15 +125,15 @@ const downloadCSV = async () => {
|
|||
},
|
||||
};
|
||||
|
||||
for (const [key, value] of Object.entries(arrayData.store.userParams)) {
|
||||
for (const [key, value] of Object.entries(userParams)) {
|
||||
if (value) {
|
||||
filterParams.where.and.push({ [key]: value });
|
||||
filterParams.where.and.push({ [key]: value });
|
||||
}
|
||||
};
|
||||
}
|
||||
|
||||
await invoiceOutGlobalStore.getNegativeBasesCsv(
|
||||
arrayData.store.userParams.from,
|
||||
arrayData.store.userParams.to,
|
||||
userParams.from,
|
||||
userParams.to,
|
||||
filterParams
|
||||
);
|
||||
};
|
||||
|
@ -171,30 +148,28 @@ const downloadCSV = async () => {
|
|||
</VnSubToolbar>
|
||||
<VnTable
|
||||
ref="tableRef"
|
||||
data-key="invoiceOut"
|
||||
data-key="negativeFilter"
|
||||
url="InvoiceOuts/negativeBases"
|
||||
:user-params="arrayData.store.userParams"
|
||||
:expr-builder="(param, value) => {
|
||||
switch (param) {
|
||||
case 'from':
|
||||
case 'to':
|
||||
return;
|
||||
default:
|
||||
return { [param]: value };
|
||||
:user-params="userParams"
|
||||
:expr-builder="
|
||||
(param, value) => {
|
||||
switch (param) {
|
||||
case 'from':
|
||||
case 'to':
|
||||
return;
|
||||
default:
|
||||
return { [param]: value };
|
||||
}
|
||||
}
|
||||
}"
|
||||
"
|
||||
:limit="0"
|
||||
:columns="columns"
|
||||
default-mode="table"
|
||||
auto-load
|
||||
:is-editable="false"
|
||||
:use-model="true"
|
||||
:order="''"
|
||||
>
|
||||
<!-- <template #moreBeforeActions>
|
||||
<QBtn color="primary" icon-right="download" @click="downloadCSV()">
|
||||
<QTooltip>{{ t('Download as CSV') }}</QTooltip>
|
||||
</QBtn>
|
||||
</template> -->
|
||||
</VnTable>
|
||||
</template>
|
||||
|
||||
|
|
|
@ -237,7 +237,7 @@ export const useInvoiceOutGlobalStore = defineStore({
|
|||
async getNegativeBasesCsv() {
|
||||
try {
|
||||
const arrayData = useArrayData('InvoiceOutNegative');
|
||||
const params = arrayData.store.currentFilter;
|
||||
const params = arrayData.store.userParams;
|
||||
|
||||
const { data } = await axios.get('InvoiceOuts/negativeBasesCsv', {
|
||||
params,
|
||||
|
|
Loading…
Reference in New Issue