egroupware/addressbook/edit.php

227 lines
7.0 KiB
PHP
Executable File

<?php
/**************************************************************************\
* phpGroupWare - addressbook *
* http://www.phpgroupware.org *
* Written by Joseph Engo <jengo@phpgroupware.org> *
* -------------------------------------------- *
* This program is free software; you can redistribute it and/or modify it *
* under the terms of the GNU General Public License as published by the *
* Free Software Foundation; either version 2 of the License, or (at your *
* option) any later version. *
\**************************************************************************/
/* $Id$ */
$phpgw_info['flags'] = array(
'noheader' => True,
'nonavbar' => True,
'currentapp' => 'addressbook',
'enable_contacts_class' => True,
'enable_config_class' => True,
'enable_country_class' => True
);
include('../header.inc.php');
$this = CreateObject('phpgwapi.contacts');
// First, make sure they have permission to this entry
$check = addressbook_read_entry($ab_id,array('owner' => 'owner'));
if ( !$this->check_perms($this->grants[$check[0]['owner']],PHPGW_ACL_EDIT) && ($check[0]['owner'] != $phpgw_info['user']['account_id']) )
{
Header("Location: "
. $phpgw->link('/addressbook/index.php',"cd=16&order=$order&sort=$sort&filter=$filter&start=$start&query=$query&cat_id=$cat_id"));
$phpgw->common->phpgw_exit();
}
if (!$ab_id)
{
Header("Location: "
. $phpgw->link('/addressbook/index.php',"cd=16&order=$order&sort=$sort&filter=$filter&start=$start&query=$query&cat_id=$cat_id"));
$phpgw->common->phpgw_exit();
}
if (!$submit)
{
$phpgw->common->phpgw_header();
echo parse_navbar();
}
// Read in user custom fields, if any
$customfields = array();
while (list($col,$descr) = @each($phpgw_info['user']['preferences']['addressbook']))
{
if ( substr($col,0,6) == 'extra_' )
{
$field = ereg_replace('extra_','',$col);
$field = ereg_replace(' ','_',$field);
$customfields[$field] = ucfirst($field);
}
}
if (!$submit)
{
// merge in extra fields
$extrafields = array(
'ophone' => 'ophone',
'address2' => 'address2',
'address3' => 'address3'
);
$qfields = $this->stock_contact_fields + $extrafields + $customfields;
$fields = addressbook_read_entry($ab_id,$qfields);
addressbook_form('edit','edit.php',lang('Edit'),$fields[0],$customfields);
$t = CreateObject('phpgwapi.Template',PHPGW_APP_TPL);
$t->set_file(array("edit" => "edit.tpl"));
$t->set_var('ab_id',$ab_id);
$t->set_var('sort',$sort);
$t->set_var('order',$order);
$t->set_var('filter',$filter);
$t->set_var('query',$query);
$t->set_var('start',$start);
$t->set_var('cat_id',$cat_id);
$t->set_var('tid',$tid);
$t->set_var('lang_ok',lang('ok'));
$t->set_var('lang_clear',lang('clear'));
$t->set_var('lang_cancel',lang('cancel'));
$t->set_var('lang_submit',lang('submit'));
$t->set_var('cancel_link','<form method="POST" action="' . $phpgw->link("/addressbook/index.php") . '">');
if (($this->grants[$check[0]['owner']] & PHPGW_ACL_DELETE) || $check[0]['owner'] == $phpgw_info['user']['account_id'])
{
$t->set_var('delete_link','<form method="POST" action="'.$phpgw->link("/addressbook/delete.php") . '">');
$t->set_var('delete_button','<input type="submit" name="delete" value="' . lang('Delete') . '">');
}
$t->pfp('out','edit');
$phpgw->common->phpgw_footer();
}
else
{
if ($url == "http://")
{
$url = "";
}
if (!$bday_month && !$bday_day && !$bday_year)
{
$bday = "";
}
else
{
if (strlen ($bday_day) == 1)
{
$bday_day = "0".$bday_day;
}
$bday = "$bday_month/$bday_day/$bday_year";
}
$fields['org_name'] = $company;
$fields['org_unit'] = $department;
$fields['n_given'] = $firstname;
$fields['n_family'] = $lastname;
$fields['n_middle'] = $middle;
$fields['n_prefix'] = $prefix;
$fields['n_suffix'] = $suffix;
if ($prefix) { $pspc = ' '; }
if ($middle) { $mspc = ' '; } else { $nspc = ' '; }
if ($suffix) { $sspc = ' '; }
$fields['fn'] = $prefix.$pspc.$firstname.$nspc.$mspc.$middle.$mspc.$lastname.$sspc.$suffix;
$fields['email'] = $email;
$fields['email_type'] = $email_type;
$fields['email_home'] = $hemail;
$fields['email_home_type'] = $hemail_type;
$fields['title'] = $title;
$fields['tel_work'] = $wphone;
$fields['tel_home'] = $hphone;
$fields['tel_fax'] = $fax;
$fields['tel_pager'] = $pager;
$fields['tel_cell'] = $mphone;
$fields['tel_msg'] = $msgphone;
$fields['tel_car'] = $carphone;
$fields['tel_video'] = $vidphone;
$fields['tel_isdn'] = $isdnphone;
$fields['tel_prefer'] = $tel_prefer;
$fields['adr_one_street'] = $bstreet;
$fields['adr_one_locality'] = $bcity;
$fields['adr_one_region'] = $bstate;
$fields['adr_one_postalcode'] = $bzip;
$fields['adr_one_countryname'] = $bcountry;
reset($this->adr_types);
$typed = '';
while (list($type,$val) = each($this->adr_types))
{
$ftype = 'one_'.$type;
eval("if (\$\$ftype=='on'\) { \$typed \.= \$type\.';'; }");
}
$fields['adr_one_type'] = substr($typed,0,-1);
$fields['address2'] = $address2;
$fields['address3'] = $address3;
$fields['adr_two_street'] = $hstreet;
$fields['adr_two_locality'] = $hcity;
$fields['adr_two_region'] = $hstate;
$fields['adr_two_postalcode'] = $hzip;
$fields['adr_two_countryname'] = $hcountry;
reset($this->adr_types);
$typed = '';
while (list($type,$val) = each($this->adr_types))
{
$ftype = 'two_'.$type;
eval("if \(\$\$ftype=='on'\) { \$typed \.= \$type\.';'; }");
}
$fields["adr_two_type"] = substr($typed,0,-1);
reset($customfields);
while (list($name,$val) = each($customfields))
{
$cust = '';
eval("if (\$name\) { \$cust \.= \$\$name; }");
if ($cust) { $fields[$name] = $cust; }
}
$fields['ophone'] = $ophone;
$fields['tz'] = $timezone;
$fields['bday'] = $bday;
$fields['url'] = $url;
$fields['pubkey'] = $pubkey;
$fields['note'] = $notes;
$fields['label'] = $label;
if ($access == True || $access == 'private')
{
$fields['access'] = 'private';
}
else
{
$fields['access'] = 'public';
}
$fields['cat_id'] = is_array($cat_id) ? implode(',',$cat_id) : $cat_id;
// make sure commas surround each value
$fields['cat_id'] = ',' . $fields['cat_id'] . ',';
if (($this->grants[$check[0]['owner']] & PHPGW_ACL_EDIT) && $check[0]['owner'] != $phpgw_info['user']['account_id'])
{
$userid = $check[0]['owner'];
}
else
{
$userid = $phpgw_info['user']['account_id'];
}
addressbook_update_entry($ab_id,$userid,$fields,$fields['access'],$fields['cat_id'],$tid);
$referer = urlencode($referer);
Header("Location: "
. $phpgw->link('/addressbook/view.php',"ab_id=$ab_id&order=$order&sort=$sort&filter=$filter&start=$start&query=$query&cat_id=$cat_id&referer=$referer"));
$phpgw->common->phpgw_exit();
}
?>