| 1 | <?php |
| 2 | |
| 3 | /** |
| 4 | * options_identities.php |
| 5 | * |
| 6 | * Display Identities Options |
| 7 | * |
| 8 | * @copyright © 1999-2006 The SquirrelMail Project Team |
| 9 | * @license http://opensource.org/licenses/gpl-license.php GNU Public License |
| 10 | * @version $Id$ |
| 11 | * @package squirrelmail |
| 12 | * @subpackage prefs |
| 13 | * @since 1.1.3 |
| 14 | */ |
| 15 | |
| 16 | /** |
| 17 | * Include the SquirrelMail initialization file. |
| 18 | */ |
| 19 | require('../include/init.php'); |
| 20 | |
| 21 | /* SquirrelMail required files. */ |
| 22 | require_once(SM_PATH . 'functions/identity.php'); |
| 23 | |
| 24 | /* make sure that page is not available when $edit_identity is false */ |
| 25 | if (!$edit_identity) { |
| 26 | error_box(_("Editing identities is disabled.")); |
| 27 | $oTemplate->display('footer.tpl'); |
| 28 | die(); |
| 29 | } |
| 30 | |
| 31 | if (!sqgetGlobalVar('identities', $identities, SQ_SESSION)) { |
| 32 | $identities = get_identities(); |
| 33 | } |
| 34 | sqgetGlobalVar('newidentities', $newidentities, SQ_POST); |
| 35 | sqgetGlobalVar('smaction', $smaction, SQ_POST); |
| 36 | sqgetGlobalVar('return', $return, SQ_POST); |
| 37 | |
| 38 | // First lets see if there are any actions to perform // |
| 39 | if (!empty($smaction) && is_array($smaction)) { |
| 40 | |
| 41 | $doaction = ''; |
| 42 | $identid = 0; |
| 43 | |
| 44 | foreach($smaction as $action=>$row) { |
| 45 | // we only need to extract the action and the identity we are |
| 46 | // altering |
| 47 | |
| 48 | foreach($row as $iKey=>$data) { |
| 49 | $identid = $iKey; |
| 50 | } |
| 51 | |
| 52 | $doaction = $action; |
| 53 | } |
| 54 | |
| 55 | $identities = sqfixidentities( $newidentities , $identid , $action ); |
| 56 | save_identities($identities); |
| 57 | } |
| 58 | |
| 59 | if (!empty($return)) { |
| 60 | header('Location: ' . get_location() . '/options_personal.php'); |
| 61 | exit; |
| 62 | } |
| 63 | |
| 64 | displayPageHeader($color, 'None'); |
| 65 | |
| 66 | /* since 1.1.3 */ |
| 67 | do_hook('options_identities_top'); |
| 68 | |
| 69 | $td_str = ''; |
| 70 | $td_str .= '<form name="f" action="options_identities.php" method="post"><br />' . "\n"; |
| 71 | $td_str .= '<table border="0" cellspacing="0" cellpadding="0" width="100%">' . "\n"; |
| 72 | $cnt = count($identities); |
| 73 | foreach( $identities as $iKey=>$ident ) { |
| 74 | |
| 75 | if ($iKey == 0) { |
| 76 | $hdr_str = _("Default Identity"); |
| 77 | } else { |
| 78 | $hdr_str = sprintf( _("Alternate Identity %d"), $iKey); |
| 79 | } |
| 80 | |
| 81 | $td_str .= ShowIdentityInfo( $hdr_str, $ident, $iKey ); |
| 82 | |
| 83 | } |
| 84 | |
| 85 | $td_str .= ShowIdentityInfo( _("Add a New Identity"), array('full_name'=>'','email_address'=>'','reply_to'=>'','signature'=>''), $cnt); |
| 86 | $td_str .= '</table>' . "\n"; |
| 87 | $td_str .= '</form>'; |
| 88 | |
| 89 | echo '<br /> ' . "\n" . |
| 90 | html_tag('table', "\n" . |
| 91 | html_tag('tr', "\n" . |
| 92 | html_tag('td' , "\n" . |
| 93 | '<b>' . _("Options") . ' - ' . _("Advanced Identities") . '</b><br />' . |
| 94 | html_tag('table', "\n" . |
| 95 | html_tag('tr', "\n" . |
| 96 | html_tag('td', "\n" . |
| 97 | html_tag('table' , "\n" . |
| 98 | html_tag('tr' , "\n" . |
| 99 | html_tag('td', "\n" . $td_str ,'','', 'style="text-align:center;"') |
| 100 | ), |
| 101 | '', '', 'width="80%" cellpadding="2" cellspacing="0" border="0"' ) , |
| 102 | 'center', $color[4]) |
| 103 | ), |
| 104 | '', '', 'width="100%" border="0" cellpadding="1" cellspacing="1"' )) , |
| 105 | 'center', $color[0]), |
| 106 | 'center', '', 'width="95%" border="0" cellpadding="2" cellspacing="0"' ) . '</body></html>'; |
| 107 | |
| 108 | /** |
| 109 | * Returns html formated identity form fields |
| 110 | * |
| 111 | * Contains options_identities_buttons and option_identities_table hooks. |
| 112 | * Before 1.4.5/1.5.1 hooks were placed in ShowTableInfo() function. |
| 113 | * In 1.1.3-1.4.1 they were called in do_hook function with two or |
| 114 | * three arguments. Since 1.4.1 hooks are called in concat_hook_function. |
| 115 | * Arguments are moved to array. |
| 116 | * |
| 117 | * options_identities_buttons hook uses array with two keys. First array key is |
| 118 | * boolean variable used to indicate empty identity field. Second array key |
| 119 | * is integer variable used to indicate identity number |
| 120 | * |
| 121 | * options_identities_table hook uses array with three keys. First array key is |
| 122 | * a string containing background color style CSS (1.4.1-1.4.4/1.5.0 uses only |
| 123 | * html color code). Second array key is boolean variable used to indicate empty |
| 124 | * identity field. Third array key is integer variable used to indicate identity |
| 125 | * number |
| 126 | * @param string $title Name displayed in header row |
| 127 | * @param array $identity Identity information |
| 128 | * @param integer $id identity ID |
| 129 | * @return string html formatted table rows with form fields for identity management |
| 130 | * @since 1.5.1 and 1.4.5 (was called ShowTableInfo() in 1.1.3-1.4.4 and 1.5.0) |
| 131 | */ |
| 132 | function ShowIdentityInfo($title, $identity, $id ) { |
| 133 | global $color; |
| 134 | |
| 135 | if (empty($identity['full_name']) && empty($identity['email_address']) && empty($identity['reply_to']) && empty($identity['signature'])) { |
| 136 | $bg = ''; |
| 137 | $empty = true; |
| 138 | } else { |
| 139 | $bg = ' style="background-color:' . $color[0] . ';"'; |
| 140 | $empty = false; |
| 141 | } |
| 142 | |
| 143 | $name = 'newidentities[%d][%s]'; |
| 144 | |
| 145 | |
| 146 | $return_str = ''; |
| 147 | |
| 148 | $return_str .= '<tr>' . "\n"; |
| 149 | $return_str .= ' <th style="text-align:center;background-color:' . $color[9] . ';" colspan="2">' . $title . '</th> '. "\n"; |
| 150 | $return_str .= '</tr>' . "\n"; |
| 151 | $return_str .= sti_input( _("Full Name") , sprintf($name, $id, 'full_name'), $identity['full_name'], $bg); |
| 152 | $return_str .= sti_input( _("E-Mail Address") , sprintf($name, $id, 'email_address'), $identity['email_address'], $bg); |
| 153 | $return_str .= sti_input( _("Reply To"), sprintf($name, $id, 'reply_to'), $identity['reply_to'], $bg); |
| 154 | $return_str .= sti_textarea( _("Signature"), sprintf($name, $id, 'signature'), $identity['signature'], $bg); |
| 155 | $return_str .= concat_hook_function('options_identities_table', array($bg, $empty, $id)); |
| 156 | $return_str .= '<tr' . $bg . '> ' . "\n"; |
| 157 | $return_str .= ' <td> </td>' . "\n"; |
| 158 | $return_str .= ' <td>' . "\n"; |
| 159 | $return_str .= ' <input type="submit" name="smaction[save][' . $id . ']" value="' . _("Save / Update") . '" />' . "\n"; |
| 160 | |
| 161 | if (!$empty && $id > 0) { |
| 162 | $return_str .= ' <input type="submit" name="smaction[makedefault][' . $id . ']" value="' . _("Make Default") . '" />' . "\n"; |
| 163 | $return_str .= ' <input type="submit" name="smaction[delete]['.$id.']" value="' . _("Delete") . '" />' . "\n"; |
| 164 | |
| 165 | if ($id > 1) { |
| 166 | $return_str .= ' <input type="submit" name="smaction[move]['.$id.']" value="' . _("Move Up") . '" />' . "\n"; |
| 167 | } |
| 168 | |
| 169 | } |
| 170 | |
| 171 | $return_str .= concat_hook_function('options_identities_buttons', array($empty, $id)); |
| 172 | $return_str .= ' </td>' . "\n"; |
| 173 | $return_str .= '</tr>' . "\n"; |
| 174 | $return_str .= '<tr>' . "\n"; |
| 175 | $return_str .= ' <td colspan="2"> </td>' . "\n"; |
| 176 | $return_str .= '</tr>'; |
| 177 | |
| 178 | return $return_str; |
| 179 | |
| 180 | } |
| 181 | |
| 182 | /** |
| 183 | * Creates html formated table row with input field |
| 184 | * @param string $title Name displayed next to input field |
| 185 | * @param string $name Name of input field |
| 186 | * @param string $data Default value of input field (data is sanitized with htmlspecialchars) |
| 187 | * @param string $bgcolor html attributes added to row element (tr) |
| 188 | * @return string html formated table row with text input field |
| 189 | * @since 1.2.0 (arguments differ since 1.4.5/1.5.1) |
| 190 | * @todo check right-to-left language issues |
| 191 | * @access private |
| 192 | */ |
| 193 | function sti_input( $title, $name, $data, $bgcolor ) { |
| 194 | $str = ''; |
| 195 | $str .= '<tr' . $bgcolor . ">\n"; |
| 196 | $str .= ' <td style="white-space: nowrap;text-align:right;">' . $title . ' </td>' . "\n"; |
| 197 | $str .= ' <td> <input type="text" name="' . $name . '" size="50" value="'. htmlspecialchars($data) . '"> </td>' . "\n"; |
| 198 | $str .= '</tr>'; |
| 199 | |
| 200 | return $str; |
| 201 | |
| 202 | } |
| 203 | |
| 204 | /** |
| 205 | * Creates html formated table row with textarea field |
| 206 | * @param string $title Name displayed next to textarea field |
| 207 | * @param string $name Name of textarea field |
| 208 | * @param string $data Default value of textarea field (data is sanitized with htmlspecialchars) |
| 209 | * @param string $bgcolor html attributes added to row element (tr) |
| 210 | * @return string html formated table row with textarea |
| 211 | * @since 1.2.5 (arguments differ since 1.4.5/1.5.1) |
| 212 | * @todo check right-to-left language issues |
| 213 | * @access private |
| 214 | */ |
| 215 | function sti_textarea( $title, $name, $data, $bgcolor ) { |
| 216 | $str = ''; |
| 217 | $str .= '<tr' . $bgcolor . ">\n"; |
| 218 | $str .= ' <td style="white-space: nowrap;text-align:right;">' . $title . ' </td>' . "\n"; |
| 219 | $str .= ' <td> <textarea name="' . $name . '" cols="50" rows="5">'. htmlspecialchars($data) . '</textarea> </td>' . "\n"; |
| 220 | $str .= '</tr>'; |
| 221 | |
| 222 | return $str; |
| 223 | |
| 224 | } |
| 225 | |
| 226 | ?> |