Handle special characters in strings
This commit is contained in:
+19
-1
@@ -64,7 +64,8 @@ function transformToCsv(cycleDays) {
|
|||||||
const rows = cycleDays
|
const rows = cycleDays
|
||||||
.map(day => {
|
.map(day => {
|
||||||
return columnNames.map(column => {
|
return columnNames.map(column => {
|
||||||
return objectPath.get(day, column, '')
|
const val = objectPath.get(day, column, '')
|
||||||
|
return typeof val === 'string' ? csvify(val) : val
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
.map(row => row.join(','))
|
.map(row => row.join(','))
|
||||||
@@ -72,3 +73,20 @@ function transformToCsv(cycleDays) {
|
|||||||
rows.unshift(columnNames.join(','))
|
rows.unshift(columnNames.join(','))
|
||||||
return rows.join('\n')
|
return rows.join('\n')
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function csvify (val) {
|
||||||
|
// escape double quotes
|
||||||
|
val = val.replace(/"/g, '""')
|
||||||
|
|
||||||
|
val = val.toLowerCase()
|
||||||
|
const hasSpecialChars = (
|
||||||
|
val.includes('\n') ||
|
||||||
|
val.includes('\t') ||
|
||||||
|
val.includes(',') ||
|
||||||
|
val.includes(';') ||
|
||||||
|
val.includes('.') ||
|
||||||
|
val.includes('\'')
|
||||||
|
)
|
||||||
|
|
||||||
|
return hasSpecialChars ? `"${val}"` : val
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user