mirror of
https://github.com/EGroupware/egroupware.git
synced 2024-11-18 14:03:19 +01:00
fixed category handling.
allow to preserv cat if record is updated
This commit is contained in:
parent
180c6b407f
commit
2cc3da5193
@ -27,10 +27,14 @@ class import_contacts_csv implements iface_import_plugin {
|
|||||||
'field_mapping', // array( $csv_col_num => adb_filed)
|
'field_mapping', // array( $csv_col_num => adb_filed)
|
||||||
'has_header_line', //bool
|
'has_header_line', //bool
|
||||||
'conditions', /* => array containing condition arrays:
|
'conditions', /* => array containing condition arrays:
|
||||||
'type' => 0, // exists
|
'type' => exists, // exists
|
||||||
'string' => '#kundennummer',
|
'string' => '#kundennummer',
|
||||||
'true' => array(
|
'true' => array(
|
||||||
'action' => update,
|
'action' => update,
|
||||||
|
'options' => array (
|
||||||
|
update_cats' => 'add' // string {override|add} overides record
|
||||||
|
), // with cat(s) from csv OR add the cat from
|
||||||
|
// csv file to exeisting cat(s) of record
|
||||||
'last' => true,
|
'last' => true,
|
||||||
),
|
),
|
||||||
'false' => array(
|
'false' => array(
|
||||||
@ -96,6 +100,7 @@ class import_contacts_csv implements iface_import_plugin {
|
|||||||
$record['contact_owner'] = $_definition->plugin_options['contact_owner'];
|
$record['contact_owner'] = $_definition->plugin_options['contact_owner'];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//
|
||||||
while ( $record = $import_csv->get_record() ) {
|
while ( $record = $import_csv->get_record() ) {
|
||||||
|
|
||||||
// don't import empty contacts
|
// don't import empty contacts
|
||||||
@ -106,15 +111,21 @@ class import_contacts_csv implements iface_import_plugin {
|
|||||||
switch ( $condition['type'] ) {
|
switch ( $condition['type'] ) {
|
||||||
// exists
|
// exists
|
||||||
case 'exists' :
|
case 'exists' :
|
||||||
$contacts = $this->bocontacts->search(array(
|
$contacts = $this->bocontacts->search(
|
||||||
$condition['string'] => $record[$condition['string']],
|
array( $condition['string'] => $record[$condition['string']],),
|
||||||
),true);
|
$condition['true']['options']['update_cats'] == 'add' ? false : true
|
||||||
|
);
|
||||||
|
|
||||||
if ( is_array( $contacts ) && count( array_keys( $contacts ) >= 1 ) ) {
|
if ( is_array( $contacts ) && count( array_keys( $contacts ) >= 1 ) ) {
|
||||||
// apply action to all contacts matching this exists condition
|
// apply action to all contacts matching this exists condition
|
||||||
$action = $condition['true'];
|
$action = $condition['true'];
|
||||||
foreach ( (array)$contacts as $contact ) {
|
foreach ( (array)$contacts as $contact ) {
|
||||||
$record['id'] = $contact['id'];
|
$record['id'] = $contact['id'];
|
||||||
|
if ( $condition['true']['options']['update_cats'] == 'add' ) {
|
||||||
|
if ( !is_array( $contact['cat_id'] ) ) $contact['cat_id'] = explode( ',', $contact['cat_id'] );
|
||||||
|
if ( !is_array( $record['cat_id'] ) ) $record['cat_id'] = explode( ',', $record['cat_id'] );
|
||||||
|
$record['cat_id'] = implode( ',', array_unique( array_merge( $record['cat_id'], $contact['cat_id'] ) ) );
|
||||||
|
}
|
||||||
$this->action( $action['action'], $record );
|
$this->action( $action['action'], $record );
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
|
Loading…
Reference in New Issue
Block a user