Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
E
erp5_workflow
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
wenjie.zheng
erp5_workflow
Commits
355c22dd
Commit
355c22dd
authored
Nov 03, 2011
by
Vincent Pelletier
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Whitespace cleanup.
parent
31f68200
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
31 additions
and
31 deletions
+31
-31
product/ERP5/Tool/SimulationTool.py
product/ERP5/Tool/SimulationTool.py
+31
-31
No files found.
product/ERP5/Tool/SimulationTool.py
View file @
355c22dd
...
@@ -216,7 +216,7 @@ class SimulationTool(BaseTool):
...
@@ -216,7 +216,7 @@ class SimulationTool(BaseTool):
def
_getSimulationStateQuery
(
self
,
**
kw
):
def
_getSimulationStateQuery
(
self
,
**
kw
):
simulation_state_dict
=
self
.
_getSimulationStateDict
(
**
kw
)
simulation_state_dict
=
self
.
_getSimulationStateDict
(
**
kw
)
return
self
.
_buildSimulationStateQuery
(
simulation_state_dict
=
simulation_state_dict
)
return
self
.
_buildSimulationStateQuery
(
simulation_state_dict
=
simulation_state_dict
)
def
_buildSimulationStateQuery
(
self
,
simulation_state_dict
,
table
=
'stock'
):
def
_buildSimulationStateQuery
(
self
,
simulation_state_dict
,
table
=
'stock'
):
input_simulation_state
=
simulation_state_dict
.
get
(
input_simulation_state
=
simulation_state_dict
.
get
(
'input_simulation_state'
)
'input_simulation_state'
)
...
@@ -358,7 +358,7 @@ class SimulationTool(BaseTool):
...
@@ -358,7 +358,7 @@ class SimulationTool(BaseTool):
omit_asset_increase
=
omit_asset_increase
,
omit_asset_increase
=
omit_asset_increase
,
omit_asset_decrease
=
omit_asset_decrease
)
omit_asset_decrease
=
omit_asset_decrease
)
return
self
.
_buildOmitQuery
(
query_table
=
query_table
,
omit_dict
=
omit_dict
)
return
self
.
_buildOmitQuery
(
query_table
=
query_table
,
omit_dict
=
omit_dict
)
def
_buildOmitQuery
(
self
,
query_table
,
omit_dict
):
def
_buildOmitQuery
(
self
,
query_table
,
omit_dict
):
"""
"""
Build a specific query in order to take:
Build a specific query in order to take:
...
@@ -482,7 +482,7 @@ class SimulationTool(BaseTool):
...
@@ -482,7 +482,7 @@ class SimulationTool(BaseTool):
related_key_group_by
=
new_kw
.
pop
(
'related_key_group_by'
,
[])
related_key_group_by
=
new_kw
.
pop
(
'related_key_group_by'
,
[])
if
related_key_group_by
:
if
related_key_group_by
:
group_by
.
extend
([
'%s_%s'
%
(
table
,
x
)
for
x
in
related_key_group_by
])
group_by
.
extend
([
'%s_%s'
%
(
table
,
x
)
for
x
in
related_key_group_by
])
# group by involving a related key (eg. group_by=['product_line_uid'])
# group by involving a related key (eg. group_by=['product_line_uid'])
related_key_dict_passthrough_group_by
=
new_kw
.
get
(
related_key_dict_passthrough_group_by
=
new_kw
.
get
(
'related_key_dict_passthrough'
,
dict
()).
pop
(
'group_by'
,
[])
'related_key_dict_passthrough'
,
dict
()).
pop
(
'group_by'
,
[])
...
@@ -556,7 +556,7 @@ class SimulationTool(BaseTool):
...
@@ -556,7 +556,7 @@ class SimulationTool(BaseTool):
column_id
=
'%s.%s'
%
(
table
,
column_id
)
column_id
=
'%s.%s'
%
(
table
,
column_id
)
new_sort_on
.
append
((
column_id
,
sort_direction
))
new_sort_on
.
append
((
column_id
,
sort_direction
))
new_kw
[
'sort_on'
]
=
tuple
(
new_sort_on
)
new_kw
[
'sort_on'
]
=
tuple
(
new_sort_on
)
# Remove some internal parameters that does not have any meaning for
# Remove some internal parameters that does not have any meaning for
# catalog
# catalog
new_kw
.
pop
(
'ignore_group_by'
,
None
)
new_kw
.
pop
(
'ignore_group_by'
,
None
)
...
@@ -753,16 +753,16 @@ class SimulationTool(BaseTool):
...
@@ -753,16 +753,16 @@ class SimulationTool(BaseTool):
related_key_dict
.
setUIDList
(
related_key_dict
.
setUIDList
(
'mirror_section_category_strict_membership_uid'
,
'mirror_section_category_strict_membership_uid'
,
mirror_section_category_strict_membership
)
mirror_section_category_strict_membership
)
new_kw
[
'related_key_dict'
]
=
related_key_dict
.
copy
()
new_kw
[
'related_key_dict'
]
=
related_key_dict
.
copy
()
new_kw
[
'related_key_dict_passthrough'
]
=
kw
new_kw
[
'related_key_dict_passthrough'
]
=
kw
#variation_category_uid_list = self._generatePropertyUidList(variation_category)
#variation_category_uid_list = self._generatePropertyUidList(variation_category)
#if len(variation_category_uid_list) :
#if len(variation_category_uid_list) :
# new_kw['variationCategory'] = variation_category_uid_list
# new_kw['variationCategory'] = variation_category_uid_list
simulation_dict
=
self
.
_getSimulationStateDict
(
simulation_dict
=
self
.
_getSimulationStateDict
(
simulation_state
=
simulation_state
,
simulation_state
=
simulation_state
,
omit_transit
=
omit_transit
,
omit_transit
=
omit_transit
,
input_simulation_state
=
input_simulation_state
,
input_simulation_state
=
input_simulation_state
,
output_simulation_state
=
output_simulation_state
,
output_simulation_state
=
output_simulation_state
,
...
@@ -776,7 +776,7 @@ class SimulationTool(BaseTool):
...
@@ -776,7 +776,7 @@ class SimulationTool(BaseTool):
new_kw
[
'omit_dict'
]
=
omit_dict
new_kw
[
'omit_dict'
]
=
omit_dict
if
reserved_kw
is
not
None
:
if
reserved_kw
is
not
None
:
if
not
isinstance
(
reserved_kw
,
dict
):
if
not
isinstance
(
reserved_kw
,
dict
):
# Not a dict when taken from URL, so, cast is needed
# Not a dict when taken from URL, so, cast is needed
# to make pop method available
# to make pop method available
reserved_kw
=
dict
(
reserved_kw
)
reserved_kw
=
dict
(
reserved_kw
)
new_reserved_kw
=
{}
new_reserved_kw
=
{}
...
@@ -968,7 +968,7 @@ class SimulationTool(BaseTool):
...
@@ -968,7 +968,7 @@ class SimulationTool(BaseTool):
section_category - only take rows in stock table which section_uid is
section_category - only take rows in stock table which section_uid is
member of section_category
member of section_category
mirror_section_category - only take rows in stock table which
mirror_section_category - only take rows in stock table which
mirror_section_uid is member of
mirror_section_uid is member of
mirror_section_category
mirror_section_category
...
@@ -1124,8 +1124,8 @@ class SimulationTool(BaseTool):
...
@@ -1124,8 +1124,8 @@ class SimulationTool(BaseTool):
Returns future inventory
Returns future inventory
"""
"""
return
self
.
getInventory
(
simulation_period
=
'Future'
,
**
kw
)
return
self
.
getInventory
(
simulation_period
=
'Future'
,
**
kw
)
def
_getDefaultGroupByParameters
(
self
,
ignore_group_by
=
0
,
def
_getDefaultGroupByParameters
(
self
,
ignore_group_by
=
0
,
group_by_node
=
0
,
group_by_mirror_node
=
0
,
group_by_node
=
0
,
group_by_mirror_node
=
0
,
group_by_section
=
0
,
group_by_mirror_section
=
0
,
group_by_section
=
0
,
group_by_mirror_section
=
0
,
group_by_payment
=
0
,
group_by_project
=
0
,
group_by_funding
=
0
,
group_by_payment
=
0
,
group_by_project
=
0
,
group_by_funding
=
0
,
...
@@ -1180,11 +1180,11 @@ class SimulationTool(BaseTool):
...
@@ -1180,11 +1180,11 @@ class SimulationTool(BaseTool):
'getInventoryList'
)
'getInventoryList'
)
def
getInventoryList
(
self
,
src__
=
0
,
optimisation__
=
True
,
def
getInventoryList
(
self
,
src__
=
0
,
optimisation__
=
True
,
ignore_variation
=
0
,
standardise
=
0
,
ignore_variation
=
0
,
standardise
=
0
,
omit_simulation
=
0
,
omit_simulation
=
0
,
only_accountable
=
True
,
only_accountable
=
True
,
default_stock_table
=
'stock'
,
default_stock_table
=
'stock'
,
selection_domain
=
None
,
selection_report
=
None
,
selection_domain
=
None
,
selection_report
=
None
,
statistic
=
0
,
inventory_list
=
1
,
statistic
=
0
,
inventory_list
=
1
,
precision
=
None
,
connection_id
=
None
,
precision
=
None
,
connection_id
=
None
,
**
kw
):
**
kw
):
"""
"""
...
@@ -1219,7 +1219,7 @@ class SimulationTool(BaseTool):
...
@@ -1219,7 +1219,7 @@ class SimulationTool(BaseTool):
- Querying multiple nodes/categories/payments in one call prevents
- Querying multiple nodes/categories/payments in one call prevents
from using optimisation, it should be equivalent to multiple calls
from using optimisation, it should be equivalent to multiple calls
on individual nodes/categories/payments.
on individual nodes/categories/payments.
-
-
"""
"""
getCategory
=
self
.
getPortalObject
().
portal_categories
.
getCategoryUid
getCategory
=
self
.
getPortalObject
().
portal_categories
.
getCategoryUid
...
@@ -1624,7 +1624,7 @@ class SimulationTool(BaseTool):
...
@@ -1624,7 +1624,7 @@ class SimulationTool(BaseTool):
security
.
declareProtected
(
Permissions
.
AccessContentsInformation
,
security
.
declareProtected
(
Permissions
.
AccessContentsInformation
,
'getCurrentInventoryList'
)
'getCurrentInventoryList'
)
def
getCurrentInventoryList
(
self
,
omit_transit
=
1
,
def
getCurrentInventoryList
(
self
,
omit_transit
=
1
,
transit_simulation_state
=
None
,
**
kw
):
transit_simulation_state
=
None
,
**
kw
):
"""
"""
Returns list of current inventory grouped by section or site
Returns list of current inventory grouped by section or site
...
@@ -1679,7 +1679,7 @@ class SimulationTool(BaseTool):
...
@@ -1679,7 +1679,7 @@ class SimulationTool(BaseTool):
"""
"""
kw
[
'group_by_variation'
]
=
0
kw
[
'group_by_variation'
]
=
0
method
=
getattr
(
self
,
'get%sInventoryList'
%
simulation_period
)
method
=
getattr
(
self
,
'get%sInventoryList'
%
simulation_period
)
return
method
(
statistic
=
1
,
inventory_list
=
0
,
return
method
(
statistic
=
1
,
inventory_list
=
0
,
ignore_group_by
=
1
,
**
kw
)
ignore_group_by
=
1
,
**
kw
)
security
.
declareProtected
(
Permissions
.
AccessContentsInformation
,
security
.
declareProtected
(
Permissions
.
AccessContentsInformation
,
...
@@ -1746,7 +1746,7 @@ class SimulationTool(BaseTool):
...
@@ -1746,7 +1746,7 @@ class SimulationTool(BaseTool):
security
.
declareProtected
(
Permissions
.
AccessContentsInformation
,
security
.
declareProtected
(
Permissions
.
AccessContentsInformation
,
'getInventoryAssetPrice'
)
'getInventoryAssetPrice'
)
def
getInventoryAssetPrice
(
self
,
src__
=
0
,
def
getInventoryAssetPrice
(
self
,
src__
=
0
,
simulation_period
=
''
,
simulation_period
=
''
,
valuation_method
=
None
,
valuation_method
=
None
,
**
kw
):
**
kw
):
...
@@ -1942,7 +1942,7 @@ class SimulationTool(BaseTool):
...
@@ -1942,7 +1942,7 @@ class SimulationTool(BaseTool):
selection_domain
=
selection_domain
,
selection_report
=
selection_report
,
selection_domain
=
selection_domain
,
selection_report
=
selection_report
,
precision
=
precision
,
**
sql_kw
)
precision
=
precision
,
**
sql_kw
)
security
.
declareProtected
(
Permissions
.
AccessContentsInformation
,
security
.
declareProtected
(
Permissions
.
AccessContentsInformation
,
'getNextNegativeInventoryDate'
)
'getNextNegativeInventoryDate'
)
def
getNextNegativeInventoryDate
(
self
,
src__
=
0
,
**
kw
):
def
getNextNegativeInventoryDate
(
self
,
src__
=
0
,
**
kw
):
"""
"""
...
@@ -2055,7 +2055,7 @@ class SimulationTool(BaseTool):
...
@@ -2055,7 +2055,7 @@ class SimulationTool(BaseTool):
if
isinstance
(
value
,
DateTime
):
if
isinstance
(
value
,
DateTime
):
value
=
value
.
toZone
(
'UTC'
).
ISO
()
value
=
value
.
toZone
(
'UTC'
).
ISO
()
value
=
'%s'
%
(
value
,
)
value
=
'%s'
%
(
value
,
)
# Do not remove dates in new_kw, they are required in
# Do not remove dates in new_kw, they are required in
# order to do a "select item left join item on date"
# order to do a "select item left join item on date"
new_kw
[
key
]
=
value
new_kw
[
key
]
=
value
...
@@ -2084,7 +2084,7 @@ class SimulationTool(BaseTool):
...
@@ -2084,7 +2084,7 @@ class SimulationTool(BaseTool):
"""
"""
kw
[
'item.simulation_state'
]
=
self
.
getPortalCurrentInventoryStateList
()
kw
[
'item.simulation_state'
]
=
self
.
getPortalCurrentInventoryStateList
()
return
self
.
getTrackingList
(
**
kw
)
return
self
.
getTrackingList
(
**
kw
)
security
.
declareProtected
(
Permissions
.
AccessContentsInformation
,
'getCurrentTrackingHistoryList'
)
security
.
declareProtected
(
Permissions
.
AccessContentsInformation
,
'getCurrentTrackingHistoryList'
)
def
getCurrentTrackingHistoryList
(
self
,
**
kw
):
def
getCurrentTrackingHistoryList
(
self
,
**
kw
):
"""
"""
...
@@ -2092,7 +2092,7 @@ class SimulationTool(BaseTool):
...
@@ -2092,7 +2092,7 @@ class SimulationTool(BaseTool):
"""
"""
kw
[
'item.simulation_state'
]
=
self
.
getPortalCurrentInventoryStateList
()
kw
[
'item.simulation_state'
]
=
self
.
getPortalCurrentInventoryStateList
()
return
self
.
getTrackingHistoryList
(
**
kw
)
return
self
.
getTrackingHistoryList
(
**
kw
)
security
.
declareProtected
(
Permissions
.
AccessContentsInformation
,
'getTrackingHistoryList'
)
security
.
declareProtected
(
Permissions
.
AccessContentsInformation
,
'getTrackingHistoryList'
)
def
getTrackingHistoryList
(
self
,
**
kw
):
def
getTrackingHistoryList
(
self
,
**
kw
):
"""
"""
...
@@ -2761,7 +2761,7 @@ class SimulationTool(BaseTool):
...
@@ -2761,7 +2761,7 @@ class SimulationTool(BaseTool):
#######################################################
#######################################################
# Sequence
# Sequence
security
.
declareProtected
(
Permissions
.
AccessContentsInformation
,
security
.
declareProtected
(
Permissions
.
AccessContentsInformation
,
'getSequence'
)
'getSequence'
)
def
getSequence
(
self
,
**
kw
):
def
getSequence
(
self
,
**
kw
):
"""
"""
...
@@ -2772,10 +2772,10 @@ class SimulationTool(BaseTool):
...
@@ -2772,10 +2772,10 @@ class SimulationTool(BaseTool):
#######################################################
#######################################################
# Time Management
# Time Management
security
.
declareProtected
(
Permissions
.
AccessContentsInformation
,
security
.
declareProtected
(
Permissions
.
AccessContentsInformation
,
'getAvailableTime'
)
'getAvailableTime'
)
def
getAvailableTime
(
self
,
from_date
=
None
,
to_date
=
None
,
def
getAvailableTime
(
self
,
from_date
=
None
,
to_date
=
None
,
portal_type
=
[],
node
=
[],
portal_type
=
[],
node
=
[],
resource
=
[],
src__
=
0
,
**
kw
):
resource
=
[],
src__
=
0
,
**
kw
):
"""
"""
Calculate available time for a node
Calculate available time for a node
...
@@ -2823,11 +2823,11 @@ class SimulationTool(BaseTool):
...
@@ -2823,11 +2823,11 @@ class SimulationTool(BaseTool):
result
=
sql_result
result
=
sql_result
return
result
return
result
security
.
declareProtected
(
Permissions
.
AccessContentsInformation
,
security
.
declareProtected
(
Permissions
.
AccessContentsInformation
,
'getAvailableTimeSequence'
)
'getAvailableTimeSequence'
)
def
getAvailableTimeSequence
(
self
,
from_date
,
to_date
,
def
getAvailableTimeSequence
(
self
,
from_date
,
to_date
,
portal_type
=
[],
node
=
[],
portal_type
=
[],
node
=
[],
resource
=
[],
resource
=
[],
src__
=
0
,
src__
=
0
,
**
kw
):
**
kw
):
"""
"""
...
@@ -2883,7 +2883,7 @@ class Sequence:
...
@@ -2883,7 +2883,7 @@ class Sequence:
Sequence is a iterable object, which calculate a range of time
Sequence is a iterable object, which calculate a range of time
period.
period.
"""
"""
def
__init__
(
self
,
from_date
,
to_date
,
def
__init__
(
self
,
from_date
,
to_date
,
second
=
None
,
minute
=
None
,
hour
=
None
,
second
=
None
,
minute
=
None
,
hour
=
None
,
day
=
None
,
month
=
None
,
year
=
None
):
day
=
None
,
month
=
None
,
year
=
None
):
"""
"""
...
@@ -2910,14 +2910,14 @@ class Sequence:
...
@@ -2910,14 +2910,14 @@ class Sequence:
# Calculate all time period
# Calculate all time period
current_from_date
=
from_date
current_from_date
=
from_date
while
current_from_date
<
to_date
:
while
current_from_date
<
to_date
:
current_to_date
=
addToDate
(
current_from_date
,
current_to_date
=
addToDate
(
current_from_date
,
second
=
second
,
second
=
second
,
minute
=
minute
,
minute
=
minute
,
hour
=
hour
,
hour
=
hour
,
day
=
day
,
day
=
day
,
month
=
month
,
month
=
month
,
year
=
year
)
year
=
year
)
self
.
item_list
.
append
(
SequenceItem
(
current_from_date
,
self
.
item_list
.
append
(
SequenceItem
(
current_from_date
,
current_to_date
))
current_to_date
))
current_from_date
=
current_to_date
current_from_date
=
current_to_date
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment