X-Git-Url: https://vcs.fsf.org/?a=blobdiff_plain;ds=sidebyside;f=plugins%2Fnewmail%2Fsetup.php;h=ab52d7b6f7b5451756e4124e2e5187da8267720d;hb=0606ca1f5af67cd6a90fa695c8a33478a04d7a7f;hp=94598761cc30e3a86ab4e43eb7ec31c5997c204a;hpb=6a7456758302ddf94ae4e13e6172b75d64827c7f;p=squirrelmail.git diff --git a/plugins/newmail/setup.php b/plugins/newmail/setup.php index 94598761..ab52d7b6 100644 --- a/plugins/newmail/setup.php +++ b/plugins/newmail/setup.php @@ -1,27 +1,27 @@ 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$ - ** - **/ + * newmail.php + * (c)2000 by Michael Huttinger + * + * 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$ + * + */ function CheckNewMailboxSound($imapConnection, $mailbox, $real_box, $delimeter, $unseen, &$total_unseen) { global $folder_prefix, $trash_folder, $sent_folder; @@ -61,7 +61,6 @@ $squirrelmail_plugin_hooks['left_main_before']['newmail'] = 'newmail_plugin'; $squirrelmail_plugin_hooks['optpage_register_block']['newmail'] = 'newmail_optpage_register_block'; - $squirrelmail_plugin_hooks['options_link_and_description']['newmail'] = 'newmail_options'; $squirrelmail_plugin_hooks['options_save']['newmail'] = 'newmail_sav'; $squirrelmail_plugin_hooks['loading_prefs']['newmail'] = 'newmail_pref'; } @@ -82,51 +81,52 @@ } } -function newmail_sav() { - - global $username,$data_dir; - global $submit_newmail,$media_file,$media_reset,$media_enable,$media_popup; - global $media_recent,$media_sel; - global $media_allbox, $media_changetitle; - - if ($submit_newmail) { - if(isset($media_enable)) { - setPref($data_dir,$username,"newmail_enable",$media_enable); - } else { - setPref($data_dir,$username,"newmail_enable",""); - } - if(isset($media_popup)) { - setPref($data_dir,$username,"newmail_popup",$media_popup); - } else { - setPref($data_dir,$username,"newmail_popup",""); - } - if(isset($media_allbox)) { - setPref($data_dir,$username,"newmail_allbox",$media_allbox); - } else { - setPref($data_dir,$username,"newmail_allbox",""); - } - if(isset($media_recent)) { - setPref($data_dir,$username,"newmail_recent",$media_recent); - } else { - setPref($data_dir,$username,"newmail_recent",""); - } - if(isset($media_changetitle)) { - setPref($data_dir,$username,"newmail_changetitle",$media_changetitle); - } else { - setPref($data_dir,$username,"newmail_changetitle",""); - } - if(isset($media_sel)) { - if($media_sel == "(local media)") { - setPref($data_dir,$username,"newmail_media",StripSlashes($media_file)); - } else { - setPref($data_dir,$username,"newmail_media",$media_sel); - } - } else { - setPref($data_dir,$username,"newmail_media",""); - } - echo '
' . _("New Mail Notification options saved") . '
'; - } -} + function newmail_sav() { + + global $username,$data_dir; + global $submit_newmail,$media_file,$media_reset,$media_enable,$media_popup; + global $media_recent,$media_sel; + global $media_allbox, $media_changetitle; + + if ( isset($submit_newmail) ) { + + if(isset($media_enable)) { + setPref($data_dir,$username,'newmail_enable',$media_enable); + } else { + setPref($data_dir,$username,'newmail_enable',''); + } + if(isset($media_popup)) { + setPref($data_dir,$username,'newmail_popup',$media_popup); + } else { + setPref($data_dir,$username,'newmail_popup',''); + } + if(isset($media_allbox)) { + setPref($data_dir,$username,'newmail_allbox',$media_allbox); + } else { + setPref($data_dir,$username,'newmail_allbox',''); + } + if(isset($media_recent)) { + setPref($data_dir,$username,'newmail_recent',$media_recent); + } else { + setPref($data_dir,$username,'newmail_recent',''); + } + if(isset($media_changetitle)) { + setPref($data_dir,$username,'newmail_changetitle',$media_changetitle); + } else { + setPref($data_dir,$username,'newmail_changetitle',''); + } + if(isset($media_sel)) { + if($media_sel == '(local media)') { + setPref($data_dir,$username,'newmail_media',StripSlashes($media_file)); + } else { + setPref($data_dir,$username,'newmail_media',$media_sel); + } + } else { + setPref($data_dir,$username,'newmail_media',''); + } + echo '
' . _("New Mail Notification options saved") . '
'; + } + } function newmail_pref() { @@ -136,106 +136,103 @@ function newmail_sav() { $newmail_recent = getPref($data_dir,$username,'newmail_recent'); $newmail_enable = getPref($data_dir,$username,'newmail_enable'); - $newmail_media = getPref($data_dir, $username, 'newmail_media'); + $newmail_media = getPref($data_dir, $username, 'newmail_media', '../plugins/newmail/sounds/Notify.wav'); $newmail_popup = getPref($data_dir, $username, 'newmail_popup'); $newmail_allbox = getPref($data_dir, $username, 'newmail_allbox'); $newmail_changetitle = getPref($data_dir, $username, 'newmail_changetitle'); - - if ($newmail_media == '') { - $newmail_media = '../plugins/newmail/sounds/Notify.wav'; - } - - } -function newmail_plugin() { - - global $username,$key,$imapServerAddress,$imapPort; - global $newmail_media,$newmail_enable,$newmail_popup,$newmail_recent; - global $newmail_changetitle; - global $imapConnection; - - if ($newmail_enable == 'on' || $newmail_popup == 'on' || $newmail_changetitle) { - - // open a connection on the imap port (143) - - // $imapConnection = sqimap_login($username, $key, $imapServerAddress, $imapPort, 10); // the 10 is to hide the output - - $boxes = sqimap_mailbox_list($imapConnection); - $delimeter = sqimap_get_delimiter($imapConnection); - - $status = 0; - $totalNew = 0; - - for ($i = 0;$i < count($boxes); $i++) { - - $line = ''; - $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 = $status + CheckNewMailboxSound($imapConnection, $mailbox, - $boxes[$i]['unformatted'], $delimeter, $boxes[$i]['unseen'], - $totalNew); - } - } else { - $status = $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 "\n"; } - if ($status > 0 && $newmail_enable == 'on') { - echo ""; - } - if ($status >0 && $newmail_popup == 'on') { -?> - -\n" . + "function ChangeTitleLoad() {\n"; + if( $totalNew > 1 ) { + echo 'window.parent.document.title = "' . + sprintf(_("%s New Messages"), $totalNew ) . + "\";\n"; + } else { + echo 'window.parent.document.title = "' . + sprintf(_("%s New Message"), $totalNew ) . + "\";\n"; + } + echo "if (BeforeChangeTitle != null)\n". + "BeforeChangeTitle();\n". + "}\n". + "BeforeChangeTitle = window.onload;\n". + "window.onload = ChangeTitleLoad;\n". + "\n"; + } + + if ($status > 0 && $newmail_enable == 'on') { + echo "\n"; + } + if ($status >0 && $newmail_popup == 'on') { + echo "\n"; + + } + } + } ?>