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

version 1.46, 2008/03/03 11:25:59 version 1.60, 2010/06/05 22:07:05
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;          }
           }          if ($env{'form.register'}) {
           $r->print(              $query_str .= '&amp;register='.$env{'form.register'};
   '<p>'.          }
 &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>'.          #Function Box for Edit Mode.
  &Apache::loncommon::help_open_topic('Uploaded_Templates_PublicView').'</p>');          my $functionbox = &Apache::lonhtmlcommon::start_funclist();
       }  elsif ($privileged and $target ne 'tex') {          $functionbox .=  &Apache::lonhtmlcommon::add_item_funclist(
           my $query_str = 'forceedit=edit';                               '<a href="'.$r->uri.'?'.$query_str.'">'.&mt('Show Student View').'</a>'.
           if (($group ne '') && ($env{'form.group'} eq $group)) {                                &Apache::loncommon::help_open_topic('Uploaded_Templates_PublicView'));
               $query_str.='&amp;group='.$group.'&amp;'.$refarg;          $functionbox.=&Apache::lonhtmlcommon::end_funclist();
           }          $r->print(&Apache::loncommon::head_subbox($functionbox).&Apache::loncommon::help_open_topic('Uploaded_Templates_TextBoxes',&mt('Help with filling in text boxes')));
   $r->print('<a href="'.$r->uri.'?'.$query_str.'"><font size="+1">'      } elsif ($privileged and $target ne 'tex') {
     .&mt('Edit').'</font></a>');          my $query_str = 'forceedit=edit';
       }           if (($group ne '') && ($env{'form.group'} eq $group)) {
               $query_str.='&amp;group='.$group.'&amp;'.$refarg;
       if (($env{'form.uploaddoc.filename'}) &&          }
           ($env{'form.storeupl'}) && ($allowed)) {          if ($env{'form.register'}) {
    if ($env{'form.uploaddoc.filename'}=~/\.(gif|jpg|png|jpeg)$/i) {              $query_str .= '&amp;register='.$env{'form.register'};
       if ($syllabus{'uploaded.photourl'}) {          }
   &Apache::lonnet::removeuploadedurl($syllabus{'uploaded.photourl'});          #Functionbox for Student view.
       }          my $functionbox = &Apache::lonhtmlcommon::start_funclist();
               if ($group ne '') {          $functionbox .=  &Apache::lonhtmlcommon::add_item_funclist(
           $syllabus{'uploaded.photourl'}=                               "<a href='".$r->uri.'?'.$query_str."'>".&mt('Edit')."</a>");
       &Apache::lonnet::userfileupload('uploaddoc',1,          $functionbox.=&Apache::lonhtmlcommon::end_funclist();
                                                       'bulletin/'.$group.'/'.$marker);          $r->print(&Apache::loncommon::head_subbox($functionbox));
               } else {      }
                   $syllabus{'uploaded.photourl'}=  
                       &Apache::lonnet::userfileupload('uploaddoc',1,      if (($env{'form.uploaddoc.filename'}) &&
           ($env{'form.storeupl'}) && ($allowed)) {
           if ($env{'form.uploaddoc.filename'}=~/\.(gif|jpg|png|jpeg)$/i) {
               if ($syllabus{'uploaded.photourl'}) {
                   &Apache::lonnet::removeuploadedurl($syllabus{'uploaded.photourl'});
               }
               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'}) {          #Print Topic as Heading
    &Apache::lonnet::allowuploaded('/adm/syllabus',          my $titletext=&HTML::Entities::encode($syllabus{'aaa_title'},'<>&"');;
   $syllabus{'uploaded.photourl'});          if ($target ne 'tex') {
    $r->print('<img src="'.$syllabus{'uploaded.photourl'}.              $r->print('<h2>'.$titletext.'</h2>');
        '" align="right" />');          } else {
        }              $r->print('\\\\\textbf{'.&Apache::lonxml::xmlparse($r,'tex',$titletext).'}\\\\');
        if ($allowed) {          }
            $r->print(          #Outputbox and Inputbox for Topic
  '<form method="post" enctype="multipart/form-data">'.          if ($allowed) {
   '<input type="hidden" name="forceedit" value="edit" />'.              $r->print('<form method="post" action="" enctype="multipart/form-data">');
          '<h3>'.&mt('Upload a Photo').'</h3>'.              &Apache::lontemplate::print_start_template($r,&mt('Title'),'LC_Box');
          '<input type="file" name="uploaddoc" size="50">'.              $r->print($titletext);
          '<input type="submit" name="storeupl" value="'.&mt('Upload').'">'.   $r->print("<br /><div>");
  '</form><form method="post">'.   &Apache::lontemplate::print_textarea_template($r, $syllabus{'aaa_title'},
          '<input type="hidden" name="forceedit" value="edit" />');   'aaa_title', Apache::lontemplate->RICH_TEXT_ALWAYS_OFF);
        }   &Apache::lontemplate::print_saveall_template($r);
        foreach my $field (sort(keys(%syllabusfields))) {   $r->print("</div>");
           if (($syllabus{$field}) || ($allowed)) {   &Apache::lontemplate::print_end_template($r);
               my $message=$syllabus{$field};          }
       &Apache::lonfeedback::newline_to_br(\$message);          if ($syllabus{'uploaded.photourl'}) {
       $message              &Apache::lonnet::allowuploaded('/adm/syllabus',
         =~s/(https*\:\/\/[^\s]+)/\<a href=\"$1\"\>\<tt\>$1\<\/tt\>\<\/a\>/g;                                             $syllabus{'uploaded.photourl'});
       if ($allowed) {          }
   $message=&Apache::lonspeller::markeduptext($message);          my @htmlids=();
       }          #Outputbox and Inputbox for Image upload
       $message=&Apache::lontexconvert::msgtexconverted($message);          if ($allowed) {
       unless ($field eq 'aaa_title') {          my $message = '<img src="'.$syllabus{'uploaded.photourl'}.'" alt="'.&mt('Image').'"/>';
  if (($field ne 'bbb_content') || ($allowed)) {          &Apache::lontemplate::print_start_template($r, &mt('Upload a Photo'),'LC_Box');
     if ($target ne 'tex') {              $r->print($message);
  $r->print('<h3>'.$syllabusfields{$field}.'</h3>');              $r->print("<br /><br />");
     } else {              $r->print(
  $r->print('\\\\\textbf{'.$syllabusfields{$field}.'}\\\\');                  '<input type="hidden" name="forceedit" value="edit" />'.
     }                  '<input type="file" name="uploaddoc" size="50" />'.
  }                  '<input type="submit" name="storeupl" value="'.&mt('Upload').'" />'.
  if ($target ne 'tex') {                  '<input type="hidden" name="forceedit" value="edit" />');
     $r->print('<blockquote>'.              &Apache::lontemplate::print_end_template($r);
                               $message.'</blockquote>');          }
  } else {          #Image in Student view.
     $r->print(' '.&Apache::lonxml::xmlparse($r,'tex',$message).' ');          elsif($syllabus{'uploaded.photourl'} && $target ne 'tex'){
  }              $r->print('<img src="'.$syllabus{'uploaded.photourl'}.'" alt="'.&mt('Image').'"/>');
                  if ($allowed) {          }
                 $r->print('<br /><textarea cols="80" rows="10" name="'.$field.'">'.          
   &HTML::Entities::encode($syllabus{$field},'&"<>').          my %custom_handlers = ( 'aaa_title' => sub {} );
            '</textarea><input type="submit" name="storesyl" value="'.&mt('Save').'" />');   @htmlids = &Apache::lontemplate::print_template_fields($r, \%syllabus, \%syllabusfields, 
         }   $target, $allowed, Apache::lontemplate->RICH_TEXT_DETECT_HTML, \%custom_handlers);
     } else {          if ($allowed) {
                 if ($target ne 'tex') {              $r->print('</form>'.
     $r->print('<h1>'.$message.'</h1>');              &Apache::lonhtmlcommon::htmlareaselectactive(@htmlids));
  } else {          }
     $r->print('\\\\\textbf{'.&Apache::lonxml::xmlparse($r,'tex',$message).'}\\\\');          if ($target ne 'tex'){
  }              $r->print('<br/><br/><hr/><br/>');
                 if ($allowed) {          }
                  $r->print(          else {
                 '<br />'.&mt('Topic').'<br /><textarea cols="80" rows="2" name="'.$field.'">'.              $r->print(&Apache::lonxml::xmlparse($r,'tex','<br/><br/><hr/><br/>'));
   &HTML::Entities::encode($syllabus{$field},'&"<>').          }
            '</textarea><input type="submit" name="storesyl" value="'.&mt('Save').'" />');  
                 }  
             }  
   }  
        }  
        if ($allowed) {  
    $r->print('</form>');  
        }  
        if ($target ne 'tex') {$r->print('</p>');} else {$r->print('\\\\');}  
     } else {      } else {
        $r->print('<p>'.&mt('No page information provided.').'</p>');          if ($target ne 'tex') {
              $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.60


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