2018-10-11 00:21:03 +05:30
|
|
|
<template>
|
2019-10-14 02:49:28 +05:30
|
|
|
<div class="flex flex-col">
|
|
|
|
<PageHeader>
|
2019-11-19 22:26:08 +05:30
|
|
|
<h1 slot="title" class="text-2xl font-bold" v-if="title">{{ title }}</h1>
|
2019-10-14 02:49:28 +05:30
|
|
|
<template slot="actions">
|
2019-11-22 00:50:30 +05:30
|
|
|
<FilterDropdown
|
|
|
|
ref="filterDropdown"
|
|
|
|
@change="applyFilter"
|
|
|
|
:fields="meta.fields"
|
|
|
|
/>
|
|
|
|
<Button class="ml-2" :icon="true" type="primary" @click="makeNewDoc">
|
2019-11-19 22:26:08 +05:30
|
|
|
<feather-icon name="plus" class="w-4 h-4 text-white" />
|
2019-10-14 02:49:28 +05:30
|
|
|
</Button>
|
|
|
|
<SearchBar class="ml-2" />
|
|
|
|
</template>
|
|
|
|
</PageHeader>
|
2019-11-09 01:27:56 +05:30
|
|
|
<div class="flex-1 flex h-full">
|
2019-11-22 00:50:30 +05:30
|
|
|
<List
|
|
|
|
ref="list"
|
|
|
|
:listConfig="listConfig"
|
|
|
|
:filters="filters"
|
|
|
|
class="flex-1"
|
|
|
|
/>
|
2019-10-05 01:48:10 +05:30
|
|
|
</div>
|
2018-10-11 00:21:03 +05:30
|
|
|
</div>
|
|
|
|
</template>
|
|
|
|
<script>
|
|
|
|
import frappe from 'frappejs';
|
2018-10-23 00:40:45 +05:30
|
|
|
import Observable from 'frappejs/utils/observable';
|
2018-10-11 00:21:03 +05:30
|
|
|
import PageHeader from '@/components/PageHeader';
|
2019-10-06 03:12:08 +05:30
|
|
|
import Button from '@/components/Button';
|
|
|
|
import SearchBar from '@/components/SearchBar';
|
2018-10-11 00:21:03 +05:30
|
|
|
import List from './List';
|
2018-10-23 02:02:37 +05:30
|
|
|
import listConfigs from './listConfig';
|
2019-11-22 00:50:30 +05:30
|
|
|
import Icon from '@/components/Icon';
|
|
|
|
import FilterDropdown from '@/components/FilterDropdown';
|
2018-10-11 00:21:03 +05:30
|
|
|
|
|
|
|
export default {
|
|
|
|
name: 'ListView',
|
2019-10-11 15:25:50 +05:30
|
|
|
props: ['doctype', 'filters'],
|
2018-10-11 00:21:03 +05:30
|
|
|
components: {
|
|
|
|
PageHeader,
|
2019-10-06 03:12:08 +05:30
|
|
|
List,
|
|
|
|
Button,
|
2019-11-22 00:50:30 +05:30
|
|
|
SearchBar,
|
|
|
|
Icon,
|
|
|
|
FilterDropdown
|
2018-10-11 00:21:03 +05:30
|
|
|
},
|
2019-12-11 17:54:02 +05:30
|
|
|
activated() {
|
2019-11-22 00:50:30 +05:30
|
|
|
if (typeof this.filters === 'object') {
|
|
|
|
this.$refs.filterDropdown.setFilter(this.filters);
|
|
|
|
}
|
2018-10-23 00:40:45 +05:30
|
|
|
},
|
2018-10-11 00:21:03 +05:30
|
|
|
methods: {
|
2019-10-11 15:25:50 +05:30
|
|
|
async makeNewDoc() {
|
2018-10-23 02:02:37 +05:30
|
|
|
const doctype = this.listConfig.doctype;
|
|
|
|
const doc = await frappe.getNewDoc(doctype);
|
|
|
|
if (this.listConfig.filters) {
|
|
|
|
doc.set(this.listConfig.filters);
|
|
|
|
}
|
2019-08-14 13:13:49 +05:30
|
|
|
if (this.filters) {
|
|
|
|
doc.set(this.filters);
|
|
|
|
}
|
2019-10-11 15:25:50 +05:30
|
|
|
let path = this.getFormPath(doc.name);
|
|
|
|
this.$router.push(path);
|
2018-10-23 02:02:37 +05:30
|
|
|
doc.on('afterInsert', () => {
|
2019-10-11 15:25:50 +05:30
|
|
|
let path = this.getFormPath(doc.name);
|
|
|
|
this.$router.replace(path);
|
2018-10-23 02:02:37 +05:30
|
|
|
});
|
2019-10-11 15:25:50 +05:30
|
|
|
},
|
2019-11-22 00:50:30 +05:30
|
|
|
applyFilter(filters) {
|
|
|
|
this.$refs.list.updateData(filters);
|
|
|
|
},
|
2019-10-11 15:25:50 +05:30
|
|
|
getFormPath(name) {
|
|
|
|
if (this.listConfig.formRoute) {
|
|
|
|
let path = this.listConfig.formRoute(name);
|
|
|
|
return path;
|
|
|
|
}
|
|
|
|
return {
|
|
|
|
path: `/list/${this.doctype}`,
|
|
|
|
query: {
|
|
|
|
edit: 1,
|
|
|
|
doctype: this.doctype,
|
|
|
|
name
|
|
|
|
}
|
|
|
|
};
|
2018-10-23 02:02:37 +05:30
|
|
|
}
|
|
|
|
},
|
|
|
|
computed: {
|
2019-11-22 00:50:30 +05:30
|
|
|
meta() {
|
|
|
|
return frappe.getMeta(this.doctype);
|
|
|
|
},
|
2018-10-23 02:02:37 +05:30
|
|
|
listConfig() {
|
2019-10-11 15:25:50 +05:30
|
|
|
if (listConfigs[this.doctype]) {
|
|
|
|
return listConfigs[this.doctype];
|
2019-08-01 18:30:52 +05:30
|
|
|
} else {
|
2019-10-13 17:33:01 +05:30
|
|
|
return {
|
|
|
|
title: this.doctype,
|
|
|
|
doctype: this.doctype,
|
2019-11-22 00:50:30 +05:30
|
|
|
columns: this.meta.getKeywordFields()
|
2019-10-14 02:49:28 +05:30
|
|
|
};
|
2019-08-01 18:30:52 +05:30
|
|
|
}
|
2019-08-14 13:13:49 +05:30
|
|
|
},
|
|
|
|
title() {
|
2019-11-22 00:50:30 +05:30
|
|
|
return this.listConfig.title || this.doctype;
|
2018-10-11 00:21:03 +05:30
|
|
|
}
|
|
|
|
}
|
2019-08-01 17:22:58 +05:30
|
|
|
};
|
2018-10-11 00:21:03 +05:30
|
|
|
</script>
|