--- loncom/interface/lonmsgdisplay.pm 2007/05/02 20:26:08 1.74 +++ loncom/interface/lonmsgdisplay.pm 2007/05/03 12:13:35 1.75 @@ -1,7 +1,7 @@ # The LearningOnline Network with CAPA # Routines for messaging display # -# $Id: lonmsgdisplay.pm,v 1.74 2007/05/02 20:26:08 albertel Exp $ +# $Id: lonmsgdisplay.pm,v 1.75 2007/05/03 12:13:35 raeburn Exp $ # # Copyright Michigan State University Board of Trustees # @@ -737,12 +737,20 @@ $content{'sendername'}.':'. '
'.&mt('Subject').': '.$content{'subject'}. '
'.
               &Apache::lontexconvert::msgtexconverted($content{'message'}).
-            '
'. -&mt('You have to confirm that you received this message. After confirmation, this message will be moved to your regular inbox'). - '
'. - ''. + ''; + my $rec_button = &mt('Move to Inbox'); + my $reprec_button = &mt('Move to Inbox/Compose reply'); + if ($content{'sendback'}) { + $rec_button = &mt('Confirm Receipt'); + $reprec_button = &mt('Confirm Receipt and Reply'); + $result .= &mt('You have to confirm that you have received this message before you can view other pages. After confirmation, this message will be moved to your regular inbox'); + } else { + $result .= &mt('Click one of the buttons below to move the message to your inbox').' '.&mt('Access to other pages will be prevented until you have done this.'); + } + $result .= '
'. + ''. ''; + 'value="'.$reprec_button.'" />'; } # Check to see if there were any messages. if ($result eq '') { @@ -2636,16 +2644,18 @@ sub handler { &printheader($r,'','Confirmed Receipt'); my $replying = 0; foreach my $envkey (keys(%env)) { - if ($envkey=~/^form\.rec\_(.*)$/) { - $r->print(''.&mt('Confirming Receipt').': '. - &Apache::lonmsg::user_crit_received($1).'
'); - } - if ($envkey=~/^form\.reprec\_(.*)$/) { - my $msgid=$1; - $r->print(''.&mt('Confirming Receipt').': '. - &Apache::lonmsg::user_crit_received($msgid).'
'); - &compout($r,'','','',$msgid); - $replying = 1; + if ($envkey=~/^form\.(rep)?rec\_(.*)$/) { + my $msgid = $2; + $r->print(''.&mt('Confirming Receipt').': '); + my $result = &Apache::lonmsg::user_crit_received($msgid); + if ($result =~ /trans:\s+ok/) { + &statuschange($msgid,'read'); + } + $r->print($result.'
'); + if ($1 eq 'rep') { + &compout($r,'','','',$msgid); + $replying = 1; + } } } if (!$replying) {