Skip to content

Commit

Permalink
Merge pull request #3 from openimis/feature/CM-210
Browse files Browse the repository at this point in the history
CM-210: code refactor
  • Loading branch information
sniedzielski committed Jul 21, 2023
2 parents b800f10 + 49ffe4f commit d922991
Showing 1 changed file with 16 additions and 11 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -28,20 +28,11 @@ def calculate(cls, calculation, payment_plan, **kwargs):
payment = payment_plan_parameters['calculation_rule']['fixed_batch']
advanced_filters_criteria = payment_plan_parameters['advanced_criteria']
for beneficiary in beneficiares:
for criterion in advanced_filters_criteria:
condition = criterion['custom_filter_condition']
calculated_amount = float(criterion['amount'])
does_amount_apply_for_limitations = criterion['count_to_max']
if cls._does_beneficiary_meet_condition(beneficiary, condition):
if does_amount_apply_for_limitations:
# TODO: ceiling part
continue
else:
payment += calculated_amount
calculated_payment = cls._calculate_payment(beneficiary, advanced_filters_criteria, payment)

additional_params = {
f"{cls.BENEFICIARY_TYPE}": beneficiary,
"amount": payment,
"amount": calculated_payment,
"user": user
}
calculation.run_convert(
Expand All @@ -50,6 +41,20 @@ def calculate(cls, calculation, payment_plan, **kwargs):
)
return "Calculation and transformation into bills completed successfully."

@classmethod
def _calculate_payment(cls, beneficiary, advanced_filters_criteria, payment):
for criterion in advanced_filters_criteria:
condition = criterion['custom_filter_condition']
calculated_amount = float(criterion['amount'])
does_amount_apply_for_limitations = criterion.get('count_to_max', False)
if cls._does_beneficiary_meet_condition(beneficiary, condition):
if does_amount_apply_for_limitations:
# TODO: ceiling part
continue
else:
payment += calculated_amount
return payment

@classmethod
def _does_beneficiary_meet_condition(cls, beneficiary, condition):
condition_key, condition_value = condition.split("=")
Expand Down

0 comments on commit d922991

Please sign in to comment.