diff --git a/bt5/erp5_budget/DocumentTemplateItem/portal_components/document.erp5.Budget.py b/bt5/erp5_budget/DocumentTemplateItem/portal_components/document.erp5.Budget.py index 439e282fc550d8e89f3254fa8ef7b7fb277d65eb..b8710bf242f5ff5782c93ce4bcf99ff1cac8931b 100644 --- a/bt5/erp5_budget/DocumentTemplateItem/portal_components/document.erp5.Budget.py +++ b/bt5/erp5_budget/DocumentTemplateItem/portal_components/document.erp5.Budget.py @@ -34,33 +34,32 @@ from Products.ERP5.mixin.variated import VariatedMixin class Budget(Predicate, VariatedMixin): - """ - Budget means a kind of budget stock. - """ + """ + Budget means a kind of budget stock. + """ - # Default Properties - property_sheets = ( PropertySheet.Base - , PropertySheet.XMLObject - , PropertySheet.SimpleItem - , PropertySheet.CategoryCore - , PropertySheet.Folder - , PropertySheet.Predicate - , PropertySheet.SortIndex - , PropertySheet.Task - , PropertySheet.Arrow - , PropertySheet.Budget - , PropertySheet.Path - , PropertySheet.VariationRange - , PropertySheet.Reference - , PropertySheet.Version - ) + # Default Properties + property_sheets = ( PropertySheet.Base + , PropertySheet.XMLObject + , PropertySheet.SimpleItem + , PropertySheet.CategoryCore + , PropertySheet.Folder + , PropertySheet.Predicate + , PropertySheet.SortIndex + , PropertySheet.Task + , PropertySheet.Arrow + , PropertySheet.Budget + , PropertySheet.Path + , PropertySheet.VariationRange + , PropertySheet.Reference + , PropertySheet.Version + ) - # CMF Type Definition - meta_type='ERP5 Budget' - portal_type='Budget' - add_permission = Permissions.AddPortalContent - - # Declarative security - security = ClassSecurityInfo() - security.declareObjectProtected(Permissions.AccessContentsInformation) + # CMF Type Definition + meta_type='ERP5 Budget' + portal_type='Budget' + add_permission = Permissions.AddPortalContent + # Declarative security + security = ClassSecurityInfo() + security.declareObjectProtected(Permissions.AccessContentsInformation) \ No newline at end of file diff --git a/bt5/erp5_budget/DocumentTemplateItem/portal_components/document.erp5.Budget.xml b/bt5/erp5_budget/DocumentTemplateItem/portal_components/document.erp5.Budget.xml index f711fde7540cc38c828b0a97269e9bf011d44ea5..cb80ba59b74180fc627fec47ac52191c99bd3171 100644 --- a/bt5/erp5_budget/DocumentTemplateItem/portal_components/document.erp5.Budget.xml +++ b/bt5/erp5_budget/DocumentTemplateItem/portal_components/document.erp5.Budget.xml @@ -6,6 +6,12 @@ </pickle> <pickle> <dictionary> + <item> + <key> <string>_recorded_property_dict</string> </key> + <value> + <persistent> <string encoding="base64">AAAAAAAAAAI=</string> </persistent> + </value> + </item> <item> <key> <string>default_reference</string> </key> <value> <string>Budget</string> </value> @@ -14,6 +20,12 @@ <key> <string>default_source_reference</string> </key> <value> <string>Products.ERP5.Document.Budget</string> </value> </item> + <item> + <key> <string>description</string> </key> + <value> + <none/> + </value> + </item> <item> <key> <string>id</string> </key> <value> <string>document.erp5.Budget</string> </value> @@ -37,15 +49,7 @@ <item> <key> <string>text_content_warning_message</string> </key> <value> - <tuple> - <string>W: 37, 0: Bad indentation. Found 4 spaces, expected 2 (bad-indentation)</string> - <string>W: 42, 0: Bad indentation. Found 4 spaces, expected 2 (bad-indentation)</string> - <string>W: 59, 0: Bad indentation. Found 4 spaces, expected 2 (bad-indentation)</string> - <string>W: 60, 0: Bad indentation. Found 4 spaces, expected 2 (bad-indentation)</string> - <string>W: 61, 0: Bad indentation. Found 4 spaces, expected 2 (bad-indentation)</string> - <string>W: 64, 0: Bad indentation. Found 4 spaces, expected 2 (bad-indentation)</string> - <string>W: 65, 0: Bad indentation. Found 4 spaces, expected 2 (bad-indentation)</string> - </tuple> + <tuple/> </value> </item> <item> @@ -55,13 +59,28 @@ <item> <key> <string>workflow_history</string> </key> <value> - <persistent> <string encoding="base64">AAAAAAAAAAI=</string> </persistent> + <persistent> <string encoding="base64">AAAAAAAAAAM=</string> </persistent> </value> </item> </dictionary> </pickle> </record> <record id="2" aka="AAAAAAAAAAI="> + <pickle> + <global name="PersistentMapping" module="Persistence.mapping"/> + </pickle> + <pickle> + <dictionary> + <item> + <key> <string>data</string> </key> + <value> + <dictionary/> + </value> + </item> + </dictionary> + </pickle> + </record> + <record id="3" aka="AAAAAAAAAAM="> <pickle> <global name="PersistentMapping" module="Persistence.mapping"/> </pickle> @@ -74,7 +93,7 @@ <item> <key> <string>component_validation_workflow</string> </key> <value> - <persistent> <string encoding="base64">AAAAAAAAAAM=</string> </persistent> + <persistent> <string encoding="base64">AAAAAAAAAAQ=</string> </persistent> </value> </item> </dictionary> @@ -83,7 +102,7 @@ </dictionary> </pickle> </record> - <record id="3" aka="AAAAAAAAAAM="> + <record id="4" aka="AAAAAAAAAAQ="> <pickle> <global name="WorkflowHistoryList" module="Products.ERP5Type.patches.WorkflowTool"/> </pickle> diff --git a/bt5/erp5_budget/DocumentTemplateItem/portal_components/document.erp5.BudgetCell.py b/bt5/erp5_budget/DocumentTemplateItem/portal_components/document.erp5.BudgetCell.py index f4805eeeb6fad750a41e16cf53ad9f0fa6a7b12e..3488a0332cf79aa05ef275654131fec03871621c 100644 --- a/bt5/erp5_budget/DocumentTemplateItem/portal_components/document.erp5.BudgetCell.py +++ b/bt5/erp5_budget/DocumentTemplateItem/portal_components/document.erp5.BudgetCell.py @@ -35,133 +35,133 @@ from Products.ERP5.Document.MetaNode import MetaNode from Products.ERP5.Document.Movement import Movement class BudgetCell(Predicate, MetaNode, Movement): - """ Budget Cell defines a cell of budget. - XXX This is not a Movement, but we need getDestinationCredit - XXX This is not a MetaNode + """ Budget Cell defines a cell of budget. + XXX This is not a Movement, but we need getDestinationCredit + XXX This is not a MetaNode + """ + + # Default Properties + property_sheets = ( PropertySheet.Base + , PropertySheet.XMLObject + , PropertySheet.SimpleItem + , PropertySheet.Folder + , PropertySheet.Predicate + , PropertySheet.SortIndex + , PropertySheet.CategoryCore + , PropertySheet.DublinCore + , PropertySheet.Task + , PropertySheet.Arrow + , PropertySheet.Amount + , PropertySheet.Budget + , PropertySheet.MappedValue + , PropertySheet.VariationRange + ) + + # CMF Type Definition + meta_type='ERP5 Budget Cell' + portal_type='Budget Cell' + add_permission = Permissions.AddPortalContent + + # Declarative security + security = ClassSecurityInfo() + security.declareObjectProtected(Permissions.AccessContentsInformation) + + security.declareProtected(Permissions.AccessContentsInformation, 'getTitle') + def getTitle(self): """ + Return a calculated title. + """ + script = self._getTypeBasedMethod('asTitle') + if script is not None: + return script() + raise UnboundLocalError( + "Did not find title script for portal type: %r" % + self.getPortalType()) + + security.declareProtected(Permissions.AccessContentsInformation, 'getCurrentInventory') + def getCurrentInventory(self, at_date=None, **kw): + """ Returns current inventory. + + at_date parameter can be used to take into account budget transactions + before that date. + """ + kw['node_uid'] = self.getUid() + resource = self.getResourceValue() + if resource is not None: + kw['resource_uid'] = resource.getUid() + if at_date: + kw['at_date'] = at_date + sign = self.getParentValue().BudgetLine_getConsumptionSign() + return sign * self.portal_simulation.getCurrentInventory(**kw) + + security.declareProtected(Permissions.AccessContentsInformation, 'getCurrentBalance') + def getCurrentBalance(self, at_date=None): + """ + Returns current balance + """ + sign = self.getParentValue().BudgetLine_getConsumptionSign() + return sign * self.getQuantity(0.0) + self.getCurrentInventory(at_date=at_date) - # Default Properties - property_sheets = ( PropertySheet.Base - , PropertySheet.XMLObject - , PropertySheet.SimpleItem - , PropertySheet.Folder - , PropertySheet.Predicate - , PropertySheet.SortIndex - , PropertySheet.CategoryCore - , PropertySheet.DublinCore - , PropertySheet.Task - , PropertySheet.Arrow - , PropertySheet.Amount - , PropertySheet.Budget - , PropertySheet.MappedValue - , PropertySheet.VariationRange - ) - - # CMF Type Definition - meta_type='ERP5 Budget Cell' - portal_type='Budget Cell' - add_permission = Permissions.AddPortalContent - - # Declarative security - security = ClassSecurityInfo() - security.declareObjectProtected(Permissions.AccessContentsInformation) - - security.declareProtected(Permissions.AccessContentsInformation, 'getTitle') - def getTitle(self): - """ - Return a calculated title. - """ - script = self._getTypeBasedMethod('asTitle') - if script is not None: - return script() - raise UnboundLocalError,\ - "Did not find title script for portal type: %r" %\ - self.getPortalType() - - security.declareProtected(Permissions.AccessContentsInformation, 'getCurrentInventory') - def getCurrentInventory(self, at_date=None, **kw): - """ Returns current inventory. - - at_date parameter can be used to take into account budget transactions - before that date. - """ - kw['node_uid'] = self.getUid() - resource = self.getResourceValue() - if resource is not None: - kw['resource_uid'] = resource.getUid() - if at_date: - kw['at_date'] = at_date - sign = self.getParentValue().BudgetLine_getConsumptionSign() - return sign * self.portal_simulation.getCurrentInventory(**kw) - - security.declareProtected(Permissions.AccessContentsInformation, 'getCurrentBalance') - def getCurrentBalance(self, at_date=None): - """ - Returns current balance - """ - sign = self.getParentValue().BudgetLine_getConsumptionSign() - return sign * self.getQuantity(0.0) + self.getCurrentInventory(at_date=at_date) - - security.declareProtected(Permissions.AccessContentsInformation, 'getConsumedBudget') - def getConsumedBudget(self, src__=0): - """ - Return consumed budget. - """ - script = self._getTypeBasedMethod('getConsumedBudget') - if script is not None: - return script(src__=src__) - raise UnboundLocalError,\ - "Did not find consumed budget script for portal type: %r" % \ - self.getPortalType() - - security.declareProtected(Permissions.AccessContentsInformation, 'getAvailableBudget') - def getAvailableBudget(self, at_date=None): - """ - Return available budget. - """ - return self.getCurrentBalance(at_date=at_date) - self.getEngagedBudget() - - security.declareProtected(Permissions.AccessContentsInformation, 'getEngagedBudget') - def getEngagedBudget(self, src__=0): - """ - Return Engaged budget. - """ - script = self._getTypeBasedMethod('getEngagedBudget') - if script is not None: - return script(src__=src__) - raise UnboundLocalError,\ - "Did not find engaged budget script for portal type: %r" % \ - self.getPortalType() - - security.declareProtected(Permissions.AccessContentsInformation, - 'getExplanationValue') - def getExplanationValue(self, default=None): - """Explanation has no meaning for a budget cell""" - return default - - security.declareProtected(Permissions.ModifyPortalContent, - 'setSourceCredit') - def setSourceCredit(self, source_credit): - """Set the quantity. - Overloaded from movement, we always set the quantity, even if not passed - """ - try: - source_credit = float(source_credit) - except TypeError: - source_credit = 0.0 - Movement.setSourceCredit(self, source_credit) - - def setSourceDebit(self, source_debit): - """Set the quantity. - Overloaded from movement, we always set the quantity, even if not passed - """ - try: - source_debit = float(source_debit) - except TypeError: - source_debit = 0.0 - Movement.setSourceDebit(self, source_debit) - - security.declareProtected( Permissions.ModifyPortalContent, - 'setDestinationDebit', 'setDestinationCredit' ) - setDestinationDebit = setSourceCredit - setDestinationCredit = setSourceDebit + security.declareProtected(Permissions.AccessContentsInformation, 'getConsumedBudget') + def getConsumedBudget(self, src__=0): + """ + Return consumed budget. + """ + script = self._getTypeBasedMethod('getConsumedBudget') + if script is not None: + return script(src__=src__) + raise UnboundLocalError( + "Did not find consumed budget script for portal type: %r" % + self.getPortalType()) + + security.declareProtected(Permissions.AccessContentsInformation, 'getAvailableBudget') + def getAvailableBudget(self, at_date=None): + """ + Return available budget. + """ + return self.getCurrentBalance(at_date=at_date) - self.getEngagedBudget() + + security.declareProtected(Permissions.AccessContentsInformation, 'getEngagedBudget') + def getEngagedBudget(self, src__=0): + """ + Return Engaged budget. + """ + script = self._getTypeBasedMethod('getEngagedBudget') + if script is not None: + return script(src__=src__) + raise UnboundLocalError( + "Did not find engaged budget script for portal type: %r" % + self.getPortalType()) + + security.declareProtected(Permissions.AccessContentsInformation, + 'getExplanationValue') + def getExplanationValue(self): + """Explanation has no meaning for a budget cell""" + return None + + security.declareProtected(Permissions.ModifyPortalContent, + 'setSourceCredit') + def setSourceCredit(self, source_credit): + """Set the quantity. + Overloaded from movement, we always set the quantity, even if not passed + """ + try: + source_credit = float(source_credit) + except TypeError: + source_credit = 0.0 + Movement.setSourceCredit(self, source_credit) + + def setSourceDebit(self, source_debit): + """Set the quantity. + Overloaded from movement, we always set the quantity, even if not passed + """ + try: + source_debit = float(source_debit) + except TypeError: + source_debit = 0.0 + Movement.setSourceDebit(self, source_debit) + + security.declareProtected(Permissions.ModifyPortalContent, + 'setDestinationDebit', 'setDestinationCredit' ) + setDestinationDebit = setSourceCredit + setDestinationCredit = setSourceDebit \ No newline at end of file diff --git a/bt5/erp5_budget/DocumentTemplateItem/portal_components/document.erp5.BudgetCell.xml b/bt5/erp5_budget/DocumentTemplateItem/portal_components/document.erp5.BudgetCell.xml index ae6109550574b81feabe834e1b9bd3ca67f0ad55..a19f2cf9a29c6b2135395b5d5033b6ead7645c39 100644 --- a/bt5/erp5_budget/DocumentTemplateItem/portal_components/document.erp5.BudgetCell.xml +++ b/bt5/erp5_budget/DocumentTemplateItem/portal_components/document.erp5.BudgetCell.xml @@ -6,6 +6,12 @@ </pickle> <pickle> <dictionary> + <item> + <key> <string>_recorded_property_dict</string> </key> + <value> + <persistent> <string encoding="base64">AAAAAAAAAAI=</string> </persistent> + </value> + </item> <item> <key> <string>default_reference</string> </key> <value> <string>BudgetCell</string> </value> @@ -14,6 +20,12 @@ <key> <string>default_source_reference</string> </key> <value> <string>Products.ERP5.Document.BudgetCell</string> </value> </item> + <item> + <key> <string>description</string> </key> + <value> + <none/> + </value> + </item> <item> <key> <string>id</string> </key> <value> <string>document.erp5.BudgetCell</string> </value> @@ -37,79 +49,7 @@ <item> <key> <string>text_content_warning_message</string> </key> <value> - <tuple> - <string>W: 38, 0: Bad indentation. Found 4 spaces, expected 2 (bad-indentation)</string> - <string>W: 44, 0: Bad indentation. Found 4 spaces, expected 2 (bad-indentation)</string> - <string>W: 61, 0: Bad indentation. Found 4 spaces, expected 2 (bad-indentation)</string> - <string>W: 62, 0: Bad indentation. Found 4 spaces, expected 2 (bad-indentation)</string> - <string>W: 63, 0: Bad indentation. Found 4 spaces, expected 2 (bad-indentation)</string> - <string>W: 66, 0: Bad indentation. Found 4 spaces, expected 2 (bad-indentation)</string> - <string>W: 67, 0: Bad indentation. Found 4 spaces, expected 2 (bad-indentation)</string> - <string>W: 69, 0: Bad indentation. Found 4 spaces, expected 2 (bad-indentation)</string> - <string>W: 70, 0: Bad indentation. Found 4 spaces, expected 2 (bad-indentation)</string> - <string>W: 71, 0: Bad indentation. Found 6 spaces, expected 4 (bad-indentation)</string> - <string>W: 74, 0: Bad indentation. Found 6 spaces, expected 4 (bad-indentation)</string> - <string>W: 75, 0: Bad indentation. Found 6 spaces, expected 4 (bad-indentation)</string> - <string>W: 76, 0: Bad indentation. Found 8 spaces, expected 6 (bad-indentation)</string> - <string>W: 77, 0: Bad indentation. Found 6 spaces, expected 4 (bad-indentation)</string> - <string>W: 81, 0: Bad indentation. Found 4 spaces, expected 2 (bad-indentation)</string> - <string>W: 82, 0: Bad indentation. Found 4 spaces, expected 2 (bad-indentation)</string> - <string>W: 83, 0: Bad indentation. Found 6 spaces, expected 4 (bad-indentation)</string> - <string>W: 88, 0: Bad indentation. Found 6 spaces, expected 4 (bad-indentation)</string> - <string>W: 89, 0: Bad indentation. Found 6 spaces, expected 4 (bad-indentation)</string> - <string>W: 90, 0: Bad indentation. Found 6 spaces, expected 4 (bad-indentation)</string> - <string>W: 91, 0: Bad indentation. Found 8 spaces, expected 6 (bad-indentation)</string> - <string>W: 92, 0: Bad indentation. Found 6 spaces, expected 4 (bad-indentation)</string> - <string>W: 93, 0: Bad indentation. Found 8 spaces, expected 6 (bad-indentation)</string> - <string>W: 94, 0: Bad indentation. Found 6 spaces, expected 4 (bad-indentation)</string> - <string>W: 95, 0: Bad indentation. Found 6 spaces, expected 4 (bad-indentation)</string> - <string>W: 97, 0: Bad indentation. Found 4 spaces, expected 2 (bad-indentation)</string> - <string>W: 98, 0: Bad indentation. Found 4 spaces, expected 2 (bad-indentation)</string> - <string>W: 99, 0: Bad indentation. Found 6 spaces, expected 4 (bad-indentation)</string> - <string>W:102, 0: Bad indentation. Found 6 spaces, expected 4 (bad-indentation)</string> - <string>W:103, 0: Bad indentation. Found 6 spaces, expected 4 (bad-indentation)</string> - <string>W:105, 0: Bad indentation. Found 4 spaces, expected 2 (bad-indentation)</string> - <string>W:106, 0: Bad indentation. Found 4 spaces, expected 2 (bad-indentation)</string> - <string>W:107, 0: Bad indentation. Found 6 spaces, expected 4 (bad-indentation)</string> - <string>W:110, 0: Bad indentation. Found 6 spaces, expected 4 (bad-indentation)</string> - <string>W:111, 0: Bad indentation. Found 6 spaces, expected 4 (bad-indentation)</string> - <string>W:112, 0: Bad indentation. Found 8 spaces, expected 6 (bad-indentation)</string> - <string>W:113, 0: Bad indentation. Found 6 spaces, expected 4 (bad-indentation)</string> - <string>W:117, 0: Bad indentation. Found 4 spaces, expected 2 (bad-indentation)</string> - <string>W:118, 0: Bad indentation. Found 4 spaces, expected 2 (bad-indentation)</string> - <string>W:119, 0: Bad indentation. Found 6 spaces, expected 4 (bad-indentation)</string> - <string>W:122, 0: Bad indentation. Found 6 spaces, expected 4 (bad-indentation)</string> - <string>W:124, 0: Bad indentation. Found 4 spaces, expected 2 (bad-indentation)</string> - <string>W:125, 0: Bad indentation. Found 4 spaces, expected 2 (bad-indentation)</string> - <string>W:126, 0: Bad indentation. Found 6 spaces, expected 4 (bad-indentation)</string> - <string>W:129, 0: Bad indentation. Found 6 spaces, expected 4 (bad-indentation)</string> - <string>W:130, 0: Bad indentation. Found 6 spaces, expected 4 (bad-indentation)</string> - <string>W:131, 0: Bad indentation. Found 8 spaces, expected 6 (bad-indentation)</string> - <string>W:132, 0: Bad indentation. Found 6 spaces, expected 4 (bad-indentation)</string> - <string>W:136, 0: Bad indentation. Found 4 spaces, expected 2 (bad-indentation)</string> - <string>W:138, 0: Bad indentation. Found 4 spaces, expected 2 (bad-indentation)</string> - <string>W:139, 0: Bad indentation. Found 6 spaces, expected 4 (bad-indentation)</string> - <string>W:140, 0: Bad indentation. Found 6 spaces, expected 4 (bad-indentation)</string> - <string>W:142, 0: Bad indentation. Found 4 spaces, expected 2 (bad-indentation)</string> - <string>W:144, 0: Bad indentation. Found 4 spaces, expected 2 (bad-indentation)</string> - <string>W:145, 0: Bad indentation. Found 6 spaces, expected 4 (bad-indentation)</string> - <string>W:148, 0: Bad indentation. Found 6 spaces, expected 4 (bad-indentation)</string> - <string>W:149, 0: Bad indentation. Found 8 spaces, expected 6 (bad-indentation)</string> - <string>W:150, 0: Bad indentation. Found 6 spaces, expected 4 (bad-indentation)</string> - <string>W:151, 0: Bad indentation. Found 8 spaces, expected 6 (bad-indentation)</string> - <string>W:152, 0: Bad indentation. Found 6 spaces, expected 4 (bad-indentation)</string> - <string>W:154, 0: Bad indentation. Found 4 spaces, expected 2 (bad-indentation)</string> - <string>W:155, 0: Bad indentation. Found 6 spaces, expected 4 (bad-indentation)</string> - <string>W:158, 0: Bad indentation. Found 6 spaces, expected 4 (bad-indentation)</string> - <string>W:159, 0: Bad indentation. Found 8 spaces, expected 6 (bad-indentation)</string> - <string>W:160, 0: Bad indentation. Found 6 spaces, expected 4 (bad-indentation)</string> - <string>W:161, 0: Bad indentation. Found 8 spaces, expected 6 (bad-indentation)</string> - <string>W:162, 0: Bad indentation. Found 6 spaces, expected 4 (bad-indentation)</string> - <string>W:164, 0: Bad indentation. Found 4 spaces, expected 2 (bad-indentation)</string> - <string>W:166, 0: Bad indentation. Found 4 spaces, expected 2 (bad-indentation)</string> - <string>W:167, 0: Bad indentation. Found 4 spaces, expected 2 (bad-indentation)</string> - <string>W:138, 4: Arguments number differs from overridden \'getExplanationValue\' method (arguments-differ)</string> - </tuple> + <tuple/> </value> </item> <item> @@ -119,13 +59,28 @@ <item> <key> <string>workflow_history</string> </key> <value> - <persistent> <string encoding="base64">AAAAAAAAAAI=</string> </persistent> + <persistent> <string encoding="base64">AAAAAAAAAAM=</string> </persistent> </value> </item> </dictionary> </pickle> </record> <record id="2" aka="AAAAAAAAAAI="> + <pickle> + <global name="PersistentMapping" module="Persistence.mapping"/> + </pickle> + <pickle> + <dictionary> + <item> + <key> <string>data</string> </key> + <value> + <dictionary/> + </value> + </item> + </dictionary> + </pickle> + </record> + <record id="3" aka="AAAAAAAAAAM="> <pickle> <global name="PersistentMapping" module="Persistence.mapping"/> </pickle> @@ -138,7 +93,7 @@ <item> <key> <string>component_validation_workflow</string> </key> <value> - <persistent> <string encoding="base64">AAAAAAAAAAM=</string> </persistent> + <persistent> <string encoding="base64">AAAAAAAAAAQ=</string> </persistent> </value> </item> </dictionary> @@ -147,7 +102,7 @@ </dictionary> </pickle> </record> - <record id="3" aka="AAAAAAAAAAM="> + <record id="4" aka="AAAAAAAAAAQ="> <pickle> <global name="WorkflowHistoryList" module="Products.ERP5Type.patches.WorkflowTool"/> </pickle> diff --git a/bt5/erp5_budget/DocumentTemplateItem/portal_components/document.erp5.BudgetTransaction.py b/bt5/erp5_budget/DocumentTemplateItem/portal_components/document.erp5.BudgetTransaction.py index ed473b8fbf1b5e1b8a62d16af59c0e40f2adb7fe..7ed3324e6d2f1dada11e2caae20aa18cb51efdc4 100644 --- a/bt5/erp5_budget/DocumentTemplateItem/portal_components/document.erp5.BudgetTransaction.py +++ b/bt5/erp5_budget/DocumentTemplateItem/portal_components/document.erp5.BudgetTransaction.py @@ -32,37 +32,35 @@ from Products.ERP5Type import Permissions, PropertySheet from Products.ERP5.Document.DeliveryLine import DeliveryLine class BudgetTransaction(DeliveryLine): - """ - BudgetTransaction an order or transfer of budget. - """ - - # Default Properties - property_sheets = ( PropertySheet.Base - , PropertySheet.XMLObject - , PropertySheet.CategoryCore - , PropertySheet.Amount - , PropertySheet.Task - , PropertySheet.Arrow - , PropertySheet.Movement - , PropertySheet.Price - , PropertySheet.VariationRange - , PropertySheet.ItemAggregation - ) - # CMF Type Definition - meta_type='ERP5 Budget Transaction' - portal_type='Budget Transaction' - add_permission = Permissions.AddPortalContent + """ + BudgetTransaction an order or transfer of budget. + """ - # Declarative security - security = ClassSecurityInfo() - security.declareObjectProtected(Permissions.AccessContentsInformation) + # Default Properties + property_sheets = ( PropertySheet.Base + , PropertySheet.XMLObject + , PropertySheet.CategoryCore + , PropertySheet.Amount + , PropertySheet.Task + , PropertySheet.Arrow + , PropertySheet.Movement + , PropertySheet.Price + , PropertySheet.VariationRange + , PropertySheet.ItemAggregation + ) + # CMF Type Definition + meta_type='ERP5 Budget Transaction' + portal_type='Budget Transaction' + add_permission = Permissions.AddPortalContent + # Declarative security + security = ClassSecurityInfo() + security.declareObjectProtected(Permissions.AccessContentsInformation) - security.declareProtected(Permissions.AccessContentsInformation, - 'isAccountable') - def isAccountable(self): - """ - Supersedes the DeliveryLine definition - """ - return 1 - + security.declareProtected(Permissions.AccessContentsInformation, + 'isAccountable') + def isAccountable(self): + """ + Supersedes the DeliveryLine definition + """ + return 1 \ No newline at end of file diff --git a/bt5/erp5_budget/DocumentTemplateItem/portal_components/document.erp5.BudgetTransaction.xml b/bt5/erp5_budget/DocumentTemplateItem/portal_components/document.erp5.BudgetTransaction.xml index 7847299de3e3516e5dc41c8cbb3c8acdd6728d54..930f336c23760cf11874a7691df20569db9c1194 100644 --- a/bt5/erp5_budget/DocumentTemplateItem/portal_components/document.erp5.BudgetTransaction.xml +++ b/bt5/erp5_budget/DocumentTemplateItem/portal_components/document.erp5.BudgetTransaction.xml @@ -6,6 +6,12 @@ </pickle> <pickle> <dictionary> + <item> + <key> <string>_recorded_property_dict</string> </key> + <value> + <persistent> <string encoding="base64">AAAAAAAAAAI=</string> </persistent> + </value> + </item> <item> <key> <string>default_reference</string> </key> <value> <string>BudgetTransaction</string> </value> @@ -14,6 +20,12 @@ <key> <string>default_source_reference</string> </key> <value> <string>Products.ERP5.Document.BudgetTransaction</string> </value> </item> + <item> + <key> <string>description</string> </key> + <value> + <none/> + </value> + </item> <item> <key> <string>id</string> </key> <value> <string>document.erp5.BudgetTransaction</string> </value> @@ -37,19 +49,7 @@ <item> <key> <string>text_content_warning_message</string> </key> <value> - <tuple> - <string>W: 35, 0: Bad indentation. Found 4 spaces, expected 2 (bad-indentation)</string> - <string>W: 40, 0: Bad indentation. Found 4 spaces, expected 2 (bad-indentation)</string> - <string>W: 52, 0: Bad indentation. Found 4 spaces, expected 2 (bad-indentation)</string> - <string>W: 53, 0: Bad indentation. Found 4 spaces, expected 2 (bad-indentation)</string> - <string>W: 54, 0: Bad indentation. Found 4 spaces, expected 2 (bad-indentation)</string> - <string>W: 57, 0: Bad indentation. Found 4 spaces, expected 2 (bad-indentation)</string> - <string>W: 58, 0: Bad indentation. Found 4 spaces, expected 2 (bad-indentation)</string> - <string>W: 61, 0: Bad indentation. Found 4 spaces, expected 2 (bad-indentation)</string> - <string>W: 63, 0: Bad indentation. Found 4 spaces, expected 2 (bad-indentation)</string> - <string>W: 64, 0: Bad indentation. Found 6 spaces, expected 4 (bad-indentation)</string> - <string>W: 67, 0: Bad indentation. Found 6 spaces, expected 4 (bad-indentation)</string> - </tuple> + <tuple/> </value> </item> <item> @@ -59,13 +59,28 @@ <item> <key> <string>workflow_history</string> </key> <value> - <persistent> <string encoding="base64">AAAAAAAAAAI=</string> </persistent> + <persistent> <string encoding="base64">AAAAAAAAAAM=</string> </persistent> </value> </item> </dictionary> </pickle> </record> <record id="2" aka="AAAAAAAAAAI="> + <pickle> + <global name="PersistentMapping" module="Persistence.mapping"/> + </pickle> + <pickle> + <dictionary> + <item> + <key> <string>data</string> </key> + <value> + <dictionary/> + </value> + </item> + </dictionary> + </pickle> + </record> + <record id="3" aka="AAAAAAAAAAM="> <pickle> <global name="PersistentMapping" module="Persistence.mapping"/> </pickle> @@ -78,7 +93,7 @@ <item> <key> <string>component_validation_workflow</string> </key> <value> - <persistent> <string encoding="base64">AAAAAAAAAAM=</string> </persistent> + <persistent> <string encoding="base64">AAAAAAAAAAQ=</string> </persistent> </value> </item> </dictionary> @@ -87,7 +102,7 @@ </dictionary> </pickle> </record> - <record id="3" aka="AAAAAAAAAAM="> + <record id="4" aka="AAAAAAAAAAQ="> <pickle> <global name="WorkflowHistoryList" module="Products.ERP5Type.patches.WorkflowTool"/> </pickle> diff --git a/bt5/erp5_budget/DocumentTemplateItem/portal_components/document.erp5.BudgetTransfer.py b/bt5/erp5_budget/DocumentTemplateItem/portal_components/document.erp5.BudgetTransfer.py index 5c1ab7d25517ea94bd1677ca9e26d26c4e28f09c..153ec7532ba1684ea7c6e4a9a173768c26150afc 100644 --- a/bt5/erp5_budget/DocumentTemplateItem/portal_components/document.erp5.BudgetTransfer.py +++ b/bt5/erp5_budget/DocumentTemplateItem/portal_components/document.erp5.BudgetTransfer.py @@ -33,25 +33,24 @@ from Products.ERP5Type import Permissions, PropertySheet class BudgetTransfer(Supply): - """ - BudgetTransfer ... - """ + """ + BudgetTransfer ... + """ + # Default Properties + property_sheets = ( PropertySheet.Base + , PropertySheet.XMLObject + , PropertySheet.CategoryCore + , PropertySheet.Folder + , PropertySheet.Task + , PropertySheet.Arrow + , PropertySheet.Movement + ) - # Default Properties - property_sheets = ( PropertySheet.Base - , PropertySheet.XMLObject - , PropertySheet.CategoryCore - , PropertySheet.Folder - , PropertySheet.Task - , PropertySheet.Arrow - , PropertySheet.Movement - ) + # CMF Type Definition + meta_type='ERP5 Budget Transfer' + portal_type='Budget Transfer' + add_permission = Permissions.AddPortalContent - # CMF Type Definition - meta_type='ERP5 Budget Transfer' - portal_type='Budget Transfer' - add_permission = Permissions.AddPortalContent - - # Declarative security - security = ClassSecurityInfo() - security.declareObjectProtected(Permissions.AccessContentsInformation) + # Declarative security + security = ClassSecurityInfo() + security.declareObjectProtected(Permissions.AccessContentsInformation) \ No newline at end of file diff --git a/bt5/erp5_budget/DocumentTemplateItem/portal_components/document.erp5.BudgetTransfer.xml b/bt5/erp5_budget/DocumentTemplateItem/portal_components/document.erp5.BudgetTransfer.xml index e5f41c1f600ada86c17b17929f6cafb293f44ffa..16f3702a33f9f87110d788c6f704360f1292078e 100644 --- a/bt5/erp5_budget/DocumentTemplateItem/portal_components/document.erp5.BudgetTransfer.xml +++ b/bt5/erp5_budget/DocumentTemplateItem/portal_components/document.erp5.BudgetTransfer.xml @@ -6,6 +6,12 @@ </pickle> <pickle> <dictionary> + <item> + <key> <string>_recorded_property_dict</string> </key> + <value> + <persistent> <string encoding="base64">AAAAAAAAAAI=</string> </persistent> + </value> + </item> <item> <key> <string>default_reference</string> </key> <value> <string>BudgetTransfer</string> </value> @@ -14,6 +20,12 @@ <key> <string>default_source_reference</string> </key> <value> <string>Products.ERP5.Document.BudgetTransfer</string> </value> </item> + <item> + <key> <string>description</string> </key> + <value> + <none/> + </value> + </item> <item> <key> <string>id</string> </key> <value> <string>document.erp5.BudgetTransfer</string> </value> @@ -37,15 +49,7 @@ <item> <key> <string>text_content_warning_message</string> </key> <value> - <tuple> - <string>W: 36, 0: Bad indentation. Found 4 spaces, expected 2 (bad-indentation)</string> - <string>W: 41, 0: Bad indentation. Found 4 spaces, expected 2 (bad-indentation)</string> - <string>W: 51, 0: Bad indentation. Found 4 spaces, expected 2 (bad-indentation)</string> - <string>W: 52, 0: Bad indentation. Found 4 spaces, expected 2 (bad-indentation)</string> - <string>W: 53, 0: Bad indentation. Found 4 spaces, expected 2 (bad-indentation)</string> - <string>W: 56, 0: Bad indentation. Found 4 spaces, expected 2 (bad-indentation)</string> - <string>W: 57, 0: Bad indentation. Found 4 spaces, expected 2 (bad-indentation)</string> - </tuple> + <tuple/> </value> </item> <item> @@ -55,13 +59,28 @@ <item> <key> <string>workflow_history</string> </key> <value> - <persistent> <string encoding="base64">AAAAAAAAAAI=</string> </persistent> + <persistent> <string encoding="base64">AAAAAAAAAAM=</string> </persistent> </value> </item> </dictionary> </pickle> </record> <record id="2" aka="AAAAAAAAAAI="> + <pickle> + <global name="PersistentMapping" module="Persistence.mapping"/> + </pickle> + <pickle> + <dictionary> + <item> + <key> <string>data</string> </key> + <value> + <dictionary/> + </value> + </item> + </dictionary> + </pickle> + </record> + <record id="3" aka="AAAAAAAAAAM="> <pickle> <global name="PersistentMapping" module="Persistence.mapping"/> </pickle> @@ -74,7 +93,7 @@ <item> <key> <string>component_validation_workflow</string> </key> <value> - <persistent> <string encoding="base64">AAAAAAAAAAM=</string> </persistent> + <persistent> <string encoding="base64">AAAAAAAAAAQ=</string> </persistent> </value> </item> </dictionary> @@ -83,7 +102,7 @@ </dictionary> </pickle> </record> - <record id="3" aka="AAAAAAAAAAM="> + <record id="4" aka="AAAAAAAAAAQ="> <pickle> <global name="WorkflowHistoryList" module="Products.ERP5Type.patches.WorkflowTool"/> </pickle> diff --git a/bt5/erp5_budget/DocumentTemplateItem/portal_components/document.erp5.BudgetTransferLine.py b/bt5/erp5_budget/DocumentTemplateItem/portal_components/document.erp5.BudgetTransferLine.py index 33b849c7ada7899c94d8a001b140319c80c562fa..88fb01a898ec77913b949a45a1d3b9149d4f9efd 100644 --- a/bt5/erp5_budget/DocumentTemplateItem/portal_components/document.erp5.BudgetTransferLine.py +++ b/bt5/erp5_budget/DocumentTemplateItem/portal_components/document.erp5.BudgetTransferLine.py @@ -35,24 +35,23 @@ from Products.ERP5Type import Permissions, PropertySheet from Products.ERP5.Document.SupplyLine import SupplyLine class BudgetTransferLine(SupplyLine): - """ - BudgetTransferLine - """ - - # Default Properties - property_sheets = ( PropertySheet.Base - , PropertySheet.XMLObject - , PropertySheet.CategoryCore - , PropertySheet.Amount - , PropertySheet.Task - , PropertySheet.Arrow - ) - - # CMF Type Definition - meta_type='ERP5 Budget Transfer Line' - portal_type='Budget Transfer Line' - add_permission = Permissions.AddPortalContent - - # Declarative security - security = ClassSecurityInfo() - security.declareObjectProtected(Permissions.AccessContentsInformation) + """ + BudgetTransferLine + """ + # Default Properties + property_sheets = ( PropertySheet.Base + , PropertySheet.XMLObject + , PropertySheet.CategoryCore + , PropertySheet.Amount + , PropertySheet.Task + , PropertySheet.Arrow + ) + + # CMF Type Definition + meta_type='ERP5 Budget Transfer Line' + portal_type='Budget Transfer Line' + add_permission = Permissions.AddPortalContent + + # Declarative security + security = ClassSecurityInfo() + security.declareObjectProtected(Permissions.AccessContentsInformation) \ No newline at end of file diff --git a/bt5/erp5_budget/DocumentTemplateItem/portal_components/document.erp5.BudgetTransferLine.xml b/bt5/erp5_budget/DocumentTemplateItem/portal_components/document.erp5.BudgetTransferLine.xml index 688d107e1c33a9c1a079d21e34640173fc00dbae..276fe14e7e93267c4f6781f106baf47dc3abb277 100644 --- a/bt5/erp5_budget/DocumentTemplateItem/portal_components/document.erp5.BudgetTransferLine.xml +++ b/bt5/erp5_budget/DocumentTemplateItem/portal_components/document.erp5.BudgetTransferLine.xml @@ -6,6 +6,12 @@ </pickle> <pickle> <dictionary> + <item> + <key> <string>_recorded_property_dict</string> </key> + <value> + <persistent> <string encoding="base64">AAAAAAAAAAI=</string> </persistent> + </value> + </item> <item> <key> <string>default_reference</string> </key> <value> <string>BudgetTransferLine</string> </value> @@ -14,6 +20,12 @@ <key> <string>default_source_reference</string> </key> <value> <string>Products.ERP5.Document.BudgetTransferLine</string> </value> </item> + <item> + <key> <string>description</string> </key> + <value> + <none/> + </value> + </item> <item> <key> <string>id</string> </key> <value> <string>document.erp5.BudgetTransferLine</string> </value> @@ -37,15 +49,7 @@ <item> <key> <string>text_content_warning_message</string> </key> <value> - <tuple> - <string>W: 38, 0: Bad indentation. Found 4 spaces, expected 2 (bad-indentation)</string> - <string>W: 43, 0: Bad indentation. Found 4 spaces, expected 2 (bad-indentation)</string> - <string>W: 52, 0: Bad indentation. Found 4 spaces, expected 2 (bad-indentation)</string> - <string>W: 53, 0: Bad indentation. Found 4 spaces, expected 2 (bad-indentation)</string> - <string>W: 54, 0: Bad indentation. Found 4 spaces, expected 2 (bad-indentation)</string> - <string>W: 57, 0: Bad indentation. Found 4 spaces, expected 2 (bad-indentation)</string> - <string>W: 58, 0: Bad indentation. Found 4 spaces, expected 2 (bad-indentation)</string> - </tuple> + <tuple/> </value> </item> <item> @@ -55,13 +59,28 @@ <item> <key> <string>workflow_history</string> </key> <value> - <persistent> <string encoding="base64">AAAAAAAAAAI=</string> </persistent> + <persistent> <string encoding="base64">AAAAAAAAAAM=</string> </persistent> </value> </item> </dictionary> </pickle> </record> <record id="2" aka="AAAAAAAAAAI="> + <pickle> + <global name="PersistentMapping" module="Persistence.mapping"/> + </pickle> + <pickle> + <dictionary> + <item> + <key> <string>data</string> </key> + <value> + <dictionary/> + </value> + </item> + </dictionary> + </pickle> + </record> + <record id="3" aka="AAAAAAAAAAM="> <pickle> <global name="PersistentMapping" module="Persistence.mapping"/> </pickle> @@ -74,7 +93,7 @@ <item> <key> <string>component_validation_workflow</string> </key> <value> - <persistent> <string encoding="base64">AAAAAAAAAAM=</string> </persistent> + <persistent> <string encoding="base64">AAAAAAAAAAQ=</string> </persistent> </value> </item> </dictionary> @@ -83,7 +102,7 @@ </dictionary> </pickle> </record> - <record id="3" aka="AAAAAAAAAAM="> + <record id="4" aka="AAAAAAAAAAQ="> <pickle> <global name="WorkflowHistoryList" module="Products.ERP5Type.patches.WorkflowTool"/> </pickle> diff --git a/bt5/erp5_budget/DocumentTemplateItem/portal_components/document.erp5.CategoryBudgetVariation.py b/bt5/erp5_budget/DocumentTemplateItem/portal_components/document.erp5.CategoryBudgetVariation.py index c593ebdd08ac58f51a003fa6ddf9eec67d02e07e..603b19a5d56b95878b2a39b0eb643bba0aa19226 100644 --- a/bt5/erp5_budget/DocumentTemplateItem/portal_components/document.erp5.CategoryBudgetVariation.py +++ b/bt5/erp5_budget/DocumentTemplateItem/portal_components/document.erp5.CategoryBudgetVariation.py @@ -30,7 +30,6 @@ from AccessControl import ClassSecurityInfo from Products.ERP5Type import Permissions, PropertySheet from erp5.component.document.BudgetVariation import BudgetVariation - class CategoryBudgetVariation(BudgetVariation): """ A budget variation based on a category """ @@ -141,7 +140,7 @@ class CategoryBudgetVariation(BudgetVariation): for criterion_category in context.getMembershipCriterionCategoryList(): if '/' not in criterion_category: # safe ... continue - criterion_base_category, category_url = criterion_category.split('/', 1) + criterion_base_category, _ = criterion_category.split('/', 1) if criterion_base_category == base_category: if uid_based_axis: category_uid = self.getPortalObject().portal_categories\ @@ -184,8 +183,9 @@ class CategoryBudgetVariation(BudgetVariation): axis = '%s_uid' % axis if self.getProperty('full_consumption_detail'): - for title, category in self.getBudgetLineVariationRangeCategoryList(context): - if not category: continue + for _, category in self.getBudgetLineVariationRangeCategoryList(context): + if not category: + continue if axis.endswith('_uid'): # XXX move out getattrs category = self.getPortalObject().portal_categories\ diff --git a/bt5/erp5_budget/DocumentTemplateItem/portal_components/document.erp5.CategoryBudgetVariation.xml b/bt5/erp5_budget/DocumentTemplateItem/portal_components/document.erp5.CategoryBudgetVariation.xml index a981f521bcf73550ec6d18478b1e98e2c51828be..687dfa89a06c0b5e48246e6333bddac1278fdf03 100644 --- a/bt5/erp5_budget/DocumentTemplateItem/portal_components/document.erp5.CategoryBudgetVariation.xml +++ b/bt5/erp5_budget/DocumentTemplateItem/portal_components/document.erp5.CategoryBudgetVariation.xml @@ -6,6 +6,12 @@ </pickle> <pickle> <dictionary> + <item> + <key> <string>_recorded_property_dict</string> </key> + <value> + <persistent> <string encoding="base64">AAAAAAAAAAI=</string> </persistent> + </value> + </item> <item> <key> <string>default_reference</string> </key> <value> <string>CategoryBudgetVariation</string> </value> @@ -14,6 +20,12 @@ <key> <string>default_source_reference</string> </key> <value> <string>Products.ERP5.Document.CategoryBudgetVariation</string> </value> </item> + <item> + <key> <string>description</string> </key> + <value> + <none/> + </value> + </item> <item> <key> <string>id</string> </key> <value> <string>document.erp5.CategoryBudgetVariation</string> </value> @@ -37,10 +49,7 @@ <item> <key> <string>text_content_warning_message</string> </key> <value> - <tuple> - <string>W:144, 31: Unused variable \'category_url\' (unused-variable)</string> - <string>W:187, 10: Unused variable \'title\' (unused-variable)</string> - </tuple> + <tuple/> </value> </item> <item> @@ -50,13 +59,28 @@ <item> <key> <string>workflow_history</string> </key> <value> - <persistent> <string encoding="base64">AAAAAAAAAAI=</string> </persistent> + <persistent> <string encoding="base64">AAAAAAAAAAM=</string> </persistent> </value> </item> </dictionary> </pickle> </record> <record id="2" aka="AAAAAAAAAAI="> + <pickle> + <global name="PersistentMapping" module="Persistence.mapping"/> + </pickle> + <pickle> + <dictionary> + <item> + <key> <string>data</string> </key> + <value> + <dictionary/> + </value> + </item> + </dictionary> + </pickle> + </record> + <record id="3" aka="AAAAAAAAAAM="> <pickle> <global name="PersistentMapping" module="Persistence.mapping"/> </pickle> @@ -69,7 +93,7 @@ <item> <key> <string>component_validation_workflow</string> </key> <value> - <persistent> <string encoding="base64">AAAAAAAAAAM=</string> </persistent> + <persistent> <string encoding="base64">AAAAAAAAAAQ=</string> </persistent> </value> </item> </dictionary> @@ -78,7 +102,7 @@ </dictionary> </pickle> </record> - <record id="3" aka="AAAAAAAAAAM="> + <record id="4" aka="AAAAAAAAAAQ="> <pickle> <global name="WorkflowHistoryList" module="Products.ERP5Type.patches.WorkflowTool"/> </pickle> diff --git a/bt5/erp5_budget/DocumentTemplateItem/portal_components/document.erp5.NodeBudgetVariation.py b/bt5/erp5_budget/DocumentTemplateItem/portal_components/document.erp5.NodeBudgetVariation.py index a922652ea8403b5c6d3ffb115568bd290559fa5c..82da49d6b084bd0f46ea52cbc14e51aa8efe53aa 100644 --- a/bt5/erp5_budget/DocumentTemplateItem/portal_components/document.erp5.NodeBudgetVariation.py +++ b/bt5/erp5_budget/DocumentTemplateItem/portal_components/document.erp5.NodeBudgetVariation.py @@ -33,7 +33,6 @@ from erp5.component.document.BudgetVariation import BudgetVariation from Products.ZSQLCatalog.SQLCatalog import Query, NegatedQuery, ComplexQuery - class NodeBudgetVariation(BudgetVariation): """ A budget variation for node @@ -282,7 +281,7 @@ class NodeBudgetVariation(BudgetVariation): found = False for node_url in category_list: if node_url != '%s/budget_special_node/none' % base_category: - __traceback_info__ = (node_url, ) + __traceback_info__ = (node_url, ) # pylint: disable=unused-variable if uid_based_axis: query_dict.setdefault(axis, []).append( portal_categories.getCategoryValue(node_url, diff --git a/bt5/erp5_budget/DocumentTemplateItem/portal_components/document.erp5.NodeBudgetVariation.xml b/bt5/erp5_budget/DocumentTemplateItem/portal_components/document.erp5.NodeBudgetVariation.xml index d9b9be1b3839e2b4e1836918bf8743be7e5f9d14..582adbeb0385c6a179d2beffa9816c2ce14300fb 100644 --- a/bt5/erp5_budget/DocumentTemplateItem/portal_components/document.erp5.NodeBudgetVariation.xml +++ b/bt5/erp5_budget/DocumentTemplateItem/portal_components/document.erp5.NodeBudgetVariation.xml @@ -6,6 +6,12 @@ </pickle> <pickle> <dictionary> + <item> + <key> <string>_recorded_property_dict</string> </key> + <value> + <persistent> <string encoding="base64">AAAAAAAAAAI=</string> </persistent> + </value> + </item> <item> <key> <string>default_reference</string> </key> <value> <string>NodeBudgetVariation</string> </value> @@ -14,6 +20,12 @@ <key> <string>default_source_reference</string> </key> <value> <string>Products.ERP5.Document.NodeBudgetVariation</string> </value> </item> + <item> + <key> <string>description</string> </key> + <value> + <none/> + </value> + </item> <item> <key> <string>id</string> </key> <value> <string>document.erp5.NodeBudgetVariation</string> </value> @@ -37,10 +49,7 @@ <item> <key> <string>text_content_warning_message</string> </key> <value> - <tuple> - <string>W:133, 6: Unused variable \'consumption_dict\' (unused-variable)</string> - <string>W:284, 8: Unused variable \'__traceback_info__\' (unused-variable)</string> - </tuple> + <tuple/> </value> </item> <item> @@ -50,13 +59,28 @@ <item> <key> <string>workflow_history</string> </key> <value> - <persistent> <string encoding="base64">AAAAAAAAAAI=</string> </persistent> + <persistent> <string encoding="base64">AAAAAAAAAAM=</string> </persistent> </value> </item> </dictionary> </pickle> </record> <record id="2" aka="AAAAAAAAAAI="> + <pickle> + <global name="PersistentMapping" module="Persistence.mapping"/> + </pickle> + <pickle> + <dictionary> + <item> + <key> <string>data</string> </key> + <value> + <dictionary/> + </value> + </item> + </dictionary> + </pickle> + </record> + <record id="3" aka="AAAAAAAAAAM="> <pickle> <global name="PersistentMapping" module="Persistence.mapping"/> </pickle> @@ -69,7 +93,7 @@ <item> <key> <string>component_validation_workflow</string> </key> <value> - <persistent> <string encoding="base64">AAAAAAAAAAM=</string> </persistent> + <persistent> <string encoding="base64">AAAAAAAAAAQ=</string> </persistent> </value> </item> </dictionary> @@ -78,7 +102,7 @@ </dictionary> </pickle> </record> - <record id="3" aka="AAAAAAAAAAM="> + <record id="4" aka="AAAAAAAAAAQ="> <pickle> <global name="WorkflowHistoryList" module="Products.ERP5Type.patches.WorkflowTool"/> </pickle> diff --git a/bt5/erp5_budget/DocumentTemplateItem/portal_components/document.erp5.TransactionQuantityValueFeasabilityConstraint.py b/bt5/erp5_budget/DocumentTemplateItem/portal_components/document.erp5.TransactionQuantityValueFeasabilityConstraint.py index d3b6fb8e8b2ef6e060fd7b1823e75d133f579995..d3560a00a561647558e9630566cd8e9f03c78ea5 100644 --- a/bt5/erp5_budget/DocumentTemplateItem/portal_components/document.erp5.TransactionQuantityValueFeasabilityConstraint.py +++ b/bt5/erp5_budget/DocumentTemplateItem/portal_components/document.erp5.TransactionQuantityValueFeasabilityConstraint.py @@ -27,54 +27,53 @@ ############################################################################## from Products.ERP5Type.mixin.constraint import ConstraintMixin -from Products.ERP5Type import PropertySheet class TransactionQuantityValueFeasabilityConstraint(ConstraintMixin): + """ + Check if the quantity of the transaction is possible + for the source and the destination + + This is only relevant for ZODB Property Sheets (filesystem Property + Sheets rely on Products.ERP5.Constraint.TransactionQuantityValueFeasability + instead). + """ + meta_type = 'ERP5 Transaction Quantity Value Feasability Constraint' + portal_type = 'Transaction Quantity Value Feasability Constraint' + + def _checkConsistency(self, obj, fixit=0, **_): """ Check if the quantity of the transaction is possible for the source and the destination - - This is only relevant for ZODB Property Sheets (filesystem Property - Sheets rely on Products.ERP5.Constraint.TransactionQuantityValueFeasability - instead). """ - meta_type = 'ERP5 Transaction Quantity Value Feasability Constraint' - portal_type = 'Transaction Quantity Value Feasability Constraint' - - def _checkConsistency(self, object, fixit=0): - """ - Check if the quantity of the transaction is possible - for the source and the destination - """ - errors = [] - source_cell = object.getSourceValue() - destination_cell = object.getDestinationValue() - # Check for source and destination - for node, sign, node_title in ((source_cell, 1, 'source'), - (destination_cell, -1, 'destination')): - # As the quantity can change a few lines letter, - # we need to get it each time. - object_quantity = object.getQuantity() - quantity = object_quantity * sign - if node is not None: - balance = node.getCurrentBalance() - is_transaction_ok = 1 - # Check if balance and quantity have the same sign - if ((balance < 0) and (quantity < 0)): - if balance > quantity: - is_transaction_ok = 0 - elif ((balance >= 0) and (quantity >= 0)): - if balance < quantity: - is_transaction_ok = 0 - # Raise error - if not is_transaction_ok: - if fixit != 0: - object.setQuantity(balance) - else: - error_message = 'The quantity "%s" of the transaction is not ' \ - 'compatible with budget "%s" defined on the ' \ - '%s "%s".' % \ - (object_quantity, balance, node_title, node) - # Add error - errors.append(self._generateError(object, error_message)) - return errors + errors = [] + source_cell = obj.getSourceValue() + destination_cell = obj.getDestinationValue() + # Check for source and destination + for node, sign, node_title in ((source_cell, 1, 'source'), + (destination_cell, -1, 'destination')): + # As the quantity can change a few lines letter, + # we need to get it each time. + object_quantity = obj.getQuantity() + quantity = object_quantity * sign + if node is not None: + balance = node.getCurrentBalance() + is_transaction_ok = 1 + # Check if balance and quantity have the same sign + if ((balance < 0) and (quantity < 0)): + if balance > quantity: + is_transaction_ok = 0 + elif ((balance >= 0) and (quantity >= 0)): + if balance < quantity: + is_transaction_ok = 0 + # Raise error + if not is_transaction_ok: + if fixit != 0: + obj.setQuantity(balance) + else: + error_message = 'The quantity "%s" of the transaction is not ' \ + 'compatible with budget "%s" defined on the ' \ + '%s "%s".' % \ + (object_quantity, balance, node_title, node) + # Add error + errors.append(self._generateError(obj, error_message)) + return errors diff --git a/bt5/erp5_budget/DocumentTemplateItem/portal_components/document.erp5.TransactionQuantityValueFeasabilityConstraint.xml b/bt5/erp5_budget/DocumentTemplateItem/portal_components/document.erp5.TransactionQuantityValueFeasabilityConstraint.xml index a55981edec55466427f29919653365b1c9a16c1c..70b29fea9948b61231aa9c971237888bedc9d341 100644 --- a/bt5/erp5_budget/DocumentTemplateItem/portal_components/document.erp5.TransactionQuantityValueFeasabilityConstraint.xml +++ b/bt5/erp5_budget/DocumentTemplateItem/portal_components/document.erp5.TransactionQuantityValueFeasabilityConstraint.xml @@ -6,6 +6,12 @@ </pickle> <pickle> <dictionary> + <item> + <key> <string>_recorded_property_dict</string> </key> + <value> + <persistent> <string encoding="base64">AAAAAAAAAAI=</string> </persistent> + </value> + </item> <item> <key> <string>default_reference</string> </key> <value> <string>TransactionQuantityValueFeasabilityConstraint</string> </value> @@ -14,6 +20,12 @@ <key> <string>default_source_reference</string> </key> <value> <string>Products.ERP5.Document.TransactionQuantityValueFeasabilityConstraint</string> </value> </item> + <item> + <key> <string>description</string> </key> + <value> + <none/> + </value> + </item> <item> <key> <string>id</string> </key> <value> <string>document.erp5.TransactionQuantityValueFeasabilityConstraint</string> </value> @@ -37,38 +49,7 @@ <item> <key> <string>text_content_warning_message</string> </key> <value> - <tuple> - <string>W: 33, 0: Bad indentation. Found 4 spaces, expected 2 (bad-indentation)</string> - <string>W: 41, 0: Bad indentation. Found 4 spaces, expected 2 (bad-indentation)</string> - <string>W: 42, 0: Bad indentation. Found 4 spaces, expected 2 (bad-indentation)</string> - <string>W: 44, 0: Bad indentation. Found 4 spaces, expected 2 (bad-indentation)</string> - <string>W: 45, 0: Bad indentation. Found 6 spaces, expected 4 (bad-indentation)</string> - <string>W: 49, 0: Bad indentation. Found 6 spaces, expected 4 (bad-indentation)</string> - <string>W: 50, 0: Bad indentation. Found 6 spaces, expected 4 (bad-indentation)</string> - <string>W: 51, 0: Bad indentation. Found 6 spaces, expected 4 (bad-indentation)</string> - <string>W: 53, 0: Bad indentation. Found 6 spaces, expected 4 (bad-indentation)</string> - <string>W: 57, 0: Bad indentation. Found 8 spaces, expected 6 (bad-indentation)</string> - <string>W: 58, 0: Bad indentation. Found 8 spaces, expected 6 (bad-indentation)</string> - <string>W: 59, 0: Bad indentation. Found 8 spaces, expected 6 (bad-indentation)</string> - <string>W: 60, 0: Bad indentation. Found 10 spaces, expected 8 (bad-indentation)</string> - <string>W: 61, 0: Bad indentation. Found 10 spaces, expected 8 (bad-indentation)</string> - <string>W: 63, 0: Bad indentation. Found 10 spaces, expected 8 (bad-indentation)</string> - <string>W: 64, 0: Bad indentation. Found 12 spaces, expected 10 (bad-indentation)</string> - <string>W: 65, 0: Bad indentation. Found 14 spaces, expected 12 (bad-indentation)</string> - <string>W: 66, 0: Bad indentation. Found 10 spaces, expected 8 (bad-indentation)</string> - <string>W: 67, 0: Bad indentation. Found 12 spaces, expected 10 (bad-indentation)</string> - <string>W: 68, 0: Bad indentation. Found 14 spaces, expected 12 (bad-indentation)</string> - <string>W: 70, 0: Bad indentation. Found 10 spaces, expected 8 (bad-indentation)</string> - <string>W: 71, 0: Bad indentation. Found 12 spaces, expected 10 (bad-indentation)</string> - <string>W: 72, 0: Bad indentation. Found 14 spaces, expected 12 (bad-indentation)</string> - <string>W: 73, 0: Bad indentation. Found 12 spaces, expected 10 (bad-indentation)</string> - <string>W: 74, 0: Bad indentation. Found 14 spaces, expected 12 (bad-indentation)</string> - <string>W: 79, 0: Bad indentation. Found 14 spaces, expected 12 (bad-indentation)</string> - <string>W: 80, 0: Bad indentation. Found 6 spaces, expected 4 (bad-indentation)</string> - <string>W: 44, 32: Redefining built-in \'object\' (redefined-builtin)</string> - <string>W: 44, 4: Arguments number differs from overridden \'_checkConsistency\' method (arguments-differ)</string> - <string>W: 30, 0: Unused PropertySheet imported from Products.ERP5Type (unused-import)</string> - </tuple> + <tuple/> </value> </item> <item> @@ -78,13 +59,28 @@ <item> <key> <string>workflow_history</string> </key> <value> - <persistent> <string encoding="base64">AAAAAAAAAAI=</string> </persistent> + <persistent> <string encoding="base64">AAAAAAAAAAM=</string> </persistent> </value> </item> </dictionary> </pickle> </record> <record id="2" aka="AAAAAAAAAAI="> + <pickle> + <global name="PersistentMapping" module="Persistence.mapping"/> + </pickle> + <pickle> + <dictionary> + <item> + <key> <string>data</string> </key> + <value> + <dictionary/> + </value> + </item> + </dictionary> + </pickle> + </record> + <record id="3" aka="AAAAAAAAAAM="> <pickle> <global name="PersistentMapping" module="Persistence.mapping"/> </pickle> @@ -97,7 +93,7 @@ <item> <key> <string>component_validation_workflow</string> </key> <value> - <persistent> <string encoding="base64">AAAAAAAAAAM=</string> </persistent> + <persistent> <string encoding="base64">AAAAAAAAAAQ=</string> </persistent> </value> </item> </dictionary> @@ -106,7 +102,7 @@ </dictionary> </pickle> </record> - <record id="3" aka="AAAAAAAAAAM="> + <record id="4" aka="AAAAAAAAAAQ="> <pickle> <global name="WorkflowHistoryList" module="Products.ERP5Type.patches.WorkflowTool"/> </pickle> diff --git a/bt5/erp5_budget/DocumentTemplateItem/portal_components/document.erp5.TransactionQuantityValueValidityConstraint.py b/bt5/erp5_budget/DocumentTemplateItem/portal_components/document.erp5.TransactionQuantityValueValidityConstraint.py index 6d04e76b558312b24047d93fc3fda972edc0d7d4..42e7cdca175dfdaf4d9af33ce24688b39a31e69a 100644 --- a/bt5/erp5_budget/DocumentTemplateItem/portal_components/document.erp5.TransactionQuantityValueValidityConstraint.py +++ b/bt5/erp5_budget/DocumentTemplateItem/portal_components/document.erp5.TransactionQuantityValueValidityConstraint.py @@ -27,46 +27,44 @@ ############################################################################## from Products.ERP5Type.mixin.constraint import ConstraintMixin -from Products.ERP5Type import PropertySheet class TransactionQuantityValueValidityConstraint(ConstraintMixin): + """ + This is only relevant for ZODB Property Sheets (filesystem Property + Sheets rely on Products.ERP5.Constraint.TransactionQuantityValueValidity + instead). + """ + meta_type = 'ERP5 Transaction Quantity Value Validity Constraint' + portal_type = 'Transaction Quantity Value Validity Constraint' + + def _checkConsistency(self, obj, fixit=0, **_): """ - This is only relevant for ZODB Property Sheets (filesystem Property - Sheets rely on Products.ERP5.Constraint.TransactionQuantityValueValidity - instead). + Check if the quantity of the transaction is greater than the + balance of the source. """ - meta_type = 'ERP5 Transaction Quantity Value Validity Constraint' - portal_type = 'Transaction Quantity Value Validity Constraint' - - def _checkConsistency(self, object, fixit=0): - """ - Check if the quantity of the transaction is greater than the - balance of the source. - """ - errors = [] + errors = [] - source_cell = object.getSourceValue() - destination_cell = object.getDestinationValue() + source_cell = obj.getSourceValue() + destination_cell = obj.getDestinationValue() - if (source_cell is not None) and \ - (destination_cell is not None): - # XXX Dirty code ! - quantity = object.getQuantity() - budget_list = object.getPortalObject().budget_module.objectValues() - max_quantity = 0 - for obj in budget_list: - for item in obj.objectValues(): - if (item.getPortalType() == 'Budget Transfer Line') and \ - (item.getSourceValue() == source_cell) and \ - (item.getDestinationValue() == destination_cell): - max_quantity = item.getQuantity() - if quantity > max_quantity: - if fixit != 0: - self.setQuantity(max_quantity) - else: - error_message = 'The quantity of the transaction is greater than ' \ - 'the transferable maximum quantity (TMQ): ' \ + if source_cell is not None and destination_cell is not None: + # XXX Dirty code ! + quantity = obj.getQuantity() + budget_list = obj.getPortalObject().budget_module.objectValues() + max_quantity = 0 + for obj in budget_list: + for item in obj.objectValues(): + if item.getPortalType() == 'Budget Transfer Line' and \ + item.getSourceValue() == source_cell and \ + item.getDestinationValue() == destination_cell: + max_quantity = item.getQuantity() + if quantity > max_quantity: + if fixit != 0: + self.setQuantity(max_quantity) + else: + error_message = 'The quantity of the transaction is greater than ' \ + 'the transferable maximum quantity (TMQ): ' \ 'TMQ = %.2f' % max_quantity - # Add error - errors.append(self._generateError(object, error_message)) - return errors + # Add error + errors.append(self._generateError(obj, error_message)) + return errors \ No newline at end of file diff --git a/bt5/erp5_budget/DocumentTemplateItem/portal_components/document.erp5.TransactionQuantityValueValidityConstraint.xml b/bt5/erp5_budget/DocumentTemplateItem/portal_components/document.erp5.TransactionQuantityValueValidityConstraint.xml index e6570b720f1f666f62f593a95d014a7352e549fd..6112653b00b4765e330a78764814687649d8c1ce 100644 --- a/bt5/erp5_budget/DocumentTemplateItem/portal_components/document.erp5.TransactionQuantityValueValidityConstraint.xml +++ b/bt5/erp5_budget/DocumentTemplateItem/portal_components/document.erp5.TransactionQuantityValueValidityConstraint.xml @@ -6,6 +6,12 @@ </pickle> <pickle> <dictionary> + <item> + <key> <string>_recorded_property_dict</string> </key> + <value> + <persistent> <string encoding="base64">AAAAAAAAAAI=</string> </persistent> + </value> + </item> <item> <key> <string>default_reference</string> </key> <value> <string>TransactionQuantityValueValidityConstraint</string> </value> @@ -14,6 +20,12 @@ <key> <string>default_source_reference</string> </key> <value> <string>Products.ERP5.Document.TransactionQuantityValueValidityConstraint</string> </value> </item> + <item> + <key> <string>description</string> </key> + <value> + <none/> + </value> + </item> <item> <key> <string>id</string> </key> <value> <string>document.erp5.TransactionQuantityValueValidityConstraint</string> </value> @@ -37,34 +49,7 @@ <item> <key> <string>text_content_warning_message</string> </key> <value> - <tuple> - <string>W: 33, 0: Bad indentation. Found 4 spaces, expected 2 (bad-indentation)</string> - <string>W: 38, 0: Bad indentation. Found 4 spaces, expected 2 (bad-indentation)</string> - <string>W: 39, 0: Bad indentation. Found 4 spaces, expected 2 (bad-indentation)</string> - <string>W: 41, 0: Bad indentation. Found 4 spaces, expected 2 (bad-indentation)</string> - <string>W: 42, 0: Bad indentation. Found 6 spaces, expected 4 (bad-indentation)</string> - <string>W: 46, 0: Bad indentation. Found 6 spaces, expected 4 (bad-indentation)</string> - <string>W: 48, 0: Bad indentation. Found 6 spaces, expected 4 (bad-indentation)</string> - <string>W: 49, 0: Bad indentation. Found 6 spaces, expected 4 (bad-indentation)</string> - <string>W: 51, 0: Bad indentation. Found 6 spaces, expected 4 (bad-indentation)</string> - <string>W: 54, 0: Bad indentation. Found 8 spaces, expected 6 (bad-indentation)</string> - <string>W: 55, 0: Bad indentation. Found 8 spaces, expected 6 (bad-indentation)</string> - <string>W: 56, 0: Bad indentation. Found 8 spaces, expected 6 (bad-indentation)</string> - <string>W: 57, 0: Bad indentation. Found 8 spaces, expected 6 (bad-indentation)</string> - <string>W: 58, 0: Bad indentation. Found 10 spaces, expected 8 (bad-indentation)</string> - <string>W: 59, 0: Bad indentation. Found 13 spaces, expected 10 (bad-indentation)</string> - <string>W: 62, 0: Bad indentation. Found 15 spaces, expected 12 (bad-indentation)</string> - <string>W: 63, 0: Bad indentation. Found 8 spaces, expected 6 (bad-indentation)</string> - <string>W: 64, 0: Bad indentation. Found 10 spaces, expected 8 (bad-indentation)</string> - <string>W: 65, 0: Bad indentation. Found 12 spaces, expected 10 (bad-indentation)</string> - <string>W: 66, 0: Bad indentation. Found 10 spaces, expected 8 (bad-indentation)</string> - <string>W: 67, 0: Bad indentation. Found 12 spaces, expected 10 (bad-indentation)</string> - <string>W: 71, 0: Bad indentation. Found 12 spaces, expected 10 (bad-indentation)</string> - <string>W: 72, 0: Bad indentation. Found 6 spaces, expected 4 (bad-indentation)</string> - <string>W: 41, 32: Redefining built-in \'object\' (redefined-builtin)</string> - <string>W: 41, 4: Arguments number differs from overridden \'_checkConsistency\' method (arguments-differ)</string> - <string>W: 30, 0: Unused PropertySheet imported from Products.ERP5Type (unused-import)</string> - </tuple> + <tuple/> </value> </item> <item> @@ -74,13 +59,28 @@ <item> <key> <string>workflow_history</string> </key> <value> - <persistent> <string encoding="base64">AAAAAAAAAAI=</string> </persistent> + <persistent> <string encoding="base64">AAAAAAAAAAM=</string> </persistent> </value> </item> </dictionary> </pickle> </record> <record id="2" aka="AAAAAAAAAAI="> + <pickle> + <global name="PersistentMapping" module="Persistence.mapping"/> + </pickle> + <pickle> + <dictionary> + <item> + <key> <string>data</string> </key> + <value> + <dictionary/> + </value> + </item> + </dictionary> + </pickle> + </record> + <record id="3" aka="AAAAAAAAAAM="> <pickle> <global name="PersistentMapping" module="Persistence.mapping"/> </pickle> @@ -93,7 +93,7 @@ <item> <key> <string>component_validation_workflow</string> </key> <value> - <persistent> <string encoding="base64">AAAAAAAAAAM=</string> </persistent> + <persistent> <string encoding="base64">AAAAAAAAAAQ=</string> </persistent> </value> </item> </dictionary> @@ -102,7 +102,7 @@ </dictionary> </pickle> </record> - <record id="3" aka="AAAAAAAAAAM="> + <record id="4" aka="AAAAAAAAAAQ="> <pickle> <global name="WorkflowHistoryList" module="Products.ERP5Type.patches.WorkflowTool"/> </pickle> diff --git a/bt5/erp5_budget/TestTemplateItem/portal_components/test.erp5.testBudget.py b/bt5/erp5_budget/TestTemplateItem/portal_components/test.erp5.testBudget.py index 9fc49097559cadf90cdfe92503e6f1ecfbf7ff77..df99a0448557d28ed134350bd340f38a5f1cfccb 100644 --- a/bt5/erp5_budget/TestTemplateItem/portal_components/test.erp5.testBudget.py +++ b/bt5/erp5_budget/TestTemplateItem/portal_components/test.erp5.testBudget.py @@ -85,7 +85,7 @@ class TestBudget(ERP5TypeTestCase): budget = self.portal.budget_module.newContent( portal_type='Budget') budget_line = budget.newContent(portal_type='Budget Line') - budget_cell = budget_line.newContent(portal_type='Budget Cell') + budget_line.newContent(portal_type='Budget Cell') self.assertEqual([], budget.checkConsistency()) def test_budget_cell_node_variation_with_aggregate(self): @@ -626,17 +626,18 @@ class TestBudget(ERP5TypeTestCase): self.assertEqual(2, len(budget_line.contentValues())) + test_class_self = self class ReferenceQuery: """Helper class to compare queries """ - def __eq__(me, query): - self.assertTrue(isinstance(query, ComplexQuery)) - self.assertEqual(query.logical_operator, 'or') - self.assertEqual(2, len(query.query_list)) - self.assertEqual(query.query_list[0].kw, {'project_uid': None}) - self.assertEqual(query.query_list[1].kw, + def __eq__(self, query): + test_class_self.assertTrue(isinstance(query, ComplexQuery)) + test_class_self.assertEqual(query.logical_operator, 'or') + test_class_self.assertEqual(2, len(query.query_list)) + test_class_self.assertEqual(query.query_list[0].kw, {'project_uid': None}) + test_class_self.assertEqual(query.query_list[1].kw, {'project_uid': - [self.portal.organisation_module.my_organisation.getUid()]}) + [test_class_self.portal.organisation_module.my_organisation.getUid()]}) return True self.assertEqual( @@ -730,12 +731,13 @@ class TestBudget(ERP5TypeTestCase): self.assertEqual(1, len(budget_line.contentValues())) + test_class_self = self class ReferenceQuery: """Helper class to compare queries """ - def __eq__(me, query): - self.assertTrue(isinstance(query, Query)) - self.assertEqual(query.kw, {'project_uid': None}) + def __eq__(self, query): + test_class_self.assertTrue(isinstance(query, Query)) + test_class_self.assertEqual(query.kw, {'project_uid': None}) return True self.assertEqual(