Skip to content

Commit

Permalink
Changing to pdfmake.org
Browse files Browse the repository at this point in the history
First version
  • Loading branch information
m20io committed Feb 11, 2016
1 parent b848a8d commit 9e00dbf
Show file tree
Hide file tree
Showing 7 changed files with 124 additions and 7 deletions.
Binary file added src/images/emo-c1_small.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added src/images/emo-c2_small.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added src/images/emo-c3_small.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added src/images/emo-c4_small.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added src/images/emo-c5_small.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
10 changes: 5 additions & 5 deletions src/javascript/utilities/index.js

Large diffs are not rendered by default.

121 changes: 119 additions & 2 deletions src/javascript/views/JournalPdfView.js
Original file line number Diff line number Diff line change
Expand Up @@ -30,6 +30,7 @@ import FeelingSmiley from '../components/FeelingSmiley'
import Content from '../constants/localizableStringsDE.js'

import FixedSectionFooter from '../components/Question/FixedSectionFooter.react.js'
import { includes, filter, first, isNil, keys, map, isEmpty } from 'lodash'
import { imageForEmotion, buildBodyForDisplay, hexToRgb, calculateEmotionColor, formatDay, formatTime, journalSorter, mapJournal, reverseArray, intersperse} from '../utilities'


Expand Down Expand Up @@ -66,14 +67,130 @@ class JournalPdfView extends Component {
right_leg: Content.QUESTION_BODY_RIGHT_LEG,
hip: Content.QUESTION_BODY_HIP
}
const { user, journals, journalsForPdf } = this.props
const selectedJournals = filter(journals, rawJournal => includes(journalsForPdf, rawJournal.id))

let journalContent = []

map(selectedJournals, rawJournal => {
const journal = mapJournal(rawJournal)
const journal_date = new Date(rawJournal.created_at)

// Journal entry headline
let answers = [{ text: `${formatDay(journal_date)}, ${formatTime(journal_date)} \n`, style:'date' }]
answers.push({ text: 'Dein Befinden:\n', bold:true })
answers.push({ stack: [{ image: imageForEmotion(journal.feeling), width: 24, height: 24 }]})
answers.push({ text: `${journal.feeling}/100\n\n`, color: calculateEmotionColor(journal.feeling) })

let printBodyHeadline = true
map(keys(body_parts), (element) => {
if(!isEmpty(journal.body[element])) {
if(printBodyHeadline) {
answers.push({ text: 'Dein Körper:\n', bold: true })
printBodyHeadline = false
}
answers.push({ text: `${body_parts[element]}\n`, bold:true, fontSize: 10 })
answers.push({ text: `${journal.body[element].join(', ')}\n`, fontSize: 9})
}
})

if(!isEmpty(journal.thoughts)) {
answers.push({ text: 'Deine Gedanken:\n', bold: true })
answers.push({ text: `${journal.thoughts.join(', ')} \n\n` })
}
if(!isEmpty(journal.situation)) {
answers.push({ text: 'Deine Situation:\n', bold: true })
answers.push({ text: `${journal.situation.join(', ')} \n\n` })
}
if(!isEmpty(journal.reaction)) {
answers.push({ text: 'Deine Reaction:\n', bold: true })
answers.push({ text: `${journal.reaction.join(', ')} \n\n` })
}

journalContent.push([{ stack : answers, style:'journal' }])
})

let dd = {
content: "This is a sample PDF printed with pdfMake",
defaultStyle: {
font: 'Raleway'
},
header: [
{ text: + user.email, margin: [55,16,16,16] }
],
content: [
{
columns: [{ image: 'rtvlogo', width: 200 }, { text: formatDay(new Date()), width: 200, alignment: 'right' }],
margin: [55, 40, 60, 40]
},
{ text: 'Achtsamkeits-Tagebuch\n', style: 'title' },
{ text: user.email + '\n\n', style: 'content' },
{
text: [ { text: 'Alle Einträge:\n\n', fontSize: 15, italics: true, bold: false },],
style: 'content'
},
{
table: {
widths: ['100%'],
body: journalContent
},
layout: {
hLineWidth: function(i, node) {
return (i === node.table.body.length) ? 0 : 1;
},
vLineWidth: function(i, node) {
return 0;
},
hLineColor: function(i, node) {
return (i === 0 || i === node.table.body.length) ? 'gray' : 'gray';
},
},
style: 'content'
},
],
styles: {
header: {
fontSize: 18,
bold: true
},
title: {
fontSize: 18,
bold:true,
margin: [55, 16, 60, 0]
},
subtitle: {

},
date: {
fontSize: 14,
bold: false,
margin:[0,8,0,8]
},
journal: {
fontSize:11,
bold: false,
margin:[0,0,0,20]
},
bigger: {
fontSize: 15,
italics: true,
},
journalHeadline: {
bold: true,
fontSize: 11
},
journalBody: {
fontSize: 10
},
content: {
margin: [55, 0, 60, 0]
}
},
images: {
rtvlogo: ''
}
}
let fontDefinition = {

const fontDefinition = {
Roboto: {
normal: 'Roboto-Regular.ttf',
bold: 'Roboto-Medium.ttf',
Expand Down

0 comments on commit 9e00dbf

Please sign in to comment.