forked from extern/egroupware
* Addressbook: doublicate check while adding/editing contacts, based on email or match of 2 out of name, first name, organisation
This commit is contained in:
parent
6615964c39
commit
c50a83a9a4
@ -1930,20 +1930,72 @@ class addressbook_ui extends addressbook_bo
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
function ajax_setFileasOptions($n_prefix,$n_given,$n_middle,$n_family,$n_suffix,$org_name)
|
/**
|
||||||
|
* Doublicate check: returns similar contacts: same email or 2 of name, firstname, org
|
||||||
|
*
|
||||||
|
* Also update/return fileas options, if necessary.
|
||||||
|
*
|
||||||
|
* @param array $values contact values from form
|
||||||
|
* @param string $name name of changed value, eg. "email"
|
||||||
|
* @param int $own_id=0 own contact id, to not check against it
|
||||||
|
* @return array with keys 'msg' => "EMail address exists, do you want to open contact?" (or null if not existing)
|
||||||
|
* 'data' => array of id => "full name (addressbook)" pairs
|
||||||
|
* 'fileas_options'
|
||||||
|
*/
|
||||||
|
public function ajax_check_values($values, $name, $own_id=0)
|
||||||
{
|
{
|
||||||
$names = array(
|
if (preg_match('/^exec\[([^\]]+)\]$/', $name, $matches)) $name = $matches[1]; // remove exec[ ]
|
||||||
'n_prefix' => $n_prefix,
|
|
||||||
'n_given' => $n_given,
|
|
||||||
'n_middle' => $n_middle,
|
|
||||||
'n_family' => $n_family,
|
|
||||||
'n_suffix' => $n_suffix,
|
|
||||||
'org_name' => $org_name,
|
|
||||||
);
|
|
||||||
$response = new xajaxResponse();
|
|
||||||
$response->addScript("setOptions('".addslashes(implode("\b",$this->fileas_options($names)))."');");
|
|
||||||
|
|
||||||
return $response->getXML();
|
$ret = array('doublicates' => array(), 'msg' => null);
|
||||||
|
|
||||||
|
// if email changed, check for doublicates
|
||||||
|
if (in_array($name, array('email', 'email_home')))
|
||||||
|
{
|
||||||
|
if (preg_match('/^'.url_widget::EMAIL_PREG.'$/i', $values[$name])) // only search for real email addresses, to not return to many contacts
|
||||||
|
{
|
||||||
|
$contacts = parent::search(array(
|
||||||
|
'email' => $values[$name],
|
||||||
|
'email_home' => $values[$name],
|
||||||
|
),$only_keys=false, $order_by='', $extra_cols='', $wildcard='', $empty=False, $op='OR');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
// only set fileas-options if other then email changed
|
||||||
|
$ret['fileas_options'] = array_values($this->fileas_options($values));
|
||||||
|
|
||||||
|
// if name, firstname or org changed and at least 2 are specified, check for doublicates
|
||||||
|
if (in_array($name, array('n_given', 'n_family', 'org_name')) &&
|
||||||
|
!empty($values['n_given'])+!empty($values['n_family'])+!empty($values['org_name']) >= 2)
|
||||||
|
{
|
||||||
|
$filter = array();
|
||||||
|
foreach(array('email', 'n_given', 'n_family', 'org_name') as $n) // use email too, to exclude obvious false positives
|
||||||
|
{
|
||||||
|
if (!empty($values[$n])) $filter[$n] = $values[$n];
|
||||||
|
}
|
||||||
|
$contacts = parent::search($criteria='', $only_keys=false, $order_by='', $extra_cols='', $wildcard='',
|
||||||
|
$empty=False, $op='AND', $start=false, $filter);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if ($contacts)
|
||||||
|
{
|
||||||
|
foreach($contacts as $contact)
|
||||||
|
{
|
||||||
|
if ($own_id && $contact['id'] == $own_id) continue;
|
||||||
|
|
||||||
|
$ret['doublicates'][$contact['id']] = $this->fileas($contact).' ('.
|
||||||
|
(!$contact['owner'] ? lang('Accounts') : ($contact['owner'] == $this->user ?
|
||||||
|
($contact['private'] ? lang('Private') : lang('Personal')) : common::grab_owner_name($contact['owner']))).')';
|
||||||
|
}
|
||||||
|
if ($ret['doublicates'])
|
||||||
|
{
|
||||||
|
$ret['msg'] = lang('Similar contacts found:').
|
||||||
|
"\n\n".implode("\n", $ret['doublicates'])."\n\n".
|
||||||
|
lang('Open for editing?');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
error_log(__METHOD__.'('.array2string($values).", '$name', $own_id) doublicates found ".array2string($ret['doublicates']));
|
||||||
|
egw_json_response::get()->data($ret);
|
||||||
}
|
}
|
||||||
|
|
||||||
function view($content=null)
|
function view($content=null)
|
||||||
|
@ -99,25 +99,39 @@ function getElement(form,pattern)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
function setName(input)
|
function check_value(input, own_id)
|
||||||
{
|
{
|
||||||
var prefix = document.getElementById("exec[n_prefix]").value;
|
var values = egw_json_getFormValues(input.form).exec; // todo use eT2 method, if running under et2
|
||||||
var given = document.getElementById("exec[n_given]").value;
|
|
||||||
var middle = document.getElementById("exec[n_middle]").value;
|
if (input.name.match(/n_/))
|
||||||
var family = document.getElementById("exec[n_family]").value;
|
{
|
||||||
var suffix = document.getElementById("exec[n_suffix]").value;
|
var name = document.getElementById("exec[n_fn]");
|
||||||
var org = document.getElementById("exec[org_name]").value;
|
name.value = "";
|
||||||
|
if (values.n_prefix) name.value += values.n_prefix+" ";
|
||||||
var name = document.getElementById("exec[n_fn]");
|
if (values.n_given) name.value += values.n_given+" ";
|
||||||
|
if (values.n_middle) name.value += values.n_middle+" ";
|
||||||
name.value = "";
|
if (values.n_family) name.value += values.n_family+" ";
|
||||||
if (prefix) name.value += prefix+" ";
|
if (values.n_suffix) name.value += values.n_suffix;
|
||||||
if (given) name.value += given+" ";
|
}
|
||||||
if (middle) name.value += middle+" ";
|
var req = new egw_json_request('addressbook.addressbook_ui.ajax_check_values', [values, input.name, own_id]);
|
||||||
if (family) name.value += family+" ";
|
req.sendRequest(true, function(data) {
|
||||||
if (suffix) name.value += suffix;
|
if (data.msg && confirm(data.msg))
|
||||||
|
{
|
||||||
xajax_doXMLHTTP("addressbook.addressbook_ui.ajax_setFileasOptions",prefix,given,middle,family,suffix,org);
|
for(var id in data.doublicates)
|
||||||
|
{
|
||||||
|
egw.open(id, 'addressbook');
|
||||||
|
//opener.egw_openWindowCentered2(egw_webserverUrl+'/index.php?menuaction=addressbook.addressbook_ui.edit&contact_id='+id, '_blank', 870, 480, 'yes', 'addressbook');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (typeof data.fileas_options == 'object')
|
||||||
|
{
|
||||||
|
var selbox = document.getElementById("exec[fileas_type]");
|
||||||
|
for (var i=0; i < data.fileas_options.length; i++)
|
||||||
|
{
|
||||||
|
selbox.options[i].text = data.fileas_options[i];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
function add_whole_list(list)
|
function add_whole_list(list)
|
||||||
@ -133,17 +147,6 @@ function add_whole_list(list)
|
|||||||
xajax_doXMLHTTP("addressbook.addressbook_ui.ajax_add_whole_list",list,email_type);
|
xajax_doXMLHTTP("addressbook.addressbook_ui.ajax_add_whole_list",list,email_type);
|
||||||
}
|
}
|
||||||
|
|
||||||
function setOptions(options_str)
|
|
||||||
{
|
|
||||||
var options = options_str.split("\\b");
|
|
||||||
var selbox = document.getElementById("exec[fileas_type]");
|
|
||||||
var i;
|
|
||||||
for (i=0; i < options.length; i++)
|
|
||||||
{
|
|
||||||
selbox.options[i].text = options[i];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
function show_custom_country(selectbox)
|
function show_custom_country(selectbox)
|
||||||
{
|
{
|
||||||
if(!selectbox) return;
|
if(!selectbox) return;
|
||||||
|
@ -314,6 +314,7 @@ no vcard addressbook de Keine VCard
|
|||||||
number addressbook de Nummer
|
number addressbook de Nummer
|
||||||
number of records to read (%1) addressbook de Anzahl der einzulesenden Datensätze (%1)
|
number of records to read (%1) addressbook de Anzahl der einzulesenden Datensätze (%1)
|
||||||
open email addresses in external mail program addressbook de Öffne E-Mail Adressen in externem Mail Programm
|
open email addresses in external mail program addressbook de Öffne E-Mail Adressen in externem Mail Programm
|
||||||
|
open for editing? addressbook de Zum Bearbeiten öffnen?
|
||||||
options for type admin de Optionen für Typ
|
options for type admin de Optionen für Typ
|
||||||
organisation addressbook de Organisation
|
organisation addressbook de Organisation
|
||||||
organisations addressbook de Organisationen
|
organisations addressbook de Organisationen
|
||||||
@ -381,6 +382,7 @@ show addressbook de Anzeigen
|
|||||||
show birthday reminders on main screen addressbook de Geburtstagserinnerungen auf der Startseite anzeigen
|
show birthday reminders on main screen addressbook de Geburtstagserinnerungen auf der Startseite anzeigen
|
||||||
show infolog entries for this organisation addressbook de InfoLog Einträge dieser Organisation anzeigen
|
show infolog entries for this organisation addressbook de InfoLog Einträge dieser Organisation anzeigen
|
||||||
show the contacts of this organisation addressbook de Kontakte dieser Organisation anzeigen
|
show the contacts of this organisation addressbook de Kontakte dieser Organisation anzeigen
|
||||||
|
similar contacts found: addressbook de Ähnliche Kontakte gefunden:
|
||||||
size of popup (wxh, eg.400x300, if a popup should be used) admin de Größe des Popup (WxH, zB. 400x300, falls ein Popup verwendet werden soll)
|
size of popup (wxh, eg.400x300, if a popup should be used) admin de Größe des Popup (WxH, zB. 400x300, falls ein Popup verwendet werden soll)
|
||||||
stadt addressbook de Stadt
|
stadt addressbook de Stadt
|
||||||
start admin de Starten
|
start admin de Starten
|
||||||
|
@ -314,6 +314,7 @@ no vcard addressbook en No vCard
|
|||||||
number addressbook en Number
|
number addressbook en Number
|
||||||
number of records to read (%1) addressbook en Number of records to read (%1)
|
number of records to read (%1) addressbook en Number of records to read (%1)
|
||||||
open email addresses in external mail program addressbook en Open EMail addresses in external mail program
|
open email addresses in external mail program addressbook en Open EMail addresses in external mail program
|
||||||
|
open for editing? addressbook en Open for editing?
|
||||||
options for type admin en Options for type
|
options for type admin en Options for type
|
||||||
organisation addressbook en Organisation
|
organisation addressbook en Organisation
|
||||||
organisations addressbook en Organisations
|
organisations addressbook en Organisations
|
||||||
@ -381,6 +382,7 @@ show addressbook en Show
|
|||||||
show birthday reminders on main screen addressbook en Birthday reminders
|
show birthday reminders on main screen addressbook en Birthday reminders
|
||||||
show infolog entries for this organisation addressbook en Show InfoLog entries for this organisation
|
show infolog entries for this organisation addressbook en Show InfoLog entries for this organisation
|
||||||
show the contacts of this organisation addressbook en Show contacts of this organisation
|
show the contacts of this organisation addressbook en Show contacts of this organisation
|
||||||
|
similar contacts found: addressbook en Similar contacts found:
|
||||||
size of popup (wxh, eg.400x300, if a popup should be used) admin en Size of popup. Width x Height e.g. 400x300
|
size of popup (wxh, eg.400x300, if a popup should be used) admin en Size of popup. Width x Height e.g. 400x300
|
||||||
stadt addressbook en City
|
stadt addressbook en City
|
||||||
start admin en Start
|
start admin en Start
|
||||||
|
File diff suppressed because one or more lines are too long
@ -28,23 +28,23 @@
|
|||||||
<rows>
|
<rows>
|
||||||
<row>
|
<row>
|
||||||
<description value="prefix" for="n_prefix"/>
|
<description value="prefix" for="n_prefix"/>
|
||||||
<textbox id="n_prefix" onchange="setName(this);" size="35" maxlength="64"/>
|
<textbox id="n_prefix" onchange="check_value(this,'$cont[id]');" size="35" maxlength="64"/>
|
||||||
</row>
|
</row>
|
||||||
<row>
|
<row>
|
||||||
<description value="first name" for="n_given"/>
|
<description value="first name" for="n_given"/>
|
||||||
<textbox id="n_given" onchange="setName(this);" size="35" maxlength="64"/>
|
<textbox id="n_given" onchange="check_value(this,'$cont[id]');" size="35" maxlength="64"/>
|
||||||
</row>
|
</row>
|
||||||
<row>
|
<row>
|
||||||
<description value="middle name" for="n_middle"/>
|
<description value="middle name" for="n_middle"/>
|
||||||
<textbox id="n_middle" onchange="setName(this);" size="35" maxlength="64"/>
|
<textbox id="n_middle" onchange="check_value(this,'$cont[id]');" size="35" maxlength="64"/>
|
||||||
</row>
|
</row>
|
||||||
<row>
|
<row>
|
||||||
<description value="last name" for="n_family"/>
|
<description value="last name" for="n_family"/>
|
||||||
<textbox id="n_family" onchange="setName(this);" size="35" maxlength="64"/>
|
<textbox id="n_family" onchange="check_value(this,'$cont[id]');" size="35" maxlength="64"/>
|
||||||
</row>
|
</row>
|
||||||
<row>
|
<row>
|
||||||
<description value="suffix" for="n_suffix"/>
|
<description value="suffix" for="n_suffix"/>
|
||||||
<textbox id="n_suffix" onchange="setName(this);" size="35" maxlength="64"/>
|
<textbox id="n_suffix" onchange="check_value(this,'$cont[id]');" size="35" maxlength="64"/>
|
||||||
</row>
|
</row>
|
||||||
<row>
|
<row>
|
||||||
<description/>
|
<description/>
|
||||||
@ -102,12 +102,12 @@
|
|||||||
<row>
|
<row>
|
||||||
<image src="home"/>
|
<image src="home"/>
|
||||||
<description value="Organisation"/>
|
<description value="Organisation"/>
|
||||||
<textbox id="org_name" onchange="setName(this);" size="45" maxlength="128"/>
|
<textbox id="org_name" onchange="check_value(this,'$cont[id]');" size="45" maxlength="128"/>
|
||||||
</row>
|
</row>
|
||||||
<row>
|
<row>
|
||||||
<description/>
|
<description/>
|
||||||
<description value="department" for="org_unit"/>
|
<description value="department" for="org_unit"/>
|
||||||
<textbox id="org_unit" size="45" maxlength="64"/>
|
<textbox id="org_unit" onchange="check_value(this,'$cont[id]');" size="45" maxlength="64"/>
|
||||||
</row>
|
</row>
|
||||||
<row>
|
<row>
|
||||||
<image src="gohome"/>
|
<image src="gohome"/>
|
||||||
@ -486,7 +486,7 @@
|
|||||||
</rows>
|
</rows>
|
||||||
</grid>
|
</grid>
|
||||||
</template>
|
</template>
|
||||||
<template id="addressbook.edit" template="" lang="" group="0" version="1.9.003">
|
<template id="addressbook.edit" template="" lang="" group="0" version="1.9.004">
|
||||||
<grid>
|
<grid>
|
||||||
<columns>
|
<columns>
|
||||||
<column width="450"/>
|
<column width="450"/>
|
||||||
@ -608,12 +608,12 @@
|
|||||||
<row>
|
<row>
|
||||||
<image src="email.png"/>
|
<image src="email.png"/>
|
||||||
<description value="email" for="email"/>
|
<description value="email" for="email"/>
|
||||||
<url-email id="email" options="28,128"/>
|
<url-email id="email" onchange="check_value(this,'$cont[id]');" options="28,128"/>
|
||||||
</row>
|
</row>
|
||||||
<row>
|
<row>
|
||||||
<description/>
|
<description/>
|
||||||
<description value="Private" for="email_home"/>
|
<description value="Private" for="email_home"/>
|
||||||
<url-email id="email_home" options="28,128"/>
|
<url-email id="email_home" onchange="check_value(this,'$cont[id]');" options="28,128"/>
|
||||||
</row>
|
</row>
|
||||||
</rows>
|
</rows>
|
||||||
</grid>
|
</grid>
|
||||||
|
Loading…
Reference in New Issue
Block a user