Diff for /loncom/interface/lonsimplepage.pm between versions 1.28 and 1.38

version 1.28, 2005/11/15 22:05:04 version 1.38, 2006/04/10 19:59:54
Line 45  sub handler { Line 45  sub handler {
     return OK if $r->header_only;      return OK if $r->header_only;
     my $target=$env{'form.grade_target'};      my $target=$env{'form.grade_target'};
 # ------------------------------------------------------------ Print the screen  # ------------------------------------------------------------ Print the screen
     if ($target ne 'tex') {      if ($target eq 'tex') {
  my $html=&Apache::lonxml::xmlbegin();  
  $r->print(<<ENDDOCUMENT);  
 $html  
 <head>  
 <title>The LearningOnline Network with CAPA</title>  
 ENDDOCUMENT  
     } else {  
  $r->print(&Apache::lonprintout::print_latex_header($env{'form.latex_type'}));   $r->print(&Apache::lonprintout::print_latex_header($env{'form.latex_type'}));
     }       } 
     my (undef,undef,undef,undef,$marker,$caller)=split(/\//,$r->uri);      my (undef,undef,undef,undef,$marker,$caller)=split(/\//,$r->uri);
 # Is this even in a course?  # Is this even in a course?
     unless ($env{'request.course.id'}) {      unless ($env{'request.course.id'}) {
  if ($target ne 'tex') {   if ($target ne 'tex') {
     $r->print('</head><body>Not in a course</body></html>');      &Apache::loncommon::simple_error_page($r,'','Not in a course');
     return OK;  
  } else {   } else {
     $r->print('\textbf{Not in a course}\end{document}');      $r->print('\textbf{Not in a course}\end{document}');
  }   }
    return OK;
     }      }
   
     my $dom = $env{'course.'.$env{'request.course.id'}.'.domain'};      my $dom = $env{'course.'.$env{'request.course.id'}.'.domain'};
     my $crs = $env{'course.'.$env{'request.course.id'}.'.num'};      my $crs = $env{'course.'.$env{'request.course.id'}.'.num'};
     my $grp_view_permission = &Apache::lonnet::allowed('vcg',      my $grp_view_permission = &Apache::lonnet::allowed('vcg',
                                                    $env{'request.course.id'});                                                     $env{'request.course.id'});
       my $namespace;
   
     my %curr_group = ();      my %curr_group = ();
     my %groupinfo = ();      my %groupinfo = ();
     if ($caller eq 'grppg') {      if ($caller eq 'grppg') {
         $marker =~ s/\W//g;          $marker =~ s/\W//g;
         unless(&Apache::lonnet::get_coursegroups($dom,$crs,\%curr_group,          $namespace = 'grppage_'.$marker;
                                                                     $marker)) {          my %curr_groups;
             $r->print('<body>Invalid group name</body>');          if (!&Apache::loncommon::coursegroups(\%curr_groups,$dom,$crs,$marker)) {
             return OK;      &Apache::loncommon::simple_error_page($r,'','Invalid group name');
       return OK;
         }          }
           %groupinfo = 
       &Apache::loncommon::get_group_settings($curr_groups{$marker});
     } else {        } else {  
         $marker=~s/\D//g;          $marker=~s/\D//g;
           $namespace = 'smppage_'.$marker;
     }      }
   
     unless ($marker) {      if (!$marker) {
  $r->print('<body>Invalid call</body>');   &Apache::loncommon::simple_error_page($r,'','Invalid call');
         return OK;   return OK;
     }      }
   
 # --------------------------------------------------------- The syllabus fields  # --------------------------------------------------------- The syllabus fields
Line 102  ENDDOCUMENT Line 100  ENDDOCUMENT
 # ------------------------------------------------------------ Get query string  # ------------------------------------------------------------ Get query string
     &Apache::loncommon::get_unprocessed_cgi      &Apache::loncommon::get_unprocessed_cgi
                         ($ENV{'QUERY_STRING'},['forcestudent','forceedit','register']);                          ($ENV{'QUERY_STRING'},['forcestudent','forceedit','register']);
 # ----------------------------------------------------- Force menu registration  
     my $addentries='';  
     if ($env{'form.register'}) {  
        $addentries=' onLoad="'.&Apache::lonmenu::loadevents().  
    '" onUnload="'.&Apache::lonmenu::unloadevents().'"';  
        $r->print(&Apache::lonmenu::registerurl(1));  
     }  
 # --------------------------------------------------------------- Force Student  # --------------------------------------------------------------- Force Student
     my $forcestudent='';      my $forcestudent='';
     if ($env{'form.forcestudent'} || $target eq 'tex' ) { $forcestudent='student'; };      if ($env{'form.forcestudent'} || $target eq 'tex' ) { $forcestudent='student'; };
      my $forceedit='';      my $forceedit='';
      if ($env{'form.forceedit'}) { $forceedit='edit'; }      if ($env{'form.forceedit'}) { $forceedit='edit'; }
   
      
     my %syllabus=&Apache::lonnet::dump($caller.'_'.$marker,$dom,$crs);      my %syllabus=&Apache::lonnet::dump($namespace,$dom,$crs);
                 
 # --------------------------------------- There is such a user, get environment  # --------------------------------------- There is such a user, get environment
   
Line 125  ENDDOCUMENT Line 116  ENDDOCUMENT
         if ($caller eq 'grppg') {          if ($caller eq 'grppg') {
             $title = 'Group Page';              $title = 'Group Page';
         }          }
  $r->print(&Apache::lonhtmlcommon::htmlareaheaders().   my $start_page = 
   '</head>'.&Apache::loncommon::bodytag      &Apache::loncommon::start_page($title,undef,
   ($title,$forcestudent,$addentries,'',$dom,$env{'form.register'}));     {'function'       => $forcestudent,
       'domain'         => $dom,
       'force_register' =>
    $env{'form.register'},});
    $r->print($start_page);
     }      }
   
     if ($caller eq 'grppg') {      if ($caller eq 'grppg') {
Line 135  ENDDOCUMENT Line 130  ENDDOCUMENT
                            (&Apache::loncommon::check_group_access($caller))) {                             (&Apache::loncommon::check_group_access($caller))) {
             unless(&Apache::lonnet::allowed('vgh',              unless(&Apache::lonnet::allowed('vgh',
                                       $env{'request.course.id'}.'/'.$marker)) {                                        $env{'request.course.id'}.'/'.$marker)) {
                 &display_group_links($r,$target,$marker,%groupinfo);                  &display_group_links($r,$target,$marker,'view',%groupinfo);
                 return OK;                  return OK;
             }              }
         } else {          } else {
       my $msg = 
    &mt('You do not currently have rights to view this group.');
             if ($target ne 'tex') {              if ($target ne 'tex') {
                 $r->print('</head><body>You do not currently have rights to                  $r->print("<p>$msg</p>".
                                         view this group.    &Apache::loncommon::end_page());
                            </body></html>');  
                 return OK;  
             } else {              } else {
                 $r->print('\textbf{You do not currently have rights to view this group}\end{document}');                  $r->print('\textbf{'.$msg.'}\end{document}');
             }              }
       return OK;
         }          }
     }      }
   
Line 189  ENDDOCUMENT Line 185  ENDDOCUMENT
             }              }
  }   }
  $syllabus{'uploaded.lastmodified'}=time;   $syllabus{'uploaded.lastmodified'}=time;
  &Apache::lonnet::put($caller.'_'.$marker,\%syllabus,$dom,$crs);   &Apache::lonnet::put($namespace,\%syllabus,$dom,$crs);
     }      }
     if (($allowed) && ($env{'form.storesyl'})) {      if (($allowed) && ($env{'form.storesyl'})) {
  foreach (keys %syllabusfields) {   foreach (keys %syllabusfields) {
Line 202  ENDDOCUMENT Line 198  ENDDOCUMENT
     $syllabus{$_}=$field;      $syllabus{$_}=$field;
  }   }
  $syllabus{'uploaded.lastmodified'}=time;   $syllabus{'uploaded.lastmodified'}=time;
  &Apache::lonnet::put($caller.'_'.$marker,\%syllabus,$dom,$crs);   &Apache::lonnet::put($namespace,\%syllabus,$dom,$crs);
     }      }
   
 # ---------------------------------------------------------------- Get syllabus  # ---------------------------------------------------------------- Get syllabus
Line 240  ENDDOCUMENT Line 236  ENDDOCUMENT
                 if ($_ eq 'abb_links' && $caller eq 'grppg') {                  if ($_ eq 'abb_links' && $caller eq 'grppg') {
                     $r->print('<br /><input type="hidden" name="'.$_.                      $r->print('<br /><input type="hidden" name="'.$_.
                                           '" value="'.$syllabus{$_}.'" />');                                            '" value="'.$syllabus{$_}.'" />');
                     &display_group_links($r,$target,$marker,%groupinfo);                      &display_group_links($r,$target,$marker,'edit',%groupinfo);
                     $r->print('<br />');                      $r->print('<br />');
                 } elsif ($_ eq 'aaa_title') {                  } elsif ($_ eq 'aaa_title') {
                     if ($target ne 'tex') {                      if ($target ne 'tex') {
Line 298  ENDDOCUMENT Line 294  ENDDOCUMENT
  $r->print('<p>No page information provided.</p>');   $r->print('<p>No page information provided.</p>');
     }      }
     if ($env{'form.grade_target'} ne 'tex') {      if ($env{'form.grade_target'} ne 'tex') {
  $r->print('</body></html>');   $r->print(&Apache::loncommon::end_page());
     } else {      } else {
  $r->print('\end{document}');   $r->print('\end{document}');
     }      }
Line 306  ENDDOCUMENT Line 302  ENDDOCUMENT
 }  }
   
 sub display_group_links {  sub display_group_links {
     my ($r,$target,$marker,%groupinfo) = @_;      my ($r,$target,$marker,$context,%groupinfo) = @_;
     my @available = ();      my @available = ();
                                                                                      
     my %menu = ();      my %menu = ();
     %{$menu{'email'}} = (      %{$menu{'email'}} = (
                         text => 'Group e-mail',                          text => 'Group e-mail',
                         href => '/adm/email?group='.$marker,                          href => '/adm/email?compose=group&group='.$marker,
                       );                        );
     %{$menu{'discussion'}} = (      %{$menu{'discussion'}} = (
                         text => 'Discussion Boards',                          text => 'Discussion Boards',
Line 324  sub display_group_links { Line 319  sub display_group_links {
                       );                        );
     %{$menu{'files'}} = (      %{$menu{'files'}} = (
                         text => 'File repository',                          text => 'File repository',
                         href => '/adm/portfolio?group='.$marker,                          href => '/adm/coursegrp_portfolio?group='.$marker,
                       );                        );
     %{$menu{'roster'}} = (      %{$menu{'roster'}} = (
                         text => 'Membership roster',                          text => 'Membership roster',
Line 352  sub display_group_links { Line 347  sub display_group_links {
             $r->print('<h3>Functions</h3>'.$output);              $r->print('<h3>Functions</h3>'.$output);
         }          }
     } else {      } else {
         my $output = 'No group functionality (e.g., e-mail, discussion,chat or file upload) is currently available to you in this group: '.$marker;          my $output;
           if ($context eq 'edit') {
               $output = 'No group functionality';
           } else {  
               $output = 'No group functionality (e.g., e-mail, discussion, chat or file upload) is currently available to you in this group: '.$marker;
           }
         if ($target eq 'tex') {          if ($target eq 'tex') {
             $r->print(&Apache::lonxml::xmlparse($r,'tex',$output));              $r->print(&Apache::lonxml::xmlparse($r,'tex',$output));
         } else {          } else {

Removed from v.1.28  
changed lines
  Added in v.1.38


FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>