From 87ffff09b0b5b9d806a330f71db694e4da2dc8f0 Mon Sep 17 00:00:00 2001 From: Matthias Sebastian Sort Date: Thu, 16 May 2024 12:51:13 +0200 Subject: [PATCH] Added culture logic when working with HasScriptWithValue in GetStringToWrite, plus setting the culture to default of CurrentCulture --- src/CSVDestinationWriter.cs | 31 +++++++++++++------ ...taIntegration.Providers.CsvProvider.csproj | 2 +- 2 files changed, 22 insertions(+), 11 deletions(-) diff --git a/src/CSVDestinationWriter.cs b/src/CSVDestinationWriter.cs index 84d96a3..ecad7ea 100644 --- a/src/CSVDestinationWriter.cs +++ b/src/CSVDestinationWriter.cs @@ -1,6 +1,7 @@ using Dynamicweb.Core; using Dynamicweb.DataIntegration.Integration; using Dynamicweb.DataIntegration.Integration.Interfaces; +using Dynamicweb.DataIntegration.ProviderHelpers; using System; using System.Collections.Generic; using System.Globalization; @@ -68,7 +69,7 @@ public CsvDestinationWriter(string path, Mapping mapping, bool firstRowContainsC private bool initialized; private readonly string path; private readonly Encoding encoding = Encoding.UTF8; - private readonly CultureInfo cultureInfo; + private readonly CultureInfo cultureInfo = CultureInfo.CurrentCulture; private readonly bool includeTimestampInFileName; public virtual Mapping Mapping @@ -93,7 +94,24 @@ private string GetStringToWrite(Dictionary row, ColumnMapping co { if (columnMapping.HasScriptWithValue) { - return quoteChar + columnMapping.GetScriptValue() + quoteChar + fieldDelimiter; + string value; + if (columnMapping.SourceColumn.Type == typeof(DateTime)) + { + DateTime theDate = DateTime.Parse(columnMapping.GetScriptValue()); + value = theDate.ToString("dd-MM-yyyy HH:mm:ss:fff", cultureInfo); + } + else if (columnMapping.SourceColumn.Type == typeof(decimal) || + columnMapping.SourceColumn.Type == typeof(double) || + columnMapping.SourceColumn.Type == typeof(float)) + { + value = ValueFormatter.GetFormattedValue(columnMapping.GetScriptValue(), cultureInfo, columnMapping.ScriptType, columnMapping.ScriptValue); + } + else + { + value = columnMapping.GetScriptValue(); + } + + return quoteChar + value + quoteChar + fieldDelimiter; } else if (row.TryGetValue(columnMapping.SourceColumn?.Name ?? "", out object rowValue)) { @@ -101,14 +119,7 @@ private string GetStringToWrite(Dictionary row, ColumnMapping co { if (DateTime.TryParse(columnMapping.ConvertInputValueToOutputValue(rowValue)?.ToString(), out var theDateTime)) { - if (cultureInfo != null) - { - return quoteChar + theDateTime.ToString("dd-MM-yyyy HH:mm:ss:fff", cultureInfo) + quoteChar + fieldDelimiter; - } - else - { - return quoteChar + theDateTime.ToString("dd-MM-yyyy HH:mm:ss:fff", CultureInfo.InvariantCulture) + quoteChar + fieldDelimiter; - } + return quoteChar + theDateTime.ToString("dd-MM-yyyy HH:mm:ss:fff", cultureInfo) + quoteChar + fieldDelimiter; } else { diff --git a/src/Dynamicweb.DataIntegration.Providers.CsvProvider.csproj b/src/Dynamicweb.DataIntegration.Providers.CsvProvider.csproj index 9b99746..c5fa08b 100644 --- a/src/Dynamicweb.DataIntegration.Providers.CsvProvider.csproj +++ b/src/Dynamicweb.DataIntegration.Providers.CsvProvider.csproj @@ -1,6 +1,6 @@  - 10.0.10 + 10.0.11 1.0.0.0 CSV Provider CSV Provider