2019-10-14 03:26:20 +05:30
|
|
|
<template>
|
2022-05-12 20:29:56 +05:30
|
|
|
<div class="flex flex-col w-full h-full">
|
|
|
|
<PageHeader :title="title">
|
|
|
|
<!--
|
2022-05-01 13:09:03 +05:30
|
|
|
<DropdownWithActions
|
|
|
|
v-for="group of actionGroups"
|
|
|
|
:key="group.label"
|
|
|
|
:type="group.type"
|
|
|
|
:actions="group.actions"
|
|
|
|
class="text-xs"
|
|
|
|
>
|
|
|
|
{{ group.label }}
|
|
|
|
</DropdownWithActions>
|
|
|
|
<DropdownWithActions :actions="actions" />
|
2022-05-12 20:29:56 +05:30
|
|
|
|
|
|
|
-->
|
2019-10-14 03:26:20 +05:30
|
|
|
</PageHeader>
|
2022-05-12 20:29:56 +05:30
|
|
|
|
|
|
|
<!-- Filters -->
|
|
|
|
<div v-if="report" class="mx-4 grid grid-cols-5 gap-2">
|
|
|
|
<FormControl
|
|
|
|
v-for="field in report.filters"
|
|
|
|
:show-label="field.fieldtype === 'Check'"
|
|
|
|
:key="field.fieldname + '-filter'"
|
|
|
|
class="bg-gray-100 rounded"
|
|
|
|
:class="field.fieldtype === 'Check' ? 'flex pl-3' : ''"
|
|
|
|
input-class="bg-transparent px-3 py-2 text-base"
|
|
|
|
:df="field"
|
|
|
|
:value="report.get(field.fieldname)"
|
|
|
|
:read-only="loading"
|
|
|
|
@change="async (value) => await report.set(field.fieldname, value)"
|
|
|
|
/>
|
2019-11-20 00:44:15 +05:30
|
|
|
</div>
|
2022-05-12 20:29:56 +05:30
|
|
|
|
|
|
|
<!-- Report Outer Container -->
|
|
|
|
<div
|
|
|
|
v-if="report"
|
|
|
|
class="mx-4 mt-4 overflow-x-scroll inline-block overflow-y-hidden"
|
|
|
|
>
|
|
|
|
<div class="inline-block">
|
|
|
|
<!-- Title Row -->
|
|
|
|
<div
|
|
|
|
class="flex items-center border-b"
|
|
|
|
:style="{ height: `${hconst}px` }"
|
|
|
|
ref="titleRow"
|
|
|
|
>
|
|
|
|
<p
|
|
|
|
v-for="(col, c) in report.columns"
|
|
|
|
:key="c + '-col'"
|
|
|
|
:style="getCellStyle(col, c)"
|
|
|
|
class="
|
|
|
|
text-gray-600 text-base
|
|
|
|
px-3
|
|
|
|
flex-shrink-0
|
|
|
|
overflow-x-scroll
|
|
|
|
whitespace-nowrap
|
|
|
|
"
|
|
|
|
>
|
|
|
|
{{ col.label }}
|
|
|
|
</p>
|
2019-11-08 16:19:06 +05:30
|
|
|
</div>
|
2022-05-12 20:29:56 +05:30
|
|
|
|
|
|
|
<!-- Report Rows Continer -->
|
|
|
|
<div
|
|
|
|
class="overflow-y-scroll"
|
|
|
|
:style="{ height: `${hconst * maxRows + 5}px` }"
|
2022-02-10 15:28:20 +05:30
|
|
|
>
|
2022-05-12 20:29:56 +05:30
|
|
|
<!-- Report Rows -->
|
|
|
|
<div
|
|
|
|
v-for="(row, r) in report.reportData"
|
|
|
|
:key="r + '-row'"
|
|
|
|
class="border-b flex items-center"
|
|
|
|
:style="{ height: `${hconst}px` }"
|
2022-02-10 15:28:20 +05:30
|
|
|
>
|
2022-05-12 20:29:56 +05:30
|
|
|
<!-- Report Cell -->
|
2022-02-10 15:28:20 +05:30
|
|
|
<div
|
2022-05-12 20:29:56 +05:30
|
|
|
v-for="(cell, c) in row"
|
|
|
|
:key="`${c}-${r}-cell`"
|
|
|
|
:style="getCellStyle(cell, c)"
|
|
|
|
class="
|
|
|
|
text-gray-900 text-base
|
|
|
|
px-3
|
|
|
|
flex-shrink-0
|
|
|
|
overflow-x-scroll
|
|
|
|
whitespace-nowrap
|
|
|
|
"
|
2019-12-03 15:53:54 +05:30
|
|
|
>
|
2022-05-12 20:29:56 +05:30
|
|
|
{{ cell.value }}
|
2022-03-02 13:00:48 +05:30
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
2019-10-14 03:26:20 +05:30
|
|
|
</div>
|
|
|
|
</div>
|
2022-05-12 20:29:56 +05:30
|
|
|
<div class="h-10 mx-4 mb-4 p-2 bg-red-100 text-base border-t">
|
|
|
|
add pagination here
|
|
|
|
</div>
|
2019-10-14 03:26:20 +05:30
|
|
|
</div>
|
|
|
|
</template>
|
|
|
|
<script>
|
2022-05-12 20:29:56 +05:30
|
|
|
import { reports } from 'reports';
|
2022-04-22 16:32:03 +05:30
|
|
|
import FormControl from 'src/components/Controls/FormControl.vue';
|
2022-05-12 20:29:56 +05:30
|
|
|
import PageHeader from 'src/components/PageHeader.vue';
|
2022-04-21 18:38:36 +05:30
|
|
|
import { fyo } from 'src/initFyo';
|
2022-05-12 20:29:56 +05:30
|
|
|
import { defineComponent } from 'vue';
|
2019-10-14 03:26:20 +05:30
|
|
|
|
2022-05-12 20:29:56 +05:30
|
|
|
export default defineComponent({
|
|
|
|
props: {
|
|
|
|
reportName: String,
|
2019-10-14 03:26:20 +05:30
|
|
|
},
|
|
|
|
data() {
|
|
|
|
return {
|
2022-05-12 20:29:56 +05:30
|
|
|
wconst: 8,
|
|
|
|
hconst: 48,
|
|
|
|
loading: false,
|
|
|
|
report: null,
|
2019-10-14 03:26:20 +05:30
|
|
|
};
|
|
|
|
},
|
2022-05-12 20:29:56 +05:30
|
|
|
components: { PageHeader, FormControl },
|
|
|
|
async mounted() {
|
|
|
|
await this.setReportData();
|
|
|
|
},
|
2019-12-20 12:24:12 +05:30
|
|
|
async activated() {
|
2022-05-12 20:29:56 +05:30
|
|
|
await this.setReportData();
|
|
|
|
if (fyo.store.isDevelopment) {
|
|
|
|
window.rep = this;
|
|
|
|
}
|
2019-10-14 03:26:20 +05:30
|
|
|
},
|
2022-05-12 20:29:56 +05:30
|
|
|
computed: {
|
|
|
|
maxRows() {
|
|
|
|
return 18 - Math.ceil(this.report.filters.length / 5);
|
2019-12-03 17:15:07 +05:30
|
|
|
},
|
2022-05-12 20:29:56 +05:30
|
|
|
title() {
|
|
|
|
return reports[this.reportName]?.title ?? t`Report`;
|
2019-12-03 17:15:07 +05:30
|
|
|
},
|
2022-05-12 20:29:56 +05:30
|
|
|
},
|
|
|
|
methods: {
|
|
|
|
getCellStyle(cell, i) {
|
|
|
|
const styles = {};
|
|
|
|
const width = cell.width ?? 1;
|
|
|
|
const align = cell.align ?? 'left';
|
2019-12-03 17:15:07 +05:30
|
|
|
|
2022-05-12 20:29:56 +05:30
|
|
|
styles['width'] = `${width * this.wconst}rem`;
|
|
|
|
styles['text-align'] = align;
|
2019-12-03 17:15:07 +05:30
|
|
|
|
2022-05-12 20:29:56 +05:30
|
|
|
if (cell.bold) {
|
|
|
|
styles['font-weight'] = 'bold';
|
2019-12-03 17:15:07 +05:30
|
|
|
}
|
|
|
|
|
2022-05-12 20:29:56 +05:30
|
|
|
if (cell.italics) {
|
|
|
|
styles['font-style'] = 'italic';
|
2019-12-03 17:15:07 +05:30
|
|
|
}
|
2019-11-20 00:44:15 +05:30
|
|
|
|
2022-05-12 20:29:56 +05:30
|
|
|
if (i === 0) {
|
|
|
|
styles['padding-left'] = '0px';
|
2019-11-20 00:44:15 +05:30
|
|
|
}
|
2019-11-27 12:16:15 +05:30
|
|
|
|
2022-05-12 20:29:56 +05:30
|
|
|
if (i === this.report.columns.length - 1) {
|
|
|
|
styles['padding-right'] = '0px';
|
2019-11-27 12:16:15 +05:30
|
|
|
}
|
2019-12-03 15:53:54 +05:30
|
|
|
|
2022-05-12 20:29:56 +05:30
|
|
|
return styles;
|
2021-12-16 15:56:18 +05:30
|
|
|
},
|
2022-05-12 20:29:56 +05:30
|
|
|
async setReportData() {
|
|
|
|
const Report = reports[this.reportName];
|
|
|
|
if (this.report === null) {
|
|
|
|
this.report = new Report(fyo);
|
2022-03-18 13:29:48 +05:30
|
|
|
}
|
2022-04-27 17:32:43 +05:30
|
|
|
|
2022-05-12 20:29:56 +05:30
|
|
|
if (!this.report.reportData.length) {
|
|
|
|
await this.report.setReportData();
|
2022-03-02 13:00:48 +05:30
|
|
|
}
|
2021-12-16 15:56:18 +05:30
|
|
|
},
|
|
|
|
},
|
2022-05-12 20:29:56 +05:30
|
|
|
});
|
2019-10-14 03:26:20 +05:30
|
|
|
</script>
|