Diff for /loncom/interface/lonbulletin.pm between versions 1.50 and 1.67

version 1.50, 2009/11/26 05:21:43 version 1.67, 2013/09/17 15:04:30
Line 33  use Apache::Constants qw(:common); Line 33  use Apache::Constants qw(:common);
 use Apache::loncommon;  use Apache::loncommon;
 use Apache::lonnet;  use Apache::lonnet;
 use Apache::lontexconvert;  use Apache::lontexconvert;
 use Apache::lonfeedback;  use Apache::lonfeedback; 
   use Apache::lonhtmlgateway;
 use Apache::lonlocal;  use Apache::lonlocal;
 use Apache::lonhtmlcommon;  use Apache::lonhtmlcommon;
 use HTML::Entities();  use HTML::Entities();
Line 78  sub handler { Line 79  sub handler {
   
 # ------------------------------------------------------------ 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'},['forceedit','register','todocs',
                                        'origpage','group','ref']);                                         'origpage','group','ref']);
 # ----------------------------------------------------- Force menu registration  # ----------------------------------------------------- Force menu registration
     my %addentries;      my %addentries;
Line 86  sub handler { Line 87  sub handler {
         $addentries{'onload'} = "document.location='#newpost';";          $addentries{'onload'} = "document.location='#newpost';";
     }      }
 # --------------------------------------------------------------- Force Student  # --------------------------------------------------------------- Force Student
     my $forcestudent='';      my ($forceedit,$forcestudent);
     if ($env{'form.forcestudent'}) { $forcestudent='student'; }      $forceedit = $env{'form.forceedit'};
       if (!$forceedit) {
     my $forceedit='';          $forcestudent=1;
     if ($env{'form.forceedit'}) { $forceedit='edit'; }      }
     my $refarg = '';      my $refarg = '';
     if (exists($env{'form.ref'})) { $refarg = 'ref='.$env{'form.ref'}; }      if (exists($env{'form.ref'})) { $refarg = 'ref='.$env{'form.ref'}; }
   
Line 125  sub handler { Line 126  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 $course_or_group;          my ($course_or_group,$brcrum);
         if($group eq '') {          if($group eq '') {
             $course_or_group="Course";              $course_or_group="Course";
         } else {          } else {
             $course_or_group="Group";              $course_or_group="Group";
         }          }
         my $start_page =          my $registered;
             &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) {
               unless ($env{'form.ref'} eq 'grouplist') {
                   $registered = $env{'form.register'}; 
               }
             my $gpterm =  &Apache::loncommon::group_term();              my $gpterm =  &Apache::loncommon::group_term();
             my $ucgpterm = $gpterm;              my $ucgpterm = $gpterm;
             $ucgpterm =~ s/^(\w)/uc($1)/e;              $ucgpterm =~ s/^(\w)/uc($1)/e;
Line 149  sub handler { Line 146  sub handler {
             if ((ref($groupboards) eq 'ARRAY') && (@{$groupboards} > 0)) {              if ((ref($groupboards) eq 'ARRAY') && (@{$groupboards} > 0)) {
                 $boardtitle = $$boards{$$groupboards[0]}{'title'};                  $boardtitle = $$boards{$$groupboards[0]}{'title'};
             }              }
             $boardurl .= '?register=1&group='.$group;              $boardurl .= '?group='.$group;
             $r->print(&groupboard_breadcrumbs($dom,$crs,$group,$refarg,$gpterm,              if ($registered) {
                                 $ucgpterm,$grp_desc,$boardurl,$boardtitle));                  $boardurl .= '&register='.$env{'form.register'};
               } else {
                   $brcrum = 
                       &groupboard_breadcrumbs($dom,$crs,$group,$refarg,$gpterm,
                                               $ucgpterm,$grp_desc,$boardurl,
                                               $boardtitle);
               }
           } else {
               $registered = $env{'form.register'};
               $brcrum = [];
         }          }
           my $start_page =
               &Apache::loncommon::start_page("$course_or_group Discussion Board",undef,
                                              {'add_entries'    => \%addentries,
                                               'domain'         => $dom,
                                               'bread_crumbs'   => $brcrum, 
                                               'group'          => $group,
                                               'force_register' => $registered}
                                             );
           $r->print($start_page);
     }      }
     my ($allowed);      my ($allowed);
     if ($group ne '') {      if ($group ne '') {
Line 173  sub handler { Line 188  sub handler {
         $allowed=&Apache::lonnet::allowed('mdc',$env{'request.course.id'});          $allowed=&Apache::lonnet::allowed('mdc',$env{'request.course.id'});
     }      }
   
     my $privileged=$allowed;  
     if (($syllabus{'uploaded.lastmodified'}) && (!$forceedit)) {  
         $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) {  
         my $query_str = 'forcestudent=1';  
         if (($group ne '') && ($env{'form.group'} eq $group)) {  
             $query_str.='&amp;group='.$group.'&amp;'.$refarg;  
         }  
         $r->print(  
             '<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>'.  
              &Apache::loncommon::help_open_topic('Uploaded_Templates_PublicView').'</p>');  
     }  elsif ($privileged and $target ne 'tex') {  
         my $query_str = 'forceedit=edit';  
         if (($group ne '') && ($env{'form.group'} eq $group)) {  
             $query_str.='&amp;group='.$group.'&amp;'.$refarg;  
         }  
         $r->print('<a href="'.$r->uri.'?'.$query_str.'"><font size="+1">'  
                      .&mt('Edit').'</font></a>');  
     }  
   
     if (($env{'form.uploaddoc.filename'}) &&      if (($env{'form.uploaddoc.filename'}) &&
         ($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) {
Line 206  sub handler { Line 198  sub handler {
             }              }
             if ($group ne '') {              if ($group ne '') {
                 $syllabus{'uploaded.photourl'}=                  $syllabus{'uploaded.photourl'}=
                     &Apache::lonnet::userfileupload('uploaddoc',1,                      &Apache::lonnet::userfileupload('uploaddoc','coursedoc',
                                                     'bulletin/'.$group.'/'.$marker);                                                      'bulletin/'.$group.'/'.$marker);
             } else {              } else {
                 $syllabus{'uploaded.photourl'}=                  $syllabus{'uploaded.photourl'}=
                     &Apache::lonnet::userfileupload('uploaddoc',1,                      &Apache::lonnet::userfileupload('uploaddoc','coursedoc',
                                                       'bulletin/'.$marker);                                                        'bulletin/'.$marker);
             }              }
         }          }
Line 220  sub handler { Line 212  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};
             $field=~s/\s+$//s;              chomp($field);
             $field=&Apache::lonfeedback::clear_out_html($field,1);              my $gateway = Apache::lonhtmlgateway->new();
               $field = $gateway->process_incoming_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)) {
           #Print Topic as Heading
           my $titletext=&HTML::Entities::encode($syllabus{'aaa_title'},'<>&"');;
           if ($target ne 'tex') {
               $r->print('<h2>'.$titletext.'</h2>');
           } else {
               $r->print('\\\\\textbf{'.&Apache::lonxml::xmlparse($r,'tex',$titletext).'}\\\\');
           }
           #Outputbox and Inputbox for Topic
           if ($allowed) {
               $r->print('<form method="post" action="" enctype="multipart/form-data">');
               &Apache::lontemplate::print_start_template($r,&mt('Title'),'LC_Box');
               $r->print($titletext);
    $r->print("<br /><div>");
    &Apache::lontemplate::print_textarea_template($r, $syllabus{'aaa_title'},
    'aaa_title', Apache::lontemplate->RICH_TEXT_ALWAYS_OFF);
    &Apache::lontemplate::print_saveall_template($r);
    $r->print("</div>");
    &Apache::lontemplate::print_end_template($r);
           }
         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) {
           my $message = '<img src="'.$syllabus{'uploaded.photourl'}.'" alt="'.&mt('Image').'"/>';
           &Apache::lontemplate::print_start_template($r, &mt('Upload a Photo'),'LC_Box');
               $r->print($message);
               $r->print("<br /><br />");
             $r->print(              $r->print(
                 '<form method="post" enctype="multipart/form-data">'.                  '<input type="hidden" name="forceedit" value="'.$env{'form.forceedit'}.'" />'.
                 '<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">'.              &Apache::lontemplate::print_end_template($r);
                 '<input type="hidden" name="forceedit" value="edit" />');  
         }  
         foreach my $field (sort(keys(%syllabusfields))) {  
             if (($syllabus{$field}) || ($allowed)) {  
                 my $message=$syllabus{$field};  
                 if (&Apache::lonfeedback::newline_to_br($message)) {  
                 &Apache::lonfeedback::newline_to_br(\$message);  
                 }  
                 $message  
                     =~s/(https*\:\/\/[^\s]+)/\<a href=\"$1\"\>\<tt\>$1\<\/tt\>\<\/a\>/g;  
                 if ($allowed) {  
                     $message=&Apache::lonspeller::markeduptext($message);  
                 }  
                 $message=&Apache::lontexconvert::msgtexconverted($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) {  
                         $r->print(  
                             '<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').'" />');  
                     }  
                 }  
             }  
         }          }
           #Image in Student view.
           elsif($syllabus{'uploaded.photourl'} && $target ne 'tex'){
               $r->print('<img src="'.$syllabus{'uploaded.photourl'}.'" alt="'.&mt('Image').'"/>');
           }
           
           my %custom_handlers = ( 'aaa_title' => sub {} );
    &Apache::lontemplate::print_template_fields($r, \%syllabus, \%syllabusfields, 
    $target, $allowed, Apache::lontemplate->RICH_TEXT_DETECT_HTML, \%custom_handlers);
         if ($allowed) {          if ($allowed) {
             $r->print('</form>');              $r->print('</form>');
         }          }
         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>');          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.'___'.
Line 326  sub groupboard_breadcrumbs { Line 307  sub groupboard_breadcrumbs {
     my ($cdom,$cnum,$group,$refarg,$gpterm,$ucgpterm,$description,$boardurl,      my ($cdom,$cnum,$group,$refarg,$gpterm,$ucgpterm,$description,$boardurl,
         $boardtitle)= @_;          $boardtitle)= @_;
     &Apache::lonhtmlcommon::clear_breadcrumbs();      &Apache::lonhtmlcommon::clear_breadcrumbs();
       my $brcrum = [];
     if ($refarg ne '') {      if ($refarg ne '') {
         &Apache::lonhtmlcommon::add_breadcrumb          push(@{$brcrum},
             ({href=>"/adm/coursegroups",                {href=>"/adm/coursegroups",
               text=>"Groups",                 text=>"Groups",
               title=>"View course groups"});                 title=>"View course groups"});
     }      }
     &Apache::lonhtmlcommon::add_breadcrumb      push(@{$brcrum},
         ({href=>"/adm/$cdom/$cnum/$group/smppg?$refarg",             {href=>"/adm/$cdom/$cnum/$group/smppg?$refarg",
           text=>"$ucgpterm: $description",              text=>"$ucgpterm: $description",
           title=>"Go to group's home page"},              title=>"Go to group's home page"},
          {href=>"/adm/groupboards?group=$group&amp;$refarg",             {href=>"/adm/groupboards?group=$group&amp;$refarg",
           text=>"Discussion Boards",              text=>"Discussion Boards",
           title=>"Display group discussion boards"},              title=>"Display group discussion boards"},
          {href=>"$boardurl",             {href=>"$boardurl",
           text=>"$boardtitle",              text=>"$boardtitle",
           title=>"$boardtitle"},              title=>"$boardtitle"},
         );          );
     my $output .= &Apache::lonhtmlcommon::breadcrumbs(&mt('[_1] discussion boards - [_2]',$gpterm,$description));      return $brcrum;
     return $output;  
 }  }
   
 1;  1;

Removed from v.1.50  
changed lines
  Added in v.1.67


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