|
@ -134,40 +134,42 @@ class File { |
|
|
const columnsIndex = {}; |
|
|
const columnsIndex = {}; |
|
|
for (let column of columns) { |
|
|
for (let column of columns) { |
|
|
columnsIndex[column] = { |
|
|
columnsIndex[column] = { |
|
|
index: -1, |
|
|
exist: false, |
|
|
main: (String(column)).split('.')[0], |
|
|
main: (String(column)).split('.')[0], |
|
|
value: column, |
|
|
value: column, |
|
|
|
|
|
rest: (String(column)).split('.').slice(1).join('.'), |
|
|
last: (String(column)).split('.').pop(), |
|
|
last: (String(column)).split('.').pop(), |
|
|
}; |
|
|
}; |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
let i = 0; |
|
|
const columnsFiltered = []; |
|
|
|
|
|
|
|
|
|
|
|
let count = 1; |
|
|
fs.createReadStream(this.filepath) |
|
|
fs.createReadStream(this.filepath) |
|
|
.pipe(csvParser({ separator: ';' })) |
|
|
.pipe(csvParser({ separator: ';' })) |
|
|
.on('headers', (headers) => { |
|
|
.on('headers', (headers) => { |
|
|
|
|
|
headers = headers.map(header => typeof header === 'string' ? header.trim() : header); |
|
|
|
|
|
|
|
|
|
|
|
const result = []; |
|
|
|
|
|
for (let key in columnsIndex) { |
|
|
|
|
|
columnsIndex[key].exist = headers.includes(columnsIndex[key].main); |
|
|
|
|
|
if ( columnsIndex[key].exist ) { |
|
|
|
|
|
columnsFiltered.push(columnsIndex[key].value); |
|
|
|
|
|
result.push(columnsIndex[key].last); |
|
|
|
|
|
} |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
// Emit a parse.start event with the url and filepath
|
|
|
// Emit a parse.start event with the url and filepath
|
|
|
emitter.emit('parse.start', { url: this.url, filepath: this.filepath, headers }); |
|
|
emitter.emit('parse.start', { url: this.url, filepath: this.filepath, headers, result: result }); |
|
|
|
|
|
|
|
|
|
|
|
stream.write(result.join(';') + "\n"); |
|
|
}) |
|
|
}) |
|
|
.on('data', (row) => { |
|
|
.on('data', (row) => { |
|
|
// Emit a parse.data event with the url, filepath and data
|
|
|
// Emit a parse.data event with the url, filepath and data
|
|
|
emitter.emit('parse.data', { url: this.url, filepath: this.filepath, data: row, index: i }); |
|
|
let result = this.processRow(row, columnsIndex, columnsFiltered); |
|
|
|
|
|
emitter.emit('parse.data', { url: this.url, filepath: this.filepath, data: row, result, index: count }); |
|
|
let result = []; |
|
|
stream.write(result.join(';') + "\n"); |
|
|
if ( i === 0 ) { |
|
|
count++; |
|
|
for(let i = 0; i < row.length; i++) { |
|
|
|
|
|
for (let key of columnsIndex) { |
|
|
|
|
|
if (row[i] === columnsIndex[key].main) { |
|
|
|
|
|
columnsIndex[key].index = i; |
|
|
|
|
|
result.push(columnsIndex[key].last); |
|
|
|
|
|
} |
|
|
|
|
|
} |
|
|
|
|
|
} |
|
|
|
|
|
} else { |
|
|
|
|
|
// Loop through indexes and push the value of the column to result
|
|
|
|
|
|
result = this.processRow(row, columnsIndex); |
|
|
|
|
|
} |
|
|
|
|
|
stream.write(result.join(';')); |
|
|
|
|
|
i++; |
|
|
|
|
|
}) |
|
|
}) |
|
|
.on('error', (err) => { |
|
|
.on('error', (err) => { |
|
|
// Emit a parse.error event with the error
|
|
|
// Emit a parse.error event with the error
|
|
@ -175,7 +177,7 @@ class File { |
|
|
}) |
|
|
}) |
|
|
.on('end', () => { |
|
|
.on('end', () => { |
|
|
// Emit a parse.end event with the url and filepath
|
|
|
// Emit a parse.end event with the url and filepath
|
|
|
emitter.emit('parse.end', { url: this.url, filepath: this.filepath, count: i }); |
|
|
emitter.emit('parse.end', { url: this.url, filepath: this.filepath, count: count - 1 }); |
|
|
stream.end(); |
|
|
stream.end(); |
|
|
}); |
|
|
}); |
|
|
|
|
|
|
|
@ -190,6 +192,10 @@ class File { |
|
|
* @return string |
|
|
* @return string |
|
|
*/ |
|
|
*/ |
|
|
getValueByPath(obj, path) { |
|
|
getValueByPath(obj, path) { |
|
|
|
|
|
if ( !path || typeof path !== 'string' ) { |
|
|
|
|
|
return obj; |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
const parts = path.split('.'); |
|
|
const parts = path.split('.'); |
|
|
let result = obj; |
|
|
let result = obj; |
|
|
for (let part of parts) { |
|
|
for (let part of parts) { |
|
@ -208,37 +214,39 @@ class File { |
|
|
/** |
|
|
/** |
|
|
* Generate exported row |
|
|
* Generate exported row |
|
|
* |
|
|
* |
|
|
* @param array row |
|
|
* @param object row |
|
|
* @param object columnsIndex |
|
|
* @param object columnsIndex |
|
|
* @return array |
|
|
* @return array |
|
|
*/ |
|
|
*/ |
|
|
processRow(row, columnsIndex) { |
|
|
processRow(row, columnsIndex, columnsFiltered) { |
|
|
const result = []; |
|
|
const result = []; |
|
|
|
|
|
|
|
|
for (let i = 0; i < row.length; i++) { |
|
|
for (let key in row) { |
|
|
try { |
|
|
try { |
|
|
row[i] = JSON.parse(row[i]); |
|
|
if ( typeof row[key] === 'string' && row[key].startsWith('{') && row[key].endsWith('}') ) { |
|
|
|
|
|
row[key] = JSON.parse(row[key]); |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
row[key.trim()] = row[key] |
|
|
} catch (err) { |
|
|
} catch (err) { |
|
|
// result.push('');
|
|
|
// result.push('');
|
|
|
console.log(err); |
|
|
console.log(err.message); |
|
|
} |
|
|
} |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
const validIndexes = Object.keys(columnsIndex).filter(key => columnsIndex[key].index !== -1); |
|
|
for (let key of columnsFiltered) { |
|
|
|
|
|
if (!columnsIndex[key].exist) { |
|
|
for (let i=0; i < row.length; i++) { |
|
|
|
|
|
if (!validIndexes.includes(i)) { |
|
|
|
|
|
continue; |
|
|
continue; |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
const column = columnsIndex[i]; |
|
|
const column = columnsIndex[key]; |
|
|
const item = row[i]; |
|
|
const item = row[column.main] || ''; |
|
|
|
|
|
|
|
|
if ( column.primary === column.value ) { |
|
|
if ( column.primary === column.value ) { |
|
|
result.push(item); |
|
|
result.push(item); |
|
|
} else { |
|
|
} else { |
|
|
if ( typeof item === 'object' ) { |
|
|
if ( typeof item === 'object' ) { |
|
|
result.push(this.getValueByPath(item, column.value)); |
|
|
result.push(this.getValueByPath(item, column.rest)); |
|
|
} else { |
|
|
} else { |
|
|
result.push(item); |
|
|
result.push(item); |
|
|
} |
|
|
} |
|
|