diff --git a/product/ERP5/Document/PaymentRule.py b/product/ERP5/Document/PaymentRule.py
index dd3021b90d9f2ad967621245038900dad8562c81..fb9b043cf7929ca73991d84c4cfba14ad1caff57 100644
--- a/product/ERP5/Document/PaymentRule.py
+++ b/product/ERP5/Document/PaymentRule.py
@@ -36,131 +36,131 @@ from Products.ERP5.Document.Rule import Rule
 from zLOG import LOG, INFO
 
 class PaymentRule(Rule):
-    """Payment Rule generates payment simulation movement from invoice
-    transaction simulation movements.
-    """
+  """Payment Rule generates payment simulation movement from invoice
+  transaction simulation movements.
+  """
+
+  # CMF Type Definition
+  meta_type = 'ERP5 Payment Rule'
+  portal_type = 'Payment Rule'
+  add_permission = Permissions.AddPortalContent
+
+  # Declarative security
+  security = ClassSecurityInfo()
+  security.declareObjectProtected(Permissions.AccessContentsInformation)
 
-    # CMF Type Definition
-    meta_type = 'ERP5 Payment Rule'
-    portal_type = 'Payment Rule'
-    add_permission = Permissions.AddPortalContent
-
-    # Declarative security
-    security = ClassSecurityInfo()
-    security.declareObjectProtected(Permissions.AccessContentsInformation)
-
-    receivable_account_type_list = ('asset/receivable', )
-    payable_account_type_list = ('liability/payable', )
-
-
-    def _getPaymentConditionList(self, movement):
-      """Returns payment conditions for this movement.
-      """
-      while 1:
-        delivery_movement = movement.getDeliveryValue()
-        if delivery_movement is not None:
-          explanation = delivery_movement.getExplanationValue()
-          payment_condition_list = explanation.contentValues(
-                 filter=dict(portal_type='Payment Condition'))
-          if payment_condition_list:
-            return payment_condition_list
-
-        # 'order' category is deprecated. it is kept for compatibility.
-        order_movement = movement.getOrderValue()
-        if order_movement is not None:
-          explanation = order_movement.getExplanationValue()
-          payment_condition_list = explanation.contentValues(
-                 filter=dict(portal_type='Payment Condition'))
-          if payment_condition_list:
-            return payment_condition_list
-
-        movement = movement.getParentValue().getParentValue()
-        if movement.getPortalType() != self.movement_type:
-          LOG('ERP5', INFO, "PaymentRule couldn't find payment condition")
-          return []
-     
-    def _createMovementsForPaymentCondition(self,
-          applied_rule, payment_condition):
-      """Create simulation movements for this payment condition.
-      """
-      simulation_movement = applied_rule.getParentValue()
-      date = payment_condition.TradeCondition_getDueDate()
-      
-      if payment_condition.getQuantity():
-        quantity = payment_condition.getQuantity()
+  receivable_account_type_list = ('asset/receivable', )
+  payable_account_type_list = ('liability/payable', )
+
+
+  def _getPaymentConditionList(self, movement):
+    """Returns payment conditions for this movement.
+    """
+    while 1:
+      delivery_movement = movement.getDeliveryValue()
+      if delivery_movement is not None:
+        explanation = delivery_movement.getExplanationValue()
+        payment_condition_list = explanation.contentValues(
+               filter=dict(portal_type='Payment Condition'))
+        if payment_condition_list:
+          return payment_condition_list
+
+      # 'order' category is deprecated. it is kept for compatibility.
+      order_movement = movement.getOrderValue()
+      if order_movement is not None:
+        explanation = order_movement.getExplanationValue()
+        payment_condition_list = explanation.contentValues(
+               filter=dict(portal_type='Payment Condition'))
+        if payment_condition_list:
+          return payment_condition_list
+
+      movement = movement.getParentValue().getParentValue()
+      if movement.getPortalType() != self.movement_type:
+        LOG('ERP5', INFO, "PaymentRule couldn't find payment condition")
+        return []
+   
+  def _createMovementsForPaymentCondition(self,
+        applied_rule, payment_condition):
+    """Create simulation movements for this payment condition.
+    """
+    simulation_movement = applied_rule.getParentValue()
+    date = payment_condition.TradeCondition_getDueDate()
+    
+    if payment_condition.getQuantity():
+      quantity = payment_condition.getQuantity()
+    else:
+      ratio = payment_condition.getEfficiency(1)
+      quantity = simulation_movement.getQuantity() * ratio
+
+    edit_dict = dict(
+          causality_value=payment_condition,
+          payment_mode=payment_condition.getPaymentMode(),
+          source=simulation_movement.getSource(),
+          source_section=simulation_movement.getSourceSection(),
+          source_payment=payment_condition.getSourcePayment() or
+                            simulation_movement.getSourcePayment(),
+          destination=simulation_movement.getDestination(),
+          destination_section=simulation_movement.getDestinationSection(),
+          destination_payment=payment_condition.getDestinationPayment() or
+                            simulation_movement.getDestinationPayment(),
+          resource=simulation_movement.getResource(),
+          start_date=date,
+          price=1,
+          quantity= - quantity,)
+    
+    applied_rule.newContent( **edit_dict )
+
+    edit_dict['source'] = self.getSourcePayment()
+    edit_dict['destination'] = self.getDestinationPayment()
+    edit_dict['quantity'] = - edit_dict['quantity']
+    applied_rule.newContent( **edit_dict )
+    
+    
+  security.declareProtected(Permissions.ModifyPortalContent, 'expand')
+  def expand(self, applied_rule, **kw):
+    """Expands the current movement downward.
+    """
+    my_parent_movement = applied_rule.getParentValue()
+    # generate for source
+    bank_account = self.getDestinationPaymentValue(
+                           portal_type='Account')
+    assert bank_account is not None
+
+    for payment_condition in self._getPaymentConditionList(
+                                          my_parent_movement):
+      payment_condition_url = payment_condition.getRelativeUrl()
+      # look for a movement for this payment condition:
+      corresponding_movement_list = []
+      for simulation_movement in applied_rule.contentValues():
+        if simulation_movement.getCausality() == payment_condition_url:
+          corresponding_movement_list.append(simulation_movement)
+      if not corresponding_movement_list:
+        self._createMovementsForPaymentCondition(applied_rule,
+                                                 payment_condition)
       else:
-        ratio = payment_condition.getEfficiency(1)
-        quantity = simulation_movement.getQuantity() * ratio
-
-      edit_dict = dict(
-            causality_value=payment_condition,
-            payment_mode=payment_condition.getPaymentMode(),
-            source=simulation_movement.getSource(),
-            source_section=simulation_movement.getSourceSection(),
-            source_payment=payment_condition.getSourcePayment() or
-                              simulation_movement.getSourcePayment(),
-            destination=simulation_movement.getDestination(),
-            destination_section=simulation_movement.getDestinationSection(),
-            destination_payment=payment_condition.getDestinationPayment() or
-                              simulation_movement.getDestinationPayment(),
-            resource=simulation_movement.getResource(),
-            start_date=date,
-            price=1,
-            quantity= - quantity,)
-      
-      applied_rule.newContent( **edit_dict )
-
-      edit_dict['source'] = self.getSourcePayment()
-      edit_dict['destination'] = self.getDestinationPayment()
-      edit_dict['quantity'] = - edit_dict['quantity']
-      applied_rule.newContent( **edit_dict )
-      
-      
-    security.declareProtected(Permissions.ModifyPortalContent, 'expand')
-    def expand(self, applied_rule, **kw):
-      """Expands the current movement downward.
-      """
-      my_parent_movement = applied_rule.getParentValue()
-      # generate for source
-      bank_account = self.getDestinationPaymentValue(
-                             portal_type='Account')
-      assert bank_account is not None
-
-      for payment_condition in self._getPaymentConditionList(
-                                            my_parent_movement):
-        payment_condition_url = payment_condition.getRelativeUrl()
-        # look for a movement for this payment condition:
-        corresponding_movement_list = []
-        for simulation_movement in applied_rule.contentValues():
-          if simulation_movement.getCausality() == payment_condition_url:
-            corresponding_movement_list.append(simulation_movement)
-        if not corresponding_movement_list:
-          self._createMovementsForPaymentCondition(applied_rule,
-                                                   payment_condition)
-        else:
-          # TODO: update corresponding_movement_list
-          pass
-      
-      #Rule.expand(self, applied_rule, **kw)
-
-    def test(self, context, tested_base_category_list=None):
-      """Test if this rule apply.
-      """
-
-      # XXX for now disable this rule
-      return False
+        # TODO: update corresponding_movement_list
+        pass
+    
+    #Rule.expand(self, applied_rule, **kw)
 
-      if context.getParentValue()\
-          .getSpecialiseValue().getPortalType() == 'Payment Rule':
-        return False
+  def test(self, context, tested_base_category_list=None):
+    """Test if this rule apply.
+    """
 
-      for account in ( context.getSourceValue(portal_type='Account'),
-          context.getDestinationValue(portal_type='Account')):
-        if account is not None:
-          account_type = account.getAccountType()
-          if account_type in self.receivable_account_type_list or \
-              account_type in self.payable_account_type_list:
-            return True
+    # XXX for now disable this rule
+    return False
 
+    if context.getParentValue()\
+        .getSpecialiseValue().getPortalType() == 'Payment Rule':
       return False
 
+    for account in ( context.getSourceValue(portal_type='Account'),
+        context.getDestinationValue(portal_type='Account')):
+      if account is not None:
+        account_type = account.getAccountType()
+        if account_type in self.receivable_account_type_list or \
+            account_type in self.payable_account_type_list:
+          return True
+
+    return False
+