Diff for /loncom/interface/lonbulletin.pm between versions 1.46 and 1.55

version 1.46, 2008/03/03 11:25:59 version 1.55, 2009/12/08 13:33:12
Line 48  sub handler { Line 48  sub handler {
   
 # ------------------------------------------------------------ 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'}));
     }      }
     my (undef,undef,undef,undef,$marker)=split(/\//,$r->uri);      my (undef,undef,undef,undef,$marker)=split(/\//,$r->uri);
 # Is this even in a course?  # Is this even in a course?
     if (!$env{'request.course.id'}) {      if (!$env{'request.course.id'}) {
  &Apache::loncommon::simple_error_page($r,'Not in a course',          &Apache::loncommon::simple_error_page($r,'Not in a course',
                 'Not in a course');                                                'Not in a course');
         return OK;          return OK;
     }      }
   
     $marker=~s/\D//g;      $marker=~s/\D//g;
   
     if (!$marker) {      if (!$marker) {
  &Apache::loncommon::simple_error_page($r,'Invalid Call',          &Apache::loncommon::simple_error_page($r,'Invalid Call',
       'Invalid Call');                                                'Invalid Call');
         return OK;          return OK;
     }      }
   
Line 83  sub handler { Line 83  sub handler {
 # ----------------------------------------------------- Force menu registration  # ----------------------------------------------------- Force menu registration
     my %addentries;      my %addentries;
     if ($env{'form.origpage'}) {      if ($env{'form.origpage'}) {
  $addentries{'onload'} = "document.location='#newpost';";          $addentries{'onload'} = "document.location='#newpost';";
     }      }
 # --------------------------------------------------------------- Force Student  # --------------------------------------------------------------- Force Student
     my $forcestudent='';      my $forcestudent='';
Line 122  sub handler { Line 122  sub handler {
             }              }
         }          }
     }      }
          
 # --------------------------------------- There is such a user, get environment  # --------------------------------------- There is such a user, get environment
     if ($target ne 'tex') {        if ($target ne 'tex') {
  my $start_page =          my $course_or_group;
     &Apache::loncommon::start_page("Bulletin Board/Discussion",undef,          if($group eq '') {
    {'function'       => $forcestudent,              $course_or_group="Course";
     'add_entries'    => \%addentries,          } else {
     'domain'         => $dom,              $course_or_group="Group";
     'force_register' =>          }
  $env{'form.register'}});          my $start_page =
  $r->print($start_page);              &Apache::loncommon::start_page("$course_or_group Discussion Board",undef,
                                              {'function'       => $forcestudent,
                                               'add_entries'    => \%addentries,
                                               'domain'         => $dom,
                                               'force_register' =>
                                                   $env{'form.register'}});
           $r->print($start_page);
         if ($group ne '' && $env{'form.group'} eq $group) {          if ($group ne '' && $env{'form.group'} eq $group) {
             my $gpterm =  &Apache::loncommon::group_term();              my $gpterm =  &Apache::loncommon::group_term();
             my $ucgpterm = $gpterm;              my $ucgpterm = $gpterm;
Line 158  sub handler { Line 164  sub handler {
         if (!$allowed) {          if (!$allowed) {
             if ((!&Apache::lonnet::allowed('vcg',$env{'request.course.id'}.($env{'request.course.sec'}?'/'.$env{'request.course.sec'}:''))) &&              if ((!&Apache::lonnet::allowed('vcg',$env{'request.course.id'}.($env{'request.course.sec'}?'/'.$env{'request.course.sec'}:''))) &&
                (!&Apache::lonnet::allowed('vgb',$env{'request.course.id'}.                 (!&Apache::lonnet::allowed('vgb',$env{'request.course.id'}.
                                                 '/'.$group))) {                                                   '/'.$group))) {
                  &print_end_page($r,$target);                   &print_end_page($r,$target);
                  return OK;                      return OK;
             }              }
         }          }
     } else {      } else {
Line 169  sub handler { Line 175  sub handler {
   
     my $privileged=$allowed;      my $privileged=$allowed;
     if (($syllabus{'uploaded.lastmodified'}) && (!$forceedit)) {      if (($syllabus{'uploaded.lastmodified'}) && (!$forceedit)) {
   $forcestudent='student';          $forcestudent='student';
     }      }
     if ($target ne 'tex') { $r->print('<table><tr><td>'); }      if ($forcestudent or $target eq 'tex') { $allowed=0; }
       if ($forcestudent or $target eq 'tex') { $allowed=0; }  
        if ($allowed) {
       if ($allowed) {          my $query_str = 'forcestudent=1';
           my $query_str = 'forcestudent=1';          if (($group ne '') && ($env{'form.group'} eq $group)) {
           if (($group ne '') && ($env{'form.group'} eq $group)) {              $query_str.='&amp;group='.$group.'&amp;'.$refarg;
               $query_str.='&amp;group='.$group.'&amp;'.$refarg;          }
           }          #Function Box for Edit Mode.
           $r->print(          my $functionbox = &Apache::lonhtmlcommon::start_funclist();
   '<p>'.          $functionbox .=  &Apache::lonhtmlcommon::add_item_funclist(
 &Apache::loncommon::help_open_topic('Uploaded_Templates_TextBoxes',&mt('Help with filling in text boxes')).'<br /><a href="'.$r->uri.'?'.$query_str.'"><font size="+1">'.&mt('Show Student View').'</font></a>'.                               '<a href="'.$r->uri.'?'.$query_str.'">'.&mt('Show Student View').'</a>'.
  &Apache::loncommon::help_open_topic('Uploaded_Templates_PublicView').'</p>');                                &Apache::loncommon::help_open_topic('Uploaded_Templates_PublicView'));
       }  elsif ($privileged and $target ne 'tex') {          $functionbox.=&Apache::lonhtmlcommon::end_funclist();
           my $query_str = 'forceedit=edit';          $r->print(&Apache::loncommon::head_subbox($functionbox).&Apache::loncommon::help_open_topic('Uploaded_Templates_TextBoxes',&mt('Help with filling in text boxes')));
           if (($group ne '') && ($env{'form.group'} eq $group)) {      } elsif ($privileged and $target ne 'tex') {
               $query_str.='&amp;group='.$group.'&amp;'.$refarg;          my $query_str = 'forceedit=edit';
           }          if (($group ne '') && ($env{'form.group'} eq $group)) {
   $r->print('<a href="'.$r->uri.'?'.$query_str.'"><font size="+1">'              $query_str.='&amp;group='.$group.'&amp;'.$refarg;
     .&mt('Edit').'</font></a>');          }
       }           #Functionbox for Student view.
           my $functionbox = &Apache::lonhtmlcommon::start_funclist();
       if (($env{'form.uploaddoc.filename'}) &&          $functionbox .=  &Apache::lonhtmlcommon::add_item_funclist(
           ($env{'form.storeupl'}) && ($allowed)) {                               "<a href='".$r->uri.'?'.$query_str."'>".&mt('Edit')."</a>");
    if ($env{'form.uploaddoc.filename'}=~/\.(gif|jpg|png|jpeg)$/i) {          $functionbox.=&Apache::lonhtmlcommon::end_funclist();
       if ($syllabus{'uploaded.photourl'}) {          $r->print(&Apache::loncommon::head_subbox($functionbox));
   &Apache::lonnet::removeuploadedurl($syllabus{'uploaded.photourl'});      }
       }  
               if ($group ne '') {      if (($env{'form.uploaddoc.filename'}) &&
           $syllabus{'uploaded.photourl'}=          ($env{'form.storeupl'}) && ($allowed)) {
       &Apache::lonnet::userfileupload('uploaddoc',1,          if ($env{'form.uploaddoc.filename'}=~/\.(gif|jpg|png|jpeg)$/i) {
                                                       'bulletin/'.$group.'/'.$marker);              if ($syllabus{'uploaded.photourl'}) {
               } else {                  &Apache::lonnet::removeuploadedurl($syllabus{'uploaded.photourl'});
                   $syllabus{'uploaded.photourl'}=              }
                       &Apache::lonnet::userfileupload('uploaddoc',1,              if ($group ne '') {
                   $syllabus{'uploaded.photourl'}=
                       &Apache::lonnet::userfileupload('uploaddoc',1,
                                                       'bulletin/'.$group.'/'.$marker);
               } else {
                   $syllabus{'uploaded.photourl'}=
                       &Apache::lonnet::userfileupload('uploaddoc',1,
                                                       'bulletin/'.$marker);                                                        'bulletin/'.$marker);
               }              }
    }          }
           $syllabus{'uploaded.lastmodified'}=time;          $syllabus{'uploaded.lastmodified'}=time;
           &Apache::lonnet::put('bulletinpage_'.$marker,\%syllabus,$dom,$crs);          &Apache::lonnet::put('bulletinpage_'.$marker,\%syllabus,$dom,$crs);
        }      }
        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};
                $field=~s/\s+$//s;              $field=~s/\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('bulletinpage_'.$marker,\%syllabus,$dom,$crs);          &Apache::lonnet::put('bulletinpage_'.$marker,\%syllabus,$dom,$crs);
        }      }
   
 # ---------------------------------------------------------------- Get syllabus  # ---------------------------------------------------------------- Get discussion board
     if (($syllabus{'uploaded.lastmodified'}) || ($allowed)) {      if (($syllabus{'uploaded.lastmodified'}) || ($allowed)) {
        if ($syllabus{'uploaded.photourl'}) {          if ($syllabus{'uploaded.photourl'}) {
    &Apache::lonnet::allowuploaded('/adm/syllabus',              &Apache::lonnet::allowuploaded('/adm/syllabus',
   $syllabus{'uploaded.photourl'});                                             $syllabus{'uploaded.photourl'});
    $r->print('<img src="'.$syllabus{'uploaded.photourl'}.          }
        '" align="right" />');          #Outputbox and Inputbox for Image upload
        }          if ($allowed) {
        if ($allowed) {              &Apache::lontemplate::print_template($r, &mt('Upload a Photo'), '<img src="'.$syllabus{'uploaded.photourl'}.'" alt="'.&mt('Image').'"/>',$allowed,'LC_Box');
            $r->print(              $r->print(
  '<form method="post" enctype="multipart/form-data">'.                  '<form method="post" enctype="multipart/form-data" action="">'.
   '<input type="hidden" name="forceedit" value="edit" />'.                  '<input type="hidden" name="forceedit" value="edit" />'.
          '<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" action="">'.
  '</form><form method="post">'.                  '<input type="hidden" name="forceedit" value="edit" />');
          '<input type="hidden" name="forceedit" value="edit" />');          }
        }          #Image in Student view.
        foreach my $field (sort(keys(%syllabusfields))) {          elsif($syllabus{'uploaded.photourl'} && $target ne 'tex'){
           if (($syllabus{$field}) || ($allowed)) {              $r->print('<img src="'.$syllabus{'uploaded.photourl'}.'" alt="'.&mt('Image').'"/>');
               my $message=$syllabus{$field};          }
       &Apache::lonfeedback::newline_to_br(\$message);          foreach my $field (sort(keys(%syllabusfields))) {
       $message              if (($syllabus{$field}) || ($allowed)) {
         =~s/(https*\:\/\/[^\s]+)/\<a href=\"$1\"\>\<tt\>$1\<\/tt\>\<\/a\>/g;                  my $message=$syllabus{$field};
       if ($allowed) {                  if (!&Apache::lonfeedback::contains_block_html($message)) {
   $message=&Apache::lonspeller::markeduptext($message);                  &Apache::lonfeedback::newline_to_br(\$message);
       }                  }
       $message=&Apache::lontexconvert::msgtexconverted($message);                  $message=&Apache::lonhtmlcommon::raw_href_to_link($message);
       unless ($field eq 'aaa_title') {  
  if (($field ne 'bbb_content') || ($allowed)) {  
     if ($target ne 'tex') {  
  $r->print('<h3>'.$syllabusfields{$field}.'</h3>');  
     } else {  
  $r->print('\\\\\textbf{'.$syllabusfields{$field}.'}\\\\');  
     }  
  }  
  if ($target ne 'tex') {  
     $r->print('<blockquote>'.  
                               $message.'</blockquote>');  
  } else {  
     $r->print(' '.&Apache::lonxml::xmlparse($r,'tex',$message).' ');  
  }  
                  if ($allowed) {  
                 $r->print('<br /><textarea cols="80" rows="10" name="'.$field.'">'.  
   &HTML::Entities::encode($syllabus{$field},'&"<>').  
            '</textarea><input type="submit" name="storesyl" value="'.&mt('Save').'" />');  
         }  
     } else {  
                 if ($target ne 'tex') {  
     $r->print('<h1>'.$message.'</h1>');  
  } else {  
     $r->print('\\\\\textbf{'.&Apache::lonxml::xmlparse($r,'tex',$message).'}\\\\');  
  }  
                 if ($allowed) {                  if ($allowed) {
                  $r->print(                      $message=&Apache::lonspeller::markeduptext($message);
                 '<br />'.&mt('Topic').'<br /><textarea cols="80" rows="2" name="'.$field.'">'.                  }
   &HTML::Entities::encode($syllabus{$field},'&"<>').                  $message=&Apache::lontexconvert::msgtexconverted($message);
            '</textarea><input type="submit" name="storesyl" value="'.&mt('Save').'" />');                  unless ($field eq 'aaa_title') {
                       #Outputbox
                       if ($target ne 'tex') {
                           &Apache::lontemplate::print_template($r, $syllabusfields{$field}, $message,$allowed,'LC_Box');
                       } else {
                           $r->print('\\\\\textbf{'.$syllabusfields{$field}.'}\\\\'.&Apache::lonxml::xmlparse($r,'tex',$message));
                       }
                       #Inputbox
                       if ($allowed) {
                            &Apache::lontemplate::print_editbox_template($r, $syllabus{$field}, $field);
                       }
                   } else {
                       #Print Topic as Heading
                       if ($target ne 'tex') {
                           $r->print('<h1>'.$message.'</h1>');
                       } else {
                           $r->print('\\\\\textbf{'.&Apache::lonxml::xmlparse($r,'tex',$message).'}\\\\');
                       }
                       #Outputbox and Inputbox for Topic
                       if ($allowed) {
                                &Apache::lontemplate::print_template($r, $syllabusfields{$field}, $message,$allowed,'LC_Box');
                                &Apache::lontemplate::print_editbox_template($r, $syllabus{$field}, $field);
                       }
                 }                  }
             }              }
   }          }
        }          if ($allowed) {
        if ($allowed) {              $r->print('</form>');
    $r->print('</form>');          }
        }          if ($target ne 'tex'){
        if ($target ne 'tex') {$r->print('</p>');} else {$r->print('\\\\');}              $r->print('<br/><br/><hr/><br/>');
           }
           else {
               $r->print(&Apache::lonxml::xmlparse($r,'tex','<br/><br/><hr/><br/>'));
           }
     } else {      } else {
        $r->print('<p>'.&mt('No page information provided.').'</p>');          $r->print('<p>'.&mt('No page information provided.').'</p>');
     }      }
     if ($target ne 'tex') { $r->print('</td></tr></table>'); }      #Lists discussion posts and box for a new discussion post.
     if ($target ne 'tex') {      if ($target ne 'tex') {
  $r->print(&Apache::lonfeedback::list_discussion          $r->print(&Apache::lonfeedback::list_discussion
            ('board','OPEN','bulletin___'.$marker.'___'.                        ('board','OPEN','bulletin___'.$marker.'___'.
             $r->uri,undef,$group));                         $r->uri,undef,$group));
     } else {      } else {
  $r->print('\\\\'.&Apache::lonxml::xmlparse($r,'tex',&Apache::lonfeedback::list_discussion          $r->print('\\\\'.&Apache::lonxml::xmlparse($r,'tex',&Apache::lonfeedback::list_discussion
            ('board','OPEN','bulletin___'.$marker.'___'.                       ('board','OPEN','bulletin___'.$marker.'___'.
             $r->uri,undef,$group)));                        $r->uri,undef,$group)));
     }      }
     &print_end_page($r,$target);      &print_end_page($r,$target);
     return OK;      return OK;

Removed from v.1.46  
changed lines
  Added in v.1.55


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