From e5057c8c356d9f3db6dee1903aef3494eab4d1a9 Mon Sep 17 00:00:00 2001 From: Kanchan Chauhan Date: Tue, 20 Sep 2016 14:31:21 +0530 Subject: [PATCH 1/2] Salary Slip fields in Condition and Formula --- .../doctype/salary_detail/salary_detail.json | 4 +-- erpnext/hr/doctype/salary_slip/salary_slip.py | 34 +++++++++++++------ 2 files changed, 26 insertions(+), 12 deletions(-) diff --git a/erpnext/hr/doctype/salary_detail/salary_detail.json b/erpnext/hr/doctype/salary_detail/salary_detail.json index 3bb621bb62..99c705af56 100644 --- a/erpnext/hr/doctype/salary_detail/salary_detail.json +++ b/erpnext/hr/doctype/salary_detail/salary_detail.json @@ -300,7 +300,7 @@ "label": "Condition and Formula Help", "length": 0, "no_copy": 0, - "options": "

Condition and Formula Help

\n\n

Notes:

\n\n
    \n
  1. Use field base for using base salary of the Employee
  2. \n
  3. Use Salary Component abbreviations in conditions and formulas. BS = Basic Salary
  4. \n
  5. Use field name for employee details in conditions and formulas. Employment Type = employment_typeBranch = branch
  6. \n
  7. Direct Amount can also be entered based on Condtion. See example 3
\n\n

Examples

\n
    \n
  1. Calculating Basic Salary based on base\n
    Condition: base < 10000
    \n
    Formula: base * .2
  2. \n
  3. Calculating HRA based on Basic SalaryBS \n
    Condition: BS > 2000
    \n
    Formula: BS * .1
  4. \n
  5. Calculating TDS based on Employment Typeemployment_type \n
    Condition: employment_type==\"Intern\"
    \n
    Amount: 1000
  6. \n
", + "options": "

Condition and Formula Help

\n\n

Notes:

\n\n
    \n
  1. Use field base for using base salary of the Employee
  2. \n
  3. Use Salary Component abbreviations in conditions and formulas. BS = Basic Salary
  4. \n
  5. Use field name for employee details in conditions and formulas. Employment Type = employment_typeBranch = branch
  6. \n
  7. Use field name from Salary Slip in conditions and formulas. Payment Days = payment_daysLeave without pay = leave_without_pay
  8. \n
  9. Direct Amount can also be entered based on Condtion. See example 3
\n\n

Examples

\n
    \n
  1. Calculating Basic Salary based on base\n
    Condition: base < 10000
    \n
    Formula: base * .2
  2. \n
  3. Calculating HRA based on Basic SalaryBS \n
    Condition: BS > 2000
    \n
    Formula: BS * .1
  4. \n
  5. Calculating TDS based on Employment Typeemployment_type \n
    Condition: employment_type==\"Intern\"
    \n
    Amount: 1000
  6. \n
", "permlevel": 0, "precision": "", "print_hide": 0, @@ -323,7 +323,7 @@ "issingle": 0, "istable": 1, "max_attachments": 0, - "modified": "2016-08-23 15:26:07.754570", + "modified": "2016-09-20 05:29:26.373992", "modified_by": "Administrator", "module": "HR", "name": "Salary Detail", diff --git a/erpnext/hr/doctype/salary_slip/salary_slip.py b/erpnext/hr/doctype/salary_slip/salary_slip.py index 1918f921c7..7727652c44 100644 --- a/erpnext/hr/doctype/salary_slip/salary_slip.py +++ b/erpnext/hr/doctype/salary_slip/salary_slip.py @@ -31,7 +31,7 @@ class SalarySlip(TransactionBase): self.get_leave_details(lwp = self.leave_without_pay) # if self.salary_slip_based_on_timesheet or not self.net_pay: - # self.calculate_net_pay() + self.calculate_net_pay() company_currency = get_company_currency(self.company) self.total_in_words = money_in_words(self.rounded_total, company_currency) @@ -52,15 +52,27 @@ class SalarySlip(TransactionBase): data = self.get_data_for_eval() for key in ('earnings', 'deductions'): - for d in self._salary_structure_doc.get(key): - amount = self.eval_condition_and_formula(d, data) - if amount: - self.append(key, { - 'amount': amount, - 'default_amount': amount, - 'depends_on_lwp' : d.depends_on_lwp, - 'salary_component' : d.salary_component - }) + for struct_row in self._salary_structure_doc.get(key): + amount = self.eval_condition_and_formula(struct_row, data) + if amount: + self.update_component_row(struct_row, amount, key) + + + def update_component_row(self, struct_row, amount, key): + component_row = None + for d in self.get(key): + if d.salary_component == struct_row.salary_component: + component_row = d + + if not component_row: + self.append(key, { + 'amount': amount, + 'default_amount': amount, + 'depends_on_lwp' : struct_row.depends_on_lwp, + 'salary_component' : struct_row.salary_component + }) + else: + component_row.amount = amount def eval_condition_and_formula(self, d, data): try: @@ -74,6 +86,7 @@ class SalarySlip(TransactionBase): amount = eval(d.formula, None, data) data[d.abbr] = amount + return amount except NameError as err: frappe.throw(_("Name error: {0}".format(err))) @@ -92,6 +105,7 @@ class SalarySlip(TransactionBase): data.base, data.variable = d.base, d.variable data.update(frappe.get_doc("Employee", self.employee).as_dict()) + data.update(self.as_dict()) # set values for components salary_components = frappe.get_all("Salary Component", fields=["salary_component_abbr"]) From 081eab147fb210f01bd0b0826d0f880f49690497 Mon Sep 17 00:00:00 2001 From: Nabin Hait Date: Wed, 21 Sep 2016 12:55:16 +0530 Subject: [PATCH 2/2] Update salary_slip.py --- erpnext/hr/doctype/salary_slip/salary_slip.py | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/erpnext/hr/doctype/salary_slip/salary_slip.py b/erpnext/hr/doctype/salary_slip/salary_slip.py index 7727652c44..dbbdf7fab0 100644 --- a/erpnext/hr/doctype/salary_slip/salary_slip.py +++ b/erpnext/hr/doctype/salary_slip/salary_slip.py @@ -55,7 +55,7 @@ class SalarySlip(TransactionBase): for struct_row in self._salary_structure_doc.get(key): amount = self.eval_condition_and_formula(struct_row, data) if amount: - self.update_component_row(struct_row, amount, key) + self.update_component_row(struct_row, amount, key) def update_component_row(self, struct_row, amount, key): @@ -365,4 +365,4 @@ class SalarySlip(TransactionBase): timesheet.salary_slip = salary_slip timesheet.flags.ignore_validate_update_after_submit = True timesheet.set_status() - timesheet.save() \ No newline at end of file + timesheet.save()