I want to add an image to the header of the pdf.
I am trying to add the image, which I converted to base 64, to exporterPdfHeader.
$scope.gmGrid.exporterPdfHeader = {
margin: [30, 5, 30, 15],
table: {
widths: [ '*', '*' ],
body: [
[ 'MC #: ' + $scope.mc, 'Week Ending Date: ' + $scope.weekEndDate ],
],
//ADD IMAGE
myImage: '',
width: 150,
height: 150,
},
},
There is no error in the console. Not sure what I am missing. Any help is appreciated.
UPDATE***
I added in the column with the image inside exporterPdfHeader, but when I do this it does not show the header which is contained in the body. It just shows the image and the table.
$scope.gridOptions.exporterPdfHeader ={
//title: 'test',
//LOGO TEST (causes the header to disappear..
columns: [{
image: '',
width: 150
}],
margin: [30, 5, 30, 15],
table: {
widths: [ '*', '*', '*' /*, '*'*/ ],
body: [
[ 'Region: ' + $scope.region, 'Group: ' + $scope.group, 'MC: ' + $scope.mc /*, 'The last one'*/ ],
[ 'District #: ' + $scope.district, 'Route #: ' + $scope.route, 'Week Ending Date: ' + $scope.weekEndDate, /*, 'Value 4' */],
]
},
};
This should get you started:
And here's the relevant angularJS code:
$scope.export = function() {
var exportData = [];
var exportColumnHeaders = $scope.gridOptions.showHeader ? uiGridExporterService.getColumnHeaders($scope.gridApi.grid, uiGridExporterConstants.VISIBLE) : [];
angular.forEach($scope.gridApi.grid.rows, function(row) {
if (row.visible) {
var values = [];
angular.forEach(exportColumnHeaders, function(column) {
var value = row.entity[column.name];
if (column.name == 'rentalCreditPercentTues') value = $filter('percentFilter')(value);
values.push({
value: value
});
});
exportData.push(values);
}
});
var content = uiGridExporterService.prepareAsPdf($scope.gridApi.grid, exportColumnHeaders, exportData);
content.pageMargins = [40, 80, 40, 60];
pdfMake.createPdf(content).open();
};
$scope.gridOptions = {
exporterPdfHeader: {
margin: 20,
columns: [{
image: '',
width: 150
}]
}
};
The trick is creating enough space in the page header using the pageMargins
.
Here's the all important Plunker, http://plnkr.co/edit/1rL7ZBPu9mPym8SEjMxe?p=preview.
Let me know if you need anymore help.
i was able to export an image within exporterPdfHeader function:
$scope.gridOptions.exporterPdfHeader = {
columns: [
{
margin: [0, 0, 0, 0],
image: 'base64 url',
width: 200,
height: 58,
},
{
margin: [0, 0, 0, 0],
table: {
widths: [ '*', '*', '*' ],
body: [
....
]
}
}
]
};
来源:https://stackoverflow.com/questions/42981314/angular-ui-grid-exporting-an-image-to-a-pdf