У меня есть этот excel, где я хочу заменить скалярные значения, как говорят документы xlsx-template:
| Extracted on: | ${extractDate} |
и я хочу отправить его поверх объекта ответа. Файл правильно записывается в выходной путь, но на клиенте он дает мне двоичный вывод. Сильфон - это бэкэнд-вызов для URL
this.downloadSheet = async (req, res) => {
let seriesNumber = Number(req.body.seriesNumber);
let sheetPath = path.resolve('../filePath/excel.xlsx');
let sheetFinalOuput = path.resolve('../filePath/excelOutput.xlsx');
#Get data needed to swap for the excel
let excelDataStream = await ReportService.getBalanceSheetAllInOne(balanceSheetPath, seriesNumber);
fs.readFile(path.resolve(balanceSheetPath), function(err, data) {
// Create a template
let template = new XlsxTemplate(data);
// Replacements take place on first sheet
const sheetNumber = 1;
// Perform substitution
template.substitute(sheetNumber, excelDataStream);
// Get binary data
var mydata = template.generate({ type: 'nodebuffer'});
fs.writeFile(path.resolve(balanceSheetFinalOuput), mydata, function(err) {
if(err) {
return console.log(err);
}
console.log(`Wrote data in file, check please!`);
// Send File & set headers
res.set({'Content-Disposition': `attachment; filename=balanceIncome${seriesNumber}.csv`, 'Content-Type': 'text/csv'});
res.write(mydata);
res.end();
});
});
};
клиентская функция http почтовый запрос
$http.post(`${settings.apiHost}/api/panel/report/balanceSheet/allInOne/false`,{seriesNumber: $scope.seriesNumber})
.success(function (response) {
var file = new Blob([response], {type: 'text/csv'});
var isGoogleChrome = window.chrome != null && window.navigator.vendor === "Google Inc.";
var isIE = /*@cc_on!@*/false || !!document.documentMode;
var isEdge = !isIE && !!window.StyleMedia;
if (isGoogleChrome){
var url = window.URL || window.webkitURL;
var downloadLink = angular.element('<a></a>');
downloadLink.attr('href',url.createObjectURL(file));
downloadLink.attr('target','_self');
downloadLink.attr('download', `balanceSheet_${$scope.seriesNumber}.csv`);
downloadLink[0].click();
}
else if(isEdge || isIE){
window.navigator.msSaveOrOpenBlob(file,`balanceSheet_${$scope.seriesNumber}.csv`);
}
else {
var fileURL = URL.createObjectURL(file);
window.open(fileURL);
}
})