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

version 1.46, 2008/03/03 11:25:59 version 1.57, 2009/12/22 06:32:04
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'}) {          #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.'">'.          foreach my $field (sort(keys(%syllabusfields))) {
   &HTML::Entities::encode($syllabus{$field},'&"<>').              if (($syllabus{$field}) || ($allowed)) {
            '</textarea><input type="submit" name="storesyl" value="'.&mt('Save').'" />');                  my $message=$syllabus{$field};
         }                  if (!&Apache::lonfeedback::contains_block_html($message)) {
     } else {                  &Apache::lonfeedback::newline_to_br(\$message);
                 if ($target ne 'tex') {                  } else {
     $r->print('<h1>'.$message.'</h1>');                      $message = &Apache::lonfeedback::tidy_html($message);
  } else {   }
     $r->print('\\\\\textbf{'.&Apache::lonxml::xmlparse($r,'tex',$message).'}\\\\');                  $message=&Apache::lonhtmlcommon::raw_href_to_link($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},'&"<>').  
            '</textarea><input type="submit" name="storesyl" value="'.&mt('Save').'" />');  
                 }                  }
                   $message=&Apache::lontexconvert::msgtexconverted($message);
                   unless ($field eq 'aaa_title') {
                       if ($target ne 'tex') {
    #output of syllabusfields will be generated here. 
    &Apache::lontemplate::print_start_template($r,$syllabusfields{$field},'LC_Box');
                           $r->print($message);
                           if ($allowed) {
                               $r->print("<br /><div>");
                               &Apache::lontemplate::print_textarea_template($r, $syllabus{$field},
                               $field, Apache::lontemplate->RICH_TEXT_DETECT_HTML);
                               &Apache::lontemplate::print_saveall_template($r);
    $r->print("</div>");
    } 
                       &Apache::lontemplate::print_end_template($r);
                       push(@htmlids,$field);
                       } else {
                           $r->print('\\\\\textbf{'.$syllabusfields{$field}.'}\\\\'.&Apache::lonxml::xmlparse($r,'tex',$message));
                       }
                   }   
             }              }
   }          }
        }          if ($allowed) {
        if ($allowed) {              $r->print('</form>'.
    $r->print('</form>');              &Apache::lonhtmlcommon::htmlareaselectactive(@htmlids));
        }          }
        if ($target ne 'tex') {$r->print('</p>');} else {$r->print('\\\\');}          if ($target ne 'tex'){
               $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.57


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