Merge pull request #65 from shariquerik/fixes-1

feat: Default View and fixes
This commit is contained in:
Shariq Ansari 2024-02-03 21:59:41 +05:30 committed by GitHub
commit 270c2bb7cd
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
12 changed files with 111 additions and 196 deletions

View File

@ -235,8 +235,8 @@ def get_list_data(
"page_length": page_length, "page_length": page_length,
"page_length_count": page_length_count, "page_length_count": page_length_count,
"is_default": is_default, "is_default": is_default,
"views": get_views(doctype, is_view=True), "views": get_views(doctype),
"total_count": frappe.client.get_count(doctype, filters=filters), "total_count": len(frappe.get_all(doctype, filters=filters)),
"row_count": len(data), "row_count": len(data),
} }

View File

@ -3,7 +3,7 @@ from pypika import Criterion
@frappe.whitelist() @frappe.whitelist()
def get_views(doctype, is_view=False): def get_views(doctype):
if frappe.session.user == "Guest": if frappe.session.user == "Guest":
frappe.throw("Authentication failed", exc=frappe.AuthenticationError) frappe.throw("Authentication failed", exc=frappe.AuthenticationError)
@ -13,8 +13,6 @@ def get_views(doctype, is_view=False):
.select("*") .select("*")
.where(Criterion.any([View.user == '', View.user == frappe.session.user])) .where(Criterion.any([View.user == '', View.user == frappe.session.user]))
) )
if is_view:
query = query.where(View.is_view == True)
if doctype: if doctype:
query = query.where(View.dt == doctype) query = query.where(View.dt == doctype)
views = query.run(as_dict=True) views = query.run(as_dict=True)

View File

@ -7,14 +7,12 @@
"field_order": [ "field_order": [
"label", "label",
"user", "user",
"user_list", "is_default",
"column_break_zacm", "column_break_zacm",
"dt", "dt",
"route_name", "route_name",
"pinned", "pinned",
"public", "public",
"default",
"is_view",
"columns_tab", "columns_tab",
"load_default_columns", "load_default_columns",
"columns", "columns",
@ -31,7 +29,6 @@
"label": "Columns" "label": "Columns"
}, },
{ {
"depends_on": "eval: doc.public == false",
"fieldname": "user", "fieldname": "user",
"fieldtype": "Link", "fieldtype": "Link",
"label": "User", "label": "User",
@ -111,26 +108,14 @@
}, },
{ {
"default": "0", "default": "0",
"fieldname": "default", "fieldname": "is_default",
"fieldtype": "Check", "fieldtype": "Check",
"label": "Default" "label": "Is Default"
},
{
"default": "0",
"fieldname": "is_view",
"fieldtype": "Check",
"label": "Is View"
},
{
"depends_on": "eval: doc.public == true",
"fieldname": "user_list",
"fieldtype": "Text",
"label": "User List"
} }
], ],
"index_web_pages_for_search": 1, "index_web_pages_for_search": 1,
"links": [], "links": [],
"modified": "2024-01-22 21:44:41.733977", "modified": "2024-02-03 18:38:09.412745",
"modified_by": "Administrator", "modified_by": "Administrator",
"module": "FCRM", "module": "FCRM",
"name": "CRM View Settings", "name": "CRM View Settings",

View File

@ -21,10 +21,12 @@ def create(view):
view.rows = view.rows + default_rows if default_rows else view.rows view.rows = view.rows + default_rows if default_rows else view.rows
view.rows = remove_duplicates(view.rows) view.rows = remove_duplicates(view.rows)
if not view.columns:
view.columns = sync_default_list_columns(view.doctype)
doc = frappe.new_doc("CRM View Settings") doc = frappe.new_doc("CRM View Settings")
doc.name = view.label doc.name = view.label
doc.label = view.label doc.label = view.label
doc.is_view = True
doc.dt = view.doctype doc.dt = view.doctype
doc.user = frappe.session.user doc.user = frappe.session.user
doc.route_name = view.route_name or "" doc.route_name = view.route_name or ""
@ -50,7 +52,6 @@ def update(view):
doc = frappe.get_doc("CRM View Settings", view.name) doc = frappe.get_doc("CRM View Settings", view.name)
doc.label = view.label doc.label = view.label
doc.is_view = True
doc.route_name = view.route_name or "" doc.route_name = view.route_name or ""
doc.load_default_columns = view.load_default_columns or False doc.load_default_columns = view.load_default_columns or False
doc.filters = json.dumps(filters) doc.filters = json.dumps(filters)
@ -81,60 +82,6 @@ def pin(name, value):
doc.pinned = value doc.pinned = value
doc.save() doc.save()
@frappe.whitelist()
def make_default(name, doctype, route_name):
existing_default_view = frappe.db.exists("CRM View Settings", {
"default": True,
"user": frappe.session.user
})
if existing_default_view:
frappe.db.set_value("CRM View Settings", existing_default_view, "default", False)
else:
public_default = frappe.db.exists("CRM View Settings", {
"default": True,
"public": True
})
if public_default:
public_default_view = frappe.get_doc("CRM View Settings", public_default)
user_list = json.loads(public_default_view.user_list)
if frappe.session.user in user_list:
updated_user_list = [user for user in user_list if user != frappe.session.user]
if not updated_user_list:
public_default_view.default = False
public_default_view.user_list = None
else:
public_default_view.user_list = json.dumps(updated_user_list)
public_default_view.save()
if not name and doctype:
exists = frappe.db.exists("CRM View Settings", {
"dt": doctype,
"is_view": False,
"user": frappe.session.user
})
if not exists:
doc = frappe.new_doc("CRM View Settings")
doc.label = "List View"
doc.default = True
doc.dt = doctype
doc.route_name = route_name
doc.user = frappe.session.user
doc.is_view = False
doc.insert()
else:
frappe.db.set_value("CRM View Settings", exists, "default", True)
elif frappe.db.get_value("CRM View Settings", name, "public"):
doc = frappe.get_doc("CRM View Settings", name)
doc.default = True
doc.user_list = (
json.dumps([frappe.session.user])
if not doc.user_list
else json.dumps(json.loads(doc.user_list) + [frappe.session.user])
)
doc.save()
else:
frappe.db.set_value("CRM View Settings", name, "default", True)
def remove_duplicates(l): def remove_duplicates(l):
return list(dict.fromkeys(l)) return list(dict.fromkeys(l))
@ -146,3 +93,57 @@ def sync_default_list_rows(doctype):
rows = list.default_list_data().get("rows") rows = list.default_list_data().get("rows")
return rows return rows
def sync_default_list_columns(doctype):
list = get_controller(doctype)
columns = []
if hasattr(list, "default_list_data"):
columns = list.default_list_data().get("columns")
return columns
@frappe.whitelist()
def create_or_update_default_view(view):
view = frappe._dict(view)
filters = parse_json(view.filters) or {}
columns = parse_json(view.columns or '[]')
rows = parse_json(view.rows or '[]')
default_rows = sync_default_list_rows(view.doctype)
rows = rows + default_rows if default_rows else rows
rows = remove_duplicates(rows)
if not columns:
columns = sync_default_list_columns(view.doctype)
doc = frappe.db.exists(
"CRM View Settings",
{"dt": view.doctype, "is_default": True, "user": frappe.session.user},
)
if doc:
doc = frappe.get_doc("CRM View Settings", doc)
doc.label = view.label
doc.route_name = view.route_name or ""
doc.load_default_columns = view.load_default_columns or False
doc.filters = json.dumps(filters)
doc.order_by = view.order_by
doc.columns = json.dumps(columns)
doc.rows = json.dumps(rows)
doc.save()
else:
doc = frappe.new_doc("CRM View Settings")
doc.name = view.label or 'List View'
doc.label = view.label or 'List View'
doc.dt = view.doctype
doc.user = frappe.session.user
doc.route_name = view.route_name or ""
doc.load_default_columns = view.load_default_columns or False
doc.filters = json.dumps(filters)
doc.order_by = view.order_by
doc.columns = json.dumps(columns)
doc.rows = json.dumps(rows)
doc.is_default = True
doc.insert()

View File

@ -26,14 +26,11 @@
</div> </div>
<div class="flex items-center gap-2"> <div class="flex items-center gap-2">
<div <div
v-if="viewUpdated && (!view.public || isManager())" v-if="viewUpdated && route.query.view && (!view.public || isManager())"
class="flex items-center gap-2 border-r pr-2" class="flex items-center gap-2 border-r pr-2"
> >
<Button label="Cancel" @click="cancelChanges" /> <Button label="Cancel" @click="cancelChanges" />
<Button <Button label="Save Changes" @click="saveView" />
:label="view?.name ? 'Save Changes' : 'Create View'"
@click="saveView"
/>
</div> </div>
<div class="flex items-center gap-2"> <div class="flex items-center gap-2">
<Filter <Filter
@ -83,7 +80,6 @@ import ViewModal from '@/components/Modals/ViewModal.vue'
import SortBy from '@/components/SortBy.vue' import SortBy from '@/components/SortBy.vue'
import Filter from '@/components/Filter.vue' import Filter from '@/components/Filter.vue'
import ColumnSettings from '@/components/ColumnSettings.vue' import ColumnSettings from '@/components/ColumnSettings.vue'
import { createToast } from '@/utils'
import { globalStore } from '@/stores/global' import { globalStore } from '@/stores/global'
import { viewsStore } from '@/stores/views' import { viewsStore } from '@/stores/views'
import { usersStore } from '@/stores/users' import { usersStore } from '@/stores/users'
@ -104,7 +100,7 @@ const props = defineProps({
}) })
const { $dialog } = globalStore() const { $dialog } = globalStore()
const { reload: reloadView, getView, getDefaultView } = viewsStore() const { reload: reloadView, getView } = viewsStore()
const { isManager } = usersStore() const { isManager } = usersStore()
const list = defineModel() const list = defineModel()
@ -155,7 +151,7 @@ watch(
) )
function getParams() { function getParams() {
let _view = getView(route.query.view) let _view = getView(route.query.view, props.doctype)
const filters = (_view?.filters && JSON.parse(_view.filters)) || {} const filters = (_view?.filters && JSON.parse(_view.filters)) || {}
const order_by = _view?.order_by || 'modified desc' const order_by = _view?.order_by || 'modified desc'
const columns = _view?.columns || '' const columns = _view?.columns || ''
@ -267,7 +263,9 @@ const viewsDropdownOptions = computed(() => {
} }
}) })
let publicViews = list.value.data.views.filter((v) => v.public) let publicViews = list.value.data.views.filter((v) => v.public)
let savedViews = list.value.data.views.filter((v) => !v.pinned && !v.public) let savedViews = list.value.data.views.filter(
(v) => !v.pinned && !v.public && !v.is_default
)
let pinnedViews = list.value.data.views.filter((v) => v.pinned) let pinnedViews = list.value.data.views.filter((v) => v.pinned)
publicViews.length && publicViews.length &&
@ -300,6 +298,10 @@ function updateFilter(filters) {
list.value.params.filters = filters list.value.params.filters = filters
view.value.filters = filters view.value.filters = filters
list.value.reload() list.value.reload()
if (!route.query.view) {
create_or_update_default_view()
}
} }
function updateSort(order_by) { function updateSort(order_by) {
@ -311,6 +313,10 @@ function updateSort(order_by) {
list.value.params.order_by = order_by list.value.params.order_by = order_by
view.value.order_by = order_by view.value.order_by = order_by
list.value.reload() list.value.reload()
if (!route.query.view) {
create_or_update_default_view()
}
} }
function updateColumns(obj) { function updateColumns(obj) {
@ -330,6 +336,21 @@ function updateColumns(obj) {
list.value.reload() list.value.reload()
} }
viewUpdated.value = true viewUpdated.value = true
if (!route.query.view) {
create_or_update_default_view()
}
}
function create_or_update_default_view() {
if (route.query.view) return
view.value.doctype = props.doctype
call(
'crm.fcrm.doctype.crm_view_settings.crm_view_settings.create_or_update_default_view',
{
view: view.value,
}
).then(() => reloadView())
} }
function updatePageLength(value, loadMore = false) { function updatePageLength(value, loadMore = false) {
@ -362,20 +383,6 @@ const viewActions = computed(() => {
}, },
] ]
let defaultView = getDefaultView()
if (
!defaultView ||
(route.query.view && route.query.view != defaultView.name) ||
(!route.query.view &&
(defaultView.route_name != route.name || defaultView.is_view))
) {
actions[0].items.push({
label: 'Make Default',
icon: () => h(FeatherIcon, { name: 'star', class: 'h-4 w-4' }),
onClick: () => makeDefault(),
})
}
if (route.query.view && (!view.value.public || isManager())) { if (route.query.view && (!view.value.public || isManager())) {
actions[0].items.push( actions[0].items.push(
{ {
@ -431,24 +438,10 @@ const viewActions = computed(() => {
return actions return actions
}) })
function makeDefault() {
call('crm.fcrm.doctype.crm_view_settings.crm_view_settings.make_default', {
name: route.query.view || '',
doctype: props.doctype,
route_name: route.name,
}).then(() => {
createToast({
title: 'Default View Set',
icon: 'check',
iconClasses: 'text-green-600',
})
reloadView()
})
}
function duplicateView() { function duplicateView() {
let label = getView(route.query.view)?.label || 'List View'
view.value.name = '' view.value.name = ''
view.value.label = getView(route.query.view).label + ' New' view.value.label = label + ' (New)'
showViewModal.value = true showViewModal.value = true
} }

View File

@ -159,14 +159,12 @@ import {
} from 'frappe-ui' } from 'frappe-ui'
import { usersStore } from '@/stores/users' import { usersStore } from '@/stores/users'
import { contactsStore } from '@/stores/contacts' import { contactsStore } from '@/stores/contacts'
import { viewsStore } from '@/stores/views'
import { computed, ref } from 'vue' import { computed, ref } from 'vue'
import { useRouter } from 'vue-router' import { useRouter } from 'vue-router'
const router = useRouter() const router = useRouter()
const { getUser } = usersStore() const { getUser } = usersStore()
const { contacts, getContact, getLeadContact } = contactsStore() const { contacts, getContact, getLeadContact } = contactsStore()
const { getDefaultView } = viewsStore()
const props = defineProps({ const props = defineProps({
callLogId: { callLogId: {
@ -241,12 +239,7 @@ function createLead() {
} }
const breadcrumbs = computed(() => { const breadcrumbs = computed(() => {
let defaultView = getDefaultView() let items = [{ label: 'Call Logs', route: { name: 'Call Logs' } }]
let route = { name: 'Call Logs' }
if (defaultView?.route_name == 'Call Logs' && defaultView?.is_view) {
route = { name: 'Call Logs', query: { view: defaultView.name } }
}
let items = [{ label: 'Call Logs', route: route }]
items.push({ items.push({
label: callLog.data?.caller.label, label: callLog.data?.caller.label,
route: { name: 'Call Log', params: { callLogId: props.callLogId } }, route: { name: 'Call Log', params: { callLogId: props.callLogId } },

View File

@ -226,7 +226,6 @@ import { usersStore } from '@/stores/users.js'
import { contactsStore } from '@/stores/contacts.js' import { contactsStore } from '@/stores/contacts.js'
import { organizationsStore } from '@/stores/organizations.js' import { organizationsStore } from '@/stores/organizations.js'
import { statusesStore } from '@/stores/statuses' import { statusesStore } from '@/stores/statuses'
import { viewsStore } from '@/stores/views'
import { ref, computed, h } from 'vue' import { ref, computed, h } from 'vue'
import { useRouter } from 'vue-router' import { useRouter } from 'vue-router'
@ -236,7 +235,6 @@ const { getContactByName, contacts } = contactsStore()
const { getUser } = usersStore() const { getUser } = usersStore()
const { getOrganization } = organizationsStore() const { getOrganization } = organizationsStore()
const { getDealStatus } = statusesStore() const { getDealStatus } = statusesStore()
const { getDefaultView } = viewsStore()
const props = defineProps({ const props = defineProps({
contactId: { contactId: {
@ -253,12 +251,7 @@ const showContactModal = ref(false)
const detailMode = ref(false) const detailMode = ref(false)
const breadcrumbs = computed(() => { const breadcrumbs = computed(() => {
let defaultView = getDefaultView() let items = [{ label: 'Contacts', route: { name: 'Contacts' } }]
let route = { name: 'Contacts' }
if (defaultView?.route_name == 'Contacts' && defaultView?.is_view) {
route = { name: 'Contacts', query: { view: defaultView.name } }
}
let items = [{ label: 'Contacts', route: route }]
items.push({ items.push({
label: contact.value.full_name, label: contact.value.full_name,
route: { name: 'Contact', params: { contactId: contact.value.name } }, route: { name: 'Contact', params: { contactId: contact.value.name } },

View File

@ -316,7 +316,6 @@ import { globalStore } from '@/stores/global'
import { contactsStore } from '@/stores/contacts' import { contactsStore } from '@/stores/contacts'
import { organizationsStore } from '@/stores/organizations' import { organizationsStore } from '@/stores/organizations'
import { statusesStore } from '@/stores/statuses' import { statusesStore } from '@/stores/statuses'
import { viewsStore } from '@/stores/views'
import { import {
createResource, createResource,
Dropdown, Dropdown,
@ -333,7 +332,6 @@ const { $dialog, makeCall } = globalStore()
const { getContactByName, contacts } = contactsStore() const { getContactByName, contacts } = contactsStore()
const { organizations, getOrganization } = organizationsStore() const { organizations, getOrganization } = organizationsStore()
const { statusOptions, getDealStatus } = statusesStore() const { statusOptions, getDealStatus } = statusesStore()
const { getDefaultView } = viewsStore()
const router = useRouter() const router = useRouter()
const props = defineProps({ const props = defineProps({
@ -422,12 +420,7 @@ function validateRequired(fieldname, value) {
} }
const breadcrumbs = computed(() => { const breadcrumbs = computed(() => {
let defaultView = getDefaultView() let items = [{ label: 'Deals', route: { name: 'Deals' } }]
let route = { name: 'Deals' }
if (defaultView?.route_name == 'Deals' && defaultView?.is_view) {
route = { name: 'Deals', query: { view: defaultView.name } }
}
let items = [{ label: 'Deals', route: route }]
items.push({ items.push({
label: organization.value?.name, label: organization.value?.name,
route: { name: 'Deal', params: { dealId: deal.data.name } }, route: { name: 'Deal', params: { dealId: deal.data.name } },

View File

@ -279,7 +279,6 @@ import { globalStore } from '@/stores/global'
import { contactsStore } from '@/stores/contacts' import { contactsStore } from '@/stores/contacts'
import { organizationsStore } from '@/stores/organizations' import { organizationsStore } from '@/stores/organizations'
import { statusesStore } from '@/stores/statuses' import { statusesStore } from '@/stores/statuses'
import { viewsStore } from '@/stores/views'
import { import {
createResource, createResource,
FileUploader, FileUploader,
@ -298,7 +297,6 @@ const { $dialog, makeCall } = globalStore()
const { getContactByName, contacts } = contactsStore() const { getContactByName, contacts } = contactsStore()
const { organizations } = organizationsStore() const { organizations } = organizationsStore()
const { statusOptions, getLeadStatus } = statusesStore() const { statusOptions, getLeadStatus } = statusesStore()
const { getDefaultView } = viewsStore()
const router = useRouter() const router = useRouter()
const props = defineProps({ const props = defineProps({
@ -380,12 +378,7 @@ function validateRequired(fieldname, value) {
} }
const breadcrumbs = computed(() => { const breadcrumbs = computed(() => {
let defaultView = getDefaultView() let items = [{ label: 'Leads', route: { name: 'Leads' } }]
let route = { name: 'Leads' }
if (defaultView?.route_name == 'Leads' && defaultView?.is_view) {
route = { name: 'Leads', query: { view: defaultView.name } }
}
let items = [{ label: 'Leads', route: route }]
items.push({ items.push({
label: lead.data.lead_name, label: lead.data.lead_name,
route: { name: 'Lead', params: { leadId: lead.data.name } }, route: { name: 'Lead', params: { leadId: lead.data.name } },

View File

@ -236,7 +236,6 @@ import { globalStore } from '@/stores/global'
import { usersStore } from '@/stores/users' import { usersStore } from '@/stores/users'
import { organizationsStore } from '@/stores/organizations.js' import { organizationsStore } from '@/stores/organizations.js'
import { statusesStore } from '@/stores/statuses' import { statusesStore } from '@/stores/statuses'
import { viewsStore } from '@/stores/views'
import { import {
dateFormat, dateFormat,
dateTooltipFormat, dateTooltipFormat,
@ -256,7 +255,6 @@ const props = defineProps({
const { $dialog } = globalStore() const { $dialog } = globalStore()
const { organizations, getOrganization } = organizationsStore() const { organizations, getOrganization } = organizationsStore()
const { getDealStatus } = statusesStore() const { getDealStatus } = statusesStore()
const { getDefaultView } = viewsStore()
const showOrganizationModal = ref(false) const showOrganizationModal = ref(false)
const detailMode = ref(false) const detailMode = ref(false)
@ -265,12 +263,7 @@ const router = useRouter()
const organization = computed(() => getOrganization(props.organizationId)) const organization = computed(() => getOrganization(props.organizationId))
const breadcrumbs = computed(() => { const breadcrumbs = computed(() => {
let defaultView = getDefaultView() let items = [{ label: 'Organizations', route: { name: 'Organizations' } }]
let route = { name: 'Organizations' }
if (defaultView?.route_name == 'Organizations' && defaultView?.is_view) {
route = { name: 'Organizations', query: { view: defaultView.name } }
}
let items = [{ label: 'Organizations', route: route }]
items.push({ items.push({
label: props.organizationId, label: props.organizationId,
route: { route: {

View File

@ -1,11 +1,11 @@
import { createRouter, createWebHistory } from 'vue-router' import { createRouter, createWebHistory } from 'vue-router'
import { usersStore } from '@/stores/users' import { usersStore } from '@/stores/users'
import { sessionStore } from '@/stores/session' import { sessionStore } from '@/stores/session'
import { viewsStore } from '@/stores/views'
const routes = [ const routes = [
{ {
path: '/', path: '/',
redirect: { name: 'Leads' },
name: 'Home', name: 'Home',
}, },
{ {
@ -130,30 +130,14 @@ let router = createRouter({
router.beforeEach(async (to, from, next) => { router.beforeEach(async (to, from, next) => {
const { users } = usersStore() const { users } = usersStore()
const { isLoggedIn } = sessionStore() const { isLoggedIn } = sessionStore()
const { views, getDefaultView } = viewsStore()
await users.promise await users.promise
await views.promise
if (from.meta?.scrollPos) { if (from.meta?.scrollPos) {
from.meta.scrollPos.top = document.querySelector('#list-rows')?.scrollTop from.meta.scrollPos.top = document.querySelector('#list-rows')?.scrollTop
} }
if (to.path === '/') { if (to.name === 'Login' && isLoggedIn) {
const defaultView = getDefaultView()
if (defaultView?.route_name) {
if (defaultView.is_view) {
next({
name: defaultView.route_name,
query: { view: defaultView.name },
})
} else {
next({ name: defaultView.route_name })
}
} else {
next({ name: 'Leads' })
}
} else if (to.name === 'Login' && isLoggedIn) {
next({ name: 'Leads' }) next({ name: 'Leads' })
} else if (to.name !== 'Login' && !isLoggedIn) { } else if (to.name !== 'Login' && !isLoggedIn) {
next({ name: 'Login' }) next({ name: 'Login' })

View File

@ -1,5 +1,4 @@
import { defineStore } from 'pinia' import { defineStore } from 'pinia'
import { sessionStore } from '@/stores/session'
import { createResource } from 'frappe-ui' import { createResource } from 'frappe-ui'
import { reactive, ref } from 'vue' import { reactive, ref } from 'vue'
@ -7,9 +6,7 @@ export const viewsStore = defineStore('crm-views', (doctype) => {
let viewsByName = reactive({}) let viewsByName = reactive({})
let pinnedViews = ref([]) let pinnedViews = ref([])
let publicViews = ref([]) let publicViews = ref([])
let defaultView = ref(null) let defaultView = ref({})
const { user } = sessionStore()
// Views // Views
const views = createResource({ const views = createResource({
@ -29,22 +26,18 @@ export const viewsStore = defineStore('crm-views', (doctype) => {
if (view.public) { if (view.public) {
publicViews.value?.push(view) publicViews.value?.push(view)
} }
if (view.is_default && view.dt) {
if ( defaultView.value[view.dt] = view
(!view.public && view.default) ||
(view.public &&
view.default &&
JSON.parse(view.user_list).includes(user))
) {
defaultView.value = view
} }
} }
return views return views
}, },
}) })
function getView(view) { function getView(view, doctype = null) {
if (!view) return null if (!view && doctype) {
return defaultView.value?.[doctype] || null
}
return viewsByName[view] return viewsByName[view]
} }
@ -58,19 +51,15 @@ export const viewsStore = defineStore('crm-views', (doctype) => {
return publicViews.value return publicViews.value
} }
function getDefaultView() {
return defaultView.value
}
async function reload() { async function reload() {
await views.reload() await views.reload()
} }
return { return {
views, views,
defaultView,
getPinnedViews, getPinnedViews,
getPublicViews, getPublicViews,
getDefaultView,
reload, reload,
getView, getView,
} }