2
0
mirror of https://github.com/frappe/books.git synced 2025-01-24 07:38:25 +00:00

fix: add grouped dropdown for export, add reset filter in Report.vue

This commit is contained in:
18alantom 2021-12-21 11:38:31 +05:30 committed by Alan
parent c4c5ef3a9f
commit 791d276f9d
2 changed files with 56 additions and 15 deletions

View File

@ -6,8 +6,15 @@
right
>
<template v-slot="{ toggleDropdown }">
<Button class="text-gray-900" :icon="true" @click="toggleDropdown()">
<feather-icon name="more-horizontal" class="w-4 h-4" />
<Button
class="text-gray-900"
:type="type"
:icon="true"
@click="toggleDropdown()"
>
<slot>
<feather-icon name="more-horizontal" class="w-4 h-4" />
</slot>
</Button>
</template>
</Dropdown>
@ -19,10 +26,13 @@ import Button from '@/components/Button';
export default {
name: 'DropdownWithActions',
props: ['actions'],
props: {
actions: { default: [] },
type: { type: String, default: 'secondary' },
},
components: {
Dropdown,
Button
}
Button,
},
};
</script>

View File

@ -2,16 +2,18 @@
<div class="flex flex-col max-w-full">
<PageHeader>
<h1 slot="title" class="text-2xl font-bold">{{ report.title }}</h1>
<template slot="actions">
<Button
@click="link.action(reportData, filters)"
v-for="link of report.linkFields"
:key="link.label"
:type="link.type"
<template slot="actions">
<DropdownWithActions
v-for="group of actionGroups"
@click="group.action(reportData, filters)"
:key="group.label"
:type="group.type"
:actions="group.actions"
class="ml-2 text-xs"
>
{{ link.label }}
</Button>
{{ group.label }}
</DropdownWithActions>
<DropdownWithActions class="ml-2" :actions="actions" />
<SearchBar class="ml-2" />
</template>
</PageHeader>
@ -25,7 +27,7 @@
v-for="df in report.filterFields"
:key="df.fieldname"
>
<div v-if="df.fieldtype === 'Check'" class="text-gray-900 text-sm">
<div v-if="df.fieldtype === 'Check'" class="text-sm">
{{ df.label }}
</div>
<FormControl
@ -34,7 +36,6 @@
:df="df"
:value="filters[df.fieldname]"
@change="(value) => onFilterChange(df, value)"
:show-label="df.fieldtype === 'Check'"
/>
</div>
</div>
@ -101,6 +102,7 @@ import SearchBar from '@/components/SearchBar';
import Row from '@/components/Row';
import WithScroll from '@/components/WithScroll';
import FormControl from '@/components/Controls/FormControl';
import DropdownWithActions from '../components/DropdownWithActions.vue';
import reportViewConfig from '@/../reports/view';
export default {
@ -113,6 +115,7 @@ export default {
Row,
FormControl,
WithScroll,
DropdownWithActions,
},
provide() {
return {
@ -210,6 +213,11 @@ export default {
this.fetchReportData();
},
async resetFilters() {
await this.setDefaultFilters();
await this.fetchReportData();
},
async setDefaultFilters() {
for (let df of this.report.filterFields) {
let defaultValue = null;
@ -273,6 +281,29 @@ export default {
},
},
computed: {
actions() {
return [
...(this.report.actions?.filter((action) => !action.group)??[]),
{
label: this._('Reset Filters'),
action: this.resetFilters,
},
];
},
actionGroups() {
const groups =
this.report.actions
?.filter((action) => action.group)
.reduce((acc, action) => {
acc[action.group] ??= { type: action.type, actions: [] };
const actionWithoutGroup = Object.assign({}, action);
delete actionWithoutGroup.group;
acc[action.group].actions.push(actionWithoutGroup);
return acc;
}, {}) ?? {};
return Object.keys(groups).map((label) => ({ label, ...groups[label] }));
},
columns() {
return this.loading
? this.blankStateData.columns