X-Git-Url: https://vcs.fsf.org/?p=squirrelmail.git;a=blobdiff_plain;f=src%2Faddressbook.php;h=7c3ae718ad57ec236ee792cdfe91c993f06f1565;hp=8d4c80ff719b6b03b327b02211ae759deb00a2bc;hb=19d01c6b200dfd6317e4a933325d903ba2901726;hpb=097437875bf27998072b139eefe18f9e6450a0ff diff --git a/src/addressbook.php b/src/addressbook.php index 8d4c80ff..7c3ae718 100644 --- a/src/addressbook.php +++ b/src/addressbook.php @@ -1,28 +1,32 @@ ' . $add . ''; + $value = ( isset($values[$field]) ? $values[$field] : ''); + + $td_str = addInput($name.'['.$field.']', $value, $size) + . $add ; + return html_tag( 'tr' , html_tag( 'td', $label . ':', 'right', $color[4]) . html_tag( 'td', $td_str, 'left', $color[4]) @@ -54,37 +69,41 @@ function adressbook_inp_field($label, $field, $name, $size, $values, $add) { . "\n"; } -/* Output form to add and modify address data */ +/** + * Output form to add and modify address data + */ function address_form($name, $submittext, $values = array()) { global $color, $squirrelmail_language; if ($squirrelmail_language == 'ja_JP') { echo html_tag( 'table', - adressbook_inp_field(_("Nickname"), 'nickname', $name, 15, $values, + addressbook_inp_field(_("Nickname"), 'nickname', $name, 15, $values, ' ' . _("Must be unique") . '') . - adressbook_inp_field(_("E-mail address"), 'email', $name, 45, $values, '') . - adressbook_inp_field(_("Last name"), 'lastname', $name, 45, $values, '') . - adressbook_inp_field(_("First name"), 'firstname', $name, 45, $values, '') . - adressbook_inp_field(_("Additional info"), 'label', $name, 45, $values, '') . + addressbook_inp_field(_("E-mail address"), 'email', $name, 45, $values, '') . + addressbook_inp_field(_("Last name"), 'lastname', $name, 45, $values, '') . + addressbook_inp_field(_("First name"), 'firstname', $name, 45, $values, '') . + addressbook_inp_field(_("Additional info"), 'label', $name, 45, $values, '') . + list_writable_backends($name) . html_tag( 'tr', html_tag( 'td', - '', 'center', $color[4], 'colspan="2"') ) , 'center', '', 'border="0" cellpadding="1" width="90%"') ."\n"; } else { echo html_tag( 'table', - adressbook_inp_field(_("Nickname"), 'nickname', $name, 15, $values, + addressbook_inp_field(_("Nickname"), 'nickname', $name, 15, $values, ' ' . _("Must be unique") . '') . - adressbook_inp_field(_("E-mail address"), 'email', $name, 45, $values, '') . - adressbook_inp_field(_("First name"), 'firstname', $name, 45, $values, '') . - adressbook_inp_field(_("Last name"), 'lastname', $name, 45, $values, '') . - adressbook_inp_field(_("Additional info"), 'label', $name, 45, $values, '') . + addressbook_inp_field(_("E-mail address"), 'email', $name, 45, $values, '') . + addressbook_inp_field(_("First name"), 'firstname', $name, 45, $values, '') . + addressbook_inp_field(_("Last name"), 'lastname', $name, 45, $values, '') . + addressbook_inp_field(_("Additional info"), 'label', $name, 45, $values, '') . + list_writable_backends($name) . html_tag( 'tr', html_tag( 'td', - '', 'center', $color[4], 'colspan="2"') ) @@ -92,6 +111,30 @@ function address_form($name, $submittext, $values = array()) { } } +function list_writable_backends($name) { + global $color, $abook; + if ( $name != 'addaddr' ) { return; } + if ( $abook->numbackends > 1 ) { + $ret = ""; + return html_tag( 'tr', + html_tag( 'td', _("Add to:"),'right', $color[4] ) . + html_tag( 'td', $ret, 'left', $color[4] )) . "\n"; + } else { + return html_tag( 'tr', + html_tag( 'td', + addHidden('backend', '1'), + 'center', $color[4], 'colspan="2"')) . "\n"; + } +} + /* Open addressbook, with error messages on but without LDAP (the * * second "true"). Don't need LDAP here anyway */ $abook = addressbook_init(true, true); @@ -119,10 +162,11 @@ if(sqgetGlobalVar('REQUEST_METHOD', $req_method, SQ_SERVER) && $req_method == 'P * Add new address * **************************************************/ if (isset($addaddr)) { - foreach( $addaddr as $k => $adr ) { - $addaddr[$k] = strip_tags( $adr ); + if (isset($backend)) { + $r = $abook->add($addaddr, $backend); + } else { + $r = $abook->add($addaddr, $abook->localbackend); } - $r = $abook->add($addaddr, $abook->localbackend); /* Handle error messages */ if (!$r) { @@ -213,11 +257,9 @@ if(sqgetGlobalVar('REQUEST_METHOD', $req_method, SQ_SERVER) && $req_method == 'P ), 'center', '', 'width="100%" ' ); address_form("editaddr", _("Update address"), $olddata); - echo '\n" . - '\n" . - '' . "\n" . + echo addHidden('oldnick', $olddata['nickname']). + addHidden('backend', $olddata['backend']). + addHidden('doedit', '1'). ''; } } else { @@ -250,11 +292,10 @@ if(sqgetGlobalVar('REQUEST_METHOD', $req_method, SQ_SERVER) && $req_method == 'P ), 'center', '', 'width="100%"' ); address_form("editaddr", _("Update address"), $newdata); - echo '\n" . - '\n" . - '' . + echo + addHidden('oldnick', $oldnick). + addHidden('backend', $backend). + addHidden('doedit', '1'). "\n" . ''; $abortform = true; } @@ -312,7 +353,7 @@ if ($showaddrlist) { /* List addresses */ if (count($alist) > 0) { - echo '
' . "\n"; + echo '' . "\n"; while(list($undef,$row) = each($alist)) { /* New table header for each backend */ @@ -321,67 +362,93 @@ if ($showaddrlist) { echo html_tag( 'table', html_tag( 'tr', html_tag( 'td', - '\n" . - '\n", + '\n" . + '\n", 'center', '', 'colspan="5"' ) ) . html_tag( 'tr', html_tag( 'td', ' 
', 'center', '', 'colspan="5"' ) ) , 'center' ); - } - - echo html_tag( 'table', - html_tag( 'tr', - html_tag( 'td', "\n" . '' . $row['source'] . '' . "\n", 'center', $color[0] ) - ) , - 'center', '', 'width="95%"' ) ."\n" - . html_tag( 'table', '', 'center', '', 'border="0" cellpadding="1" cellspacing="0" width="90%"' ) . + echo "\n\n" . + html_tag( 'table', '', 'center', '', 'border="0" cellpadding="1" cellspacing="0" width="90%"' ) . html_tag( 'tr', "\n" . - html_tag( 'th', ' ', 'left', '', 'width="1%"' ) . - html_tag( 'th', _("Nickname"), 'left', '', 'width="1%"' ) . - html_tag( 'th', _("Name"), 'left', '', 'width="1%"' ) . - html_tag( 'th', _("E-mail"), 'left', '', 'width="1%"' ) . - html_tag( 'th', _("Info"), 'left', '', 'width="1%"' ) , - '', $color[9] ) . "\n"; - + html_tag( 'th', ' ', 'left', '', 'width="1%"' ) . "\n" . + html_tag( 'th', _("Nickname") . + show_abook_sort_button($abook_sort_order, _("sort by nickname"), 0, 1) + , 'left', '', 'width="1%"' ) . "\n" . + html_tag( 'th', _("Name") . + show_abook_sort_button($abook_sort_order, _("sort by name"), 2, 3) + , 'left', '', 'width="1%"' ) . "\n" . + html_tag( 'th', _("E-mail") . + show_abook_sort_button($abook_sort_order, _("sort by email"), 4, 5) + , 'left', '', 'width="1%"' ) . "\n" . + html_tag( 'th', _("Info") . + show_abook_sort_button($abook_sort_order, _("sort by info"), 6, 7) + , 'left', '', 'width="1%"' ) . "\n", + '', $color[9] ) . "\n"; + } + + // Separate different backends with
+ if($prevbackend > 0) { + echo html_tag( 'tr', + html_tag( 'td', "
", 'center', '' ,'colspan="5"' ) + ); + } + + // Print backend name + echo html_tag( 'tr', + html_tag( 'td', "\n" . '' . $row['source'] . '' . "\n", 'center', $color[0] ,'colspan="5"' ) + ); + $line = 0; $headerprinted = true; } /* End of header */ - + $prevbackend = $row['backend']; /* Check if this user is selected */ - if(in_array($row['backend'] . ':' . $row['nickname'], $defselected)) { - $selected = 'CHECKED'; + $selected = in_array($row['backend'] . ':' . $row['nickname'], $defselected); + + /* Print one row, with alternating color */ + if ($line % 2) { + $tr_bgcolor = $color[12]; } else { - $selected = ''; + $tr_bgcolor = $color[4]; } - - /* Print one row */ - $tr_bgcolor = ''; - if ($line % 2) { $tr_bgcolor = $color[0]; } if ($squirrelmail_language == 'ja_JP') { - echo html_tag( 'tr', '') . - html_tag( 'td', - '' . - '' , - 'center', '', 'valign="top" width="1%"' ) . - html_tag( 'td', ' ' . $row['nickname'] . ' ', 'left', '', 'valign="top" width="1%" nowrap' ) . + echo html_tag( 'tr', '', '', $tr_bgcolor); + if ($abook->backends[$row['backend']]->writeable) { + echo html_tag( 'td', + '' . + addCheckBox('sel[]', $selected, $row['backend'].':'.$row['nickname']). + '' , + 'center', '', 'valign="top" width="1%"' ); + } else { + echo html_tag( 'td', + ' ' , + 'center', '', 'valign="top" width="1%"' ); + } + echo html_tag( 'td', ' ' . $row['nickname'] . ' ', 'left', '', 'valign="top" width="1%" nowrap' ) . html_tag( 'td', ' ' . $row['lastname'] . ' ' . $row['firstname'] . ' ', 'left', '', 'valign="top" width="1%" nowrap' ) . html_tag( 'td', '', 'left', '', 'valign="top" width="1%" nowrap' ) . ' '; } else { - echo html_tag( 'tr', '') . - html_tag( 'td', - '' . - '' , - 'center', '', 'valign="top" width="1%"' ) . - html_tag( 'td', ' ' . $row['nickname'] . ' ', 'left', '', 'valign="top" width="1%" nowrap' ) . + echo html_tag( 'tr', '', '', $tr_bgcolor); + if ($abook->backends[$row['backend']]->writeable) { + echo html_tag( 'td', + '' . + '' , + 'center', '', 'valign="top" width="1%"' ); + } else { + echo html_tag( 'td', + ' ' , + 'center', '', 'valign="top" width="1%"' ); + } + echo html_tag( 'td', ' ' . $row['nickname'] . ' ', 'left', '', 'valign="top" width="1%" nowrap' ) . html_tag( 'td', ' ' . $row['name'] . ' ', 'left', '', 'valign="top" width="1%" nowrap' ) . html_tag( 'td', '', 'left', '', 'valign="top" width="1%" nowrap' ) . ' '; } @@ -393,38 +460,42 @@ if ($showaddrlist) { "\n"; $line++; } - - /* End of list. Close table. */ + echo "" . + "\n\n"; + + /* End of list. Add edit/delete select buttons */ if ($headerprinted) { - echo html_tag( 'tr', - html_tag( 'td', - '\n" . - '\n", - 'center', '', 'colspan="5"' ) - ); + echo html_tag( 'table', + html_tag( 'tr', + html_tag( 'td', + '\n" . + '\n", + 'center', '', 'colspan="5"' ) + ), + 'center' ); } - echo '
'; + echo "\n"; } } /* end of addresslist */ /* Display the "new address" form */ echo '' . "\n" . - '
' . "\n" . + '' . "\n" . html_tag( 'table', html_tag( 'tr', - html_tag( 'td', "\n". '' . sprintf(_("Add to %s"), $abook->localbackendname) . '' . "\n", + html_tag( 'td', "\n". '' . _("Add to address book") . '' . "\n", 'center', $color[0] ) ) , 'center', '', 'width="100%"' ) ."\n"; address_form('addaddr', _("Add address"), $defdata); -echo '
'; +echo "\n"; /* Add hook for anything that wants on the bottom */ do_hook('addressbook_bottom'); ?> - +