From c2bd7c16a9ef95a189ce9cb21a202d3d1585ff9a Mon Sep 17 00:00:00 2001 From: Sean Date: Tue, 14 Jul 2020 12:34:05 +0200 Subject: [PATCH] Fix PDF generation for motion with free amendments Fixes an issue where motions which had free form amendments were not be able to render as pdf --- .../motions/services/motion-pdf.service.ts | 31 ++++++++++++------- 1 file changed, 20 insertions(+), 11 deletions(-) diff --git a/client/src/app/site/motions/services/motion-pdf.service.ts b/client/src/app/site/motions/services/motion-pdf.service.ts index 28b6b5709..875d7e4f7 100644 --- a/client/src/app/site/motions/services/motion-pdf.service.ts +++ b/client/src/app/site/motions/services/motion-pdf.service.ts @@ -630,17 +630,26 @@ export class MotionPdfService { * @returns */ private getUnifiedChanges(motion: ViewMotion, lineLength: number): ViewUnifiedChange[] { - return this.changeRecoRepo - .getChangeRecoOfMotion(motion.id) - .concat( - this.motionRepo.getAmendmentsInstantly(motion.id).flatMap((amendment: ViewMotion) => { - const changeRecos = this.changeRecoRepo - .getChangeRecoOfMotion(amendment.id) - .filter(reco => reco.showInFinalView()); - return this.motionRepo.getAmendmentAmendedParagraphs(amendment, lineLength, changeRecos); - }) - ) - .sort((a, b) => a.getLineFrom() - b.getLineFrom()) as ViewUnifiedChange[]; + const changeRecosOfMotion = this.changeRecoRepo.getChangeRecoOfMotion(motion.id); + + if (changeRecosOfMotion && changeRecosOfMotion.length) { + return changeRecosOfMotion + .concat( + this.motionRepo.getAmendmentsInstantly(motion.id).flatMap((amendment: ViewMotion) => { + const changeRecos = this.changeRecoRepo + .getChangeRecoOfMotion(amendment.id) + .filter(reco => reco.showInFinalView()); + if (changeRecos && changeRecos.length) { + return this.motionRepo.getAmendmentAmendedParagraphs(amendment, lineLength, changeRecos); + } + }) + ) + .sort((a, b) => { + return a.getLineFrom() - b.getLineFrom(); + }); + } else { + return []; + } } /**