adding phpdoc blocks
authortokul <tokul@7612ce4b-ef26-0410-bec9-ea0150e637f0>
Mon, 1 Nov 2004 10:29:36 +0000 (10:29 +0000)
committertokul <tokul@7612ce4b-ef26-0410-bec9-ea0150e637f0>
Mon, 1 Nov 2004 10:29:36 +0000 (10:29 +0000)
fixed test sound popup button
whitespace fixes
removed "options saved" message from options_save hook. This hook is active before
any html output begins.
removed includes that are already loaded by validate.php
functions/display_messages.php is already loaded by validate.php, if file based
prefs are used. db_prefs does not include it.

git-svn-id: https://svn.code.sf.net/p/squirrelmail/code/trunk/squirrelmail@8298 7612ce4b-ef26-0410-bec9-ea0150e637f0

plugins/newmail/index.php
plugins/newmail/newmail.php
plugins/newmail/newmail_opt.php
plugins/newmail/setup.php
plugins/newmail/testsound.php

index 04efb25..766c7e0 100644 (file)
@@ -1,19 +1,16 @@
 <?php
-
-   /**
-    **  index.php -- Displays the main frameset
-    **
-    **  Copyright (c) 1999-2004 The SquirrelMail development team
-    **  Licensed under the GNU GPL. For full terms see the file COPYING.
-    **
-    **  Redirects to the login page.
-    **
-    **  $Id$
-    * @package plugins
-    * @subpackage newmail
-    **/
-
-   header("Location:../../src/login.php\n\n");
-   exit();
-
-?>
+/**
+ *  index.php -- Displays the main frameset
+ *
+ *  Copyright (c) 1999-2004 The SquirrelMail development team
+ *  Licensed under the GNU GPL. For full terms see the file COPYING.
+ *
+ *  Redirects to the login page.
+ *
+ * @version $Id$
+ * @package plugins
+ * @subpackage newmail
+ **/
+header("Location:../../src/login.php\n\n");
+exit();
+?>
\ No newline at end of file
index 04d9210..0e88712 100644 (file)
@@ -1,14 +1,13 @@
 <?php
-
 /**
- * newmail.php
+ * newmail.php - popup page
  *
  * Copyright (c) 1999-2004 The SquirrelMail Project Team
  * Licensed under the GNU GPL. For full terms see the file COPYING.        
  *
  * Displays all options relating to new mail sounds
  *
- * $Id$
+ * @version $Id$
  * @package plugins
  * @subpackage newmail
  */
@@ -18,8 +17,6 @@ define('SM_PATH','../../');
 
 /* SquirrelMail required files. */
 require_once(SM_PATH . 'include/validate.php');
-require_once(SM_PATH . 'include/load_prefs.php');
-require_once(SM_PATH . 'functions/page_header.php');
 
 sqGetGlobalVar('numnew', $numnew, SQ_GET);
 
index c0a3b2a..a118c09 100644 (file)
@@ -1,14 +1,13 @@
 <?php
-
 /**
- * newmails_opt.php
+ * newmails_opt.php - options page
  *
  * Copyright (c) 1999-2004 The SquirrelMail Project Team
  * Licensed under the GNU GPL. For full terms see the file COPYING.
  *
  * Displays all options relating to new mail sounds
  *
- * $Id$
+ * @version $Id$
  * @package plugins
  * @subpackage newmail
  */
@@ -18,10 +17,8 @@ define('SM_PATH','../../');
 
 /* SquirrelMail required files. */
 require_once(SM_PATH . 'include/validate.php');
-require_once(SM_PATH . 'functions/page_header.php');
+/* sqm_baseuri function */
 require_once(SM_PATH . 'functions/display_messages.php');
-require_once(SM_PATH . 'functions/imap.php');
-require_once(SM_PATH . 'include/load_prefs.php');
 
 displayPageHeader($color, 'None');
 
@@ -152,7 +149,7 @@ if ($allowsound == "true") {
             "window.open('testsound.php?sound='+media_sel.options[media_sel.selectedIndex].value, 'TestSound'," .
             "'width=150,height=30,scrollbars=no');" .
             'return false;' .
-            ' /"></td></tr>' .
+            '" /></td></tr>' .
             html_tag( 'tr', "\n" .
                 html_tag( 'td', _("Current File:"), 'right', '', 'nowrap' ) .
                     html_tag( 'td', '<input type="hidden" value="' .
@@ -164,6 +161,7 @@ echo html_tag( 'tr', "\n" .
     html_tag( 'td', '&nbsp;' ) .
         html_tag( 'td',
             '<input type="hidden" name="optmode" value="submit" />' .
+            '<input type="hidden" name="optpage" value="newmail" />' .
             '<input type="submit" value="' . _("Submit") . '" name="submit_newmail" />',
         'left' )
      ) . "\n";
index 0e3d2c0..0505765 100644 (file)
 <?php
+/**
+ * newmail.php
+ *
+ * Copyright (c) 1999-2004 The SquirrelMail Project Team
+ * Copyright (c) 2000 by Michael Huttinger
+ * Licensed under the GNU GPL. For full terms see the file COPYING.
+ *
+ * Quite a hack -- but my first attempt at a plugin.  We were
+ * looking for a way to play a sound when there was unseen
+ * messages to look at.  Nice for users who keep the squirrel
+ * mail window up for long periods of time and want to know
+ * when mail arrives.
+ *
+ * Basically, I hacked much of left_main.php into a plugin that
+ * goes through each mail folder and increments a flag if
+ * there are unseen messages.  If the final count of unseen
+ * folders is > 0, then we play a sound (using the HTML at the
+ * far end of this script).
+ *
+ * This was tested with IE5.0 - but I hear Netscape works well,
+ * too (with a plugin).
+ *
+ * @version $Id$
+ * @package plugins
+ * @subpackage newmail
+ */
 
-   /**
-    * newmail.php
-    *
-    * Copyright (c) 1999-2002 The SquirrelMail Project Team
-    * Copyright (c) 2000 by Michael Huttinger
-    * Licensed under the GNU GPL. For full terms see the file COPYING.
-    *
-    * Quite a hack -- but my first attempt at a plugin.  We were
-    * looking for a way to play a sound when there was unseen
-    * messages to look at.  Nice for users who keep the squirrel
-    * mail window up for long periods of time and want to know
-    * when mail arrives.
-    *
-    * Basically, I hacked much of left_main.php into a plugin that
-    * goes through each mail folder and increments a flag if
-    * there are unseen messages.  If the final count of unseen
-    * folders is > 0, then we play a sound (using the HTML at the
-    * far end of this script).
-    *
-    * This was tested with IE5.0 - but I hear Netscape works well,
-    * too (with a plugin).
-    *
-    * $Id$
-    * @package plugins
-    * @subpackage newmail
-    */
-
-    /**
-    */
-    include_once(SM_PATH . 'functions/display_messages.php');
-
-    function CheckNewMailboxSound($imapConnection, $mailbox, $real_box, $delimeter, $unseen, &$total_new) {
-    
-        global $trash_folder, $sent_folder,
-               $unseen_notify, $newmail_allbox, 
-               $newmail_recent;
-
-        $mailboxURL = urlencode($real_box);
-
-        // Skip folders for Sent and Trash
-
-        if ($real_box == $sent_folder ||
-            $real_box == $trash_folder) {
-            return 0;
-        }
+/**
+ */
+include_once(SM_PATH . 'functions/display_messages.php');
 
-        if (($unseen_notify == 2 && $real_box == 'INBOX') ||
-            ($unseen_notify == 3 && ($newmail_allbox == 'on' ||
-                                     $real_box == 'INBOX'))) {
-            $status = sqimap_status_messages( $imapConnection, $real_box);
-            if($newmail_recent == 'on') {
-                $total_new += $status['RECENT'];
-            } else {
-                $total_new += $status['UNSEEN'];
-            }
-            if ($total_new) {
-                    return 1;
-            }
-            
-        }
+/**
+ * Checks if mailbox contains new messages.
+ *
+ * @param object $imapConnection
+ * @param mixed $mailbox FIXME: option is not used
+ * @param string $real_box unformated mailbox name 
+ * @param mixed $delimeter FIXME: option is not used
+ * @param string $unseen FIXME: option is not used
+ * @param integer $total_new number of new messages
+ * @return bool true, if there are new messages
+ */
+function CheckNewMailboxSound($imapConnection, $mailbox, $real_box, $delimeter, $unseen, &$total_new) {
+    global $trash_folder, $sent_folder,
+        $unseen_notify, $newmail_allbox, 
+        $newmail_recent;
+
+    $mailboxURL = urlencode($real_box);
+
+    // Skip folders for Sent and Trash
+    if ($real_box == $sent_folder ||
+        $real_box == $trash_folder) {
         return 0;
     }
 
-    function squirrelmail_plugin_init_newmail() {
-        global $squirrelmail_plugin_hooks;
-
-        $squirrelmail_plugin_hooks['left_main_before']['newmail'] = 'newmail_plugin';
-        $squirrelmail_plugin_hooks['optpage_register_block']['newmail'] = 'newmail_optpage_register_block';
-        $squirrelmail_plugin_hooks['options_save']['newmail'] = 'newmail_sav';
-        $squirrelmail_plugin_hooks['loading_prefs']['newmail'] = 'newmail_pref';
+    if (($unseen_notify == 2 && $real_box == 'INBOX') ||
+        ($unseen_notify == 3 && ($newmail_allbox == 'on' ||
+                                 $real_box == 'INBOX'))) {
+        $status = sqimap_status_messages( $imapConnection, $real_box);
+        if($newmail_recent == 'on') {
+            $total_new += $status['RECENT'];
+        } else {
+            $total_new += $status['UNSEEN'];
+        }
+        if ($total_new) {
+            return 1;
+        }
     }
+    return 0;
+}
+
+/** 
+ * Init newmail plugin
+ */
+function squirrelmail_plugin_init_newmail() {
+    global $squirrelmail_plugin_hooks;
+
+    $squirrelmail_plugin_hooks['left_main_before']['newmail'] = 'newmail_plugin';
+    $squirrelmail_plugin_hooks['optpage_register_block']['newmail'] = 'newmail_optpage_register_block';
+    $squirrelmail_plugin_hooks['options_save']['newmail'] = 'newmail_sav';
+    $squirrelmail_plugin_hooks['loading_prefs']['newmail'] = 'newmail_pref';
+    $squirrelmail_plugin_hooks['optpage_set_loadinfo']['newmail'] = 'newmail_set_loadinfo';
+}
 
-    function newmail_optpage_register_block() {
-       // Gets added to the user's OPTIONS page.
-       global $optpage_blocks;
-
-       if ( checkForJavascript() ) {
-       /* Register Squirrelspell with the $optionpages array. */
-           $optpage_blocks[] = array(
-               'name' => _("NewMail Options"),
-               'url'  => SM_PATH . 'plugins/newmail/newmail_opt.php',
-               'desc' => _("This configures settings for playing sounds and/or showing popup windows when new mail arrives."),
-               'js'   => TRUE
+/**
+ * Register newmail option block
+ */
+function newmail_optpage_register_block() {
+    // Gets added to the user's OPTIONS page.
+    global $optpage_blocks;
+
+    if ( checkForJavascript() ) {
+        /* Register Squirrelspell with the $optionpages array. */
+        $optpage_blocks[] = array(
+            'name' => _("NewMail Options"),
+            'url'  => SM_PATH . 'plugins/newmail/newmail_opt.php',
+            'desc' => _("This configures settings for playing sounds and/or showing popup windows when new mail arrives."),
+            'js'   => TRUE
             );
-        }
     }
+}
 
-    function newmail_sav() {
-        global $data_dir, $username;
-
-        if ( sqgetGlobalVar('submit_newmail', $submit, SQ_POST) ) {        
-            $media_enable = '';
-            $media_popup = '';
-            $media_allbox = '';
-            $media_recent = '';
-            $media_changetitle = '';
-            $media_sel = '';
-
-            sqgetGlobalVar('media_enable',      $media_enable,      SQ_POST);
-            sqgetGlobalVar('media_popup',       $media_popup,       SQ_POST);
-            sqgetGlobalVar('media_allbox',      $media_allbox,      SQ_POST);
-            sqgetGlobalVar('media_recent',      $media_recent,      SQ_POST);
-            sqgetGlobalVar('media_changetitle', $media_changetitle, SQ_POST);
-
-            setPref($data_dir,$username,'newmail_enable',$media_enable);
-            setPref($data_dir,$username,'newmail_popup', $media_popup);
-            setPref($data_dir,$username,'newmail_allbox',$media_allbox);
-            setPref($data_dir,$username,'newmail_recent',$media_recent);
-            setPref($data_dir,$username,'newmail_changetitle',$media_changetitle);
-            
-            if( sqgetGlobalVar('media_sel', $media_sel, SQ_POST) &&
-                ($media_sel == '(none)' || $media_sel == '(local media)') ) {
-                removePref($data_dir,$username,'newmail_media');
-            } else {
-                setPref($data_dir,$username,'newmail_media',$media_sel);
-            }
-            echo html_tag( 'p', _("New Mail Notification options saved"), 'center' );
+/**
+ * Save newmail plugin settings
+ */
+function newmail_sav() {
+    global $data_dir, $username;
+
+    if ( sqgetGlobalVar('submit_newmail', $submit, SQ_POST) ) {
+        $media_enable = '';
+        $media_popup = '';
+        $media_allbox = '';
+        $media_recent = '';
+        $media_changetitle = '';
+        $media_sel = '';
+
+        sqgetGlobalVar('media_enable',      $media_enable,      SQ_POST);
+        sqgetGlobalVar('media_popup',       $media_popup,       SQ_POST);
+        sqgetGlobalVar('media_allbox',      $media_allbox,      SQ_POST);
+        sqgetGlobalVar('media_recent',      $media_recent,      SQ_POST);
+        sqgetGlobalVar('media_changetitle', $media_changetitle, SQ_POST);
+
+        setPref($data_dir,$username,'newmail_enable',$media_enable);
+        setPref($data_dir,$username,'newmail_popup', $media_popup);
+        setPref($data_dir,$username,'newmail_allbox',$media_allbox);
+        setPref($data_dir,$username,'newmail_recent',$media_recent);
+        setPref($data_dir,$username,'newmail_changetitle',$media_changetitle);
+
+        if( sqgetGlobalVar('media_sel', $media_sel, SQ_POST) &&
+            ($media_sel == '(none)' || $media_sel == '(local media)') ) {
+            removePref($data_dir,$username,'newmail_media');
+        } else {
+            setPref($data_dir,$username,'newmail_media',$media_sel);
         }
     }
+}
 
-    function newmail_pref() {
-      
-        global $username,$data_dir;
-        global $newmail_media,$newmail_enable,$newmail_popup,$newmail_allbox;
-        global $newmail_recent, $newmail_changetitle;
-        
-        $newmail_recent = getPref($data_dir,$username,'newmail_recent');
-        $newmail_enable = getPref($data_dir,$username,'newmail_enable');
-        $newmail_media = getPref($data_dir, $username, 'newmail_media', '(none)');
-        $newmail_popup = getPref($data_dir, $username, 'newmail_popup');
-        $newmail_allbox = getPref($data_dir, $username, 'newmail_allbox');
-        $newmail_changetitle = getPref($data_dir, $username, 'newmail_changetitle');
+/**
+ * Load newmail plugin settings
+ */
+function newmail_pref() {
+    global $username,$data_dir;
+    global $newmail_media,$newmail_enable,$newmail_popup,$newmail_allbox;
+    global $newmail_recent, $newmail_changetitle;
 
-    }
+    $newmail_recent = getPref($data_dir,$username,'newmail_recent');
+    $newmail_enable = getPref($data_dir,$username,'newmail_enable');
+    $newmail_media = getPref($data_dir, $username, 'newmail_media', '(none)');
+    $newmail_popup = getPref($data_dir, $username, 'newmail_popup');
+    $newmail_allbox = getPref($data_dir, $username, 'newmail_allbox');
+    $newmail_changetitle = getPref($data_dir, $username, 'newmail_changetitle');
+}
 
-    function newmail_plugin() {
+/**
+ * Set loadinfo data
+ *
+ * Used by option page when saving settings.
+ */
+function newmail_set_loadinfo() {
+    global $optpage, $optpage_name;
+    if ($optpage=='newmail') {
+        $optpage_name=_("NewMail Options");
+    }
+}
 
-        global $username, $newmail_media, $newmail_enable, $newmail_popup,
-               $newmail_recent, $newmail_changetitle, $imapConnection, $PHP_SELF;
+/**
+ * Insert needed data in left_main
+ */
+function newmail_plugin() {
+    global $username, $newmail_media, $newmail_enable, $newmail_popup,
+        $newmail_recent, $newmail_changetitle, $imapConnection, $PHP_SELF;
 
-        if ($newmail_enable == 'on' ||
-            $newmail_popup == 'on' ||
-            $newmail_changetitle) {
+    if ($newmail_enable == 'on' ||
+        $newmail_popup == 'on' ||
+        $newmail_changetitle) {
 
-            // open a connection on the imap port (143)
+        // open a connection on the imap port (143)
 
-            $boxes = sqimap_mailbox_list($imapConnection);
-            $delimeter = sqimap_get_delimiter($imapConnection);
+        $boxes = sqimap_mailbox_list($imapConnection);
+        $delimeter = sqimap_get_delimiter($imapConnection);
 
-            $status = 0;
-            $totalNew = 0;
+        $status = 0;
+        $totalNew = 0;
 
-            for ($i = 0;$i < count($boxes); $i++) {
+        for ($i = 0;$i < count($boxes); $i++) {
 
-                $mailbox = $boxes[$i]['formatted'];
+            $mailbox = $boxes[$i]['formatted'];
 
-                if (! isset($boxes[$i]['unseen'])) {
-                    $boxes[$i]['unseen'] = '';
-                }
-                if ($boxes[$i]['flags']) {
-                    $noselect = false;
-                    for ($h = 0; $h < count($boxes[$i]['flags']); $h++) {
-                        if (strtolower($boxes[$i]["flags"][$h]) == 'noselect') {
-                            $noselect = TRUE;
-                        }
-                    }
-                    if (! $noselect) {
-                        $status += CheckNewMailboxSound($imapConnection, 
-                                                        $mailbox,
-                                                        $boxes[$i]['unformatted'], 
-                                                        $delimeter, 
-                                                        $boxes[$i]['unseen'],
-                                                        $totalNew);
+            if (! isset($boxes[$i]['unseen'])) {
+                $boxes[$i]['unseen'] = '';
+            }
+            if ($boxes[$i]['flags']) {
+                $noselect = false;
+                for ($h = 0; $h < count($boxes[$i]['flags']); $h++) {
+                    if (strtolower($boxes[$i]["flags"][$h]) == 'noselect') {
+                        $noselect = TRUE;
                     }
-                } else {
+                }
+                if (! $noselect) {
                     $status += CheckNewMailboxSound($imapConnection, 
-                                                    $mailbox, 
-                                                    $boxes[$i]['unformatted'],
+                                                    $mailbox,
+                                                    $boxes[$i]['unformatted'], 
                                                     $delimeter, 
-                                                    $boxes[$i]['unseen'], 
+                                                    $boxes[$i]['unseen'],
                                                     $totalNew);
                 }
-
+            } else {
+                $status += CheckNewMailboxSound($imapConnection, 
+                                                $mailbox, 
+                                                $boxes[$i]['unformatted'],
+                                                $delimeter, 
+                                                $boxes[$i]['unseen'], 
+                                                $totalNew);
             }
+        }
 
-            // sqimap_logout($imapConnection);
-
-            // If we found unseen messages, then we
-            // will play the sound as follows:
-
-            if ($newmail_changetitle) {
-                echo "<script language=\"javascript\">\n" .
-                    "function ChangeTitleLoad() {\n";
-                echo 'window.parent.document.title = "' .
-                     sprintf(ngettext("%s New Message","%s New Messages",$totalNew), $totalNew) . 
-                     "\";\n";
-                echo    "if (BeforeChangeTitle != null)\n".
-                            "BeforeChangeTitle();\n".
-                    "}\n".
-                    "BeforeChangeTitle = window.onload;\n".
-                    "window.onload = ChangeTitleLoad;\n".
-                    "</script>\n";
-            }
+        // sqimap_logout($imapConnection);
 
-            if ($totalNew > 0 && $newmail_enable == 'on' && $newmail_media != '' ) {
-                echo '<embed src="'.htmlspecialchars($newmail_media) .
-                    "\" hidden=\"true\" autostart=\"true\">\n";
-            }
-            if ($totalNew > 0 && $newmail_popup == 'on') {
-                echo "<script language=\"JavaScript\">\n".
-                    "<!--\n".
-                    "function PopupScriptLoad() {\n".
-                        'window.open("'.sqm_baseuri().'plugins/newmail/newmail.php?numnew='.$totalNew.
-                                    '", "SMPopup",'.
-                                     "\"width=200,height=130,scrollbars=no\");\n".
-                        "if (BeforePopupScript != null)\n".
-                            "BeforePopupScript();\n".
-                    "}\n".
-                    "BeforePopupScript = window.onload;\n".
-                    "window.onload = PopupScriptLoad;\n".
-                    // Idea by:  Nic Wolfe (Nic@TimelapseProductions.com)
-                    // Web URL:  http://fineline.xs.mw
-                    // More code from Tyler Akins
-                    "// End -->\n".
-                    "</script>\n";
-            }
+        // If we found unseen messages, then we
+        // will play the sound as follows:
+
+        if ($newmail_changetitle) {
+            echo "<script language=\"javascript\">\n" .
+                "function ChangeTitleLoad() {\n";
+            echo 'window.parent.document.title = "' .
+                sprintf(ngettext("%s New Message","%s New Messages",$totalNew), $totalNew) . 
+                "\";\n";
+            echo    "if (BeforeChangeTitle != null)\n".
+                "BeforeChangeTitle();\n".
+                "}\n".
+                "BeforeChangeTitle = window.onload;\n".
+                "window.onload = ChangeTitleLoad;\n".
+                "</script>\n";
+        }
+
+        if ($totalNew > 0 && $newmail_enable == 'on' && $newmail_media != '' ) {
+            echo '<embed src="'.htmlspecialchars($newmail_media) .
+                "\" hidden=\"true\" autostart=\"true\">\n";
+        }
+        if ($totalNew > 0 && $newmail_popup == 'on') {
+            echo "<script language=\"JavaScript\">\n".
+                "<!--\n".
+                "function PopupScriptLoad() {\n".
+                'window.open("'.sqm_baseuri().'plugins/newmail/newmail.php?numnew='.$totalNew.
+                '", "SMPopup",'.
+                "\"width=200,height=130,scrollbars=no\");\n".
+                "if (BeforePopupScript != null)\n".
+                "BeforePopupScript();\n".
+                "}\n".
+                "BeforePopupScript = window.onload;\n".
+                "window.onload = PopupScriptLoad;\n".
+                // Idea by:  Nic Wolfe (Nic@TimelapseProductions.com)
+                // Web URL:  http://fineline.xs.mw
+                // More code from Tyler Akins
+                "// End -->\n".
+                "</script>\n";
         }
     }
+}
 ?>
\ No newline at end of file
index 711036d..79806ee 100644 (file)
@@ -16,8 +16,6 @@ define('SM_PATH','../../');
 
 /* SquirrelMail required files. */
 require_once(SM_PATH . 'include/validate.php');
-require_once(SM_PATH . 'functions/global.php');
-require_once(SM_PATH . 'functions/html.php');
 
 displayHtmlHeader( _("Test Sound"), '', FALSE );