Annotation of loncom/interface/groupboards.pm, revision 1.21

1.1       raeburn     1: # The LearningOnline Network
                      2: # Group Bulletin Boards Manager
                      3: #
1.21    ! raeburn     4: # $Id: groupboards.pm,v 1.20 2013/09/23 17:35:07 bisitz Exp $
1.14      bisitz      5: #
1.1       raeburn     6: # Copyright Michigan State University Board of Trustees
                      7: #
                      8: # This file is part of the LearningOnline Network with CAPA (LON-CAPA).
                      9: #
                     10: # LON-CAPA is free software; you can redistribute it and/or modify
                     11: # it under the terms of the GNU General Public License as published by
                     12: # the Free Software Foundation; either version 2 of the License, or
                     13: # (at your option) any later version.
                     14: #
                     15: # LON-CAPA is distributed in the hope that it will be useful,
                     16: # but WITHOUT ANY WARRANTY; without even the implied warranty of
                     17: # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
                     18: # GNU General Public License for more details.
                     19: #
                     20: # You should have received a copy of the GNU General Public License
                     21: # along with LON-CAPA; if not, write to the Free Software
                     22: # Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
                     23: #
                     24: # /home/httpd/html/adm/gpl.txt
                     25: #
                     26: # http://www.lon-capa.org/
                     27: #
                     28: 
                     29: package Apache::groupboards;
1.2       albertel   30: 
1.1       raeburn    31: use strict;
                     32: use Apache::Constants qw(:common :http);
1.10      albertel   33: use Apache::loncommon();
1.1       raeburn    34: use Apache::lonnet;
1.10      albertel   35: use Apache::lonuserstate();
                     36: use LONCAPA::map();
1.1       raeburn    37: use Apache::lonlocal;
                     38: use LONCAPA;
                     39: 
                     40: sub handler {
                     41:     my ($r) = @_;
                     42:     &Apache::loncommon::content_type($r,'text/html');
                     43:     $r->send_http_header;
                     44:     return OK if $r->header_only;
                     45: 
                     46:     #  Needs to be in a course
                     47:     if (! ($env{'request.course.fn'})) {
                     48:         # Not in a course
                     49:         $env{'user.error.msg'}=
                     50:      "/adm/groupboards:mdg:0:0:Cannot edit or view course groups";
                     51:         return HTTP_NOT_ACCEPTABLE;
                     52:     }
                     53: 
                     54:     &Apache::loncommon::get_unprocessed_cgi($ENV{'QUERY_STRING'},
1.7       raeburn    55:                         ['group','ref']);
1.1       raeburn    56: 
                     57:     my $cdom = $env{'course.'.$env{'request.course.id'}.'.domain'};
                     58:     my $cnum = $env{'course.'.$env{'request.course.id'}.'.num'};
                     59:     my $now = time;
                     60:     my $crstype = &Apache::loncommon::course_type();
                     61:     my $gpterm =  &Apache::loncommon::group_term();
1.5       raeburn    62:     my $ucgpterm = $gpterm;
                     63:     $ucgpterm =~ s/^(\w)/uc($1)/e;
1.13      schafran   64:     my $bodytitle = $ucgpterm.' Discussion Boards';
1.1       raeburn    65:     my $group = $env{'form.group'};
1.5       raeburn    66:     $group =~ s/\W//g;
1.7       raeburn    67:     my ($description,$earlyout,$refarg);
                     68: 
                     69:     if (exists($env{'form.ref'})) {
                     70:         $refarg = 'ref='.$env{'form.ref'};
                     71:     }
1.5       raeburn    72: 
                     73:     &Apache::lonhtmlcommon::clear_breadcrumbs();
1.1       raeburn    74:     if (!defined($group)) {
1.21    ! raeburn    75:         $earlyout = &mt("No $gpterm defined, so there are no $gpterm discussion boards to display");
1.5       raeburn    76:         $r->print(&display_error($cdom,$cnum,$group,$description,$gpterm,
1.7       raeburn    77:                                  $ucgpterm,$bodytitle,$earlyout,$refarg));
1.5       raeburn    78:         return OK;
                     79:     }
                     80:     my %curr_groups = &Apache::longroup::coursegroups($cdom,$cnum,$group);
                     81:     if (!defined($curr_groups{$group})) {
1.8       raeburn    82:         $earlyout = &mt('Invalid group');
1.5       raeburn    83:         $r->print(&display_error($cdom,$cnum,$group,$description,$gpterm,
1.7       raeburn    84:                                  $ucgpterm,$bodytitle,$earlyout,$refarg));
1.1       raeburn    85:         return OK;
                     86:     }
1.5       raeburn    87:     my %content = &Apache::longroup::get_group_settings($curr_groups{$group});
1.6       albertel   88:     $description = &unescape($content{'description'});
1.5       raeburn    89: 
1.1       raeburn    90:     my $can_create=&Apache::lonnet::allowed('cgb',$env{'request.course.id'}.
                     91:                                             '/'.$group);
1.7       raeburn    92:     my $can_view = &Apache::lonnet::allowed('vcg',$env{'request.course.id'}.($env{'request.course.sec'}?'/'.$env{'request.course.sec'}:''));
1.5       raeburn    93: 
                     94:     if (!$can_view) {
1.7       raeburn    95:         $can_view = &Apache::lonnet::allowed('vgb',$env{'request.course.id'}.
1.1       raeburn    96:                                           '/'.$group);
1.5       raeburn    97:     }
                     98:     if (!$can_view) {
1.21    ! raeburn    99:         $earlyout=&mt("You do not have privileges to view discussion boards in this $gpterm");
1.5       raeburn   100:         $r->print(&display_error($cdom,$cnum,$group,$description,$gpterm,
1.7       raeburn   101:                                  $ucgpterm,$bodytitle,$earlyout,$refarg));
1.5       raeburn   102:         return OK;
                    103:     }
1.1       raeburn   104:     if (defined($env{'form.newbul'})) {
                    105:         if (($can_create) || (&Apache::lonnet::allowed('mdg',$env{'request.course.id'}))) {
1.5       raeburn   106:             $r->print(&boards_header($cdom,$cnum,$group,$description,$gpterm,
1.7       raeburn   107:                                      $ucgpterm,$bodytitle,$refarg));
1.16      raeburn   108:             my ($outcome,$newurl,$bbtitle,$lockfreed) = 
1.2       albertel  109: 		&create_board($cdom,$cnum,$group,$env{'form.newbul'});
1.1       raeburn   110:             if ($outcome eq 'ok') {
                    111:                 my ($furl,$ferr)= &Apache::lonuserstate::readmap($cdom.'/'.$cnum);
1.18      bisitz    112:                 $r->print(&mt('The new discussion board was added successfully.').'<br />');
1.1       raeburn   113:                 $r->print('<table border="0"><tr><td>'.
1.7       raeburn   114:                           '<a href="'.$newurl.'?group='.$group.'&amp;'.$refarg.
                    115:                           '">'.&mt('Edit [_1] board',$bbtitle).'</a></td>'.
1.1       raeburn   116:                            '<td>&nbsp;&nbsp;</td><td>'.
1.7       raeburn   117:                           '<a href="/adm/groupboards?group='.$group.'&amp;'.
                    118:                           $refarg.'">'.&mt('View all group discussion boards').
1.1       raeburn   119:                           '</a></td></tr></table>');
1.16      raeburn   120:                 if ($lockfreed ne 'ok') {
                    121:                     $r->print(&mt('There was a problem removing a lockfile for the group ([_1]).',$description).'<br />'.
1.20      bisitz    122:                               &mt('This may prevent creation of additional discussion boards in this group.').'<br />'.
1.19      raeburn   123:                               &mt('Please contact the [_1]helpdesk[_2] for assistance.',
                    124:                                   '<a href="/adm/helpdesk">','</a>')
                    125:                              );
1.8       raeburn   126:                 }
1.1       raeburn   127:             } else {
1.2       albertel  128:                 $r->print(&mt('There was a problem creating the new discussion board - [_1]','<span class="LC_error">'.$outcome.'</span>').'<br /><a href="/adm/groupboards?group='.$group.'">'.
1.1       raeburn   129:                          &mt('Return to discussion boards').'</a>');
                    130:             }
                    131:             $r->print(&Apache::loncommon::end_page());
                    132:             return OK;
                    133:         }
                    134:     }
                    135:     my $jscript;
                    136:     if (($can_create) || (&Apache::lonnet::allowed('mdg',$env{'request.course.id'}))) {
                    137:         $jscript = qq|
1.5       raeburn   138: <script type="text/javascript">
1.1       raeburn   139: function makebulboard() {
                    140:    var title=prompt('Discussion Board Title');
                    141:    if (title) {
1.8       raeburn   142:     this.document.forms.newbb.newbul.value=title;
1.1       raeburn   143:     this.document.forms.newbb.submit();
                    144:    }
                    145: }
1.5       raeburn   146: </script>
1.1       raeburn   147: |;
                    148:     }
1.5       raeburn   149:     $r->print(&boards_header($cdom,$cnum,$group,$description,$gpterm,$ucgpterm,
1.7       raeburn   150:                              $bodytitle,$refarg,$jscript));
1.4       raeburn   151:     my ($groupboards,$boards) = &Apache::longroup::get_group_bbinfo($cdom,$cnum,
                    152:                                                                     $group);
1.1       raeburn   153:     if (($can_create) || (&Apache::lonnet::allowed('mdg',$env{'request.course.id'}))) {
1.5       raeburn   154:         $r->print('<br /><form method="post" name="newbb" action="/adm/groupboards">'.
1.1       raeburn   155:                   "\n".'<input type="button" name="bbbutton" value="'.
                    156:                   &mt('New Discussion Board').
1.17      bisitz    157:                   '" onclick="javascript:makebulboard();" />'."\n".
1.7       raeburn   158:                   '<input type="hidden" name="newbul" />'."\n".
                    159:                   '<input type="hidden" name="group" value="'.$group.'" />'.
                    160:                   '<input type="hidden" name="ref" value="'.$env{'form.ref'}.'" />'.
1.1       raeburn   161:                   "\n".'</form><br />');
                    162:     }
1.4       raeburn   163:     if (@{$groupboards} > 0) {
1.12      bisitz    164:         $r->print('<br />'
                    165:                  .&Apache::loncommon::start_data_table()
                    166:                  .&Apache::loncommon::start_data_table_header_row()
                    167:                  .'<th>'.&mt('Discussion Boards').'</th>'
                    168:                  .&Apache::loncommon::end_data_table_header_row()
                    169:         );
1.4       raeburn   170:         foreach my $board (@{$groupboards}) {
1.5       raeburn   171:             my $board_url = $$boards{$board}{'url'};
                    172:             if ($board_url =~ /\?/) {
                    173:                 $board_url .= '&amp;group='.$group;
                    174:             } else {
                    175:                 $board_url .= '?group='.$group;
                    176:             }
1.12      bisitz    177:             $r->print(&Apache::loncommon::start_data_table_row()
                    178:                      .'<td>'
                    179:                      .'<a href="'.$board_url.'&amp;'.$refarg.'">'
                    180:                      .$$boards{$board}{'title'}.'</a>'
                    181:                      .'</td>'
                    182:                      .&Apache::loncommon::end_data_table_row()
                    183:             );
1.1       raeburn   184:         }
1.12      bisitz    185:         $r->print(&Apache::loncommon::end_data_table());
1.1       raeburn   186:     } else {
1.12      bisitz    187:         $r->print('<p class="LC_info">'
                    188:                  .&mt('There are currently no discussion boards in this '.$gpterm.'.',)
                    189:                  .'</p>'
                    190:         );
1.1       raeburn   191:     }
                    192:     $r->print(&Apache::loncommon::end_page());
                    193:     return OK;
                    194: }
                    195: 
                    196: sub create_board {
1.8       raeburn   197:     my ($cdom,$cnum,$group,$bbtitle) = @_;
1.16      raeburn   198:     my ($outcome,$newurl,$idtype);
1.8       raeburn   199:     $bbtitle=&unescape($bbtitle);
1.16      raeburn   200:     $idtype = 'inc';
                    201:     my ($boardid,$dellock,$error) = 
                    202:         &Apache::lonnet::get_timebased_id($group,'boardids','groupboards',
                    203:                                           $cdom,$cnum);
                    204:     if ($boardid) {
                    205:          $newurl = '/adm/'.$cdom.'/'.$cnum.'/'.$boardid.'/bulletinboard';
1.8       raeburn   206:     } else {
1.16      raeburn   207:          return ($error,$newurl,$bbtitle,$dellock);
1.8       raeburn   208:     }
1.16      raeburn   209: 
1.8       raeburn   210:     # need to check here if group_boards_$group.sequence is in the course
                    211:     # if not - add it as an item in group_folder_$group.sequence 
1.4       raeburn   212:     my $allbbsmap = &Apache::longroup::get_bbfolder_url($cdom,$cnum,$group);
1.1       raeburn   213:     if ($allbbsmap =~ m|^/uploaded|) {
1.10      albertel  214:         my ($errtext,$fatal)=&LONCAPA::map::mapread($allbbsmap);
1.1       raeburn   215:         if (!$fatal) {
1.10      albertel  216:             my $newidx=&LONCAPA::map::getresidx($newurl);
                    217:             $LONCAPA::map::resources[$newidx]=$bbtitle.':'.$newurl.
1.1       raeburn   218:                                                    ':false:normal:res';
1.10      albertel  219:             push(@LONCAPA::map::order,$newidx);
1.15      raeburn   220:             my ($errtext,$fatal)=&LONCAPA::map::storemap($allbbsmap,1,1);
1.1       raeburn   221:             if ($fatal) {
1.11      albertel  222:                 $outcome = "error: failed to save discussion boards map - $errtext\n";
1.1       raeburn   223:             } else {
1.5       raeburn   224:                 my %boardinfo = (
                    225:                   'group' => $group,
                    226:                 );
                    227:                 $outcome = &Apache::lonnet::put('bulletinpage_'.$boardid,
                    228:                                                 \%boardinfo,$cdom,$cnum);
1.1       raeburn   229:             }
                    230:         } else {
1.2       albertel  231:             $outcome = "error: failed to read all discussion boards map - $errtext\n";
1.1       raeburn   232:         }
                    233:     } else {
1.2       albertel  234:         $outcome = 'error: discussion boards folder absent, '.
1.1       raeburn   235:                    'or in unexpected location - '.$allbbsmap."\n";
                    236:     }
1.16      raeburn   237:     return ($outcome,$newurl,$bbtitle,$dellock);
1.1       raeburn   238: }
                    239: 
1.5       raeburn   240: sub display_error {
1.7       raeburn   241:     my ($cdom,$cnum,$group,$description,$gpterm,$ucgpterm,$bodytitle,$earlyout,
                    242:         $refarg)=@_;
1.5       raeburn   243:     my $output = &boards_header($cdom,$cnum,$group,$description,$gpterm,
1.7       raeburn   244:                                 $ucgpterm,$bodytitle,$refarg);
1.5       raeburn   245:     $output .= $earlyout;
                    246:     $output .= &Apache::loncommon::end_page();
                    247:     return $output;
                    248: }
                    249: 
                    250: sub boards_header {
1.7       raeburn   251:     my ($cdom,$cnum,$group,$description,$gpterm,$ucgpterm,$bodytitle,$refarg,
                    252:         $jscript)=@_;
1.5       raeburn   253:     my $output = &Apache::loncommon::start_page($bodytitle,$jscript);
1.7       raeburn   254:     if ($refarg) {
                    255:         &Apache::lonhtmlcommon::add_breadcrumb
                    256:         ({href=>"/adm/coursegroups",
                    257:           text=>"Groups",
                    258:           title=>"View course groups"},);
                    259:     }
1.5       raeburn   260:     &Apache::lonhtmlcommon::add_breadcrumb
1.7       raeburn   261:         ({href=>"/adm/$cdom/$cnum/$group/smppg?$refarg",
1.5       raeburn   262:           text=>"$ucgpterm: $description",
                    263:           title=>"Go to group's home page"},
1.7       raeburn   264:          {href=>"/adm/groupboards?group=$group&amp;$refarg",
1.5       raeburn   265:           text=>"Discussion Boards",
                    266:           title=>"Display group discussion boards"},);
                    267:     $output .= &Apache::lonhtmlcommon::breadcrumbs(&mt('[_1] discussion boards - [_2]',$gpterm,$description));
                    268:     return $output;
                    269: }
                    270: 
1.1       raeburn   271: 1;

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