-function ShowTableInfo($full_name, $email_address, $reply_to, $post)
-{
- global $color;
-
- $OtherBG = '';
-
- if ($post == '')
- $OtherBG = ' bgcolor="' . $color[10] . '"';
-
- if ($full_name == '' && $email_address == '' && $reply_to == '')
- $isEmptySection = true;
- else
- $isEmptySection = false;
-
-?>
- <tr<?PHP echo $OtherBG ?>>
- <td align=right nowrap>
- <?php echo _("Full Name"); ?>:
- </td>
- <td>
- <input size=50 type=text value="<?php echo htmlspecialchars($full_name)
- ?>" name="full_name<?PHP echo $post ?>">
- </td>
- </tr>
- <tr<?PHP echo $OtherBG ?>>
- <td align=right nowrap>
- <?php echo _("E-Mail Address"); ?>:
- </td>
- <td>
- <input size=50 type=text value="<?php echo htmlspecialchars($email_address)
- ?>" name="email_address<?PHP echo $post ?>">
- </td>
- </tr>
- <tr<?PHP echo $OtherBG ?>>
- <td align=right nowrap>
- <?php echo _("Reply To"); ?>:
- </td>
- <td>
- <input size=50 type=text value="<?php echo htmlspecialchars($reply_to)
- ?>" name="reply_to<?PHP echo $post ?>">
- </td>
- </tr>
-<?PHP
- if (! $isEmptySection && $post != '') {
-?>
- <tr>
- <td align=right>
- <?PHP echo _("Delete") ?>:
- </td>
- <td>
- <input type=checkbox name="delete_<?PHP echo $post ?>"> <?PHP
- echo _("Delete this identity"); ?>
- </td>
- </tr>
-<?PHP
- }
-?>
- <tr>
- <td colspan=2 align=center>
- <input type=hidden name="form_for_<?PHP echo $post ?>" value="1">
- <input type=submit name="update" value="<?PHP
- echo _("Save / Update") ?>">
-<?PHP
- if (! $isEmptySection && $post != '') {
-?>
- <input type=submit name="make_default_<?PHP echo $post ?>" value="<?PHP
- echo _("Make Default") ?>">
-<?PHP
- }
- if (! $isEmptySection && $post != '' && $post > 1) {
-?>
- <input type=submit name="promote_<?PHP echo $post ?>" value="<?PHP
- echo _("Move Up") ?>">
-<?PHP
- }
-?>
- </td>
- </tr>
-<?PHP
+$td_str .= ShowIdentityInfo( _("Add a New Identity"), array('full_name'=>'','email_address'=>'','reply_to'=>'','signature'=>''), $cnt);
+$td_str .= '</table>' . "\n";
+$td_str .= '</form>';
+
+echo '<br /> ' . "\n" .
+ html_tag('table', "\n" .
+ html_tag('tr', "\n" .
+ html_tag('td' , "\n" .
+ '<b>' . _("Options") . ' - ' . _("Advanced Identities") . '</b><br />' .
+ html_tag('table', "\n" .
+ html_tag('tr', "\n" .
+ html_tag('td', "\n" .
+ html_tag('table' , "\n" .
+ html_tag('tr' , "\n" .
+ html_tag('td', "\n" . $td_str ,'','', 'style="text-align:center;"')
+ ),
+ '', '', 'width="80%" cellpadding="2" cellspacing="0" border="0"' ) ,
+ 'center', $color[4])
+ ),
+ '', '', 'width="100%" border="0" cellpadding="1" cellspacing="1"' )) ,
+ 'center', $color[0]),
+ 'center', '', 'width="95%" border="0" cellpadding="2" cellspacing="0"' ) . '</body></html>';
+
+/**
+ * Returns html formated identity form fields
+ *
+ * Contains options_identities_buttons and option_identities_table hooks.
+ * Before 1.4.5/1.5.1 hooks were placed in ShowTableInfo() function.
+ * In 1.1.3-1.4.1 they were called in do_hook function with two or
+ * three arguments. Since 1.4.1 hooks are called in concat_hook_function.
+ * Arguments are moved to array.
+ *
+ * options_identities_buttons hook uses array with two keys. First array key is
+ * boolean variable used to indicate empty identity field. Second array key
+ * is integer variable used to indicate identity number
+ *
+ * options_identities_table hook uses array with three keys. First array key is
+ * a string containing background color style CSS (1.4.1-1.4.4/1.5.0 uses only
+ * html color code). Second array key is boolean variable used to indicate empty
+ * identity field. Third array key is integer variable used to indicate identity
+ * number
+ * @param string $title Name displayed in header row
+ * @param array $identity Identity information
+ * @param integer $id identity ID
+ * @return string html formatted table rows with form fields for identity management
+ * @since 1.5.1 and 1.4.5 (was called ShowTableInfo() in 1.1.3-1.4.4 and 1.5.0)
+ */
+function ShowIdentityInfo($title, $identity, $id ) {
+ global $color;
+
+ if (empty($identity['full_name']) && empty($identity['email_address']) && empty($identity['reply_to']) && empty($identity['signature'])) {
+ $bg = '';
+ $empty = true;
+ } else {
+ $bg = ' style="background-color:' . $color[0] . ';"';
+ $empty = false;
+ }
+
+ $name = 'newidentities[%d][%s]';
+
+
+ $return_str = '';
+
+ $return_str .= '<tr>' . "\n";
+ $return_str .= ' <th style="text-align:center;background-color:' . $color[9] . ';" colspan="2">' . $title . '</th> '. "\n";
+ $return_str .= '</tr>' . "\n";
+ $return_str .= sti_input( _("Full Name") , sprintf($name, $id, 'full_name'), $identity['full_name'], $bg);
+ $return_str .= sti_input( _("E-Mail Address") , sprintf($name, $id, 'email_address'), $identity['email_address'], $bg);
+ $return_str .= sti_input( _("Reply To"), sprintf($name, $id, 'reply_to'), $identity['reply_to'], $bg);
+ $return_str .= sti_textarea( _("Signature"), sprintf($name, $id, 'signature'), $identity['signature'], $bg);
+ $return_str .= concat_hook_function('options_identities_table', array($bg, $empty, $id));
+ $return_str .= '<tr' . $bg . '> ' . "\n";
+ $return_str .= ' <td> </td>' . "\n";
+ $return_str .= ' <td>' . "\n";
+ $return_str .= ' <input type="submit" name="smaction[save][' . $id . ']" value="' . _("Save / Update") . '" />' . "\n";
+
+ if (!$empty && $id > 0) {
+ $return_str .= ' <input type="submit" name="smaction[makedefault][' . $id . ']" value="' . _("Make Default") . '" />' . "\n";
+ $return_str .= ' <input type="submit" name="smaction[delete]['.$id.']" value="' . _("Delete") . '" />' . "\n";
+
+ if ($id > 1) {
+ $return_str .= ' <input type="submit" name="smaction[move]['.$id.']" value="' . _("Move Up") . '" />' . "\n";
+ }
+
+ }
+
+ $return_str .= concat_hook_function('options_identities_buttons', array($empty, $id));
+ $return_str .= ' </td>' . "\n";
+ $return_str .= '</tr>' . "\n";
+ $return_str .= '<tr>' . "\n";
+ $return_str .= ' <td colspan="2"> </td>' . "\n";
+ $return_str .= '</tr>';
+
+ return $return_str;
+
+}
+
+/**
+ * Creates html formated table row with input field
+ * @param string $title Name displayed next to input field
+ * @param string $name Name of input field
+ * @param string $data Default value of input field (data is sanitized with htmlspecialchars)
+ * @param string $bgcolor html attributes added to row element (tr)
+ * @return string html formated table row with text input field
+ * @since 1.2.0 (arguments differ since 1.4.5/1.5.1)
+ * @todo check right-to-left language issues
+ * @access private
+ */
+function sti_input( $title, $name, $data, $bgcolor ) {
+ $str = '';
+ $str .= '<tr' . $bgcolor . ">\n";
+ $str .= ' <td style="white-space: nowrap;text-align:right;">' . $title . ' </td>' . "\n";
+ $str .= ' <td> <input type="text" name="' . $name . '" size="50" value="'. htmlspecialchars($data) . '"> </td>' . "\n";
+ $str .= '</tr>';
+
+ return $str;
+