Index: openacs-4/packages/project-manager/lib/tasks-portlet.adp
===================================================================
RCS file: /usr/local/cvsroot/openacs-4/packages/project-manager/lib/tasks-portlet.adp,v
diff -u -N -r1.13 -r1.14
--- openacs-4/packages/project-manager/lib/tasks-portlet.adp 25 Jan 2006 14:55:05 -0000 1.13
+++ openacs-4/packages/project-manager/lib/tasks-portlet.adp 10 May 2006 19:40:52 -0000 1.14
@@ -16,7 +16,11 @@
-
+
|
Index: openacs-4/packages/project-manager/lib/tasks-portlet.tcl
===================================================================
RCS file: /usr/local/cvsroot/openacs-4/packages/project-manager/lib/tasks-portlet.tcl,v
diff -u -N -r1.8 -r1.9
--- openacs-4/packages/project-manager/lib/tasks-portlet.tcl 10 May 2006 19:01:02 -0000 1.8
+++ openacs-4/packages/project-manager/lib/tasks-portlet.tcl 10 May 2006 19:40:52 -0000 1.9
@@ -12,7 +12,7 @@
return -code error "$required_param is a required parameter."
}
}
-foreach optional_param { page page_size } {
+foreach optional_param { page page_size orderby_tasks } {
if {![info exists $optional_param]} {
set $optional_param {}
}
Index: openacs-4/packages/project-manager/lib/tasks-postgresql.xql
===================================================================
RCS file: /usr/local/cvsroot/openacs-4/packages/project-manager/lib/tasks-postgresql.xql,v
diff -u -N -r1.22 -r1.23
--- openacs-4/packages/project-manager/lib/tasks-postgresql.xql 12 Mar 2006 16:54:57 -0000 1.22
+++ openacs-4/packages/project-manager/lib/tasks-postgresql.xql 10 May 2006 19:40:52 -0000 1.23
@@ -130,7 +130,8 @@
ti.status = s.status_id
and cp.live_revision = o.object_id
[template::list::filter_where_clauses -and -name tasks]
- group by t.item_id, t.title, t.description, status, t.end_date, t.latest_finish, t.latest_start, t.earliest_start
+ group by t.item_id, t.title, t.description, status, t.end_date,
+ t.latest_finish, t.latest_start, t.earliest_start, t.priority
[template::list::orderby_clause -name tasks -orderby]
Index: openacs-4/packages/project-manager/lib/tasks.tcl
===================================================================
RCS file: /usr/local/cvsroot/openacs-4/packages/project-manager/lib/tasks.tcl,v
diff -u -N -r1.53 -r1.54
--- openacs-4/packages/project-manager/lib/tasks.tcl 3 May 2006 18:22:02 -0000 1.53
+++ openacs-4/packages/project-manager/lib/tasks.tcl 10 May 2006 19:40:52 -0000 1.54
@@ -16,7 +16,7 @@
# page The page to show on the paginate.
# page_size The number of rows to display in the list
# orderby_p Set it to 1 if you want to show the order by menu.
-# orderby To sort the list using this orderby value
+# orderby_tasks To sort the list using this orderby value
#
# For Project Manager Task Portlet:
# ---------------------------------
@@ -63,7 +63,7 @@
}
if ![info exists orderby_p] {
- set orderby_p 0
+ set orderby_p 1
}
if { ![exists_and_not_null tasks_portlet_p] } {
@@ -229,8 +229,8 @@
where_clause "$project_item_where_clause"
] \
project_item_id [list \
- label "[_ project-manager.Project_1]" \
- where_clause "$project_item_where_clause"
+ label "[_ project-manager.Project_1]" \
+ where_clause "$project_item_where_clause"
] \
instance_id [list \
where_clause "o.package_id = :instance_id"
@@ -304,12 +304,12 @@
"${base_url}assign-myself" \
"[_ project-manager.Assign_myself_as_lead]"]
- set bulk_action_export_vars [list [list return_url] [list project_item_id]]
+
} else {
set bulk_actions [list]
- set bulk_action_export_vars [list]
}
+set bulk_action_export_vars [list [list return_url] [list project_item_id]]
# Orderby's to use in
if { $orderby_p } {
set order_by_list [list \
@@ -338,6 +338,11 @@
orderby_asc "status asc, t.latest_finish desc, task_item_id"
default_direction asc
} \
+ priority {
+ orderby_asc "priority, earliest_start, task_item_id asc"
+ orderby_desc "priority desc, earliest_start desc, task_item_id desc"
+ default_direction desc
+ } \
end_date {
orderby_asc "end_date, task_item_id asc"
orderby_desc "end_date desc, task_item_id desc"
@@ -507,7 +512,7 @@
-page_size $page_size \
-page_flush_p 1 \
-page_query_name tasks_pagination \
- -orderby_name orderby \
+ -orderby_name orderby_tasks \
-html {
width 100%
} \
Index: openacs-4/packages/project-manager/sql/postgresql/upgrade/upgrade-3.0b4-3.1d12.sql
===================================================================
RCS file: /usr/local/cvsroot/openacs-4/packages/project-manager/sql/postgresql/upgrade/Attic/upgrade-3.0b4-3.1d12.sql,v
diff -u -N
--- openacs-4/packages/project-manager/sql/postgresql/upgrade/upgrade-3.0b4-3.1d12.sql 18 Nov 2005 17:40:28 -0000 1.3
+++ /dev/null 1 Jan 1970 00:00:00 -0000
@@ -1,527 +0,0 @@
---
--- Upgrade script
---
--- @author (alexk@bread.com)
--- @creation-date 2005-10-24
--- @arch-tag: cf494b6b-fd68-4cc8-9516-7f7f091c4f65
--- @cvs-id $Id: upgrade-3.0b4-3.1d12.sql,v 1.3 2005/11/18 17:40:28 alexk Exp $
---
-
-select content_type__create_attribute (
- 'pm_project', -- content_type
- 'dform', -- attribute_name
- 'string', -- datatype
- 'dform', -- pretty_name
- 'dform', -- pretty_plural
- null, -- sort_order
- null, -- default value
- 'varchar(100)' -- column_spec
-);
-
-select content_type__create_attribute (
- 'pm_task', -- content_type
- 'dform', -- attribute_name
- 'string', -- datatype
- 'dform', -- pretty_name
- 'dform', -- pretty_plural
- null, -- sort_order
- null, -- default value
- 'varchar(100)' -- column_spec
-);
-
-select acs_rel_type__create_type (
- 'application_link',
- '#Application_Link#',
- '#Application_Links#',
- 'relationship',
- 'apm_package',
- 'package_id',
- 'application_link_rel',
- 'acs_object',
- 'user',
- 1,
- 1,
- 'acs_object',
- 'user',
- 1,
- 1
-);
-
-select acs_rel_type__create_type (
- 'application_data_link',
- '#Application_Data_Link#',
- '#Application_Data_Links#',
- 'relationship',
- 'apm_package_rel',
- 'package_id',
- 'application_data_link_rel',
- 'acs_object',
- 'user',
- 1,
- 1,
- 'acs_object',
- 'user',
- 1,
- 1
-);
-
-create function inline_0 ()
-returns integer as '
-DECLARE
- lp RECORD;
-BEGIN
- FOR lp IN
- SELECT distinct(item_id), logger_project
- FROM pm_projectsx where logger_project IS NOT NULL
- LOOP
- raise NOTICE ''item_id (%) | logger_project (%)'', lp.item_id, lp.logger_project;
- perform acs_rel__new (
- null,
- ''application_data_link'',
- lp.item_id,
- lp.logger_project,
- lp.item_id,
- null,
- null
- );
-
- perform acs_rel__new (
- null,
- ''application_data_link'',
- lp.logger_project,
- lp.item_id,
- lp.item_id,
- null,
- null
- );
-
- END LOOP;
- return 0;
-END;
-' language 'plpgsql';
-
-select inline_0 ();
-drop function inline_0 ();
-
-drop table pm_task_logger_proj_map;
-
-alter table pm_projects drop column logger_project cascade;
-
-alter table pm_projects alter column dform set default 'implicit';
-update pm_projects set dform = 'implicit';
-
-alter table pm_tasks_revisions alter column dform set default 'implicit';
-update pm_tasks_revisions set dform = 'implicit';
-
-drop view pm_tasks_revisionsx;
-
-create or replace view pm_tasks_revisionsx as
- SELECT acs_objects.object_id, acs_objects.object_type, acs_objects.context_id, acs_objects.security_inherit_p, acs_objects.creation_user, acs_objects.creation_date, acs_objects.creation_ip, acs_objects.last_modified, acs_objects.modifying_user, acs_objects.modifying_ip, acs_objects.tree_sortkey, acs_objects.max_child_sortkey, cr.revision_id, cr.title, cr.item_id, cr.description, cr.publish_date, cr.mime_type, cr.nls_language, i.name, i.parent_id, pm_tasks_revisions.task_revision_id, pm_tasks_revisions.end_date, pm_tasks_revisions.percent_complete, pm_tasks_revisions.estimated_hours_work, pm_tasks_revisions.estimated_hours_work_min, pm_tasks_revisions.estimated_hours_work_max, pm_tasks_revisions.actual_hours_worked, pm_tasks_revisions.earliest_start, pm_tasks_revisions.earliest_finish, pm_tasks_revisions.latest_start, pm_tasks_revisions.latest_finish, pm_tasks_revisions.priority, pm_tasks_revisions.dform
- FROM acs_objects, cr_revisions cr, cr_items i, cr_text, pm_tasks_revisions
- WHERE acs_objects.object_id = cr.revision_id AND cr.item_id = i.item_id AND acs_objects.object_id = pm_tasks_revisions.task_revision_id;
-
-
-select define_function_args('pm_project__new_project_item', 'project_name, project_code, parent_id, goal, description, mime_type, planned_start_date, planned_end_date, actual_start_date, actual_end_date, ongoing_p, status_id, customer_id, dform, creation_date, creation_user, creation_ip, package_id');
-
-create or replace function pm_project__new_project_item (
- varchar, -- project_name
- varchar, -- project_code
- integer, -- parent_id
- varchar, -- goal
- varchar, -- description
- varchar, -- mime_type
- timestamptz, -- planned_start_date
- timestamptz, -- planned_end_date
- timestamptz, -- actual_start_date
- timestamptz, -- actual_end_date
- char(1), -- ongoing_p
- integer, -- status_id
- integer, -- customer_id (organization_id)
- varchar, -- dform
- timestamptz, -- creation_date
- integer, -- creation_user
- varchar, -- creation_ip
- integer -- package_id
-) returns integer
-as '
-declare
- p_project_name alias for $1;
- p_project_code alias for $2;
- p_parent_id alias for $3;
- p_goal alias for $4;
- p_description alias for $5;
- p_mime_type alias for $6;
- p_planned_start_date alias for $7;
- p_planned_end_date alias for $8;
- p_actual_start_date alias for $9;
- p_actual_end_date alias for $10;
- p_ongoing_p alias for $11;
- p_status_id alias for $12;
- p_customer_id alias for $13;
- p_dform alias for $14;
- p_creation_date alias for $15;
- p_creation_user alias for $16;
- p_creation_ip alias for $17;
- p_package_id alias for $18;
-
- v_item_id cr_items.item_id%TYPE;
- v_revision_id cr_revisions.revision_id%TYPE;
- v_id cr_items.item_id%TYPE;
- v_parent_id cr_items.parent_id%TYPE;
-begin
- select acs_object_id_seq.nextval into v_id from dual;
-
- v_parent_id := pm_project__get_root_folder (p_package_id, ''t'');
-
- -- raise notice ''v_parent_id (%) p_parent_id (%)'', v_parent_id, p_parent_id;
-
- if p_parent_id is not null
- then
- v_parent_id = p_parent_id;
- end if;
-
- -- raise notice ''v_parent_id (%) p_parent_id (%)'', v_parent_id, p_parent_id;
-
- v_item_id := content_item__new (
- v_id::varchar, -- name
- v_parent_id, -- parent_id
- v_id, -- item_id
- null, -- locale
- now(), -- creation_date
- p_creation_user, -- creation_user
- p_parent_id, -- context_id
- p_creation_ip, -- creation_ip
- ''pm_project'', -- item_subtype
- ''pm_project'', -- content_type
- p_project_name, -- title
- p_description, -- description
- p_mime_type, -- mime_type
- null, -- nls_language
- null -- data
- );
-
- v_revision_id := content_revision__new (
- p_project_name, -- title
- p_description, -- description
- now(), -- publish_date
- p_mime_type, -- mime_type
- NULL, -- nls_language
- NULL, -- data
- v_item_id, -- item_id
- NULL, -- revision_id
- now(), -- creation_date
- p_creation_user, -- creation_user
- p_creation_ip -- creation_ip
- );
-
- PERFORM content_item__set_live_revision (v_revision_id);
-
- insert into pm_projects (
- project_id, project_code,
- goal, planned_start_date,
- planned_end_date, actual_start_date, actual_end_date,
- ongoing_p, estimated_finish_date,
- earliest_finish_date, latest_finish_date,
- actual_hours_completed,
- estimated_hours_total, status_id, customer_id, dform)
- values (
- v_revision_id, p_project_code,
- p_goal, p_planned_start_date,
- p_planned_end_date, p_actual_start_date,
- p_actual_end_date, p_ongoing_p,
- p_planned_end_date,
- p_planned_end_date, p_planned_end_date, ''0'',
- ''0'', p_status_id, p_customer_id, p_dform
- );
-
- PERFORM acs_permission__grant_permission(
- v_revision_id,
- p_creation_user,
- ''admin''
- );
-
- return v_revision_id;
-end;' language 'plpgsql';
-
-select define_function_args('pm_project__new_project_revision', 'item_id, project_name, project_code, parent_id, goal, description, planned_start_date, planned_end_date, actual_start_date, actual_end_date, ongoing_p, status_id, organization_id, dform, creation_date, creation_user, creation_ip, package_id');
-
-create or replace function pm_project__new_project_revision (
- integer, -- item_id
- varchar, -- project_name
- varchar, -- project_code
- integer, -- parent_id
- varchar, -- goal
- varchar, -- description
- timestamptz, -- planned_start_date
- timestamptz, -- planned_end_date
- timestamptz, -- actual_start_date
- timestamptz, -- actual_end_date
- char(1), -- ongoing_p
- integer, -- status_id
- integer, -- organization_id (customer)
- varchar, -- dform
- timestamptz, -- creation_date
- integer, -- creation_user
- varchar, -- creation_ip
- integer -- package_id
-) returns integer
-as '
-declare
- p_item_id alias for $1;
- p_project_name alias for $2;
- p_project_code alias for $3;
- p_parent_id alias for $4;
- p_goal alias for $5;
- p_description alias for $6;
- p_planned_start_date alias for $7;
- p_planned_end_date alias for $8;
- p_actual_start_date alias for $9;
- p_actual_end_date alias for $10;
- p_ongoing_p alias for $11;
- p_status_id alias for $12;
- p_customer_id alias for $13;
- p_dform alias for $14;
- p_creation_date alias for $15;
- p_creation_user alias for $16;
- p_creation_ip alias for $17;
- p_package_id alias for $18;
-
- v_revision_id cr_revisions.revision_id%TYPE;
-begin
-
- -- the item_id is the project_id
-
- v_revision_id := content_revision__new (
- p_project_name, -- title
- p_description, -- description
- now(), -- publish_date
- ''text/plain'', -- mime_type
- NULL, -- nls_language
- NULL, -- data
- p_item_id, -- item_id
- NULL, -- revision_id
- now(), -- creation_date
- p_creation_user, -- creation_user
- p_creation_ip -- creation_ip
- );
-
- PERFORM content_item__set_live_revision (v_revision_id);
-
- insert into pm_projects (
- project_id, project_code,
- goal, planned_start_date,
- planned_end_date, actual_start_date, actual_end_date,
- ongoing_p, status_id, customer_id, dform)
- values (
- v_revision_id, p_project_code,
- p_goal, p_planned_start_date,
- p_planned_end_date, p_actual_start_date,
- p_actual_end_date,
- p_ongoing_p, p_status_id, p_customer_id, p_dform);
-
- PERFORM acs_permission__grant_permission(
- v_revision_id,
- p_creation_user,
- ''admin''
- );
-
- return v_revision_id;
-end;' language 'plpgsql';
-
-select define_function_args('pm_task__new_task_revision', 'task_id, project_id, title, description, mime_type, end_date, percent_complete, estimated_hours_work, estimated_hours_work_min, estimated_hours_work_max, actual_hours_worked, status_id, dform, creation_date, creation_user, creation_ip, package_id, priority');
-
-create or replace function pm_task__new_task_revision (
- integer, -- task_id (the item_id)
- integer, -- project_id
- varchar, -- title
- varchar, -- description
- varchar, -- mime_type
- timestamptz, -- end_date
- numeric, -- percent_complete
- numeric, -- estimated_hours_work
- numeric, -- estimated_hours_work_min
- numeric, -- estimated_hours_work_max
- numeric, -- actual_hours_worked
- integer, -- status_id
- varchar, -- dform
- timestamptz, -- creation_date
- integer, -- creation_user
- varchar, -- creation_ip
- integer, -- package_id
- integer -- priority
-) returns integer
-as '
-declare
- p_task_id alias for $1;
- p_project_id alias for $2;
- p_title alias for $3;
- p_description alias for $4;
- p_mime_type alias for $5;
- p_end_date alias for $6;
- p_percent_complete alias for $7;
- p_estimated_hours_work alias for $8;
- p_estimated_hours_work_min alias for $9;
- p_estimated_hours_work_max alias for $10;
- p_actual_hours_worked alias for $11;
- p_status_id alias for $12;
- p_dform alias for $13;
- p_creation_date alias for $14;
- p_creation_user alias for $15;
- p_creation_ip alias for $16;
- p_package_id alias for $17;
- p_priority alias for $18;
- v_revision_id cr_revisions.revision_id%TYPE;
- v_id cr_items.item_id%TYPE;
-begin
- select acs_object_id_seq.nextval into v_id from dual;
-
- -- We want to put the task under the project item
- update cr_items set parent_id = p_project_id where item_id = p_task_id;
-
- v_revision_id := content_revision__new (
- p_title, -- title
- p_description, -- description
- now(), -- publish_date
- p_mime_type, -- mime_type
- NULL, -- nls_language
- NULL, -- data
- p_task_id, -- item_id
- NULL, -- revision_id
- now(), -- creation_date
- p_creation_user, -- creation_user
- p_creation_ip -- creation_ip
- );
-
- PERFORM content_item__set_live_revision (v_revision_id);
-
- insert into pm_tasks_revisions (
- task_revision_id, end_date, percent_complete, estimated_hours_work, estimated_hours_work_min, estimated_hours_work_max, actual_hours_worked, priority, dform)
- values (
- v_revision_id, p_end_date, p_percent_complete, p_estimated_hours_work, p_estimated_hours_work_min, p_estimated_hours_work_max, p_actual_hours_worked, p_priority, p_dform);
-
- update pm_tasks set status = p_status_id where task_id = p_task_id;
-
- PERFORM acs_permission__grant_permission(
- v_revision_id,
- p_creation_user,
- ''admin''
- );
-
- return v_revision_id;
-end;' language 'plpgsql';
-
-select define_function_args('pm_task__new_task_item', 'project_id, title, description, html_p, end_date, percent_complete, estimated_hours_work, estimated_hours_work_min, estimated_hours_work_max, status_id, process_instance_id, dform, creation_date, creation_user, creation_ip, package_id, priority, task_id');
-
-create or replace function pm_task__new_task_item (
- integer, -- project_id
- varchar, -- title
- varchar, -- description
- varchar, -- html_p
- timestamptz, -- end_date
- numeric, -- percent_complete
- numeric, -- estimated_hours_work
- numeric, -- estimated_hours_work_min
- numeric, -- estimated_hours_work_max,
- integer, -- status_id
- integer, -- process_instance_id
- varchar, -- dform
- timestamptz, -- creation_date
- integer, -- creation_user
- varchar, -- creation_ip
- integer, -- package_id
- integer, -- priority
- integer -- task_id
-) returns integer
-as '
-declare
- p_project_id alias for $1;
- p_title alias for $2;
- p_description alias for $3;
- p_mime_type alias for $4;
- p_end_date alias for $5;
- p_percent_complete alias for $6;
- p_estimated_hours_work alias for $7;
- p_estimated_hours_work_min alias for $8;
- p_estimated_hours_work_max alias for $9;
- p_status_id alias for $10;
- p_process_instance_id alias for $11;
- p_dform alias for $12;
- p_creation_date alias for $13;
- p_creation_user alias for $14;
- p_creation_ip alias for $15;
- p_package_id alias for $16;
- p_priority alias for $17;
- p_task_id alias for $18;
-
- v_item_id cr_items.item_id%TYPE;
- v_id cr_items.item_id%TYPE;
- v_revision_id cr_revisions.revision_id%TYPE;
- v_task_number integer;
-begin
- -- We want to put the task under the project item
-
- -- create the task_number
- if p_task_id is null then
- select acs_object_id_seq.nextval into v_id from dual;
- else
- v_id := p_task_id;
- end if;
-
- v_item_id := content_item__new (
- v_id::varchar, -- name
- p_project_id, -- parent_id
- v_id, -- item_id
- null, -- locale
- now(), -- creation_date
- p_creation_user, -- creation_user
- p_package_id, -- context_id
- p_creation_ip, -- creation_ip
- ''pm_task'', -- item_subtype
- ''pm_task'', -- content_type
- p_title, -- title
- p_description, -- description
- p_mime_type, -- mime_type
- null, -- nls_language
- null, -- data
- p_package_id -- package_id
- );
-
- v_revision_id := content_revision__new (
- p_title, -- title
- p_description, -- description
- now(), -- publish_date
- p_mime_type, -- mime_type
- NULL, -- nls_language
- NULL, -- data
- v_item_id, -- item_id
- NULL, -- revision_id
- now(), -- creation_date
- p_creation_user, -- creation_user
- p_creation_ip, -- creation_ip
- p_package_id -- package_id
- );
-
- PERFORM content_item__set_live_revision (v_revision_id);
-
- insert into pm_tasks (
- task_id, task_number, status, process_instance)
- values (
- v_item_id, v_task_number, p_status_id, p_process_instance_id);
-
- insert into pm_tasks_revisions (
- task_revision_id, end_date, percent_complete, estimated_hours_work, estimated_hours_work_min, estimated_hours_work_max, actual_hours_worked, priority, dform)
- values (
- v_revision_id, p_end_date, p_percent_complete, p_estimated_hours_work, p_estimated_hours_work_min, p_estimated_hours_work_max, ''0'', p_priority, p_dform);
-
- update acs_objects set context_id = p_project_id where object_id = v_item_id;
-
- PERFORM acs_permission__grant_permission(
- v_revision_id,
- p_creation_user,
- ''admin''
- );
-
- return v_revision_id;
-end;' language 'plpgsql';
-
-select content_type__refresh_view('pm_project');
Index: openacs-4/packages/project-manager/sql/postgresql/upgrade/upgrade-3.1d11-3.1d12.sql
===================================================================
RCS file: /usr/local/cvsroot/openacs-4/packages/project-manager/sql/postgresql/upgrade/upgrade-3.1d11-3.1d12.sql,v
diff -u -N
--- /dev/null 1 Jan 1970 00:00:00 -0000
+++ openacs-4/packages/project-manager/sql/postgresql/upgrade/upgrade-3.1d11-3.1d12.sql 10 May 2006 19:40:52 -0000 1.1
@@ -0,0 +1,570 @@
+--
+-- Upgrade script
+--
+-- @author (alexk@bread.com)
+-- @creation-date 2005-10-24
+-- @arch-tag: cf494b6b-fd68-4cc8-9516-7f7f091c4f65
+-- @cvs-id $Id: upgrade-3.1d11-3.1d12.sql,v 1.1 2006/05/10 19:40:52 maltes Exp $
+--
+
+select content_type__create_attribute (
+ 'pm_project', -- content_type
+ 'dform', -- attribute_name
+ 'string', -- datatype
+ 'dform', -- pretty_name
+ 'dform', -- pretty_plural
+ null, -- sort_order
+ null, -- default value
+ 'varchar(100)' -- column_spec
+);
+
+select content_type__create_attribute (
+ 'pm_task', -- content_type
+ 'dform', -- attribute_name
+ 'string', -- datatype
+ 'dform', -- pretty_name
+ 'dform', -- pretty_plural
+ null, -- sort_order
+ null, -- default value
+ 'varchar(100)' -- column_spec
+);
+
+select acs_rel_type__create_type (
+ 'application_link',
+ '#Application_Link#',
+ '#Application_Links#',
+ 'relationship',
+ 'apm_package',
+ 'package_id',
+ 'application_link_rel',
+ 'acs_object',
+ 'user',
+ 1,
+ 1,
+ 'acs_object',
+ 'user',
+ 1,
+ 1
+);
+
+select acs_rel_type__create_type (
+ 'application_data_link',
+ '#Application_Data_Link#',
+ '#Application_Data_Links#',
+ 'relationship',
+ 'apm_package_rel',
+ 'package_id',
+ 'application_data_link_rel',
+ 'acs_object',
+ 'user',
+ 1,
+ 1,
+ 'acs_object',
+ 'user',
+ 1,
+ 1
+);
+
+create function inline_0 ()
+returns integer as '
+DECLARE
+ lp RECORD;
+BEGIN
+ FOR lp IN
+ SELECT distinct(item_id), logger_project
+ FROM pm_projectsx where logger_project IS NOT NULL
+ LOOP
+ raise NOTICE ''item_id (%) | logger_project (%)'', lp.item_id, lp.logger_project;
+ perform acs_rel__new (
+ null,
+ ''application_data_link'',
+ lp.item_id,
+ lp.logger_project,
+ lp.item_id,
+ null,
+ null
+ );
+
+ perform acs_rel__new (
+ null,
+ ''application_data_link'',
+ lp.logger_project,
+ lp.item_id,
+ lp.item_id,
+ null,
+ null
+ );
+
+ END LOOP;
+ return 0;
+END;
+' language 'plpgsql';
+
+select inline_0 ();
+drop function inline_0 ();
+
+-- Create logger task links
+create function inline_0 ()
+returns integer as '
+declare
+ ct RECORD;
+begin
+ for ct in select task_item_id, logger_entry
+ from pm_task_logger_proj_map
+ loop
+ perform acs_rel__new (
+ null,
+ ''application_data_link'',
+ lp.task_item_id,
+ lp.logger_entry,
+ lp.task_item_id,
+ null,
+ null
+ );
+
+ perform acs_rel__new (
+ null,
+ ''application_data_link'',
+ lp.logger_entry,
+ lp.task_item_id,
+ lp.task_item_id,
+ null,
+ null
+ );
+ end loop;
+
+ return null;
+end;' language 'plpgsql';
+
+select inline_0();
+drop function inline_0();
+
+drop table pm_task_logger_proj_map;
+
+alter table pm_projects drop column logger_project cascade;
+
+alter table pm_projects alter column dform set default 'implicit';
+update pm_projects set dform = 'implicit';
+
+alter table pm_tasks_revisions alter column dform set default 'implicit';
+update pm_tasks_revisions set dform = 'implicit';
+
+drop view pm_tasks_revisionsx;
+
+create or replace view pm_tasks_revisionsx as
+ SELECT acs_objects.object_id, acs_objects.object_type, acs_objects.context_id, acs_objects.security_inherit_p, acs_objects.creation_user, acs_objects.creation_date, acs_objects.creation_ip, acs_objects.last_modified, acs_objects.modifying_user, acs_objects.modifying_ip, acs_objects.tree_sortkey, acs_objects.max_child_sortkey, cr.revision_id, cr.title, cr.item_id, cr.description, cr.publish_date, cr.mime_type, cr.nls_language, i.name, i.parent_id, pm_tasks_revisions.task_revision_id, pm_tasks_revisions.end_date, pm_tasks_revisions.percent_complete, pm_tasks_revisions.estimated_hours_work, pm_tasks_revisions.estimated_hours_work_min, pm_tasks_revisions.estimated_hours_work_max, pm_tasks_revisions.actual_hours_worked, pm_tasks_revisions.earliest_start, pm_tasks_revisions.earliest_finish, pm_tasks_revisions.latest_start, pm_tasks_revisions.latest_finish, pm_tasks_revisions.priority, pm_tasks_revisions.dform
+ FROM acs_objects, cr_revisions cr, cr_items i, cr_text, pm_tasks_revisions
+ WHERE acs_objects.object_id = cr.revision_id AND cr.item_id = i.item_id AND acs_objects.object_id = pm_tasks_revisions.task_revision_id;
+
+
+select define_function_args('pm_project__new_project_item', 'project_name, project_code, parent_id, goal, description, mime_type, planned_start_date, planned_end_date, actual_start_date, actual_end_date, ongoing_p, status_id, customer_id, dform, creation_date, creation_user, creation_ip, package_id');
+
+create or replace function pm_project__new_project_item (
+ varchar, -- project_name
+ varchar, -- project_code
+ integer, -- parent_id
+ varchar, -- goal
+ varchar, -- description
+ varchar, -- mime_type
+ timestamptz, -- planned_start_date
+ timestamptz, -- planned_end_date
+ timestamptz, -- actual_start_date
+ timestamptz, -- actual_end_date
+ char(1), -- ongoing_p
+ integer, -- status_id
+ integer, -- customer_id (organization_id)
+ varchar, -- dform
+ timestamptz, -- creation_date
+ integer, -- creation_user
+ varchar, -- creation_ip
+ integer -- package_id
+) returns integer
+as '
+declare
+ p_project_name alias for $1;
+ p_project_code alias for $2;
+ p_parent_id alias for $3;
+ p_goal alias for $4;
+ p_description alias for $5;
+ p_mime_type alias for $6;
+ p_planned_start_date alias for $7;
+ p_planned_end_date alias for $8;
+ p_actual_start_date alias for $9;
+ p_actual_end_date alias for $10;
+ p_ongoing_p alias for $11;
+ p_status_id alias for $12;
+ p_customer_id alias for $13;
+ p_dform alias for $14;
+ p_creation_date alias for $15;
+ p_creation_user alias for $16;
+ p_creation_ip alias for $17;
+ p_package_id alias for $18;
+
+ v_item_id cr_items.item_id%TYPE;
+ v_revision_id cr_revisions.revision_id%TYPE;
+ v_id cr_items.item_id%TYPE;
+ v_parent_id cr_items.parent_id%TYPE;
+begin
+ select acs_object_id_seq.nextval into v_id from dual;
+
+ v_parent_id := pm_project__get_root_folder (p_package_id, ''t'');
+
+ -- raise notice ''v_parent_id (%) p_parent_id (%)'', v_parent_id, p_parent_id;
+
+ if p_parent_id is not null
+ then
+ v_parent_id = p_parent_id;
+ end if;
+
+ -- raise notice ''v_parent_id (%) p_parent_id (%)'', v_parent_id, p_parent_id;
+
+ v_item_id := content_item__new (
+ v_id::varchar, -- name
+ v_parent_id, -- parent_id
+ v_id, -- item_id
+ null, -- locale
+ now(), -- creation_date
+ p_creation_user, -- creation_user
+ p_parent_id, -- context_id
+ p_creation_ip, -- creation_ip
+ ''pm_project'', -- item_subtype
+ ''pm_project'', -- content_type
+ p_project_name, -- title
+ p_description, -- description
+ p_mime_type, -- mime_type
+ null, -- nls_language
+ null -- data
+ );
+
+ v_revision_id := content_revision__new (
+ p_project_name, -- title
+ p_description, -- description
+ now(), -- publish_date
+ p_mime_type, -- mime_type
+ NULL, -- nls_language
+ NULL, -- data
+ v_item_id, -- item_id
+ NULL, -- revision_id
+ now(), -- creation_date
+ p_creation_user, -- creation_user
+ p_creation_ip -- creation_ip
+ );
+
+ PERFORM content_item__set_live_revision (v_revision_id);
+
+ insert into pm_projects (
+ project_id, project_code,
+ goal, planned_start_date,
+ planned_end_date, actual_start_date, actual_end_date,
+ ongoing_p, estimated_finish_date,
+ earliest_finish_date, latest_finish_date,
+ actual_hours_completed,
+ estimated_hours_total, status_id, customer_id, dform)
+ values (
+ v_revision_id, p_project_code,
+ p_goal, p_planned_start_date,
+ p_planned_end_date, p_actual_start_date,
+ p_actual_end_date, p_ongoing_p,
+ p_planned_end_date,
+ p_planned_end_date, p_planned_end_date, ''0'',
+ ''0'', p_status_id, p_customer_id, p_dform
+ );
+
+ PERFORM acs_permission__grant_permission(
+ v_revision_id,
+ p_creation_user,
+ ''admin''
+ );
+
+ return v_revision_id;
+end;' language 'plpgsql';
+
+select define_function_args('pm_project__new_project_revision', 'item_id, project_name, project_code, parent_id, goal, description, planned_start_date, planned_end_date, actual_start_date, actual_end_date, ongoing_p, status_id, organization_id, dform, creation_date, creation_user, creation_ip, package_id');
+
+create or replace function pm_project__new_project_revision (
+ integer, -- item_id
+ varchar, -- project_name
+ varchar, -- project_code
+ integer, -- parent_id
+ varchar, -- goal
+ varchar, -- description
+ timestamptz, -- planned_start_date
+ timestamptz, -- planned_end_date
+ timestamptz, -- actual_start_date
+ timestamptz, -- actual_end_date
+ char(1), -- ongoing_p
+ integer, -- status_id
+ integer, -- organization_id (customer)
+ varchar, -- dform
+ timestamptz, -- creation_date
+ integer, -- creation_user
+ varchar, -- creation_ip
+ integer -- package_id
+) returns integer
+as '
+declare
+ p_item_id alias for $1;
+ p_project_name alias for $2;
+ p_project_code alias for $3;
+ p_parent_id alias for $4;
+ p_goal alias for $5;
+ p_description alias for $6;
+ p_planned_start_date alias for $7;
+ p_planned_end_date alias for $8;
+ p_actual_start_date alias for $9;
+ p_actual_end_date alias for $10;
+ p_ongoing_p alias for $11;
+ p_status_id alias for $12;
+ p_customer_id alias for $13;
+ p_dform alias for $14;
+ p_creation_date alias for $15;
+ p_creation_user alias for $16;
+ p_creation_ip alias for $17;
+ p_package_id alias for $18;
+
+ v_revision_id cr_revisions.revision_id%TYPE;
+begin
+
+ -- the item_id is the project_id
+
+ v_revision_id := content_revision__new (
+ p_project_name, -- title
+ p_description, -- description
+ now(), -- publish_date
+ ''text/plain'', -- mime_type
+ NULL, -- nls_language
+ NULL, -- data
+ p_item_id, -- item_id
+ NULL, -- revision_id
+ now(), -- creation_date
+ p_creation_user, -- creation_user
+ p_creation_ip -- creation_ip
+ );
+
+ PERFORM content_item__set_live_revision (v_revision_id);
+
+ insert into pm_projects (
+ project_id, project_code,
+ goal, planned_start_date,
+ planned_end_date, actual_start_date, actual_end_date,
+ ongoing_p, status_id, customer_id, dform)
+ values (
+ v_revision_id, p_project_code,
+ p_goal, p_planned_start_date,
+ p_planned_end_date, p_actual_start_date,
+ p_actual_end_date,
+ p_ongoing_p, p_status_id, p_customer_id, p_dform);
+
+ PERFORM acs_permission__grant_permission(
+ v_revision_id,
+ p_creation_user,
+ ''admin''
+ );
+
+ return v_revision_id;
+end;' language 'plpgsql';
+
+select define_function_args('pm_task__new_task_revision', 'task_id, project_id, title, description, mime_type, end_date, percent_complete, estimated_hours_work, estimated_hours_work_min, estimated_hours_work_max, actual_hours_worked, status_id, dform, creation_date, creation_user, creation_ip, package_id, priority');
+
+create or replace function pm_task__new_task_revision (
+ integer, -- task_id (the item_id)
+ integer, -- project_id
+ varchar, -- title
+ varchar, -- description
+ varchar, -- mime_type
+ timestamptz, -- end_date
+ numeric, -- percent_complete
+ numeric, -- estimated_hours_work
+ numeric, -- estimated_hours_work_min
+ numeric, -- estimated_hours_work_max
+ numeric, -- actual_hours_worked
+ integer, -- status_id
+ varchar, -- dform
+ timestamptz, -- creation_date
+ integer, -- creation_user
+ varchar, -- creation_ip
+ integer, -- package_id
+ integer -- priority
+) returns integer
+as '
+declare
+ p_task_id alias for $1;
+ p_project_id alias for $2;
+ p_title alias for $3;
+ p_description alias for $4;
+ p_mime_type alias for $5;
+ p_end_date alias for $6;
+ p_percent_complete alias for $7;
+ p_estimated_hours_work alias for $8;
+ p_estimated_hours_work_min alias for $9;
+ p_estimated_hours_work_max alias for $10;
+ p_actual_hours_worked alias for $11;
+ p_status_id alias for $12;
+ p_dform alias for $13;
+ p_creation_date alias for $14;
+ p_creation_user alias for $15;
+ p_creation_ip alias for $16;
+ p_package_id alias for $17;
+ p_priority alias for $18;
+ v_revision_id cr_revisions.revision_id%TYPE;
+ v_id cr_items.item_id%TYPE;
+begin
+ select acs_object_id_seq.nextval into v_id from dual;
+
+ -- We want to put the task under the project item
+ update cr_items set parent_id = p_project_id where item_id = p_task_id;
+
+ v_revision_id := content_revision__new (
+ p_title, -- title
+ p_description, -- description
+ now(), -- publish_date
+ p_mime_type, -- mime_type
+ NULL, -- nls_language
+ NULL, -- data
+ p_task_id, -- item_id
+ NULL, -- revision_id
+ now(), -- creation_date
+ p_creation_user, -- creation_user
+ p_creation_ip -- creation_ip
+ );
+
+ PERFORM content_item__set_live_revision (v_revision_id);
+
+ insert into pm_tasks_revisions (
+ task_revision_id, end_date, percent_complete, estimated_hours_work, estimated_hours_work_min, estimated_hours_work_max, actual_hours_worked, priority, dform)
+ values (
+ v_revision_id, p_end_date, p_percent_complete, p_estimated_hours_work, p_estimated_hours_work_min, p_estimated_hours_work_max, p_actual_hours_worked, p_priority, p_dform);
+
+ update pm_tasks set status = p_status_id where task_id = p_task_id;
+
+ PERFORM acs_permission__grant_permission(
+ v_revision_id,
+ p_creation_user,
+ ''admin''
+ );
+
+ return v_revision_id;
+end;' language 'plpgsql';
+
+select define_function_args('pm_task__new_task_item', 'project_id, title, description, html_p, end_date, percent_complete, estimated_hours_work, estimated_hours_work_min, estimated_hours_work_max, status_id, process_instance_id, dform, creation_date, creation_user, creation_ip, package_id, priority, task_id');
+
+create or replace function pm_task__new_task_item (
+ integer, -- project_id
+ varchar, -- title
+ varchar, -- description
+ varchar, -- html_p
+ timestamptz, -- end_date
+ numeric, -- percent_complete
+ numeric, -- estimated_hours_work
+ numeric, -- estimated_hours_work_min
+ numeric, -- estimated_hours_work_max,
+ integer, -- status_id
+ integer, -- process_instance_id
+ varchar, -- dform
+ timestamptz, -- creation_date
+ integer, -- creation_user
+ varchar, -- creation_ip
+ integer, -- package_id
+ integer, -- priority
+ integer -- task_id
+) returns integer
+as '
+declare
+ p_project_id alias for $1;
+ p_title alias for $2;
+ p_description alias for $3;
+ p_mime_type alias for $4;
+ p_end_date alias for $5;
+ p_percent_complete alias for $6;
+ p_estimated_hours_work alias for $7;
+ p_estimated_hours_work_min alias for $8;
+ p_estimated_hours_work_max alias for $9;
+ p_status_id alias for $10;
+ p_process_instance_id alias for $11;
+ p_dform alias for $12;
+ p_creation_date alias for $13;
+ p_creation_user alias for $14;
+ p_creation_ip alias for $15;
+ p_package_id alias for $16;
+ p_priority alias for $17;
+ p_task_id alias for $18;
+
+ v_item_id cr_items.item_id%TYPE;
+ v_id cr_items.item_id%TYPE;
+ v_revision_id cr_revisions.revision_id%TYPE;
+ v_task_number integer;
+begin
+ -- We want to put the task under the project item
+
+ -- create the task_number
+ if p_task_id is null then
+ select acs_object_id_seq.nextval into v_id from dual;
+ else
+ v_id := p_task_id;
+ end if;
+
+ v_item_id := content_item__new (
+ v_id::varchar, -- name
+ p_project_id, -- parent_id
+ v_id, -- item_id
+ null, -- locale
+ now(), -- creation_date
+ p_creation_user, -- creation_user
+ p_package_id, -- context_id
+ p_creation_ip, -- creation_ip
+ ''pm_task'', -- item_subtype
+ ''pm_task'', -- content_type
+ p_title, -- title
+ p_description, -- description
+ p_mime_type, -- mime_type
+ null, -- nls_language
+ null, -- data
+ p_package_id -- package_id
+ );
+
+ v_revision_id := content_revision__new (
+ p_title, -- title
+ p_description, -- description
+ now(), -- publish_date
+ p_mime_type, -- mime_type
+ NULL, -- nls_language
+ NULL, -- data
+ v_item_id, -- item_id
+ NULL, -- revision_id
+ now(), -- creation_date
+ p_creation_user, -- creation_user
+ p_creation_ip, -- creation_ip
+ p_package_id -- package_id
+ );
+
+ PERFORM content_item__set_live_revision (v_revision_id);
+
+ insert into pm_tasks (
+ task_id, task_number, status, process_instance)
+ values (
+ v_item_id, v_task_number, p_status_id, p_process_instance_id);
+
+ insert into pm_tasks_revisions (
+ task_revision_id, end_date, percent_complete, estimated_hours_work, estimated_hours_work_min, estimated_hours_work_max, actual_hours_worked, priority, dform)
+ values (
+ v_revision_id, p_end_date, p_percent_complete, p_estimated_hours_work, p_estimated_hours_work_min, p_estimated_hours_work_max, ''0'', p_priority, p_dform);
+
+ update acs_objects set context_id = p_project_id where object_id = v_item_id;
+
+ PERFORM acs_permission__grant_permission(
+ v_revision_id,
+ p_creation_user,
+ ''admin''
+ );
+
+ return v_revision_id;
+end;' language 'plpgsql';
+
+select content_type__refresh_view('pm_project');
+
+-- Make sure the upgrade to acs_data_links got through
+
+insert into acs_data_links
+(select - rel_id as rel_id, object_id_one, object_id_two
+ from acs_rels
+ where rel_type = 'application_data_link');
Index: openacs-4/packages/project-manager/sql/postgresql/upgrade/upgrade-3.1d12-3.1d13.sql
===================================================================
RCS file: /usr/local/cvsroot/openacs-4/packages/project-manager/sql/postgresql/upgrade/upgrade-3.1d12-3.1d13.sql,v
diff -u -N
--- /dev/null 1 Jan 1970 00:00:00 -0000
+++ openacs-4/packages/project-manager/sql/postgresql/upgrade/upgrade-3.1d12-3.1d13.sql 10 May 2006 19:40:52 -0000 1.1
@@ -0,0 +1,85 @@
+-- Update the package ids for projects
+create function inline_0 ()
+returns integer as '
+declare
+ ct RECORD;
+begin
+ for ct in select package_id, item_id
+ from cr_items ci, cr_folders cf
+ where ci.parent_id = cf.folder_id
+ and ci.content_type = ''pm_project''
+ loop
+ update acs_objects set package_id = ct.package_id where object_id = ct.item_id;
+ end loop;
+
+ return null;
+end;' language 'plpgsql';
+
+select inline_0();
+drop function inline_0();
+
+-- Update the package ids of project_revisions
+create function inline_0 ()
+returns integer as '
+declare
+ ct RECORD;
+begin
+ for ct in select package_id, revision_id
+ from cr_items ci, cr_folders cf, cr_revisions cr
+ where ci.parent_id = cf.folder_id
+ and ci.item_id = cr.item_id
+ and ci.content_type = ''pm_project''
+ loop
+ update acs_objects set package_id = ct.package_id where object_id = ct.revision_id;
+ end loop;
+
+ return null;
+end;' language 'plpgsql';
+
+select inline_0();
+drop function inline_0();
+
+-- Update the package ids for subprojects
+create function inline_0 ()
+returns integer as '
+declare
+ ct RECORD;
+begin
+ for ct in select package_id, c2.item_id
+ from cr_items ci, cr_folders cf, cr_items c2
+ where ci.parent_id = cf.folder_id
+ and c2.content_type = ''pm_project''
+ and c2.parent_id = ci.item_id
+ loop
+ update acs_objects set package_id = ct.package_id where object_id = ct.item_id;
+ end loop;
+
+ return null;
+end;' language 'plpgsql';
+
+select inline_0();
+drop function inline_0();
+
+-- Update the package ids of project_revisions
+create function inline_0 ()
+returns integer as '
+declare
+ ct RECORD;
+begin
+ for ct in select package_id, revision_id
+ from cr_items ci, cr_folders cf, cr_revisions cr, cr_items c2
+ where ci.parent_id = cf.folder_id
+ and c2.item_id = cr.item_id
+ and c2.content_type = ''pm_project''
+ and c2.parent_id = ci.item_id
+ loop
+ if ct.package_id is not null then
+ update acs_objects set package_id = ct.package_id where object_id = ct.revision_id;
+ end if;
+ end loop;
+
+ return null;
+end;' language 'plpgsql';
+
+select inline_0();
+drop function inline_0();
Index: openacs-4/packages/project-manager/templates/project-one.adp
===================================================================
RCS file: /usr/local/cvsroot/openacs-4/packages/project-manager/templates/project-one.adp,v
diff -u -N -r1.16 -r1.17
--- openacs-4/packages/project-manager/templates/project-one.adp 10 May 2006 18:51:42 -0000 1.16
+++ openacs-4/packages/project-manager/templates/project-one.adp 10 May 2006 19:40:52 -0000 1.17
@@ -48,6 +48,8 @@
return_url="@return_url@"
instance_id="@instance_id@"
fmt="@fmt@"
+ orderby_p="1"
+ orderby_tasks="@orderby_tasks@"
page="@page@"
/>
Index: openacs-4/packages/project-manager/www/one.tcl
===================================================================
RCS file: /usr/local/cvsroot/openacs-4/packages/project-manager/www/one.tcl,v
diff -u -N -r1.11 -r1.12
--- openacs-4/packages/project-manager/www/one.tcl 18 Nov 2005 16:27:19 -0000 1.11
+++ openacs-4/packages/project-manager/www/one.tcl 10 May 2006 19:40:53 -0000 1.12
@@ -23,10 +23,12 @@
@param use_uncertain_completion_times_p Specifies whether or not to use PERT style uncertainty times 1 = yes
@param logger_days The number of days back to view logged entries
@param instance_id The process instance ID to show for tasks
+ @param pid_filter
} {
project_item_id:integer,optional
project_id:integer,optional
+ pid_filter:integer,optional
{page:integer ""}
{orderby_subproject ""}
{orderby_tasks ""}
@@ -60,7 +62,7 @@
} -validate {
project_exists {
if {![exists_and_not_null project_item_id] && \
- ![exists_and_not_null project_id]} {
+ ![exists_and_not_null project_id] && ![exists_and_not_null pid_filter]} {
ad_complain "[_ project-manager.No_project_passed_in]"
@@ -78,6 +80,13 @@
-project_item_id $project_item_id]
}
}
+ pid_filter_exists {
+ if {[exists_and_not_null pid_filter]} {
+ set project_item_id $pid_filter
+ set project_id [pm::project::get_project_id \
+ -project_item_id $project_item_id]
+ }
+ }
logger_days_positive {
if {$logger_days < 1} {
set logger_days 1