2012-02-23 07:05:32 +00:00
|
|
|
// ERPNext - web based ERP (http://erpnext.com)
|
|
|
|
// Copyright (C) 2012 Web Notes Technologies Pvt Ltd
|
|
|
|
//
|
|
|
|
// This program is free software: you can redistribute it and/or modify
|
|
|
|
// it under the terms of the GNU General Public License as published by
|
|
|
|
// the Free Software Foundation, either version 3 of the License, or
|
|
|
|
// (at your option) any later version.
|
|
|
|
//
|
|
|
|
// This program is distributed in the hope that it will be useful,
|
|
|
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
// GNU General Public License for more details.
|
|
|
|
//
|
|
|
|
// You should have received a copy of the GNU General Public License
|
|
|
|
// along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
|
2012-04-13 13:34:55 +00:00
|
|
|
// tree of chart of accounts / cost centers
|
|
|
|
// multiple companies
|
|
|
|
// add node
|
|
|
|
// edit node
|
|
|
|
// see ledger
|
2012-02-21 11:56:50 +00:00
|
|
|
|
2012-04-13 13:34:55 +00:00
|
|
|
pscript['onload_Accounts Browser'] = function(wrapper){
|
2013-06-14 06:03:01 +00:00
|
|
|
console.log($(wrapper).html());
|
2013-05-23 10:33:49 +00:00
|
|
|
wn.ui.make_app_page({
|
|
|
|
parent: wrapper,
|
|
|
|
single_column: true
|
|
|
|
})
|
2013-06-14 06:03:01 +00:00
|
|
|
|
2013-05-23 10:33:49 +00:00
|
|
|
wrapper.appframe.add_module_icon("Accounts");
|
|
|
|
|
|
|
|
var main = $(wrapper).find(".layout-main"),
|
|
|
|
chart_area = $("<div>")
|
|
|
|
.css({"margin-bottom": "15px"})
|
|
|
|
.appendTo(main),
|
|
|
|
help_area = $('<div class="well">\
|
|
|
|
<h4>Quick Help</h4>\
|
|
|
|
<ol>\
|
|
|
|
<li>To add child nodes, explore tree and click on the node under which you \
|
|
|
|
want to add more nodes.\
|
|
|
|
<li>Accounting Entries can be made against leaf nodes, called <b>Ledgers</b>.\
|
|
|
|
Entries against <b>Groups</b> are not allowed.\
|
|
|
|
<li>Please do NOT create Account (Ledgers) for Customers and Suppliers. \
|
|
|
|
They are created directly from the Customer / Supplier masters.\
|
|
|
|
<li><b>To create a Bank Account:</b> Go to the appropriate group \
|
|
|
|
(usually Application of Funds > Current Assets > Bank Accounts)\
|
|
|
|
and create a new Account Ledger (by clicking on Add Child) of \
|
|
|
|
type "Bank or Cash"\
|
|
|
|
<li><b>To create a Tax Account:</b> Go to the appropriate group \
|
|
|
|
(usually Source of Funds > Current Liabilities > Taxes and Duties) \
|
|
|
|
and create a new Account Ledger (by clicking on Add Child) of type\
|
|
|
|
"Tax" and do mention the Tax rate.\
|
|
|
|
</ol>\
|
|
|
|
<p>Please setup your chart of accounts before you start Accounting Entries</p>\
|
|
|
|
</div>').appendTo(main);
|
2012-09-10 08:43:01 +00:00
|
|
|
|
|
|
|
if (wn.boot.profile.can_create.indexOf("Company") !== -1) {
|
|
|
|
wrapper.appframe.add_button('New Company', function() { newdoc('Company'); },
|
|
|
|
'icon-plus');
|
|
|
|
}
|
|
|
|
|
2012-05-22 11:24:46 +00:00
|
|
|
wrapper.appframe.add_button('Refresh', function() {
|
2012-04-16 13:06:46 +00:00
|
|
|
wrapper.$company_select.change();
|
|
|
|
}, 'icon-refresh');
|
2012-04-13 06:31:23 +00:00
|
|
|
|
2012-04-13 13:34:55 +00:00
|
|
|
// company-select
|
2013-05-23 10:33:49 +00:00
|
|
|
wrapper.$company_select = wrapper.appframe.add_select("Company", [])
|
2012-04-13 13:34:55 +00:00
|
|
|
.change(function() {
|
|
|
|
var ctype = wn.get_route()[1] || 'Account';
|
2013-05-23 10:33:49 +00:00
|
|
|
erpnext.account_chart = new erpnext.AccountsChart(ctype, $(this).val(),
|
|
|
|
chart_area.get(0));
|
2012-12-03 10:15:03 +00:00
|
|
|
pscript.set_title(wrapper, ctype, $(this).val());
|
2012-04-13 13:34:55 +00:00
|
|
|
})
|
|
|
|
|
|
|
|
// load up companies
|
|
|
|
wn.call({
|
|
|
|
method:'accounts.page.accounts_browser.accounts_browser.get_companies',
|
|
|
|
callback: function(r) {
|
|
|
|
wrapper.$company_select.empty();
|
|
|
|
$.each(r.message, function(i, v) {
|
|
|
|
$('<option>').html(v).attr('value', v).appendTo(wrapper.$company_select);
|
|
|
|
});
|
2012-09-10 08:43:01 +00:00
|
|
|
wrapper.$company_select.val(sys_defaults.company || r[0]).change();
|
2012-04-13 13:34:55 +00:00
|
|
|
}
|
|
|
|
});
|
2011-06-08 09:07:15 +00:00
|
|
|
}
|
|
|
|
|
2012-12-03 10:15:03 +00:00
|
|
|
pscript.set_title = function(wrapper, ctype, val) {
|
|
|
|
if(val) {
|
|
|
|
wrapper.appframe.set_title('Chart of '+ctype+'s' + " - " + cstr(val));
|
|
|
|
} else {
|
|
|
|
wrapper.appframe.set_title('Chart of '+ctype+'s');
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2012-04-13 13:34:55 +00:00
|
|
|
pscript['onshow_Accounts Browser'] = function(wrapper){
|
|
|
|
// set route
|
|
|
|
var ctype = wn.get_route()[1] || 'Account';
|
2012-07-11 07:48:58 +00:00
|
|
|
|
2012-04-13 13:34:55 +00:00
|
|
|
if(erpnext.account_chart && erpnext.account_chart.ctype != ctype) {
|
|
|
|
wrapper.$company_select.change();
|
2012-12-03 10:15:03 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
pscript.set_title(wrapper, ctype);
|
2012-04-13 13:34:55 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
erpnext.AccountsChart = Class.extend({
|
|
|
|
init: function(ctype, company, wrapper) {
|
2013-05-23 10:33:49 +00:00
|
|
|
$(wrapper).empty();
|
2012-04-13 13:34:55 +00:00
|
|
|
var me = this;
|
|
|
|
me.ctype = ctype;
|
2012-12-06 06:39:52 +00:00
|
|
|
me.can_create = wn.model.can_create(this.ctype);
|
2012-12-03 08:41:24 +00:00
|
|
|
me.can_delete = wn.model.can_delete(this.ctype);
|
2012-12-06 06:39:52 +00:00
|
|
|
me.can_write = wn.model.can_write(this.ctype);
|
2012-12-03 08:41:24 +00:00
|
|
|
|
|
|
|
|
2012-04-16 13:06:46 +00:00
|
|
|
me.company = company;
|
2012-04-13 13:34:55 +00:00
|
|
|
this.tree = new wn.ui.Tree({
|
2013-05-23 10:33:49 +00:00
|
|
|
parent: $(wrapper),
|
2013-06-24 10:13:18 +00:00
|
|
|
label: ctype==="Account" ? "Accounts" : "Cost Centers",
|
2012-05-22 11:24:46 +00:00
|
|
|
args: {ctype: ctype, comp: company},
|
2012-04-13 13:34:55 +00:00
|
|
|
method: 'accounts.page.accounts_browser.accounts_browser.get_children',
|
|
|
|
click: function(link) {
|
|
|
|
if(me.cur_toolbar)
|
|
|
|
$(me.cur_toolbar).toggle(false);
|
|
|
|
|
|
|
|
if(!link.toolbar)
|
|
|
|
me.make_link_toolbar(link);
|
|
|
|
|
|
|
|
if(link.toolbar) {
|
|
|
|
me.cur_toolbar = link.toolbar;
|
2012-12-06 06:39:52 +00:00
|
|
|
$(me.cur_toolbar).toggle(true);
|
2012-04-13 13:34:55 +00:00
|
|
|
}
|
2012-05-22 11:24:46 +00:00
|
|
|
|
|
|
|
// bold
|
|
|
|
$('.balance-bold').removeClass('balance-bold'); // deselect
|
|
|
|
$(link).parent().find('.balance-area:first').addClass('balance-bold'); // select
|
2012-12-06 06:39:52 +00:00
|
|
|
|
2012-05-22 11:24:46 +00:00
|
|
|
},
|
|
|
|
onrender: function(treenode) {
|
2013-03-13 07:23:00 +00:00
|
|
|
if (ctype == 'Account' && treenode.data) {
|
|
|
|
if(treenode.data.balance) {
|
2013-01-23 14:09:51 +00:00
|
|
|
treenode.parent.append('<span class="balance-area">'
|
2013-03-13 07:23:00 +00:00
|
|
|
+ format_currency(treenode.data.balance, treenode.data.currency)
|
|
|
|
+ '</span>');
|
2012-06-29 13:37:20 +00:00
|
|
|
}
|
2012-05-31 08:02:45 +00:00
|
|
|
}
|
2012-04-13 13:34:55 +00:00
|
|
|
}
|
|
|
|
});
|
2012-05-22 11:24:46 +00:00
|
|
|
this.tree.rootnode.$a.click();
|
2012-04-13 13:34:55 +00:00
|
|
|
},
|
|
|
|
make_link_toolbar: function(link) {
|
|
|
|
var data = $(link).data('node-data');
|
|
|
|
if(!data) return;
|
|
|
|
|
2012-04-17 07:10:37 +00:00
|
|
|
link.toolbar = $('<span class="tree-node-toolbar"></span>').insertAfter(link);
|
2012-08-23 13:03:58 +00:00
|
|
|
|
|
|
|
var node_links = [];
|
2012-04-13 13:34:55 +00:00
|
|
|
// edit
|
2012-12-06 09:28:44 +00:00
|
|
|
if (wn.model.can_read(this.ctype) !== -1) {
|
2012-12-06 06:39:52 +00:00
|
|
|
node_links.push('<a onclick="erpnext.account_chart.open();">Edit</a>');
|
2012-04-17 07:10:37 +00:00
|
|
|
}
|
2013-06-11 12:18:59 +00:00
|
|
|
if (data.expandable && wn.boot.profile.in_create.indexOf(this.ctype) !== -1) {
|
2012-12-06 09:28:44 +00:00
|
|
|
node_links.push('<a onclick="erpnext.account_chart.new_node();">Add Child</a>');
|
2012-08-23 13:03:58 +00:00
|
|
|
} else if (this.ctype === 'Account' && wn.boot.profile.can_read.indexOf("GL Entry") !== -1) {
|
|
|
|
node_links.push('<a onclick="erpnext.account_chart.show_ledger();">View Ledger</a>');
|
|
|
|
}
|
2012-12-03 08:41:24 +00:00
|
|
|
|
2012-12-06 06:39:52 +00:00
|
|
|
if (this.can_write) {
|
2012-12-03 08:41:24 +00:00
|
|
|
node_links.push('<a onclick="erpnext.account_chart.rename()">Rename</a>');
|
|
|
|
};
|
|
|
|
|
2012-12-06 06:39:52 +00:00
|
|
|
if (this.can_delete) {
|
2012-12-03 08:41:24 +00:00
|
|
|
node_links.push('<a onclick="erpnext.account_chart.delete()">Delete</a>');
|
|
|
|
};
|
2012-08-23 13:03:58 +00:00
|
|
|
|
|
|
|
link.toolbar.append(node_links.join(" | "));
|
2012-04-13 13:34:55 +00:00
|
|
|
},
|
2012-12-06 06:39:52 +00:00
|
|
|
open: function() {
|
|
|
|
var node = this.selected_node();
|
|
|
|
wn.set_route("Form", this.ctype, node.data("label"));
|
|
|
|
},
|
2012-04-16 13:06:46 +00:00
|
|
|
show_ledger: function() {
|
|
|
|
var me = this;
|
|
|
|
var node = me.selected_node();
|
2012-11-13 06:12:42 +00:00
|
|
|
wn.set_route("general-ledger", "account=" + node.data('label'));
|
2012-04-16 13:06:46 +00:00
|
|
|
},
|
2012-12-03 08:41:24 +00:00
|
|
|
rename: function() {
|
2012-12-06 06:39:52 +00:00
|
|
|
var node = this.selected_node();
|
|
|
|
wn.model.rename_doc(this.ctype, node.data('label'), function(new_name) {
|
2013-03-26 11:45:49 +00:00
|
|
|
node.parents("ul:first").parent().find(".tree-link:first").trigger("reload");
|
2012-12-06 06:39:52 +00:00
|
|
|
});
|
2012-12-03 08:41:24 +00:00
|
|
|
},
|
|
|
|
delete: function() {
|
2012-12-06 06:39:52 +00:00
|
|
|
var node = this.selected_node();
|
|
|
|
wn.model.delete_doc(this.ctype, node.data('label'), function() {
|
2012-12-03 08:41:24 +00:00
|
|
|
node.parent().remove();
|
|
|
|
});
|
|
|
|
},
|
2012-04-16 13:06:46 +00:00
|
|
|
new_node: function() {
|
|
|
|
if(this.ctype=='Account') {
|
|
|
|
this.new_account();
|
|
|
|
} else {
|
|
|
|
this.new_cost_center();
|
|
|
|
}
|
|
|
|
},
|
|
|
|
selected_node: function() {
|
|
|
|
return this.tree.$w.find('.tree-link.selected');
|
|
|
|
},
|
2012-04-13 13:34:55 +00:00
|
|
|
new_account: function() {
|
2012-04-16 13:06:46 +00:00
|
|
|
var me = this;
|
|
|
|
|
|
|
|
// the dialog
|
|
|
|
var d = new wn.ui.Dialog({
|
|
|
|
title:'New Account',
|
|
|
|
fields: [
|
2012-11-15 09:41:15 +00:00
|
|
|
{fieldtype:'Data', fieldname:'account_name', label:'New Account Name', reqd:true,
|
|
|
|
description: "Name of new Account. Note: Please don't create accounts for Customers and Suppliers, \
|
|
|
|
they are created automatically from the Customer and Supplier master"},
|
2012-04-16 13:06:46 +00:00
|
|
|
{fieldtype:'Select', fieldname:'group_or_ledger', label:'Group or Ledger',
|
2012-07-11 09:09:33 +00:00
|
|
|
options:'Group\nLedger', description:'Further accounts can be made under Groups,\
|
|
|
|
but entries can be made against Ledger'},
|
2012-04-16 13:06:46 +00:00
|
|
|
{fieldtype:'Select', fieldname:'account_type', label:'Account Type',
|
|
|
|
options: ['', 'Fixed Asset Account', 'Bank or Cash', 'Expense Account', 'Tax',
|
2012-11-15 09:41:15 +00:00
|
|
|
'Income Account', 'Chargeable'].join('\n'),
|
|
|
|
description: "Optional. This setting will be used to filter in various transactions." },
|
2012-04-16 13:06:46 +00:00
|
|
|
{fieldtype:'Float', fieldname:'tax_rate', label:'Tax Rate'},
|
|
|
|
{fieldtype:'Button', fieldname:'create_new', label:'Create New' }
|
|
|
|
]
|
|
|
|
})
|
2012-04-13 13:34:55 +00:00
|
|
|
|
2012-04-16 13:06:46 +00:00
|
|
|
var fd = d.fields_dict;
|
|
|
|
|
|
|
|
// account type if ledger
|
|
|
|
$(fd.group_or_ledger.input).change(function() {
|
|
|
|
if($(this).val()=='Group') {
|
|
|
|
$(fd.account_type.wrapper).toggle(false);
|
|
|
|
$(fd.tax_rate.wrapper).toggle(false);
|
|
|
|
} else {
|
|
|
|
$(fd.account_type.wrapper).toggle(true);
|
|
|
|
if(fd.account_type.get_value()=='Tax') {
|
|
|
|
$(fd.tax_rate.wrapper).toggle(true);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
// tax rate if tax
|
|
|
|
$(fd.account_type.input).change(function() {
|
|
|
|
if($(this).val()=='Tax') {
|
2012-11-29 12:59:56 +00:00
|
|
|
$(fd.tax_rate.wrapper).toggle(true);
|
2012-04-16 13:06:46 +00:00
|
|
|
} else {
|
2012-11-29 12:59:56 +00:00
|
|
|
$(fd.tax_rate.wrapper).toggle(false);
|
2012-04-16 13:06:46 +00:00
|
|
|
}
|
|
|
|
})
|
|
|
|
|
|
|
|
// create
|
|
|
|
$(fd.create_new.input).click(function() {
|
|
|
|
var btn = this;
|
|
|
|
$(btn).set_working();
|
|
|
|
var v = d.get_values();
|
|
|
|
if(!v) return;
|
|
|
|
|
|
|
|
var node = me.selected_node();
|
|
|
|
v.parent_account = node.data('label');
|
2012-07-11 09:09:33 +00:00
|
|
|
v.master_type = '';
|
2012-04-16 13:06:46 +00:00
|
|
|
v.company = me.company;
|
|
|
|
|
2013-01-30 13:46:13 +00:00
|
|
|
wn.call({
|
|
|
|
args: v,
|
|
|
|
method:'accounts.utils.add_ac',
|
|
|
|
callback: function(r) {
|
2012-04-16 13:06:46 +00:00
|
|
|
$(btn).done_working();
|
|
|
|
d.hide();
|
2013-01-30 13:46:13 +00:00
|
|
|
node.trigger('reload');
|
|
|
|
}
|
|
|
|
});
|
2012-04-16 13:06:46 +00:00
|
|
|
});
|
|
|
|
|
|
|
|
// show
|
|
|
|
d.onshow = function() {
|
|
|
|
$(fd.group_or_ledger.input).change();
|
2012-11-29 12:59:56 +00:00
|
|
|
$(fd.account_type.input).change();
|
2012-04-16 13:06:46 +00:00
|
|
|
}
|
2012-12-03 08:41:24 +00:00
|
|
|
|
|
|
|
$(fd.group_or_ledger.input).val("Ledger").change();
|
2012-04-16 13:06:46 +00:00
|
|
|
d.show();
|
2012-04-13 13:34:55 +00:00
|
|
|
},
|
2012-04-16 13:06:46 +00:00
|
|
|
|
2012-04-13 13:34:55 +00:00
|
|
|
new_cost_center: function(){
|
2012-04-16 13:06:46 +00:00
|
|
|
var me = this;
|
|
|
|
// the dialog
|
|
|
|
var d = new wn.ui.Dialog({
|
|
|
|
title:'New Cost Center',
|
|
|
|
fields: [
|
|
|
|
{fieldtype:'Data', fieldname:'cost_center_name', label:'New Cost Center Name', reqd:true},
|
|
|
|
{fieldtype:'Select', fieldname:'group_or_ledger', label:'Group or Ledger',
|
2012-07-11 09:09:33 +00:00
|
|
|
options:'Group\nLedger', description:'Further accounts can be made under Groups,\
|
|
|
|
but entries can be made against Ledger'},
|
2012-04-16 13:06:46 +00:00
|
|
|
{fieldtype:'Button', fieldname:'create_new', label:'Create New' }
|
|
|
|
]
|
2012-07-11 09:09:33 +00:00
|
|
|
});
|
2012-04-16 13:06:46 +00:00
|
|
|
|
|
|
|
// create
|
|
|
|
$(d.fields_dict.create_new.input).click(function() {
|
|
|
|
var btn = this;
|
|
|
|
$(btn).set_working();
|
|
|
|
var v = d.get_values();
|
|
|
|
if(!v) return;
|
|
|
|
|
|
|
|
var node = me.selected_node();
|
|
|
|
|
|
|
|
v.parent_cost_center = node.data('label');
|
2013-07-09 10:15:38 +00:00
|
|
|
v.company = me.company;
|
2012-04-16 13:06:46 +00:00
|
|
|
|
2013-01-30 13:46:13 +00:00
|
|
|
wn.call({
|
|
|
|
args: v,
|
|
|
|
method:'accounts.utils.add_cc',
|
|
|
|
callback: function(r) {
|
2012-04-16 13:06:46 +00:00
|
|
|
$(btn).done_working();
|
|
|
|
d.hide();
|
2013-01-30 13:46:13 +00:00
|
|
|
node.trigger('reload');
|
|
|
|
}
|
|
|
|
});
|
2012-04-16 13:06:46 +00:00
|
|
|
});
|
|
|
|
d.show();
|
|
|
|
}
|
2012-05-22 11:24:46 +00:00
|
|
|
});
|