forked from extern/egroupware
Add 'All custom fields' field option, that will cause all custom fields to be exported
This commit is contained in:
parent
886335e073
commit
c99e804d8d
@ -112,10 +112,18 @@ class importexport_export_csv implements importexport_iface_export_record
|
|||||||
*
|
*
|
||||||
* @param array $_mapping egw_field_name => csv_field_name
|
* @param array $_mapping egw_field_name => csv_field_name
|
||||||
*/
|
*/
|
||||||
public function set_mapping( array $_mapping) {
|
public function set_mapping( array &$_mapping) {
|
||||||
if ($this->num_of_records > 0) {
|
if ($this->num_of_records > 0) {
|
||||||
throw new Exception('Error: Field mapping can\'t be set during ongoing export!');
|
throw new Exception('Error: Field mapping can\'t be set during ongoing export!');
|
||||||
}
|
}
|
||||||
|
if($_mapping['all_custom_fields']) {
|
||||||
|
// Field value is the appname, so we can pull the fields
|
||||||
|
$custom = config::get_customfields($_mapping['all_custom_fields']);
|
||||||
|
unset($_mapping['all_custom_fields']);
|
||||||
|
foreach($custom as $field => $info) {
|
||||||
|
$_mapping['#'.$field] = $this->csv_options['begin_with_fieldnames'] == 'label' ? $info['label'] : $field;
|
||||||
|
}
|
||||||
|
}
|
||||||
$this->mapping = $_mapping;
|
$this->mapping = $_mapping;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -60,7 +60,7 @@ class importexport_wizard_basic_export_csv
|
|||||||
'wizard_step40' => lang('Choose seperator and charset'),
|
'wizard_step40' => lang('Choose seperator and charset'),
|
||||||
);
|
);
|
||||||
list($appname, $part2) = explode('_', get_class($this));
|
list($appname, $part2) = explode('_', get_class($this));
|
||||||
if(!$GLOBALS['egw_info']['apps'][$appname]) $appname .= $part2; // Handle apps with _ in the name
|
if(!$GLOBALS['egw_info']['apps'][$appname]) $appname .= '_'.$part2; // Handle apps with _ in the name
|
||||||
translation::add_app($appname);
|
translation::add_app($appname);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -74,6 +74,16 @@ class importexport_wizard_basic_export_csv
|
|||||||
if ($content['step'] == 'wizard_step30')
|
if ($content['step'] == 'wizard_step30')
|
||||||
{
|
{
|
||||||
$content['mapping'] = array_combine($content['fields']['export'], $content['fields']['export']);
|
$content['mapping'] = array_combine($content['fields']['export'], $content['fields']['export']);
|
||||||
|
if($content['mapping']['all_custom_fields']) {
|
||||||
|
// Need the appname during actual export, to fetch the fields
|
||||||
|
$parts = explode('_', get_class($this));
|
||||||
|
$appname = $parts[0];
|
||||||
|
foreach($parts as $name_part) {
|
||||||
|
if($GLOBALS['egw_info']['apps'][$appname]) break;
|
||||||
|
$appname .= '_'.$name_part; // Handle apps with _ in the name
|
||||||
|
}
|
||||||
|
$content['mapping']['all_custom_fields'] = $appname;
|
||||||
|
}
|
||||||
unset($content['mapping']['']);
|
unset($content['mapping']['']);
|
||||||
unset($content['fields']);
|
unset($content['fields']);
|
||||||
switch (array_search('pressed', $content['button']))
|
switch (array_search('pressed', $content['button']))
|
||||||
@ -93,11 +103,14 @@ class importexport_wizard_basic_export_csv
|
|||||||
{
|
{
|
||||||
$content['msg'] = $this->steps['wizard_step30'];
|
$content['msg'] = $this->steps['wizard_step30'];
|
||||||
$content['step'] = 'wizard_step30';
|
$content['step'] = 'wizard_step30';
|
||||||
|
$this->export_fields += array('all_custom_fields' => 'All custom fields');
|
||||||
$sel_options['field'] = $this->export_fields;
|
$sel_options['field'] = $this->export_fields;
|
||||||
$preserv = $content;
|
$preserv = $content;
|
||||||
unset ($preserv['button']);
|
unset ($preserv['button']);
|
||||||
|
unset ($preserv['fields']);
|
||||||
$content['fields'] = array('');
|
$content['fields'] = array('');
|
||||||
if(!$content['mapping']) $content['mapping'] = $content['plugin_options']['mapping'];
|
if(!$content['mapping']) $content['mapping'] = $content['plugin_options']['mapping'];
|
||||||
|
|
||||||
$row = 1;
|
$row = 1;
|
||||||
foreach($this->export_fields as $field => $name) {
|
foreach($this->export_fields as $field => $name) {
|
||||||
$content['fields'][] = array(
|
$content['fields'][] = array(
|
||||||
@ -131,7 +144,8 @@ class importexport_wizard_basic_export_csv
|
|||||||
if ($content['step'] == 'wizard_step40') {
|
if ($content['step'] == 'wizard_step40') {
|
||||||
if($content['begin_with_fieldnames'] == 'label') {
|
if($content['begin_with_fieldnames'] == 'label') {
|
||||||
foreach($content['mapping'] as $field => &$label) {
|
foreach($content['mapping'] as $field => &$label) {
|
||||||
$label = $this->export_fields[$field];
|
// Check first, to avoid clearing any pseudo-columns (ex: All custom fields)
|
||||||
|
$label = $this->export_fields[$field] ? $this->export_fields[$field] : $label;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
switch (array_search('pressed', $content['button']))
|
switch (array_search('pressed', $content['button']))
|
||||||
|
Loading…
Reference in New Issue
Block a user