[fixes] comnify tree view
This commit is contained in:
parent
091ca75fa3
commit
eda1afb4eb
@ -2,15 +2,15 @@ import frappe
|
|||||||
from frappe import _
|
from frappe import _
|
||||||
|
|
||||||
def execute():
|
def execute():
|
||||||
if not frappe.db.exists("Warehouse", {"warehouse_name": _("All Warehouses")}):
|
if not frappe.db.exists("Warehouse", {"warehouse_name": _("Warehouses")}):
|
||||||
parent_warehouse = frappe.get_doc({
|
parent_warehouse = frappe.get_doc({
|
||||||
"doctype": "Warehouse",
|
"doctype": "Warehouse",
|
||||||
"warehouse_name": _("All Warehouses"),
|
"warehouse_name": _("Warehouses"),
|
||||||
"is_group": "Yes"
|
"is_group": "Yes"
|
||||||
}).insert(ignore_permissions=True)
|
}).insert(ignore_permissions=True)
|
||||||
|
|
||||||
for warehouse in frappe.db.sql_list("""select name from tabWarehouse
|
for warehouse in frappe.db.sql_list("""select name from tabWarehouse
|
||||||
where name != %s order by name asc""", "All Warehouses - SI"):
|
where name != %s order by name asc""", "Warehouses - SI"):
|
||||||
print warehouse
|
print warehouse
|
||||||
warehouse = frappe.get_doc("Warehouse", warehouse)
|
warehouse = frappe.get_doc("Warehouse", warehouse)
|
||||||
warehouse.is_group = "No"
|
warehouse.is_group = "No"
|
||||||
|
@ -87,7 +87,7 @@ class Company(Document):
|
|||||||
.format(self.country.lower()))(self)
|
.format(self.country.lower()))(self)
|
||||||
|
|
||||||
def create_default_warehouses(self):
|
def create_default_warehouses(self):
|
||||||
for wh_detail in [{"warehouse_name": _("All Warehouses"), "is_group": "Yes"},
|
for wh_detail in [{"warehouse_name": _("Warehouses"), "is_group": "Yes"},
|
||||||
{"warehouse_name": _("Stores"), "is_group": "No"},
|
{"warehouse_name": _("Stores"), "is_group": "No"},
|
||||||
{"warehouse_name": _("Work In Progress"), "is_group": "No"},
|
{"warehouse_name": _("Work In Progress"), "is_group": "No"},
|
||||||
{"warehouse_name": _("Finished Goods"), "is_group": "No"}]:
|
{"warehouse_name": _("Finished Goods"), "is_group": "No"}]:
|
||||||
@ -102,7 +102,7 @@ class Company(Document):
|
|||||||
"is_group": wh_detail["is_group"],
|
"is_group": wh_detail["is_group"],
|
||||||
"company": self.name,
|
"company": self.name,
|
||||||
"parent_warehouse": "" if wh_detail["is_group"] == "Yes" \
|
"parent_warehouse": "" if wh_detail["is_group"] == "Yes" \
|
||||||
else "{0} - {1}".format(_("All Warehouses"), self.abbr),
|
else "{0} - {1}".format(_("Warehouses"), self.abbr),
|
||||||
"create_account_under": stock_group
|
"create_account_under": stock_group
|
||||||
})
|
})
|
||||||
warehouse.flags.ignore_permissions = True
|
warehouse.flags.ignore_permissions = True
|
||||||
|
@ -3,7 +3,16 @@
|
|||||||
"company": "_Test Company",
|
"company": "_Test Company",
|
||||||
"create_account_under": "Stock Assets - _TC",
|
"create_account_under": "Stock Assets - _TC",
|
||||||
"doctype": "Warehouse",
|
"doctype": "Warehouse",
|
||||||
"warehouse_name": "_Test Warehouse"
|
"warehouse_name": "_Test Warehouse",
|
||||||
|
|
||||||
|
|
||||||
|
}
|
||||||
|
{
|
||||||
|
"company": "_Test Company",
|
||||||
|
"create_account_under": "Stock Assets - _TC",
|
||||||
|
"doctype": "Warehouse",
|
||||||
|
"warehouse_name": "_Test Warehouse",
|
||||||
|
""
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"company": "_Test Company",
|
"company": "_Test Company",
|
||||||
|
@ -1,158 +0,0 @@
|
|||||||
frappe.pages['warehouse-browser'].on_page_load = function(wrapper) {
|
|
||||||
var page = frappe.ui.make_app_page({
|
|
||||||
parent: wrapper,
|
|
||||||
single_column: true
|
|
||||||
});
|
|
||||||
|
|
||||||
wrapper.page.add_menu_item(__('Refresh'), function() {
|
|
||||||
wrapper.make_tree();
|
|
||||||
});
|
|
||||||
|
|
||||||
wrapper.make_tree = function() {
|
|
||||||
var ctype = frappe.get_route()[1] || 'Warehouse';
|
|
||||||
return frappe.call({
|
|
||||||
method: 'erpnext.stock.page.warehouse_browser.warehouse_browser.get_children',
|
|
||||||
args: {ctype: ctype},
|
|
||||||
callback: function(r) {
|
|
||||||
var root = r.message[0]["value"];
|
|
||||||
erpnext.warehouse_chart = new erpnext.WarehouseChart(ctype, root, page,
|
|
||||||
page.main.css({
|
|
||||||
"min-height": "300px",
|
|
||||||
"padding-bottom": "25px"
|
|
||||||
}));
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
wrapper.make_tree();
|
|
||||||
}
|
|
||||||
|
|
||||||
frappe.pages['warehouse-browser'].on_page_show = function(wrapper){
|
|
||||||
// set route
|
|
||||||
var ctype = frappe.get_route()[1] || 'Warehouse';
|
|
||||||
|
|
||||||
wrapper.page.set_title(__('{0} Tree',[__(ctype)]));
|
|
||||||
|
|
||||||
if(erpnext.warehouse_chart && erpnext.warehouse_chart.ctype != ctype) {
|
|
||||||
wrapper.make_tree();
|
|
||||||
}
|
|
||||||
|
|
||||||
frappe.breadcrumbs.add(frappe.breadcrumbs.last_module || "Stock");
|
|
||||||
};
|
|
||||||
|
|
||||||
erpnext.WarehouseChart = Class.extend({
|
|
||||||
init: function(ctype, root, page, parent){
|
|
||||||
$(parent).empty();
|
|
||||||
var me = this;
|
|
||||||
me.ctype = ctype;
|
|
||||||
me.page = page;
|
|
||||||
me.can_read = frappe.model.can_read(this.ctype);
|
|
||||||
me.can_create = frappe.boot.user.can_create.indexOf(this.ctype) !== -1 ||
|
|
||||||
frappe.boot.user.in_create.indexOf(this.ctype) !== -1;
|
|
||||||
me.can_write = frappe.model.can_write(this.ctype);
|
|
||||||
me.can_delete = frappe.model.can_delete(this.ctype);
|
|
||||||
|
|
||||||
me.page.set_primary_action(__("New"), function() {
|
|
||||||
me.new_node();
|
|
||||||
}, "octicon octicon-plus");
|
|
||||||
|
|
||||||
this.tree = new frappe.ui.Tree({
|
|
||||||
parent: $(parent),
|
|
||||||
label: __(root),
|
|
||||||
args: {ctype: ctype},
|
|
||||||
method: 'erpnext.stock.page.warehouse_browser.warehouse_browser.get_children',
|
|
||||||
toolbar: [
|
|
||||||
{toggle_btn: true},
|
|
||||||
{
|
|
||||||
label:__("Edit"),
|
|
||||||
condition: function(node) {
|
|
||||||
return !node.root && me.can_read;
|
|
||||||
},
|
|
||||||
click: function(node) {
|
|
||||||
frappe.set_route("Form", me.ctype, node.label);
|
|
||||||
}
|
|
||||||
},
|
|
||||||
{
|
|
||||||
label:__("Add Child"),
|
|
||||||
condition: function(node) { return me.can_create && node.expandable; },
|
|
||||||
click: function(node) {
|
|
||||||
me.new_node();
|
|
||||||
},
|
|
||||||
btnClass: "hidden-xs"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
label:__("Rename"),
|
|
||||||
condition: function(node) { return !node.root && me.can_write; },
|
|
||||||
click: function(node) {
|
|
||||||
frappe.model.rename_doc(me.ctype, node.label, function(new_name) {
|
|
||||||
node.$a.html(new_name);
|
|
||||||
});
|
|
||||||
},
|
|
||||||
btnClass: "hidden-xs"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
label:__("Delete"),
|
|
||||||
condition: function(node) { return !node.root && me.can_delete; },
|
|
||||||
click: function(node) {
|
|
||||||
frappe.model.delete_doc(me.ctype, node.label, function() {
|
|
||||||
node.parent.remove();
|
|
||||||
});
|
|
||||||
},
|
|
||||||
btnClass: "hidden-xs"
|
|
||||||
}
|
|
||||||
|
|
||||||
]
|
|
||||||
});
|
|
||||||
},
|
|
||||||
new_node: function() {
|
|
||||||
var me = this;
|
|
||||||
var node = me.tree.get_selected_node();
|
|
||||||
|
|
||||||
if(!(node && node.expandable)) {
|
|
||||||
frappe.msgprint(__("Select a group node first."));
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
var fields = [
|
|
||||||
{fieldtype:'Data', fieldname: 'name_field',
|
|
||||||
label:__('New {0} Name',[__(me.ctype)]), reqd:true},
|
|
||||||
{fieldtype:'Select', fieldname:'is_group', label:__('Group Node'), options:'No\nYes',
|
|
||||||
description: __("Further nodes can be only created under 'Group' type nodes")}
|
|
||||||
]
|
|
||||||
|
|
||||||
// the dialog
|
|
||||||
var d = new frappe.ui.Dialog({
|
|
||||||
title: __('New {0}',[__(me.ctype)]),
|
|
||||||
fields: fields
|
|
||||||
})
|
|
||||||
|
|
||||||
d.set_value("is_group", "No");
|
|
||||||
// create
|
|
||||||
d.set_primary_action(__("Create New"), function() {
|
|
||||||
var btn = this;
|
|
||||||
var v = d.get_values();
|
|
||||||
if(!v) return;
|
|
||||||
|
|
||||||
var node = me.tree.get_selected_node();
|
|
||||||
|
|
||||||
v.parent = node.label;
|
|
||||||
v.ctype = me.ctype;
|
|
||||||
|
|
||||||
return frappe.call({
|
|
||||||
method: 'erpnext.stock.page.warehouse_browser.warehouse_browser.add_node',
|
|
||||||
args: v,
|
|
||||||
callback: function(r) {
|
|
||||||
if(!r.exc) {
|
|
||||||
d.hide();
|
|
||||||
if(node.expanded) {
|
|
||||||
node.toggle_node();
|
|
||||||
}
|
|
||||||
node.reload();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
});
|
|
||||||
});
|
|
||||||
|
|
||||||
d.show();
|
|
||||||
},
|
|
||||||
})
|
|
@ -1,27 +0,0 @@
|
|||||||
{
|
|
||||||
"content": null,
|
|
||||||
"creation": "2016-05-24 11:01:06.887660",
|
|
||||||
"docstatus": 0,
|
|
||||||
"doctype": "Page",
|
|
||||||
"idx": 0,
|
|
||||||
"modified": "2016-05-24 11:11:32.317342",
|
|
||||||
"modified_by": "Administrator",
|
|
||||||
"module": "Stock",
|
|
||||||
"name": "warehouse-browser",
|
|
||||||
"owner": "Administrator",
|
|
||||||
"page_name": "Warehouse Browser",
|
|
||||||
"roles": [
|
|
||||||
{
|
|
||||||
"role": "Stock Manager"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"role": "Stock User"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"role": "System Manager"
|
|
||||||
}
|
|
||||||
],
|
|
||||||
"script": null,
|
|
||||||
"standard": "Yes",
|
|
||||||
"style": null
|
|
||||||
}
|
|
@ -1,35 +0,0 @@
|
|||||||
# Copyright (c) 2015, Frappe Technologies Pvt. Ltd. and Contributors
|
|
||||||
# License: GNU General Public License v3. See license.txt
|
|
||||||
|
|
||||||
from __future__ import unicode_literals
|
|
||||||
import frappe
|
|
||||||
|
|
||||||
@frappe.whitelist()
|
|
||||||
def get_children():
|
|
||||||
ctype = frappe.local.form_dict.get('ctype')
|
|
||||||
parent_field = 'parent_' + ctype.lower().replace(' ', '_')
|
|
||||||
parent = frappe.form_dict.get("parent") or ""
|
|
||||||
|
|
||||||
return frappe.db.sql("""select name as value,
|
|
||||||
if(is_group='Yes', 1, 0) as expandable
|
|
||||||
from `tab{ctype}`
|
|
||||||
where docstatus < 2
|
|
||||||
and ifnull(`{parent_field}`,'') = %s
|
|
||||||
order by name""".format(ctype=frappe.db.escape(ctype), parent_field=frappe.db.escape(parent_field)),
|
|
||||||
parent, as_dict=1)
|
|
||||||
|
|
||||||
@frappe.whitelist()
|
|
||||||
def add_node():
|
|
||||||
ctype = frappe.form_dict.get('ctype')
|
|
||||||
parent_field = 'parent_' + ctype.lower().replace(' ', '_')
|
|
||||||
name_field = ctype.lower().replace(' ', '_') + '_name'
|
|
||||||
|
|
||||||
doc = frappe.new_doc(ctype)
|
|
||||||
|
|
||||||
doc.update({
|
|
||||||
name_field: frappe.form_dict['name_field'],
|
|
||||||
parent_field: frappe.form_dict['parent'],
|
|
||||||
"is_group": frappe.form_dict['is_group']
|
|
||||||
})
|
|
||||||
|
|
||||||
doc.save()
|
|
Loading…
x
Reference in New Issue
Block a user