Added configurable header and footer logos for PDF.
This commit is contained in:
parent
06adfa0301
commit
2b94dc5942
@ -223,7 +223,9 @@ def get_config_variables():
|
|||||||
name='logos_available',
|
name='logos_available',
|
||||||
default_value=[
|
default_value=[
|
||||||
'logo_projector_main',
|
'logo_projector_main',
|
||||||
'logo_projector_header'],
|
'logo_projector_header',
|
||||||
|
'logo_pdf_header',
|
||||||
|
'logo_pdf_footer'],
|
||||||
weight=300,
|
weight=300,
|
||||||
group='Logo',
|
group='Logo',
|
||||||
hidden=True)
|
hidden=True)
|
||||||
@ -247,3 +249,24 @@ def get_config_variables():
|
|||||||
weight=302,
|
weight=302,
|
||||||
group='Logo',
|
group='Logo',
|
||||||
hidden=True)
|
hidden=True)
|
||||||
|
|
||||||
|
#PDF logos
|
||||||
|
yield ConfigVariable(
|
||||||
|
name='logo_pdf_header',
|
||||||
|
default_value={
|
||||||
|
'display_name': 'Header PDF logo',
|
||||||
|
'path': ''},
|
||||||
|
input_type='logo',
|
||||||
|
weight=310,
|
||||||
|
group='Logo',
|
||||||
|
hidden=True)
|
||||||
|
|
||||||
|
yield ConfigVariable(
|
||||||
|
name='logo_pdf_footer',
|
||||||
|
default_value={
|
||||||
|
'display_name': 'Footer PDF logo',
|
||||||
|
'path': ''},
|
||||||
|
input_type='logo',
|
||||||
|
weight=311,
|
||||||
|
group='Logo',
|
||||||
|
hidden=True)
|
||||||
|
@ -144,18 +144,19 @@ angular.module('OpenSlidesApp.core.pdf', [])
|
|||||||
* @param {object} contentProvider - Object with on method `getContent`, which
|
* @param {object} contentProvider - Object with on method `getContent`, which
|
||||||
* returns an array for content
|
* returns an array for content
|
||||||
*/
|
*/
|
||||||
var createInstance = function(contentProvider) {
|
//images shall contain the the logos as URL: base64Str, just like the converter
|
||||||
|
var createInstance = function(contentProvider, images) {
|
||||||
// PDF header
|
// PDF header
|
||||||
var getHeader = function() {
|
var getHeader = function() {
|
||||||
var columns = [];
|
var columns = [];
|
||||||
|
var logoUrl = Config.get('logo_pdf_header').value.path;
|
||||||
|
|
||||||
// add here your custom logo (which has to be added to a custom vfs_fonts.js)
|
if (logoUrl) {
|
||||||
// see https://github.com/pdfmake/pdfmake/wiki/Custom-Fonts---client-side
|
columns.push({
|
||||||
/*
|
image: images[logoUrl],
|
||||||
columns.push({
|
fit: [180,40]
|
||||||
image: 'logo.png',
|
});
|
||||||
fit: [180,40]
|
}
|
||||||
});*/
|
|
||||||
|
|
||||||
var line1 = [
|
var line1 = [
|
||||||
Config.translate(Config.get('general_event_name').value),
|
Config.translate(Config.get('general_event_name').value),
|
||||||
@ -768,7 +769,7 @@ angular.module('OpenSlidesApp.core.pdf', [])
|
|||||||
height *= scaleByHeight;
|
height *= scaleByHeight;
|
||||||
}
|
}
|
||||||
alreadyConverted.push({
|
alreadyConverted.push({
|
||||||
image: BaseMap[element.getAttribute("src")],
|
image: images[element.getAttribute("src")],
|
||||||
width: width,
|
width: width,
|
||||||
height: height
|
height: height
|
||||||
});
|
});
|
||||||
@ -837,7 +838,6 @@ angular.module('OpenSlidesApp.core.pdf', [])
|
|||||||
ParseHtml(content, html);
|
ParseHtml(content, html);
|
||||||
return content;
|
return content;
|
||||||
},
|
},
|
||||||
BaseMap = images,
|
|
||||||
/**
|
/**
|
||||||
* Creates containerelements for pdfMake
|
* Creates containerelements for pdfMake
|
||||||
* e.g create("text":"MyText") result in { text: "MyText" }
|
* e.g create("text":"MyText") result in { text: "MyText" }
|
||||||
|
@ -321,6 +321,7 @@
|
|||||||
ng-mouseleave="mediafile.logoHover=false"
|
ng-mouseleave="mediafile.logoHover=false"
|
||||||
ng-show="mediafile.canBeUsedAsLogo()">
|
ng-show="mediafile.canBeUsedAsLogo()">
|
||||||
<span uib-dropdown>
|
<span uib-dropdown>
|
||||||
|
<<<<<<< e1a95588e7f81cf06db3e753be82bc17a125d059
|
||||||
<span id="dropdownLogo{{ mediafile.id }}" class="pointer nobr" uib-dropdown-toggle>
|
<span id="dropdownLogo{{ mediafile.id }}" class="pointer nobr" uib-dropdown-toggle>
|
||||||
<span uib-tooltip="{{ 'Manage logos' | translate }}" tooltip-class="nobr">
|
<span uib-tooltip="{{ 'Manage logos' | translate }}" tooltip-class="nobr">
|
||||||
<span ng-if="!mediafile.isUsedAsLogo()" ng-show="mediafile.hover">
|
<span ng-if="!mediafile.isUsedAsLogo()" ng-show="mediafile.hover">
|
||||||
@ -335,6 +336,22 @@
|
|||||||
{{ logo.display_name | translate }}<span ng-if="!$last">,</br></span>
|
{{ logo.display_name | translate }}<span ng-if="!$last">,</br></span>
|
||||||
</small>
|
</small>
|
||||||
</span>
|
</span>
|
||||||
|
=======
|
||||||
|
<span id="dropdownLogo{{ mediafile.id }}" class="pointer nobr"
|
||||||
|
uib-dropdown-toggle uib-tooltip="{{ 'Manage logos' | translate }}"
|
||||||
|
tooltip-class="nobr">
|
||||||
|
<span ng-if="!mediafile.isUsedAsLogo()" ng-show="mediafile.hover">
|
||||||
|
<i class="fa fa-picture-o"></i>
|
||||||
|
<i class="fa fa-plus"></i>
|
||||||
|
</span>
|
||||||
|
<span ng-if="mediafile.isUsedAsLogo()">
|
||||||
|
<i class="fa fa-picture-o spacer-right"></i>
|
||||||
|
<span ng-repeat="logo in mediafile.getLogos()">
|
||||||
|
<small>
|
||||||
|
{{ logo.display_name }}
|
||||||
|
</small>
|
||||||
|
<span ng-if="!$last"><br /><i class="fa fa-picture-o spacer-right"></i></span>
|
||||||
|
>>>>>>> add logos in PDF (WIP)
|
||||||
</span>
|
</span>
|
||||||
</span>
|
</span>
|
||||||
<span ng-if="hasProjectorHeaderLogo(mediafile) && mediafile.logoHover"
|
<span ng-if="hasProjectorHeaderLogo(mediafile) && mediafile.logoHover"
|
||||||
|
@ -495,9 +495,11 @@ angular.module('OpenSlidesApp.users.site', [
|
|||||||
'osTableSort',
|
'osTableSort',
|
||||||
'gettext',
|
'gettext',
|
||||||
'PdfCreate',
|
'PdfCreate',
|
||||||
|
'PDFLayout',
|
||||||
|
'$q',
|
||||||
function($scope, $state, $http, ngDialog, UserForm, User, Group, PasswordGenerator, Projector, ProjectionDefault,
|
function($scope, $state, $http, ngDialog, UserForm, User, Group, PasswordGenerator, Projector, ProjectionDefault,
|
||||||
UserListContentProvider, Config, UserAccessDataListContentProvider, PdfMakeDocumentProvider, gettextCatalog,
|
UserListContentProvider, Config, UserAccessDataListContentProvider, PdfMakeDocumentProvider, gettextCatalog,
|
||||||
UserCsvExport, osTableFilter, osTableSort, gettext, PdfCreate) {
|
UserCsvExport, osTableFilter, osTableSort, gettext, PdfCreate, PDFLayout, $q) {
|
||||||
User.bindAll({}, $scope, 'users');
|
User.bindAll({}, $scope, 'users');
|
||||||
Group.bindAll({where: {id: {'>': 1}}}, $scope, 'groups');
|
Group.bindAll({where: {id: {'>': 1}}}, $scope, 'groups');
|
||||||
$scope.$watch(function () {
|
$scope.$watch(function () {
|
||||||
@ -685,10 +687,27 @@ angular.module('OpenSlidesApp.users.site', [
|
|||||||
|
|
||||||
// Export as PDF
|
// Export as PDF
|
||||||
$scope.pdfExportUserList = function () {
|
$scope.pdfExportUserList = function () {
|
||||||
var filename = gettextCatalog.getString("List of participants")+".pdf";
|
var imageMap = {};
|
||||||
var userListContentProvider = UserListContentProvider.createInstance($scope.usersFiltered, $scope.groups);
|
var imagePromises = [];
|
||||||
var documentProvider = PdfMakeDocumentProvider.createInstance(userListContentProvider);
|
var imageSources = [];
|
||||||
PdfCreate.download(documentProvider.getDocument(), filename);
|
|
||||||
|
imageSources.push(Config.get('logo_pdf_header').value.path);
|
||||||
|
imageSources.push(Config.get('logo_pdf_footer').value.path);
|
||||||
|
|
||||||
|
imagePromises = _.map(imageSources, function (image_source) {
|
||||||
|
return PDFLayout.imageURLtoBase64(image_source).then(function (base64Str) {
|
||||||
|
imageMap[image_source] = base64Str;
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
return $q(function (resolve) {
|
||||||
|
$q.all(imagePromises).then(function(base64Str) {
|
||||||
|
var filename = gettextCatalog.getString("List of participants")+".pdf";
|
||||||
|
var userListContentProvider = UserListContentProvider.createInstance($scope.usersFiltered, $scope.groups);
|
||||||
|
var documentProvider = PdfMakeDocumentProvider.createInstance(userListContentProvider, imageMap);
|
||||||
|
PdfCreate.download(documentProvider.getDocument(), filename);
|
||||||
|
});
|
||||||
|
});
|
||||||
};
|
};
|
||||||
$scope.pdfExportUserAccessDataList = function () {
|
$scope.pdfExportUserAccessDataList = function () {
|
||||||
var filename = gettextCatalog.getString("List of access data")+".pdf";
|
var filename = gettextCatalog.getString("List of access data")+".pdf";
|
||||||
@ -1506,7 +1525,7 @@ angular.module('OpenSlidesApp.users.site', [
|
|||||||
},
|
},
|
||||||
function (error) {
|
function (error) {
|
||||||
// Error: Username or password is not correct.
|
// Error: Username or password is not correct.
|
||||||
$state.transitionTo($state.current, {msg: error.data.detail}, {
|
$state.transitionTo($state.current, {msg: error.data.detail}, {
|
||||||
reload: true, inherit: false, notify: true
|
reload: true, inherit: false, notify: true
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user