--- loncom/imspackages/imsimportdocs.pm	2004/12/13 20:01:09	1.8
+++ loncom/imspackages/imsimportdocs.pm	2009/11/20 14:39:32	1.26
@@ -1,3 +1,7 @@
+# The LearningOnline Network with CAPA
+#
+# $Id: imsimportdocs.pm,v 1.26 2009/11/20 14:39:32 bisitz Exp $
+#
 # Copyright Michigan State University Board of Trustees
 #
 # This file is part of the LearningOnline Network with CAPA (LON-CAPA).
@@ -30,6 +34,10 @@ use Apache::loncommon;
 use Apache::lonlocal;
 use Apache::imsprocessor;
 use LONCAPA::Configuration;
+use LONCAPA::map();
+use lib '/home/httpd/lib/perl/';
+use LONCAPA;
+ 
 use strict;
 
 sub jscript_one {
@@ -143,59 +151,62 @@ sub handler {
     &Apache::imsprocessor::ims_config(\@areas,\%cmsmap,\%areaname);
 
 # get course data
-    my $coursenum=$ENV{'course.'.$ENV{'request.course.id'}.'.num'};
-    my $coursedom=$ENV{'course.'.$ENV{'request.course.id'}.'.domain'};
-    my $coursehome=$ENV{'course.'.$ENV{'request.course.id'}.'.home'};
+    my $coursenum=$env{'course.'.$env{'request.course.id'}.'.num'};
+    my $coursedom=$env{'course.'.$env{'request.course.id'}.'.domain'};
 
 # get personal data
  
-    my $uname=$ENV{'user.name'};
-    my $udom=$ENV{'user.domain'};
-    my $plainname=&Apache::lonnet::escape(
+    my $uname=$env{'user.name'};
+    my $udom=$env{'user.domain'};
+    my $plainname=&escape(
                      &Apache::loncommon::plainname($uname,$udom));
 
 # does this user have privileges to post, etc?
-    my $allowed=&Apache::lonnet::allowed('mdc',$ENV{'request.course.id'});
+    my $allowed=&Apache::lonnet::allowed('mdc',$env{'request.course.id'});
     unless ($allowed) {
-        $r->print("<html><head><title>The LearningOnline Network with CAPA</title></head>");
-        $r->print(&Apache::loncommon::bodytag('Import IMS package',undef,'',1));  
-        $r->print('<h3>'.&mt('Modification of Course Contents Disallowed').'</h3>'.&mt('Your current role does not grant you the right to modify course content in this course.').'</body></html>');
+        $r->print(&Apache::loncommon::start_page('Import IMS package',undef,
+                                                 {'only_body' => 1,}));  
+        $r->print(
+            '<p class="LC_error">'
+           .&mt('Modification of Course Contents Disallowed')
+           .'</p><p>'
+           .&mt('Your current role does not grant you the right to modify course content in this course.')
+           .'</p>'
+           .&Apache::loncommon::end_page()
+        );
         return OK;
     }
 
     &Apache::loncommon::get_unprocessed_cgi($ENV{'QUERY_STRING'},
        ['phase']);
 
-    if ($ENV{'form.phase'} eq 'one') {    
+    if ($env{'form.phase'} eq 'one') {    
         &jscript_one(\$javascript);
-    } elsif ($ENV{'form.phase'} eq 'two') {
+    } elsif ($env{'form.phase'} eq 'two') {
         &jscript_two(\$javascript);
-    } elsif ($ENV{'form.phase'} eq 'three') {
+    } elsif ($env{'form.phase'} eq 'three') {
         &jscript_three(\$javascript);
     }
 
+    $javascript = 
+        "<script type=\"text/javascript\">\n".
+        "//<!--\n$javascript\n// --></script>\n";
+    my $headline = 'Import IMS package';
+    my $start_page = &Apache::loncommon::start_page($headline,
+                                                    $javascript,
+                                                    {'only_body' => 1,})
+                    .'<h1>'.&mt($headline).'</h1>';
 # print screen
-    $r->print(<<ENDHEAD);
-<html>
-<head>
-<title>The LearningOnline Network with CAPA</title>
-<script type="text/javascript">
-<!--
-$javascript
--->
-</script>
-</head>
-ENDHEAD
-# -------------------------------------------------------------------- Body tag
-    $r->print(&Apache::loncommon::bodytag('Import IMS package',undef,'',1));
-    if ($ENV{'form.phase'} eq 'one') {
+    $r->print($start_page);
+
+    if ($env{'form.phase'} eq 'one') {
         &display_one($r);       
-    } elsif ($ENV{'form.phase'} eq 'two') {
+    } elsif ($env{'form.phase'} eq 'two') {
         &display_two($r,$coursenum,\@areas,\%areaname,%cmsmap);
-    } elsif ($ENV{'form.phase'} eq 'three') {
-        &display_three($r,$coursenum,$coursedom,$coursehome,$uname,$udom,\@areas,%cmsmap);
+    } elsif ($env{'form.phase'} eq 'three') {
+        &display_three($r,$coursenum,$coursedom,$uname,$udom,\@areas,%cmsmap);
     }   
-    $r->print("</body><html>");
+    $r->print(&Apache::loncommon::end_page());
     return OK;
 } 
 
@@ -204,102 +215,45 @@ sub display_one {
     my ($r) = @_;
     &Apache::loncommon::get_unprocessed_cgi($ENV{'QUERY_STRING'},['folder']);
 
-    $r->print(<<ENDBLOCK);
-<form action="/adm/imsimportdocs" method="post" enctype="multipart/form-data" name="pickcms">
-  <table border='0' bgcolor='#F6F6F6' cellspacing='0' cellpadding ='0' width='100%'>
-   <tr>
-    <td colspan='2'>
-     <table border='0' cellspacing='0' cellpadding='0'>
-      <tr>
-        <td colspan='2'  align='left'>&nbsp;
-        </td>
-       </tr>
-       <tr bgcolor='#CCCCFF'>
-        <td valign='middle'><img src='/res/adm/pages/bl_step1.gif'>&nbsp;
-        </td>
-        <td width='100%' align='left'>&nbsp;&nbsp;
-         <font face='arial,helvetica,sans-serif'><b>Specify the Course Management system used to create the package.</b>&nbsp;&nbsp;
-         </font>
-       </td>
-      </tr>
-      <tr>
-       <td colspan='2'>&nbsp;</td>
-      </tr>
-      <tr>
-       <td>&nbsp;</td>
-       <td>
-        <font face='Arial,Helvetica,sans-serif'>
-Please choose the CMS used to create your IMS content package.&nbsp;&nbsp;
-        <select name="source">
-         <option value='-1' selected="true">Please select
-         <option value='bb5'>Blackboard 5
-         <option value='bb6'>Blackboard 6
-         <option value='angel'>ANGEL
-        </select>
-        </font>
-       </td>
-      </tr>
-      <tr>
-       <td colspan='2'>&nbsp;</td>
-      </tr>
-      <tr>
-       <td colspan='2'>&nbsp;</td>
-      </tr>
-      <tr bgcolor='#CCCCFF'>
-        <td valign='middle'><img src='/res/adm/pages/bl_step2.gif'>&nbsp;
-        </td>
-        <td width='100%' align='left'>&nbsp;&nbsp;
-         <font face='arial,helvetica,sans-serif'><b>Locate the IMS content package you wish to upload.</b>&nbsp;&nbsp;
-         </font>
-       </td>
-      </tr>
-      <tr>
-       <td colspan='2'>&nbsp;</td>
-      </tr>
-      <tr>
-       <td colspan='2'>&nbsp;
-        <input type="hidden" name="folder" value="$ENV{'form.folder'}" />
-        <input type="hidden" name="phase" value="two" />
-        <input type="file" name="uploadname" size="40" />
-       </td>
-      </tr>
-      <tr>
-       <td colspan='2'>&nbsp;</td>
-      </tr>
-      <tr>
-       <td>&nbsp;</td>
-       <td><font face='arial,helvetica,sans-serif'>If you have selected the CMS, and located the IMS package, you should click the 'Upload IMS package' button to upload the file to the server.</font></td>
-      </tr>
-      <tr>
-       <td colspan='2'>&nbsp;</td>
-      </tr>
-      <tr
-       <td colspan='2'>
-        <table border='0' cellspacing='0' cellpadding='0' width="100%">
-         <tr>
-          <td align='left'>
-           <input type="button" name="exitpage" value="Exit now" onClick="javascript:self.close()">
-          </td>
-          <td align='right'>
-           <input type="button" name="nextpage" value="Upload IMS package" onClick="javascript:nextPage()">
-          </td>
-         </tr>
-        </table>
-       </td>
-      </tr>
-     </table>
-    </td>
-   </tr>
-  </table>
-</form>
-ENDBLOCK
+    $r->print(
+        '<form action="/adm/imsimportdocs" method="post"'
+       .' enctype="multipart/form-data" name="pickcms">'
+       .&Apache::lonhtmlcommon::topic_bar(
+            1,&mt('Specify the Course Management system used to create the package'))
+       .&mt('Please choose the CMS used to create your IMS content package:').' '
+       .'<select name="source">'
+       .'<option value="-1" selected="selected">'.&mt('Please select').'</option>'
+       .'<option value="bb5">Blackboard 5</option>'
+       .'<option value="bb6">Blackboard 6</option>'
+       .'<option value="angel5">ANGEL 5.5</option>'
+       .'<option value="webctce4">WebCT 4 Campus Edition</option>'
+       .'</select>'
+    );
+    $r->print(
+       &Apache::lonhtmlcommon::topic_bar(
+           2,&mt('Locate the IMS content package you wish to upload'))
+      .'<input type="hidden" name="folder" value="'.$env{'form.folder'}.'" />'
+      .'<input type="hidden" name="phase" value="two" />'
+      .&mt('File:')
+      .' <input type="file" name="uploadname" size="40" />'
+    );
+    $r->print(
+       '<hr />'
+      .'<p>'
+      .'<input type="button" name="exitpage" value="'.&mt('Cancel').'"'
+      .' onclick="javascript:self.close()" />'
+      .' '
+      .'<input type="button" name="nextpage" value="'.&mt('Upload IMS package').'"'
+      .' onclick="javascript:nextPage()" />'
+      .'</p>'
+    );
 }
 
 
 sub display_two {
     my ($r,$crs,$areasref,$areaname,%cmsmap) = @_;
     &Apache::loncommon::get_unprocessed_cgi($ENV{'QUERY_STRING'},['folder','source']);
-    my $cms = $ENV{'form.source'};
+    my $cms = $env{'form.source'};
     my $timenow = time;
     my $tempdir = &Apache::imsprocessor::create_tempdir('DOCS',$crs,$timenow);
     my $fname = &Apache::imsprocessor::uploadzip('DOCS',$tempdir);
@@ -309,14 +263,13 @@ sub display_two {
         $unzip_result = &Apache::imsprocessor::expand_zip($tempdir,$fname);
     }
     my %resources = ();
+    my %includedres = ();
+    my %includeditems = ();
     my %items = ();
     my %hrefs = ();
     my %resinfo = ();
     my %count = ();
-    my @bgcolors = ("#eeeeee","#dddddd");
-
     my $counter = 0;
-    my $iter = 0;
     my %count = (
                 announce => 0,
                 board => 0,
@@ -330,184 +283,185 @@ sub display_two {
                 users => 0,
                 );
 
-    if ($unzip_result eq 'ok') {
-        $manifest_result = &Apache::imsprocessor::process_manifest($cms,$tempdir,\%resources,\%items,\%hrefs,\%resinfo);
-        if ($manifest_result eq 'ok') {
-            foreach my $res (sort keys %resources) {
-                if ($cms eq 'bb5' || $cms eq 'bb6') {
-                    foreach my $area (keys %{$cmsmap{$cms}}) {
-                        if ($resources{$res}{type} eq $cmsmap{$cms}{$area}) {
-                            $count{$area} ++;
-                        }
-                    }
-                } elsif ($cms eq 'angel') {
-                    foreach my $area (keys %{$cmsmap{$cms}}) {
-                        if ($area eq 'doc') {
-                            if (grep/^$resources{$res}{type}$/,@{$cmsmap{$cms}{doc}}) {
-                                $count{$area} ++;
-                            }
-                        } elsif ($resources{$res}{type} eq $cmsmap{$cms}{$area}) {
-                            $count{$area} ++;
-                        }
-                    }
+    if ($unzip_result ne 'ok') {
+        $r->print(
+            '<p class="LC_warning">'
+           .&mt('Processing of your IMS package failed because the file you'
+               .' uploaded could not be unzipped.')
+           .'</p>'
+        );
+        return();
+    }
+
+    # Get manifest file from package
+    $manifest_result = &Apache::imsprocessor::process_manifest(
+                           $cms,$tempdir,\%resources,\%items,\%hrefs,
+                           \%resinfo,'choose',\%includedres,\%includeditems);
+    if ($manifest_result ne 'ok') {
+        $r->print(
+           '<p class="LC_warning">'
+          .&mt('Unpacking of your IMS package failed because an IMS manifest file was not located in the package.')
+          .'</p>'
+        );
+        return();
+    }
+
+    # Count areas depending on cms version
+    foreach my $res (sort keys %resources) {
+        if ($cms eq 'bb5' || $cms eq 'bb6' || $cms eq 'webctce4') {
+            foreach my $area (keys %{$cmsmap{$cms}}) {
+                if ($resources{$res}{type} eq $cmsmap{$cms}{$area}) {
+                    $count{$area} ++;
                 }
             }
-            $r->print(<<ENDBLOCK);
-<form name="pickoptions" method="post">
-  <table border='0' bgcolor='#F6F6F6'' cellspacing='0' cellpadding ='0' width='100%'>
-   <tr>
-    <td colspan='2'>
-     <table border='0' cellspacing='0' cellpadding='0'>
-      <tr>
-       <td colspan='2'  align='left'>&nbsp;
-       </td>
-      </tr>
-      <tr bgcolor='#CCCCFF'>
-       <td valign='middle'><img src='/res/adm/pages/bl_step3.gif'>
-       </td>
-       <td width='100%' align='left'>&nbsp;&nbsp;
-        <font face='arial,helvetica,sans-serif'><b>Choose which content types you wish to import</b></font>
-       </td>
-      </tr>
-      <tr>
-       <td colspan='2'>&nbsp;</td>
-      </tr>
-      <tr>
-       <td>&nbsp;</td>
-       <td>
-        <table border='0' cellspacing='0' cellpadding='1' bgcolor='#000000'>
-         <tr>
-          <td>
-           <table border='0' cellspacing='0' cellpadding='0' bgcolor='#ffffff' width='100%'>
-            <tr>
-             <td>
-              <table border='0' cellspacing='1' cellpadding='1' bgcolor='#ffffff' width='100%'>
-               <tr bgcolor='#CCCCFF'>
-                <td align='center'><font face='arial,helvetica,sans-serif'><b>Import?</b></font></td>           
-                <td align='center'><font face='arial,helvetica,sans-serif'><b>Content type</b></font></td>
-                <td align='center'><font face='arial,helvetica,sans-serif'><b>Additional options</b></font></td>
-               </tr>
-ENDBLOCK
-            foreach my $area (@{$areasref}) {
-                if ($count{$area} > 0) {
-                    my $count_tag = 'flag_'.$counter;
-                    $r->print("               <tr bgcolor='@bgcolors[$iter]'>
-                <td align='left'><font face='arial,helvetica,sans-serif'><input name='$area' type='checkbox' ");
-                    if ($area eq 'board' || $area eq 'users') {
-                        $r->print(qq|onClick='javascript:setOptions("$area","$counter")'|);
-                    }
-                    $r->print("/></font></td>
-                <td align='left'><font face='arial,helvetica,sans-serif'>&nbsp;&nbsp;$$areaname{$area}&nbsp;&nbsp; - $count{$area} item(s)</font></td>");
-                    if ($area eq 'board') {
-                        $r->print("            <td align='left'><font face='arial,helvetica,sans-serif'>&nbsp;&nbsp;
-                 <select name='db_handling'>
-                  <option value='-2'>&lt;-- Check Import first
-                 </select></font>
-                </td>");
-                    } elsif ($area eq 'users') {
-                        $r->print("            <td align='left'><font face='arial,helvetica,sans-serif'>&nbsp;&nbsp;
-                 <select name='user_handling'>
-                  <option value='-2'>&lt;-- Check Import first
-                 </select>
-                 </font>        
-                </td>");
-                    } else {
-                        $r->print("            <td align='left'><font face='arial,helvetica,sans-serif'>&nbsp;&nbsp;None<input type='hidden' name='$count_tag' /></font></td>");
+        } elsif ($cms eq 'angel5') {
+            foreach my $area (keys %{$cmsmap{$cms}}) {
+                if ($area eq 'doc') {
+                    if (grep/^$resources{$res}{type}$/,@{$cmsmap{$cms}{doc}}) {
+                        $count{$area} ++;
                     }
-                    $counter ++;
-                    $iter = $counter%2;
+                } elsif ($resources{$res}{type} eq $cmsmap{$cms}{$area}) {
+                    $count{$area} ++;
                 }
             }
-            $r->print(<<ENDDOCUMENT);
-               </tr>
-              </table>
-             </td>
-            </tr>
-           </table>
-          </td>
-         </tr>
-        </table>
-       </td>
-      </tr>
-      <tr>
-       <td colspan='2'>&nbsp;<br /><br /></td>
-      </tr>
-      <tr bgcolor='#CCCCFF'>
-       <td valign='middle'><img src='/res/adm/pages/bl_step4.gif'>
-       </td>
-       <td width='100%' align='left'>&nbsp;&nbsp;
-        <font face='arial,helvetica,sans-serif'><b>Choose display options for listing of contents of top level of package.</b></font>
-       </td>
-      </tr>
-      <tr>
-       <td colspan='2'>&nbsp;</td>
-      </tr>
-      <tr>
-       <td>&nbsp;</td>
-       <td>
-        <table border='0'>
-         <tr>
-          <td><font face='arial,helvetica,sans-serif'><input type="radio" name="toplevel" value="newfolder" />Display listing of contents in a new folder, with folder name:&nbsp;&nbsp;&nbsp;<input type="text" name="foldername" size="15" value="Type Name Here" /></font></td>
-         </tr>
-         <tr>
-          <td><font face='arial,helvetica,sans-serif'><input type="radio" name="toplevel" value="oldfolder" />Append listing of contents of top level of package to contents list for the current folder.</font></td>
-         </tr>
-        </table>
-       </td>
-      </tr>
-      <tr>
-       <td colspan='2'>&nbsp;</td>
-      </tr>
-      <tr>
-       <td>&nbsp;</td>
-       <td><font face='arial,helvetica,sans-serif'>Once you have checked the checkboxes for all areas you wish to import from the IMS package, selected options (if available), and selected a display option for the package contents you should click the 'Complete Import' button.</font></td>
-      </tr>
-      <tr>
-       <td colspan='2'>&nbsp;
-          <input type="hidden" name="folder" value="$ENV{'form.folder'}" />
-          <input type="hidden" name="source" value="$cms" />
-          <input type="hidden" name="tempdir" value="$tempdir" />
-          <input type="hidden" name="phase" value="three" />
-       </td>
-      </tr>
-      <tr>
-       <td colspan='2'>
-        <table border='0' cellspacing='0' cellpadding='0' width="100%">
-         <tr>
-          <td align='left'>
-           <input type='button' name='exitpage' value='Exit now' onClick="javascript:self.close()">
-          </td>
-          <td align='right'>
-           <input type="button" name="nextpage" value="Complete Import" onClick="javascript:nextPage($counter)">
-          </td>
-         </tr>
-        </table>
-       </td>
-      </tr>
-     </table>
-    </td>
-   </tr>
-  </table>
-ENDDOCUMENT
+        } else { # Unknown cms format
+            $r->print(
+                '<span class="LC_warning">'
+               .&mt('Unsupported IMS format: [_1]',$cms)
+               .'</span><br />'
+            );
+            # return();
+        }
+    }
+
+
+    # Start output: Step 3 and step 4
+
+    $r->print(
+        '<form name="pickoptions" method="post">'
+       .&Apache::lonhtmlcommon::topic_bar(
+            3,&mt('Choose which content types you wish to import'))
+       .'<p>'
+       .&mt('Check the checkboxes for all areas you wish to import from the IMS package:')
+       .'</p>'
+    );
+
+    $r->print(
+        &Apache::loncommon::start_data_table()
+       .&Apache::loncommon::start_data_table_header_row()
+       .'<th>'.&mt('Import?').'</th>'
+       .'<th>'.&mt('Content type').'</th>'
+       .'<th>'.&mt('Additional options').'</th>'
+       .&Apache::loncommon::end_data_table_header_row()
+    );
+
+    # Display import row for each area/content type
+    foreach my $area (@{$areasref}) {
+        unless ($count{$area} > 0) { next };
+
+        my $count_tag = 'flag_'.$counter;
+
+        # Checkbox: Import?
+        $r->print(
+            &Apache::loncommon::start_data_table_row()
+           .'<td><input name="'.$area.'" type="checkbox"'
+        );
+        if ($area eq 'board' || $area eq 'users') {
+            $r->print(qq| onclick='javascript:setOptions("$area","$counter")'|);
+        }
+
+        $r->print(' /></td>');
+
+        # Content Type
+        $r->print(
+            '<td>'
+           .$$areaname{$area}.'&nbsp;&nbsp; - '
+           .&mt('[quant,_1,item]',$count{$area})
+           .'</td>'
+        );
+
+        # Additional Options
+        $r->print('<td>');
+        if ($area eq 'board') {
+            $r->print(
+                '<select name="db_handling">'
+               .'<option value="-2">&lt;-- '.&mt('Check Import first').'</option>'
+               .'</select>'
+            );
+        } elsif ($area eq 'users') {
+            $r->print(
+                '<select name="user_handling">'
+               .'<option value="-2">&lt;-- '.&mt('Check Import first').'</option>'
+               .'</select>'
+            );
         } else {
-            $r->print("Unpacking of your IMS package failed because an IMS manifest file was not located in the package\n");
-        }
-    } else {
-        $r->print("Processing of your IMS package failed because the file you uploaded could not be unzipped\n");
-    }
+            $r->print(
+                &mt('None')
+               .'<input type="hidden" name="'.$count_tag.'" />'
+            );
+        }
+        $r->print('</td>');
+
+        $r->print(&Apache::loncommon::end_data_table_row());
+        $counter ++;
+    }
+
+    $r->print(&Apache::loncommon::end_data_table());
+
+    $r->print(
+        &Apache::lonhtmlcommon::topic_bar(
+            4,&mt('Choose display options for listing of contents of top level of package'))
+       .'<p>'
+       .&mt('Select a display option for the package content:')
+       .'</p>'
+    );
+    $r->print(
+        '<label>'
+       .'<input type="radio" name="toplevel" value="newfolder" />'
+       .&mt('Display listing of contents in a new folder, with folder name:')
+       .'</label>'
+       .' <input type="text" name="foldername" size="15" value="'.&mt('Type Name Here').'" />'
+       .'<br />'
+       .'<label>'
+       .'<input type="radio" name="toplevel" value="oldfolder" />'
+       .&mt('Append listing of contents of top level of package to contents list for the current folder.')
+       .'</label>'
+    );
+
+    # Buttons
+    $r->print(
+        '<input type="hidden" name="folder" value="'.$env{'form.folder'}.'" />'
+       .'<input type="hidden" name="source" value="'.$cms.'" />'
+       .'<input type="hidden" name="tempdir" value="'.$tempdir.'" />'
+       .'<input type="hidden" name="phase" value="three" />'
+    );
+    $r->print(
+        '<hr />'
+       .'<p>'
+       .'<input type="button" name="exitpage" value="'.&mt('Cancel').'"'
+       .' onclick="javascript:self.close()" />'
+       .' '
+       .'<input type="button" name="nextpage" value="'.&mt('Finish Import').'"'
+       .' onclick="javascript:nextPage('.$counter.')" />'
+       .'</p>'
+    );
+
+   $r->print('</form>');
 }
 
 
 sub display_three {
-    my ($r,$crs,$cdom,$chome,$uname,$udom,$areas,%cmsmap) = @_;
-    my $folder = $ENV{'form.folder'};
-    my $cms = $ENV{'form.source'};
-    my $tempdir = $ENV{'form.tempdir'};
+    my ($r,$crs,$cdom,$uname,$udom,$areas,%cmsmap) = @_;
+    my $folder = $env{'form.folder'};
+    my $cms = $env{'form.source'};
+    my $tempdir = $env{'form.tempdir'};
     my $longcrs = '';
     if ($crs =~ m/^(\d)(\d)(\d)/) {
         $longcrs = $1.'/'.$2.'/'.$3.'/'.$crs;
     }
-    my %imports = ();
+    my %importareas = ();
+    my %includedres = ();
+    my %includeditems = ();
     my @targets = ();
     my %resources = ();
     my %items = ();
@@ -536,32 +490,48 @@ sub display_three {
     my $toplevel = '';
     my $foldername = '';
     my %topitems = ();
-    if (defined($ENV{'form.toplevel'}) ) {
-        $toplevel = $ENV{'form.toplevel'};     
+    if (defined($env{'form.toplevel'}) ) {
+        $toplevel = $env{'form.toplevel'};     
     }
-    if (defined($ENV{'form.foldername'}) ) {
-        $foldername = $ENV{'form.foldername'}; 
+    if (defined($env{'form.foldername'}) ) {
+        $foldername = $env{'form.foldername'}; 
     }
 
     foreach my $area (@{$areas}) {
-        if (defined($ENV{"form.$area"}) && ($ENV{'form.'.$area} ne '')) {
-            if ($cms eq 'angel' && $area eq 'doc') {
+        if (defined($env{"form.$area"}) && ($env{'form.'.$area} ne '')) {
+            if ($cms eq 'angel5' && $area eq 'doc') {
                 foreach (@{$cmsmap{$cms}{$area}}) {
-                    $imports{$_} = 1;
+                    $importareas{$_} = 1;
                 }
             } else {
-                $imports{$cmsmap{$cms}{$area}} = 1;
+                $importareas{$cmsmap{$cms}{$area}} = 1;
             }
             if ($area eq 'board') {
-                $db_handling = $ENV{'form.db_handling'};
+                $db_handling = $env{'form.db_handling'};
             } elsif ($area eq 'users') {
-                $user_handling = $ENV{'form.user_handling'};
+                $user_handling = $env{'form.user_handling'};
+            }
+        }
+    }
+
+    my $manifest_result = &Apache::imsprocessor::process_manifest($cms,$tempdir,\%resources,\%items,\%hrefs,\%resinfo,'prepare',\%includedres,\%includeditems);
+    if ($manifest_result eq 'ok') {
+        foreach my $res (sort keys %resources) {
+            if ($importareas{$resources{$res}{type}}) {
+                $includedres{$res} = 1;
             }
         }
+        foreach my $itm (sort keys %items) {
+            &Apache::imsprocessor::get_imports(\%includeditems,\%items,\%resources,\%importareas,$itm);
+        }
     }
-   
-    my $manifest_result = &Apache::imsprocessor::process_manifest($cms,$tempdir,\%resources,\%items,\%hrefs,\%resinfo);
+    foreach my $itm (sort keys %includeditems) {
+        &Apache::imsprocessor::get_parents(\%includeditems,\%items,$itm);
+    }
+
+    $manifest_result = &Apache::imsprocessor::process_manifest($cms,$tempdir,\%resources,\%items,\%hrefs,\%resinfo,'build',\%includedres,\%includeditems);
     if ($manifest_result eq 'ok') {
+
         my @path = ($cdom,$crs,$timenow);
         my $fullpath = $Apache::lonnet::perlvar{'lonDocRoot'}.'/userfiles';
         foreach my $item (@path) {
@@ -576,12 +546,13 @@ sub display_three {
                 mkdir("$fullpath/$name",0770);
             }
         }
-        &Apache::imsprocessor::target_resources(\%resources,\%imports,\@targets);
+        &Apache::imsprocessor::target_resources(\%resources,\%importareas,\@targets);
 
         my @boards = ();
         my @announcements = ();
         my @quizzes = ();
         my @surveys = ();
+        my @pools = ();
         my @groups = ();
         my %messages = ();
         my @timestamp = ();
@@ -590,49 +561,49 @@ sub display_three {
         my @topnames = ();
         my @packages = ();
 
-        &Apache::imsprocessor::process_resinfo($cms,'DOCS',$tempdir,$destdir,\%items,\%resources,\@boards,\@announcements,\@quizzes,\@surveys,\@groups,\%messages,\@timestamp,\%boardnum,\%resinfo,$udom,$uname,$cdom,$crs,$db_handling,$user_handling,\%total,$seqstem,$seqstem,\@resrcfiles,\@packages,\%hrefs,\@pages,\@sequences);
+        &Apache::imsprocessor::process_resinfo($cms,'DOCS',$tempdir,$destdir,\%items,\%resources,\@targets,\@boards,\@announcements,\@quizzes,\@surveys,\@pools,\@groups,\%messages,\@timestamp,\%boardnum,\%resinfo,$udom,$uname,$cdom,$crs,$db_handling,$user_handling,\%total,$seqstem,$seqstem,\@resrcfiles,\@packages,\%hrefs,\@pages,\@sequences);
 
-        my $copy_result = &Apache::imsprocessor::copy_resources('DOCS',$cms,\%hrefs,$tempdir,\@targets,\%urls,$crs,$cdom,$chome,$destdir,$timenow);
+        my $copy_result = &Apache::imsprocessor::copy_resources('DOCS',$cms,\%hrefs,$tempdir,\@targets,\%urls,$crs,$cdom,$destdir,$timenow,\%importareas);
+
+        &Apache::imsprocessor::build_structure($cms,'DOCS',$destdir,\%items,\%resinfo,\%resources,\@targets,\%hrefs,$udom,$uname,'',$timenow,$cdom,$crs,\@timestamp,\%total,\@boards,\@announcements,\@quizzes,\@surveys,\@pools,\%boardnum,\@pages,\@sequences,\@topurls,\@topnames,\@packages,\%includeditems);
 
-        &Apache::imsprocessor::build_structure($cms,'DOCS',$destdir,\%items,\%resinfo,\%resources,\%hrefs,$udom,$uname,'',$timenow,$cdom,$crs,\@timestamp,\%total,\@boards,\@announcements,\@quizzes,\@surveys,\%boardnum,\@pages,\@sequences,\@topurls,\@topnames,\@packages);
- 
         foreach my $item (@pages) {
             my $filename = $timenow.'/pages/'.$item;
-            my $fetchresult= &Apache::lonnet::process_coursefile('propagate',$crs,$cdom,$chome,$filename,'');
+            my $fetchresult= &Apache::lonnet::process_coursefile('propagate',$crs,$cdom,$filename,'');
         }
         foreach my $item (@sequences) {
             unless ($item eq 'Top.sequence' && $toplevel eq 'oldfolder') {
                 my $filename = $timenow.'/sequences/'.$item;
-                my $fetchresult= &Apache::lonnet::process_coursefile('propagate',$crs,$cdom,$chome,$filename,'');
+                my $fetchresult= &Apache::lonnet::process_coursefile('propagate',$crs,$cdom,$filename,'');
             }
         }
         foreach my $item (@resrcfiles) {
             my $filename = $timenow.'/resfiles/'.$item;
-            my $fetchresult= &Apache::lonnet::process_coursefile('propagate',$crs,$cdom,$chome,$filename,'');
+            my $fetchresult= &Apache::lonnet::process_coursefile('propagate',$crs,$cdom,$filename,'');
         }
 
         my @imports = ();
         if ($toplevel eq 'oldfolder') {
             for (my $i=0; $i<@topurls; $i++) {
-                my $url = &Apache::lonnet::unescape($topurls[$i]);
-                my $name = &Apache::lonnet::unescape($topnames[$i]);
-                push @imports, $name, $url;
+                my $url = &unescape($topurls[$i]);
+                my $name = &unescape($topnames[$i]);
+                push(@imports, [$name, $url]);
             }
         } elsif ($toplevel eq 'newfolder') {
-            my $url = &Apache::lonnet::unescape("/uploaded/$cdom/$crs/$timenow/sequences/Top.sequence");
-            my $name = &Apache::lonnet::unescape("$ENV{'form.foldername'}");
-            push @imports, $name, $url;
+            my $url = &unescape("/uploaded/$cdom/$crs/$timenow/sequences/Top.sequence");
+            my $name = &unescape("$env{'form.foldername'}");
+            push(@imports, [$name, $url]);
         }
         my $errtext='';
         my $fatal=0;
         ($errtext,$fatal)=  &Apache::londocs::mapread($crs,$cdom,$folder.'.sequence');
-        if ($#Apache::lonratedt::order<1) {
-            $Apache::lonratedt::order[0]=1;
-            $Apache::lonratedt::resources[1]='';
+        if ($#LONCAPA::map::order<1) {
+            $LONCAPA::map::order[0]=1;
+            $LONCAPA::map::resources[1]='';
         }
         my ($errtext,$fatal)=&Apache::londocs::group_import($crs,$cdom,$folder,'sequence','imsimport',@imports);
         if ($fatal) {
-            print STDERR "Fatal error during group_import\n";
+            &Apache::lonnet::logthis("Fatal error during group_import.");
         }
     }
     if ($tempdir =~ m/^\/home\/httpd\/perl\/tmp\/$crs\/\d{10}/) {
@@ -648,7 +619,7 @@ sub display_three {
        </td>
       </tr>
       <tr bgcolor='#CCCCFF'>
-       <td valign='middle'><img src='/res/adm/pages/bl_step5.gif'>
+       <td valign="middle"><img src="/res/adm/pages/bl_step5.gif" alt="5" />
        </td>
        <td width='100%' align='left'>&nbsp;&nbsp;
         <font face='arial,helvetica,sans-serif'><b>Your import is complete</b></font>
@@ -666,10 +637,10 @@ ENDBLOCK
            <input type="hidden" name="orgurl" value="/adm/coursedocs" />
            <input type="hidden" name="selectrole" value="1" />
            <h3><font color="red">Changes will become active for your current session after
-           <input type="hidden" name="$ENV{'request.role'}" value="1" />
+           <input type="hidden" name="$env{'request.role'}" value="1" />
            <input type="button" value="|;
     $initblock .= &mt('re-initializing course');
-    $initblock .= qq|" onClick="javascript:init(this.form)"/>|;
+    $initblock .= qq|" onClick="javascript:init(this.form)" />|;
     $initblock .= ', '.&mt('or the next time you log in.');
     $initblock .= qq|</font></h3></form>|;  
     $r->print($initblock);