ImportExport: Fix custom dates formatting to work for more than just the first row

This commit is contained in:
nathangray 2020-09-10 11:39:25 -06:00
parent 372eadcff3
commit edaf3abd4f

View File

@ -246,24 +246,23 @@ class importexport_export_csv implements importexport_iface_export_record
switch($c_field['type']) { switch($c_field['type']) {
case 'date': case 'date':
case 'date-time': case 'date-time':
$fields[$c_field['type']][] = $name;
if ($c_field['values']['format'] && (is_array($record) ? $record[$name] : $record->$name)) if ($c_field['values']['format'] && (is_array($record) ? $record[$name] : $record->$name))
{ {
// Date has custom format. Convert so it's standard. // Date has custom format. Convert so it's standard, don't do normal processing
$val = is_array($record) ? $record[$name] : $record->$name; $format = $c_field['values']['format'];
$date = Api\DateTime::createFromFormat($c_field['values']['format'], $val, Api\DateTime::$user_timezone); $methods[$name] = function($val) use ($format)
{
$date = Api\DateTime::createFromFormat($format, $val, Api\DateTime::$user_timezone);
if($date) if($date)
{ {
$val = $date->format(APi\DateTime::DATABASE); return $date->format(APi\DateTime::DATABASE);
if (is_array($record)) }
{ };
$record[$name] = $val;
} }
else else
{ {
$record->$name = $val; // Process as normal
} $fields[$c_field['type']][] = $name;
}
} }
break; break;
case 'select-account': case 'select-account':
@ -442,7 +441,17 @@ class importexport_export_csv implements importexport_iface_export_record
// Some custom methods for conversion // Some custom methods for conversion
foreach((array)$methods as $name => $method) { foreach((array)$methods as $name => $method) {
if($record->$name) $record->$name = ExecMethod($method, $record->$name); if ($record->$name)
{
if(is_string($method))
{
$record->$name = ExecMethod($method, $record->$name);
}
else if (is_callable($method))
{
$record->$name = $method($record->$name);
}
}
} }
static $cat_object; static $cat_object;