2020-05-01 04:14:59 +00:00
|
|
|
import Papa from 'papaparse'
|
2020-07-09 06:42:48 +00:00
|
|
|
import escapeHTML from 'lodash/escape'
|
2020-05-01 04:14:59 +00:00
|
|
|
|
|
|
|
const safeParse = d => {
|
|
|
|
try {
|
|
|
|
return JSON.parse(d)
|
|
|
|
} catch (err) {
|
|
|
|
return d
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
export function renderCSVPreview (csv, options = {}, attr = '') {
|
|
|
|
const opt = Object.keys(options).reduce((acc, key) => {
|
|
|
|
return Object.assign(acc, {
|
|
|
|
[key]: safeParse(options[key])
|
|
|
|
})
|
|
|
|
}, {})
|
|
|
|
|
|
|
|
const results = Papa.parse(csv.trim(), opt)
|
|
|
|
|
|
|
|
if (opt.header) {
|
|
|
|
const fields = results.meta.fields
|
|
|
|
return `<table ${attr}>
|
|
|
|
<thead>
|
|
|
|
<tr>
|
2020-07-09 06:42:48 +00:00
|
|
|
${fields.map(f => `<th>${escapeHTML(f)}</th>`).join('')}
|
2020-05-01 04:14:59 +00:00
|
|
|
</tr>
|
|
|
|
</thead>
|
|
|
|
<tbody>
|
|
|
|
${results.data.map(d => `<tr>
|
2020-07-09 06:42:48 +00:00
|
|
|
${fields.map(f => `<td>${escapeHTML(d[f])}</td>`).join('')}
|
2020-05-01 04:14:59 +00:00
|
|
|
</tr>`).join('')}
|
|
|
|
</tbody>
|
|
|
|
</table>`
|
|
|
|
} else {
|
|
|
|
return `<table ${attr}>
|
|
|
|
<tbody>
|
|
|
|
${results.data.map(d => `<tr>
|
2020-07-09 06:42:48 +00:00
|
|
|
${d.map(f => `<td>${escapeHTML(f)}</td>`).join('')}
|
2020-05-01 04:14:59 +00:00
|
|
|
</tr>`).join('')}
|
|
|
|
</tbody>
|
|
|
|
</table>`
|
|
|
|
}
|
|
|
|
}
|