projects: milestones have events, tasks have events with better description
This commit is contained in:
parent
6252c13ec8
commit
df196c12a9
@ -90,3 +90,22 @@ class DocType:
|
|||||||
if getdate(self.doc.completion_date) < getdate(self.doc.project_start_date):
|
if getdate(self.doc.completion_date) < getdate(self.doc.project_start_date):
|
||||||
msgprint("Expected Completion Date can not be less than Project Start Date")
|
msgprint("Expected Completion Date can not be less than Project Start Date")
|
||||||
raise Exception
|
raise Exception
|
||||||
|
|
||||||
|
def on_update(self):
|
||||||
|
# update milestones
|
||||||
|
webnotes.conn.sql("""delete from tabEvent where ref_type='Project' and ref_name=%s""",
|
||||||
|
self.doc.name)
|
||||||
|
for d in self.doclist:
|
||||||
|
if d.doctype=='Project Milestone' and d.docstatus!=2:
|
||||||
|
self.add_calendar_event(d.milestone, d.milestone_date)
|
||||||
|
|
||||||
|
def add_calendar_event(self, milestone, date):
|
||||||
|
""" Add calendar event for task in calendar of Allocated person"""
|
||||||
|
event = Document('Event')
|
||||||
|
event.description = milestone + ' for ' + self.doc.name
|
||||||
|
event.event_date = date
|
||||||
|
event.event_hour = '10:00'
|
||||||
|
event.event_type = 'Public'
|
||||||
|
event.ref_type = 'Project'
|
||||||
|
event.ref_name = self.doc.name
|
||||||
|
event.save(1)
|
@ -3,9 +3,9 @@
|
|||||||
|
|
||||||
# These values are common in all dictionaries
|
# These values are common in all dictionaries
|
||||||
{
|
{
|
||||||
'creation': '2012-03-27 14:36:05',
|
'creation': '2012-05-03 18:41:42',
|
||||||
'docstatus': 0,
|
'docstatus': 0,
|
||||||
'modified': '2012-03-27 14:36:05',
|
'modified': '2012-08-07 15:48:47',
|
||||||
'modified_by': u'Administrator',
|
'modified_by': u'Administrator',
|
||||||
'owner': u'Administrator'
|
'owner': u'Administrator'
|
||||||
},
|
},
|
||||||
@ -29,7 +29,7 @@
|
|||||||
'show_in_menu': 0,
|
'show_in_menu': 0,
|
||||||
'subject': u' ',
|
'subject': u' ',
|
||||||
'tag_fields': u'status',
|
'tag_fields': u'status',
|
||||||
'version': 33
|
'version': 1
|
||||||
},
|
},
|
||||||
|
|
||||||
# These values are common for all DocField
|
# These values are common for all DocField
|
||||||
@ -43,12 +43,17 @@
|
|||||||
|
|
||||||
# These values are common for all DocPerm
|
# These values are common for all DocPerm
|
||||||
{
|
{
|
||||||
|
'cancel': 1,
|
||||||
|
'create': 1,
|
||||||
'doctype': u'DocPerm',
|
'doctype': u'DocPerm',
|
||||||
'name': '__common__',
|
'name': '__common__',
|
||||||
'parent': u'Project',
|
'parent': u'Project',
|
||||||
'parentfield': u'permissions',
|
'parentfield': u'permissions',
|
||||||
'parenttype': u'DocType',
|
'parenttype': u'DocType',
|
||||||
'read': 1
|
'permlevel': 0,
|
||||||
|
'read': 1,
|
||||||
|
'role': u'Projects User',
|
||||||
|
'write': 1
|
||||||
},
|
},
|
||||||
|
|
||||||
# DocType, Project
|
# DocType, Project
|
||||||
@ -59,33 +64,7 @@
|
|||||||
|
|
||||||
# DocPerm
|
# DocPerm
|
||||||
{
|
{
|
||||||
'amend': 0,
|
'doctype': u'DocPerm'
|
||||||
'cancel': 1,
|
|
||||||
'create': 1,
|
|
||||||
'doctype': u'DocPerm',
|
|
||||||
'permlevel': 0,
|
|
||||||
'role': u'All',
|
|
||||||
'submit': 0,
|
|
||||||
'write': 1
|
|
||||||
},
|
|
||||||
|
|
||||||
# DocPerm
|
|
||||||
{
|
|
||||||
'amend': 0,
|
|
||||||
'cancel': 1,
|
|
||||||
'create': 1,
|
|
||||||
'doctype': u'DocPerm',
|
|
||||||
'permlevel': 0,
|
|
||||||
'role': u'Projects User',
|
|
||||||
'submit': 0,
|
|
||||||
'write': 1
|
|
||||||
},
|
|
||||||
|
|
||||||
# DocPerm
|
|
||||||
{
|
|
||||||
'doctype': u'DocPerm',
|
|
||||||
'permlevel': 1,
|
|
||||||
'role': u'All'
|
|
||||||
},
|
},
|
||||||
|
|
||||||
# DocField
|
# DocField
|
||||||
@ -100,6 +79,15 @@
|
|||||||
'permlevel': 0
|
'permlevel': 0
|
||||||
},
|
},
|
||||||
|
|
||||||
|
# DocField
|
||||||
|
{
|
||||||
|
'doctype': u'DocField',
|
||||||
|
'fieldname': u'cb_project_status',
|
||||||
|
'fieldtype': u'Column Break',
|
||||||
|
'label': u'Status',
|
||||||
|
'permlevel': 0
|
||||||
|
},
|
||||||
|
|
||||||
# DocField
|
# DocField
|
||||||
{
|
{
|
||||||
'description': u'Project will get saved and will be searchable with project name given',
|
'description': u'Project will get saved and will be searchable with project name given',
|
||||||
@ -163,71 +151,10 @@
|
|||||||
# DocField
|
# DocField
|
||||||
{
|
{
|
||||||
'doctype': u'DocField',
|
'doctype': u'DocField',
|
||||||
'fieldname': u'project_value',
|
'fieldname': u'cb_project_dates',
|
||||||
'fieldtype': u'Currency',
|
'fieldtype': u'Column Break',
|
||||||
'label': u'Project Value',
|
'label': u'Dates',
|
||||||
'no_copy': 0,
|
'permlevel': 0
|
||||||
'oldfieldname': u'project_value',
|
|
||||||
'oldfieldtype': u'Currency',
|
|
||||||
'permlevel': 0,
|
|
||||||
'reqd': 1,
|
|
||||||
'search_index': 0,
|
|
||||||
'trigger': u'Client'
|
|
||||||
},
|
|
||||||
|
|
||||||
# DocField
|
|
||||||
{
|
|
||||||
'doctype': u'DocField',
|
|
||||||
'fieldname': u'gross_margin_value',
|
|
||||||
'fieldtype': u'Currency',
|
|
||||||
'label': u'Gross Margin Value',
|
|
||||||
'no_copy': 0,
|
|
||||||
'oldfieldname': u'gross_margin_value',
|
|
||||||
'oldfieldtype': u'Currency',
|
|
||||||
'permlevel': 0,
|
|
||||||
'reqd': 1,
|
|
||||||
'search_index': 0
|
|
||||||
},
|
|
||||||
|
|
||||||
# DocField
|
|
||||||
{
|
|
||||||
'doctype': u'DocField',
|
|
||||||
'fieldname': u'per_gross_margin',
|
|
||||||
'fieldtype': u'Currency',
|
|
||||||
'label': u'Gross Margin %',
|
|
||||||
'no_copy': 0,
|
|
||||||
'oldfieldname': u'per_gross_margin',
|
|
||||||
'oldfieldtype': u'Currency',
|
|
||||||
'permlevel': 0,
|
|
||||||
'reqd': 1,
|
|
||||||
'search_index': 0
|
|
||||||
},
|
|
||||||
|
|
||||||
# DocField
|
|
||||||
{
|
|
||||||
'doctype': u'DocField',
|
|
||||||
'fieldname': u'est_material_cost',
|
|
||||||
'fieldtype': u'Currency',
|
|
||||||
'label': u'Estimated Material Cost',
|
|
||||||
'no_copy': 0,
|
|
||||||
'oldfieldname': u'est_material_cost',
|
|
||||||
'oldfieldtype': u'Currency',
|
|
||||||
'permlevel': 0,
|
|
||||||
'search_index': 0,
|
|
||||||
'trigger': u'Client'
|
|
||||||
},
|
|
||||||
|
|
||||||
# DocField
|
|
||||||
{
|
|
||||||
'doctype': u'DocField',
|
|
||||||
'fieldname': u'project_type',
|
|
||||||
'fieldtype': u'Data',
|
|
||||||
'label': u'Project Type',
|
|
||||||
'no_copy': 0,
|
|
||||||
'oldfieldname': u'project_type',
|
|
||||||
'oldfieldtype': u'Data',
|
|
||||||
'permlevel': 0,
|
|
||||||
'search_index': 0
|
|
||||||
},
|
},
|
||||||
|
|
||||||
# DocField
|
# DocField
|
||||||
@ -273,51 +200,41 @@
|
|||||||
# DocField
|
# DocField
|
||||||
{
|
{
|
||||||
'doctype': u'DocField',
|
'doctype': u'DocField',
|
||||||
'fieldname': u'amended_from',
|
'fieldname': u'project_type',
|
||||||
'fieldtype': u'Data',
|
'fieldtype': u'Select',
|
||||||
'hidden': 1,
|
'label': u'Project Type',
|
||||||
'label': u'Amended From',
|
'no_copy': 0,
|
||||||
'no_copy': 1,
|
'oldfieldname': u'project_type',
|
||||||
'oldfieldname': u'amended_from',
|
|
||||||
'oldfieldtype': u'Data',
|
'oldfieldtype': u'Data',
|
||||||
'permlevel': 1,
|
'options': u'Internal\nExternal\nOther',
|
||||||
'print_hide': 0,
|
'permlevel': 0,
|
||||||
'search_index': 0
|
'search_index': 0
|
||||||
},
|
},
|
||||||
|
|
||||||
# DocField
|
# DocField
|
||||||
{
|
{
|
||||||
|
'colour': u'White:FFF',
|
||||||
|
'description': u'Important dates and commitments in your project life cycle',
|
||||||
'doctype': u'DocField',
|
'doctype': u'DocField',
|
||||||
'fieldname': u'amemdment_date',
|
'fieldname': u'sb_milestones',
|
||||||
'fieldtype': u'Date',
|
|
||||||
'hidden': 1,
|
|
||||||
'label': u'Amemdment Date',
|
|
||||||
'no_copy': 1,
|
|
||||||
'oldfieldname': u'amemdment_date',
|
|
||||||
'oldfieldtype': u'Date',
|
|
||||||
'permlevel': 1,
|
|
||||||
'search_index': 0
|
|
||||||
},
|
|
||||||
|
|
||||||
# DocField
|
|
||||||
{
|
|
||||||
'doctype': u'DocField',
|
|
||||||
'fieldname': u'project_details',
|
|
||||||
'fieldtype': u'Section Break',
|
'fieldtype': u'Section Break',
|
||||||
'label': u'Project Details',
|
'label': u'Milestones',
|
||||||
'oldfieldtype': u'Section Break',
|
'oldfieldtype': u'Section Break',
|
||||||
'options': u'Simple',
|
|
||||||
'permlevel': 0
|
'permlevel': 0
|
||||||
},
|
},
|
||||||
|
|
||||||
# DocField
|
# DocField
|
||||||
{
|
{
|
||||||
'doctype': u'DocField',
|
'doctype': u'DocField',
|
||||||
'fieldname': u'column_break0',
|
'fieldname': u'project_milestones',
|
||||||
'fieldtype': u'Column Break',
|
'fieldtype': u'Table',
|
||||||
'oldfieldtype': u'Column Break',
|
'label': u'Project Milestones',
|
||||||
|
'no_copy': 0,
|
||||||
|
'oldfieldname': u'project_milestones',
|
||||||
|
'oldfieldtype': u'Table',
|
||||||
|
'options': u'Project Milestone',
|
||||||
'permlevel': 0,
|
'permlevel': 0,
|
||||||
'width': u'50%'
|
'search_index': 0
|
||||||
},
|
},
|
||||||
|
|
||||||
# DocField
|
# DocField
|
||||||
@ -325,6 +242,7 @@
|
|||||||
'doctype': u'DocField',
|
'doctype': u'DocField',
|
||||||
'fieldname': u'section_break0',
|
'fieldname': u'section_break0',
|
||||||
'fieldtype': u'Section Break',
|
'fieldtype': u'Section Break',
|
||||||
|
'label': u'Project Details',
|
||||||
'oldfieldtype': u'Section Break',
|
'oldfieldtype': u'Section Break',
|
||||||
'options': u'Simple',
|
'options': u'Simple',
|
||||||
'permlevel': 0
|
'permlevel': 0
|
||||||
@ -343,6 +261,85 @@
|
|||||||
'search_index': 0
|
'search_index': 0
|
||||||
},
|
},
|
||||||
|
|
||||||
|
# DocField
|
||||||
|
{
|
||||||
|
'doctype': u'DocField',
|
||||||
|
'fieldname': u'project_details',
|
||||||
|
'fieldtype': u'Section Break',
|
||||||
|
'label': u'Project Costing',
|
||||||
|
'oldfieldtype': u'Section Break',
|
||||||
|
'options': u'Simple',
|
||||||
|
'permlevel': 0
|
||||||
|
},
|
||||||
|
|
||||||
|
# DocField
|
||||||
|
{
|
||||||
|
'doctype': u'DocField',
|
||||||
|
'fieldname': u'project_value',
|
||||||
|
'fieldtype': u'Currency',
|
||||||
|
'label': u'Project Value',
|
||||||
|
'no_copy': 0,
|
||||||
|
'oldfieldname': u'project_value',
|
||||||
|
'oldfieldtype': u'Currency',
|
||||||
|
'permlevel': 0,
|
||||||
|
'reqd': 1,
|
||||||
|
'search_index': 0,
|
||||||
|
'trigger': u'Client'
|
||||||
|
},
|
||||||
|
|
||||||
|
# DocField
|
||||||
|
{
|
||||||
|
'doctype': u'DocField',
|
||||||
|
'fieldname': u'est_material_cost',
|
||||||
|
'fieldtype': u'Currency',
|
||||||
|
'label': u'Estimated Material Cost',
|
||||||
|
'no_copy': 0,
|
||||||
|
'oldfieldname': u'est_material_cost',
|
||||||
|
'oldfieldtype': u'Currency',
|
||||||
|
'permlevel': 0,
|
||||||
|
'search_index': 0,
|
||||||
|
'trigger': u'Client'
|
||||||
|
},
|
||||||
|
|
||||||
|
# DocField
|
||||||
|
{
|
||||||
|
'doctype': u'DocField',
|
||||||
|
'fieldname': u'column_break0',
|
||||||
|
'fieldtype': u'Column Break',
|
||||||
|
'label': u'Margin',
|
||||||
|
'oldfieldtype': u'Column Break',
|
||||||
|
'permlevel': 0,
|
||||||
|
'width': u'50%'
|
||||||
|
},
|
||||||
|
|
||||||
|
# DocField
|
||||||
|
{
|
||||||
|
'doctype': u'DocField',
|
||||||
|
'fieldname': u'gross_margin_value',
|
||||||
|
'fieldtype': u'Currency',
|
||||||
|
'label': u'Gross Margin Value',
|
||||||
|
'no_copy': 0,
|
||||||
|
'oldfieldname': u'gross_margin_value',
|
||||||
|
'oldfieldtype': u'Currency',
|
||||||
|
'permlevel': 0,
|
||||||
|
'reqd': 1,
|
||||||
|
'search_index': 0
|
||||||
|
},
|
||||||
|
|
||||||
|
# DocField
|
||||||
|
{
|
||||||
|
'doctype': u'DocField',
|
||||||
|
'fieldname': u'per_gross_margin',
|
||||||
|
'fieldtype': u'Currency',
|
||||||
|
'label': u'Gross Margin %',
|
||||||
|
'no_copy': 0,
|
||||||
|
'oldfieldname': u'per_gross_margin',
|
||||||
|
'oldfieldtype': u'Currency',
|
||||||
|
'permlevel': 0,
|
||||||
|
'reqd': 1,
|
||||||
|
'search_index': 0
|
||||||
|
},
|
||||||
|
|
||||||
# DocField
|
# DocField
|
||||||
{
|
{
|
||||||
'doctype': u'DocField',
|
'doctype': u'DocField',
|
||||||
@ -474,32 +471,6 @@
|
|||||||
'search_index': 0
|
'search_index': 0
|
||||||
},
|
},
|
||||||
|
|
||||||
# DocField
|
|
||||||
{
|
|
||||||
'colour': u'White:FFF',
|
|
||||||
'description': u'Important dates and commitments in your project life cycle',
|
|
||||||
'doctype': u'DocField',
|
|
||||||
'fieldname': u'milestones',
|
|
||||||
'fieldtype': u'Section Break',
|
|
||||||
'label': u'Milestones',
|
|
||||||
'oldfieldtype': u'Section Break',
|
|
||||||
'permlevel': 0
|
|
||||||
},
|
|
||||||
|
|
||||||
# DocField
|
|
||||||
{
|
|
||||||
'doctype': u'DocField',
|
|
||||||
'fieldname': u'project_milestones',
|
|
||||||
'fieldtype': u'Table',
|
|
||||||
'label': u'Project Milestones',
|
|
||||||
'no_copy': 0,
|
|
||||||
'oldfieldname': u'project_milestones',
|
|
||||||
'oldfieldtype': u'Table',
|
|
||||||
'options': u'Project Milestone',
|
|
||||||
'permlevel': 0,
|
|
||||||
'search_index': 0
|
|
||||||
},
|
|
||||||
|
|
||||||
# DocField
|
# DocField
|
||||||
{
|
{
|
||||||
'doctype': u'DocField',
|
'doctype': u'DocField',
|
||||||
@ -517,12 +488,15 @@
|
|||||||
|
|
||||||
# DocField
|
# DocField
|
||||||
{
|
{
|
||||||
|
'colour': u'White:FFF',
|
||||||
'doctype': u'DocField',
|
'doctype': u'DocField',
|
||||||
'fieldname': u'file_list',
|
'fieldname': u'file_list',
|
||||||
'fieldtype': u'Small Text',
|
'fieldtype': u'Small Text',
|
||||||
|
'hidden': 1,
|
||||||
'label': u'File List',
|
'label': u'File List',
|
||||||
'no_copy': 1,
|
'no_copy': 1,
|
||||||
'permlevel': 0,
|
'permlevel': 0,
|
||||||
|
'print_hide': 1,
|
||||||
'search_index': 0
|
'search_index': 0
|
||||||
}
|
}
|
||||||
]
|
]
|
@ -216,7 +216,7 @@ class DocType:
|
|||||||
""" Add calendar event for task in calendar of Allocated person"""
|
""" Add calendar event for task in calendar of Allocated person"""
|
||||||
event = Document('Event')
|
event = Document('Event')
|
||||||
event.owner = self.doc.allocated_to
|
event.owner = self.doc.allocated_to
|
||||||
event.description = self.doc.name
|
event.description = self.doc.subject
|
||||||
event.event_date = self.doc.exp_start_date and self.doc.exp_start_date or ''
|
event.event_date = self.doc.exp_start_date and self.doc.exp_start_date or ''
|
||||||
event.event_hour = self.doc.event_hour and self.doc.event_hour or '10:00'
|
event.event_hour = self.doc.event_hour and self.doc.event_hour or '10:00'
|
||||||
event.event_type = 'Private'
|
event.event_type = 'Private'
|
||||||
|
Loading…
x
Reference in New Issue
Block a user