Diff for /loncom/interface/lonsimplepage.pm between versions 1.79 and 1.82

version 1.79, 2009/05/07 16:20:37 version 1.82, 2009/05/19 09:59:48
Line 51  sub get_db_name { Line 51  sub get_db_name {
     my $db_name;      my $db_name;
   
     if ($dom && $crs && ($udom eq $dom) && ($uname eq $crs)) {      if ($dom && $crs && ($udom eq $dom) && ($uname eq $crs)) {
  $marker =~ s/\W//g;          $marker =~ s/\W//g;
  $db_name = 'grppage_'.$marker;          $db_name = 'grppage_'.$marker;
     } else {      } else {
  $marker=~s/\D//g;          $marker=~s/\D//g;
         $db_name = 'smppage_'.$marker;          $db_name = 'smppage_'.$marker;
     }      }
     return if (!defined($marker));      return if (!defined($marker));
Line 70  sub handler { Line 70  sub handler {
     my $target=$env{'form.grade_target'};      my $target=$env{'form.grade_target'};
 # ------------------------------------------------------------ Print the screen  # ------------------------------------------------------------ Print the screen
     if ($target eq 'tex') {      if ($target eq 'tex') {
  $r->print(&Apache::lonprintout::print_latex_header($env{'form.latex_type'}));          $r->print(&Apache::lonprintout::print_latex_header($env{'form.latex_type'}));
     }      }
   
 # 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') {
     &Apache::loncommon::simple_error_page($r,'','Not in a course');              &Apache::loncommon::simple_error_page($r,'','Not in a course');
  } else {          } else {
     $r->print('\textbf{Not in a course}\end{document}');              $r->print('\textbf{Not in a course}\end{document}');
  }          }
  return OK;          return OK;
     }      }
   
     my $db_name = &get_db_name($r->uri);      my $db_name = &get_db_name($r->uri);
Line 93  sub handler { Line 93  sub handler {
     my %groupinfo = ();      my %groupinfo = ();
     if ($db_name =~ /^grppage_/) {      if ($db_name =~ /^grppage_/) {
         $group = (split(m{/},$r->uri))[4];          $group = (split(m{/},$r->uri))[4];
  $group =~ s/\W//g;          $group =~ s/\W//g;
         my %curr_groups = &Apache::longroup::coursegroups($dom,$crs,$group);          my %curr_groups = &Apache::longroup::coursegroups($dom,$crs,$group);
         if (!%curr_groups) {          if (!%curr_groups) {
     &Apache::loncommon::simple_error_page($r,'','Invalid group name');              &Apache::loncommon::simple_error_page($r,'','Invalid group name');
     return OK;              return OK;
         }          }
         %groupinfo =          %groupinfo =
     &Apache::longroup::get_group_settings($curr_groups{$group});          &Apache::longroup::get_group_settings($curr_groups{$group});
         $group_desc = &unescape($groupinfo{'description'});          $group_desc = &unescape($groupinfo{'description'});
     }      }
   
     if (!$db_name) {      if (!$db_name) {
  &Apache::loncommon::simple_error_page($r,'','Invalid call');          &Apache::loncommon::simple_error_page($r,'','Invalid call');
  return OK;          return OK;
     }      }
   
 # --------------------------------------------------------- The syllabus fields  # --------------------------------------------------------- The syllabus fields
Line 143  sub handler { Line 143  sub handler {
         if ($group ne '') {          if ($group ne '') {
             $title = 'Simple Group Page';              $title = 'Simple Group Page';
         }          }
  my $start_page =          my $start_page =
     &Apache::loncommon::start_page($title,undef,          &Apache::loncommon::start_page($title,undef,
    {'function'       => $forcestudent,                         {'function'       => $forcestudent,
     'domain'         => $dom,                          'domain'         => $dom,
     'force_register' =>                          'force_register' =>
  $env{'form.register'},});                          $env{'form.register'},});
  $r->print($start_page);          $r->print($start_page);
     }      }
   
     if ($group ne '') {      if ($group ne '') {
Line 179  sub handler { Line 179  sub handler {
                 return OK;                  return OK;
             }              }
         } else {          } else {
     my $msg =              my $msg =
  &mt('You do not currently have rights to view this group.');              &mt('You do not currently have rights to view this group.');
             if ($target ne 'tex') {              if ($target ne 'tex') {
                 $r->print("<p>$msg</p>".                  $r->print("<p>$msg</p>".
   &Apache::loncommon::end_page());                  &Apache::loncommon::end_page());
             } else {              } else {
                 $r->print('\textbf{'.$msg.'}\end{document}');                  $r->print('\textbf{'.$msg.'}\end{document}');
             }              }
     return OK;              return OK;
         }          }
         my ($blocked,$blocktext) =          my ($blocked,$blocktext) =
              &Apache::loncommon::blocking_status('groups');               &Apache::loncommon::blocking_status('groups');
Line 210  sub handler { Line 210  sub handler {
     }      }
     my $privileged=$allowed;      my $privileged=$allowed;
     if (($syllabus{'uploaded.lastmodified'}) && (!$forceedit)) {      if (($syllabus{'uploaded.lastmodified'}) && (!$forceedit)) {
  $forcestudent='student';          $forcestudent='student';
     }      }
   
     if ($forcestudent or $target eq 'tex') { $allowed=0; }      if ($forcestudent or $target eq 'tex') { $allowed=0; }
   
     if (($env{'form.uploaddoc.filename'} and $target ne 'tex') &&      if (($env{'form.uploaddoc.filename'} and $target ne 'tex') &&
  ($env{'form.storeupl'}) && ($allowed)) {      ($env{'form.storeupl'}) && ($allowed)) {
  if ($env{'form.uploaddoc.filename'}=~/\.(gif|jpg|png|jpeg)$/i) {          if ($env{'form.uploaddoc.filename'}=~/\.(gif|jpg|png|jpeg)$/i) {
     if ($syllabus{'uploaded.photourl'}) {              if ($syllabus{'uploaded.photourl'}) {
  &Apache::lonnet::removeuploadedurl($syllabus{'uploaded.photourl'});                  &Apache::lonnet::removeuploadedurl($syllabus{'uploaded.photourl'});
     }              }
             if ($group ne '') {              if ($group ne '') {
                 $syllabus{'uploaded.photourl'}=&Apache::lonnet::userfileupload(                  $syllabus{'uploaded.photourl'}=&Apache::lonnet::userfileupload(
                                               'uploaddoc',1,"grouppage/$group");                                                'uploaddoc',1,"grouppage/$group");
             } else {              } else {
         $syllabus{'uploaded.photourl'}=                  $syllabus{'uploaded.photourl'}=
      &Apache::lonnet::userfileupload('uploaddoc',1,'simplepage');                  &Apache::lonnet::userfileupload('uploaddoc',1,'simplepage');
             }              }
  }          }
  $syllabus{'uploaded.lastmodified'}=time;          $syllabus{'uploaded.lastmodified'}=time;
  &Apache::lonnet::put($db_name,\%syllabus,$dom,$crs);          &Apache::lonnet::put($db_name,\%syllabus,$dom,$crs);
     }      }
     if ($allowed && $env{'form.delupl'}) {      if ($allowed && $env{'form.delupl'}) {
         if ($syllabus{'uploaded.photourl'}) {          if ($syllabus{'uploaded.photourl'}) {
Line 240  sub handler { Line 240  sub handler {
         }          }
     }      }
     if (($allowed) && ($env{'form.storesyl'})) {      if (($allowed) && ($env{'form.storesyl'})) {
  foreach my $syl_field (keys(%syllabusfields)) {          foreach my $syl_field (keys(%syllabusfields)) {
     my $field=$env{'form.'.$syl_field};              my $field=$env{'form.'.$syl_field};
     chomp($field);              chomp($field);
     $field=~s/\s+$//s;              $field=~s/\s+$//s;
     $field=~s/^\s+//s;              $field=~s/^\s+//s;
     $field=~s/\<br\s*\/*\>$//s;              $field=~s/\<br\s*\/*\>$//s;
     $field=&Apache::lonfeedback::clear_out_html($field,1);              $field=&Apache::lonfeedback::clear_out_html($field,1);
     $syllabus{$syl_field}=$field;              $syllabus{$syl_field}=$field;
  }          }
  $syllabus{'uploaded.lastmodified'}=time;          $syllabus{'uploaded.lastmodified'}=time;
  &Apache::lonnet::put($db_name,\%syllabus,$dom,$crs);          &Apache::lonnet::put($db_name,\%syllabus,$dom,$crs);
     }      }
   
 #---Print help Text  #---Print help Text
 if($target ne 'tex'){      if($target ne 'tex'){
  if($allowed){          if ($allowed) {
  $r->print(&Apache::loncommon::help_open_topic('Uploaded_Templates_TextBoxes',&mt('Help with filling in text boxes')));              $r->print(&Apache::loncommon::help_open_topic('Uploaded_Templates_TextBoxes',&mt('Help with filling in text boxes')));
  }          }
 }      }
 #---Print Function  #---Print Function
  if ($target ne 'tex') {      if ($target ne 'tex') {
  if($allowed || $privileged){          if ($allowed || $privileged) {
                         $r->print(&Apache::lontemplate::start_functionslist());              $r->print(&Apache::lontemplate::start_functionslist());
  if($allowed){              if ($allowed) {
                                 $r->print(&Apache::lontemplate::item_functionslist(                  $r->print(&Apache::lontemplate::item_functionslist(
                                     '<a href="'.$r->uri.'?forcestudent=1">'.&mt('Show Student View').'</a>'                  '<a href="'.$r->uri.'?forcestudent=1">'.&mt('Show Student View').'</a>'
                                    .&Apache::loncommon::help_open_topic('Uploaded_Templates_PublicView')));                  .&Apache::loncommon::help_open_topic('Uploaded_Templates_PublicView')));
  }elsif($privileged){              } elsif ($privileged) {
  my $edittext = &mt('Edit');                  my $edittext = &mt('Edit');
         if ($group ne '') {                      if ($group ne '') {
             $edittext = &mt('Edit Group Homepage');                      $edittext = &mt('Edit Group Homepage');
         }                  }
                                 $r->print(&Apache::lontemplate::item_functionslist(                  $r->print(&Apache::lontemplate::item_functionslist(
                                     '<a href="'.$r->uri.'?forceedit=edit'.$refarg.'">'.$edittext.'</a>'));                  '<a href="'.$r->uri.'?forceedit=edit'.$refarg.'">'.$edittext.'</a>'));
         if ($group ne '') {                  if ($group ne '') {
             if ($group_edit_perm) {                      if ($group_edit_perm) {
                                                 $r->print(&Apache::lontemplate::item_functionslist(                          $r->print(&Apache::lontemplate::item_functionslist(
                                                     '<a href="/adm/coursegroups?action=modify&amp;refpage=grouplist'                          '<a href="/adm/coursegroups?action=modify&amp;refpage=grouplist'
                                                    .'&amp;state=pick_task&amp;groupname='.$group.'">'                          .'&amp;state=pick_task&amp;groupname='.$group.'">'
                                                    .&mt('Edit Group Settings').'</a>'));                          .&mt('Edit Group Settings').'</a>'));
             }                         }
       }                      }
  }              }
                         $r->print(&Apache::lontemplate::end_functionslist());              $r->print(&Apache::lontemplate::end_functionslist());
  }          }
   }      }
   
 # ---------------------------------------------------------------- Get syllabus  # ---------------------------------------------------------------- Get syllabus
     if ((($syllabus{'uploaded.lastmodified'}) &&      if ((($syllabus{'uploaded.lastmodified'}) &&
          (($group ne '' && ($group_home_view || $group_edit_perm ||           (($group ne '' && ($group_home_view || $group_edit_perm ||
            $group_view_perm)) || ($group eq ''))) || ($allowed)) {             $group_view_perm)) || ($group eq ''))) || ($allowed)) {
  my $image;          my $image;
  if ($syllabus{'uploaded.photourl'}) {          if ($syllabus{'uploaded.photourl'}) {
     &Apache::lonnet::allowuploaded('/adm/smppg',              &Apache::lonnet::allowuploaded('/adm/smppg',
    $syllabus{'uploaded.photourl'});                      $syllabus{'uploaded.photourl'});
   
     $image='<img src="'.$syllabus{'uploaded.photourl'}.'"              $image='<img src="'.$syllabus{'uploaded.photourl'}.'"
                             />';                              />';
     if ($target eq 'tex') {              if ($target eq 'tex') {
  $image=&Apache::lonxml::xmlparse($r,'tex',$image);                  $image=&Apache::lonxml::xmlparse($r,'tex',$image);
             }              }
         }          }
   
  if ($allowed) {          if ($allowed) {
     $r->print(              $r->print(
       '<form method="post" enctype="multipart/form-data">'.                    '<form method="post" enctype="multipart/form-data">'.
       '<input type="hidden" name="forceedit" value="edit" />'.                    '<input type="hidden" name="forceedit" value="edit" />'.
       '<h3>'.&mt('Upload a Photo').'</h3>'.                    '<h3>'.&mt('Upload a Photo').'</h3>'.
       '<input type="file" name="uploaddoc" size="50" />'.                    '<input type="file" name="uploaddoc" size="50" />'.
       '<input type="submit" name="storeupl" value="'.&mt('Upload').'" />'.                    '<input type="submit" name="storeupl" value="'.&mt('Upload').'" />'.
       '</form><form method="post">'.                    '</form><form method="post">'.
                       '<input type="hidden" name="forceedit" value="edit" />');                    '<input type="hidden" name="forceedit" value="edit" />');
         if($syllabus{'uploaded.photourl'}) {              if ($syllabus{'uploaded.photourl'}) {
       $r->print('<form method="post"><input type="submit" name="delupl" value="'.&mt('Delete Photo').'" />' );                  $r->print('<form method="post"><input type="submit" name="delupl" value="'.&mt('Delete Photo').'" />' );
         }              }
  }          }
  if($allowed){          if ($allowed) {
                $r->print($image.'<div class="clear">&nbsp;</div>');              $r->print($image.'<div class="clear">&nbsp;</div>');
        }          }
   
  foreach my $field (sort(keys(%syllabusfields))) {          foreach my $field (sort(keys(%syllabusfields))) {
     if (($syllabus{$field}) || ($allowed) ||              if (($syllabus{$field}) || ($allowed) ||
                 ($field eq 'abb_links' && $group ne '')) {                  ($field eq 'abb_links' && $group ne '')) {
  my $message=$syllabus{$field};                  my $message=$syllabus{$field};
  &Apache::lonfeedback::newline_to_br(\$message);                  &Apache::lonfeedback::newline_to_br(\$message);
  $message                  $message=~s/(https*\:\/\/[^\s]+)/\<a href=\"$1\"\>\<tt\>$1\<\/tt\>\<\/a\>/g;
     =~s/(https*\:\/\/[^\s]+)/\<a href=\"$1\"\>\<tt\>$1\<\/tt\>\<\/a\>/g;                  if ($allowed) {
  if ($allowed) {                      $message=&Apache::lonspeller::markeduptext($message);
     $message=&Apache::lonspeller::markeduptext($message);                  }
  }                  if ($target ne 'tex') {
  if ($target ne 'tex') {                      $message=&Apache::lontexconvert::msgtexconverted($message);
     $message=&Apache::lontexconvert::msgtexconverted($message);                  }
  }  
                 if ($field eq 'abb_links' && $group ne '') {                  if ($field eq 'abb_links' && $group ne '') {
                     $r->print('<br /><input type="hidden" name="'.$field.                      $r->print('<br /><input type="hidden" name="'.$field.
                                           '" value="'.$syllabus{$field}.'" />');                                            '" value="'.$syllabus{$field}.'" />');
                     &display_group_links($r,$target,$group,'edit',$refarg,                      &display_group_links($r,$target,$group,'edit',$refarg,
                                          %groupinfo);                                      %groupinfo);
                     $r->print('<br />');                      $r->print('<br />');
                 } elsif ($field eq 'aaa_title') {                  } elsif ($field eq 'aaa_title') {
                     if ($target ne 'tex') {                      if ($target ne 'tex') {
  if($allowed){                          if ($allowed) {
  $r->print('<p>');                              $r->print('<p>');
  }                          }
                         $r->print('<h2>'.$message.'</h2>');                          $r->print('<h2>'.$message.'</h2>');
                     } else {                      } else {
                         my $safeinit;                          my $safeinit;
Line 351  if($target ne 'tex'){ Line 350  if($target ne 'tex'){
                     }                      }
                     if ($allowed) {                      if ($allowed) {
                         if ($env{'form.grade_target'} ne 'tex') {                          if ($env{'form.grade_target'} ne 'tex') {
     &Apache::lontemplate::print_template($r, &mt('Title'), $message, $allowed, 'LC_ContentBoxSpecial');                              &Apache::lontemplate::print_template($r, &mt('Title'), $message, $allowed, 'LC_ContentBoxSpecial');
     &Apache::lontemplate::print_editbox_template($r,$syllabus{$field},$field);                              &Apache::lontemplate::print_editbox_template($r,$syllabus{$field},$field);
     $r->print('</p>');                              $r->print('</p>');
                         } else {                          } else {
                             my $safeinit;                              my $safeinit;
                             $r->print(&Apache::lonxml::xmlparse($r,'tex',$syllabus{$field},$safeinit));                              $r->print(&Apache::lonxml::xmlparse($r,'tex',$syllabus{$field},$safeinit));
                         }                          }
                     }                      }
     if(!$allowed) {$r->print($image); }                      if (!$allowed) {$r->print($image); }
                 } else {                  } else {
     if ($target ne 'tex') {                      if ($target ne 'tex') {
  if($allowed){                          if ($allowed) {
  $r->print('<p>');                              $r->print('<p>');
  }                          }
  &Apache::lontemplate::print_template($r,$syllabusfields{$field},$message,$allowed,'LC_ContentBoxSpecial');                          &Apache::lontemplate::print_template($r,$syllabusfields{$field},$message,$allowed,'LC_ContentBoxSpecial');
     } else {                      } else {
  my $safeinit;                          my $safeinit;
  $r->print(&Apache::lonxml::xmlparse($r,'tex','<h3>'.$syllabusfields{$field}.'</h3>'));                          $r->print(&Apache::lonxml::xmlparse($r,'tex','<h3>'.$syllabusfields{$field}.'</h3>'));
  $r->print(&Apache::lonxml::xmlparse($r,'tex',$message));                          $r->print(&Apache::lonxml::xmlparse($r,'tex',$message));
     }                      }
     if ($allowed) {                      if ($allowed) {
  if ($target ne 'tex') {                          if ($target ne 'tex') {
     &Apache::lontemplate::print_editbox_template($r,$syllabus{$field},$field);                              &Apache::lontemplate::print_editbox_template($r,$syllabus{$field},$field);
     $r->print('</p>');                              $r->print('</p>');
  } else {                          } else {
     my $safeinit;                              my $safeinit;
     $r->print(&Apache::lonxml::xmlparse($r,'tex',$syllabus{$field},$safeinit));                              $r->print(&Apache::lonxml::xmlparse($r,'tex',$syllabus{$field},$safeinit));
  }                          }
     }                      }
  }                  }
     }              }
  }          }
  if ($allowed && ($env{'form.grade_target'} ne 'tex')) {          if ($allowed && ($env{'form.grade_target'} ne 'tex')) {
     $r->print(&Apache::lonhtmlcommon::htmlareaselectactive              $r->print(&Apache::lonhtmlcommon::htmlareaselectactive
       ('bbb_content').'</form>');                  ('bbb_content').'</form>');
  }          }
  if ($env{'form.grade_target'} ne 'tex') {$r->print('</p>');}          if ($env{'form.grade_target'} ne 'tex') {$r->print('</p>');}
   
     } else {      } else {
         if ($group ne '') {          if ($group ne '') {
             &display_group_links($r,$target,$group,'view',$refarg,%groupinfo);              &display_group_links($r,$target,$group,'view',$refarg,%groupinfo);
         } else {          } else {
     $r->print('<p>'.&mt('No page information provided.').'</p>');              $r->print('<p>'.&mt('No page information provided.').'</p>');
         }          }
     }      }
     if ($env{'form.grade_target'} ne 'tex') {      if ($env{'form.grade_target'} ne 'tex') {
  $r->print(&Apache::loncommon::end_page());          $r->print(&Apache::loncommon::end_page());
     } else {      } else {
  $r->print('\end{document}');          $r->print('\end{document}');
     }      }
     return OK;      return OK;
 }  }

Removed from v.1.79  
changed lines
  Added in v.1.82


FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>
500 Internal Server Error

Internal Server Error

The server encountered an internal error or misconfiguration and was unable to complete your request.

Please contact the server administrator at root@localhost to inform them of the time this error occurred, and the actions you performed just before this error.

More information about this error may be available in the server error log.