alecpl
2009-07-13 3536577bcbc908dbfd26d8b74696ce3da30bf48b
- improve responsiveness by flushing template output asap, also set the \Seen flag after message page display


2 files modified
34 ■■■■■ changed files
program/include/rcube_template.php 4 ●●●● patch | view | raw | blame | history
program/steps/mail/show.inc 30 ●●●●● patch | view | raw | blame | history
program/include/rcube_template.php
@@ -294,6 +294,10 @@
            $this->write();
        }
    // set output asap
    ob_flush();
    flush();
        if ($exit) {
            exit;
        }
program/steps/mail/show.inc
@@ -25,10 +25,6 @@
if ($_GET['_uid']) {
  $MESSAGE = new rcube_message(get_input_value('_uid', RCUBE_INPUT_GET));
  // set message charset as default
  if (!empty($MESSAGE->headers->charset))
    $IMAP->set_charset($MESSAGE->headers->charset);
  // if message not found (wrong UID)...
  if (empty($MESSAGE->headers)) {
    $OUTPUT->show_message('messageopenerror', 'error');
@@ -64,6 +60,10 @@
    send_nocacheing_headers();
  else if (empty($CONFIG['devel_mode']))
    send_modified_header($_SESSION['login_time'], $etag, !$MESSAGE->headers->seen);
  // set message charset as default
  if (!empty($MESSAGE->headers->charset))
    $IMAP->set_charset($MESSAGE->headers->charset);
  $OUTPUT->set_pagetitle($MESSAGE->subject);
  
@@ -143,11 +143,9 @@
      $OUTPUT->set_env('last_uid', $last);
    }
  // mark message as read
  if (!$MESSAGE->headers->seen) {
    $IMAP->set_flag($MESSAGE->uid, 'SEEN');
    $RCMAIL->plugins->exec_hook('message_read', array('uid' => $MESSAGE->uid, 'mailbox' => $IMAP->mailbox, 'message' => $MESSAGE));
  }
  if (!$MESSAGE->headers->seen)
    $RCMAIL->plugins->exec_hook('message_read', array('uid' => $MESSAGE->uid,
    'mailbox' => $IMAP->mailbox, 'message' => $MESSAGE));
}
@@ -223,9 +221,17 @@
if ($RCMAIL->action=='print' && $OUTPUT->template_exists('printmessage'))
  $OUTPUT->send('printmessage');
  $OUTPUT->send('printmessage', false);
else if ($RCMAIL->action=='preview' && $OUTPUT->template_exists('messagepreview'))
  $OUTPUT->send('messagepreview');
  $OUTPUT->send('messagepreview', false);
else
  $OUTPUT->send('message');
  $OUTPUT->send('message', false);
// mark message as read
if ($MESSAGE && $MESSAGE->headers && !$MESSAGE->headers->seen)
  $IMAP->set_flag($MESSAGE->uid, 'SEEN');
exit;
?>