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 -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 @@
   </if>
 <tr>
   <td colspan="2" class="fill-list-middle">
-    <include src=/packages/project-manager/lib/tasks project_id="@project_id@" pid_filter="@project_item_id@" return_url="@return_url@" elements="@elements@" display_mode="list" fmt=@fmt@ instance_id="@instance_id@" status_id="1" page="@page@" page_size="@page_size@">
+    <include src=/packages/project-manager/lib/tasks project_id="@project_id@"
+    pid_filter="@project_item_id@" return_url="@return_url@"
+    elements="@elements@" display_mode="list" fmt=@fmt@
+    instance_id="@instance_id@" status_id="1" page="@page@"
+    page_size="@page_size@" orderby_tasks="@orderby_tasks@">
   </td>
 </tr>
 <tr class="list-button-bar">
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 -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 -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]
     </querytext>
 </fullquery>
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 -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%
     } \
Fisheye: Tag 1.4 refers to a dead (removed) revision in file `openacs-4/packages/project-manager/sql/postgresql/upgrade/upgrade-3.0b4-3.1d12.sql'.
Fisheye: No comparison available.  Pass `N' to diff?
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
--- /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
--- /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 -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@"
 	/>
     <p />
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 -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