2020-09-03 11:11:43 -04:00
const bindAll = require ( 'lodash.bindall' ) ;
2020-08-10 16:43:07 -04:00
const FormattedHTMLMessage = require ( 'react-intl' ) . FormattedHTMLMessage ;
const FormattedMessage = require ( 'react-intl' ) . FormattedMessage ;
2020-09-03 11:11:43 -04:00
// const injectIntl = require('react-intl').injectIntl;
2020-08-31 17:00:50 -04:00
// const intlShape = require('react-intl').intlShape;
2020-08-10 16:43:07 -04:00
const React = require ( 'react' ) ;
const Button = require ( '../../components/forms/button.jsx' ) ;
const FlexRow = require ( '../../components/flex-row/flex-row.jsx' ) ;
2020-08-31 17:00:50 -04:00
// const MasonryGrid = require('../../components/masonrygrid/masonrygrid.jsx');
2020-08-10 16:43:07 -04:00
const TitleBanner = require ( '../../components/title-banner/title-banner.jsx' ) ;
2020-08-31 17:00:50 -04:00
// const NavigationBox = require('../../components/navigation/base/navigation.jsx');
2020-08-28 16:55:16 -04:00
const Comment = require ( '../../components/comment/comment.jsx' ) ;
2020-08-10 16:43:07 -04:00
const Page = require ( '../../components/page/www/page.jsx' ) ;
const render = require ( '../../lib/render.jsx' ) ;
2020-08-17 12:04:38 -04:00
2020-08-10 16:43:07 -04:00
require ( './annual-report.scss' ) ;
2020-09-03 11:11:43 -04:00
class AnnualReport extends React . Component {
constructor ( ) {
super ( ) ;
2020-09-03 16:01:16 -04:00
this . messageRef = null ;
2020-09-03 11:11:43 -04:00
this . missionRef = null ;
2020-09-03 16:01:16 -04:00
this . reachRef = null ;
this . milestonesRef = null ;
this . initiativesRef = null ;
this . financialsRef = null ;
this . supportersRef = null ;
this . leadershipRef = null ;
this . donateRef = null ;
this . sectionRefs = {
message : ( ) => this . messageRef ,
mission : ( ) => this . missionRef ,
reach : ( ) => this . reachRef ,
milestones : ( ) => this . milestonesRef ,
initiatives : ( ) => this . initiativesRef ,
financials : ( ) => this . financialsRef ,
supporters : ( ) => this . supportersRef ,
leadership : ( ) => this . leadershipRef ,
donate : ( ) => this . donateRef
} ;
2020-09-03 11:11:43 -04:00
bindAll ( this , [
'scrollTo' ,
2020-09-03 16:01:16 -04:00
'setMessageRef' ,
'setMissionRef' ,
'setReachRef' ,
'setMilestonesRef' ,
'setInitiativesRef' ,
'setFinancialsRef' ,
'setSupportersRef' ,
'setLeadershipRef' ,
'setDonateRef' ,
'handleSubNavItemClick'
2020-09-03 11:11:43 -04:00
] ) ;
}
2020-09-03 16:01:16 -04:00
// A generic handler for a subnav item that takes the name of the
// section to scroll to (all lowercase)
handleSubNavItemClick ( sectionName ) {
// Return a button click handler that scrolls to the
// correct section
return ( ) => {
this . scrollTo ( this . sectionRefs [ sectionName ] ( ) ) ;
} ;
}
2020-09-03 11:11:43 -04:00
scrollTo ( element ) {
2020-09-03 16:01:16 -04:00
if ( element ) {
element . scrollIntoView ( {
behavior : 'smooth' ,
block : 'start'
} ) ;
}
2020-09-03 11:11:43 -04:00
}
2020-09-03 16:01:16 -04:00
setMessageRef ( ref ) {
this . messageRef = ref ;
}
2020-09-03 11:11:43 -04:00
setMissionRef ( ref ) {
this . missionRef = ref ;
}
2020-09-03 16:01:16 -04:00
setReachRef ( ref ) {
this . reachRef = ref ;
}
setMilestonesRef ( ref ) {
this . milestonesRef = ref ;
}
setInitiativesRef ( ref ) {
this . initiativesRef = ref ;
}
setFinancialsRef ( ref ) {
this . financialsRef = ref ;
}
setSupportersRef ( ref ) {
this . supportersRef = ref ;
}
setLeadershipRef ( ref ) {
this . leadershipRef = ref ;
}
setDonateRef ( ref ) {
this . donateRef = ref ;
}
2020-09-03 11:11:43 -04:00
render ( ) {
return (
< div >
< div className = "subnavigation" >
< FlexRow className = "inner" >
< a
className = "link"
2020-09-03 16:01:16 -04:00
onClick = { this . handleSubNavItemClick ( 'message' ) }
2020-09-03 11:11:43 -04:00
>
< FormattedMessage id = "annualReport.subnavMessage" / >
< / a >
< a
className = "link"
2020-09-03 16:01:16 -04:00
onClick = { this . handleSubNavItemClick ( 'mission' ) }
2020-09-03 11:11:43 -04:00
>
< FormattedMessage id = "annualReport.subnavMission" / >
< / a >
< a
className = "link"
2020-09-03 16:01:16 -04:00
onClick = { this . handleSubNavItemClick ( 'reach' ) }
2020-09-03 11:11:43 -04:00
>
< FormattedMessage id = "annualReport.subnavReach" / >
< / a >
< a
className = "link"
2020-09-03 16:01:16 -04:00
onClick = { this . handleSubNavItemClick ( 'milestones' ) }
2020-09-03 11:11:43 -04:00
>
< FormattedMessage id = "annualReport.subnavMilestones" / >
< / a >
< a
className = "link"
2020-09-03 16:01:16 -04:00
onClick = { this . handleSubNavItemClick ( 'initiatives' ) }
2020-09-03 11:11:43 -04:00
>
2020-09-03 16:01:16 -04:00
< FormattedMessage id = "annualReport.subnavInitiatives" / >
2020-09-03 11:11:43 -04:00
< / a >
< a
className = "link"
2020-09-03 16:01:16 -04:00
onClick = { this . handleSubNavItemClick ( 'financials' ) }
2020-09-03 11:11:43 -04:00
>
< FormattedMessage id = "annualReport.subnavFinancials" / >
< / a >
< a
className = "link"
2020-09-03 16:01:16 -04:00
onClick = { this . handleSubNavItemClick ( 'supporters' ) }
2020-09-03 11:11:43 -04:00
>
< FormattedMessage id = "annualReport.subnavSupporters" / >
< / a >
< a
className = "link"
2020-09-03 16:01:16 -04:00
onClick = { this . handleSubNavItemClick ( 'leadership' ) }
2020-09-03 11:11:43 -04:00
>
< FormattedMessage id = "annualReport.subnavLeadership" / >
< / a >
< a
className = "link"
2020-09-03 16:01:16 -04:00
onClick = { this . handleSubNavItemClick ( 'donate' ) }
2020-09-03 11:11:43 -04:00
>
< FormattedMessage id = "annualReport.subnavDonate" / >
< / a >
< / FlexRow >
2020-08-10 16:43:07 -04:00
< / div >
2020-09-03 11:11:43 -04:00
< div className = "banner-wrapper" >
< TitleBanner className = "masthead masthead" >
< div className = "title-banner-p" >
< img src = "/images/ideas/masthead-illustration.svg" / >
< h1 className = "title-banner-h1" >
< FormattedMessage id = "ideas.headerMessage" / >
< / h1 >
< a href = "/projects/editor/?tutorial=all" >
< Button className = "ideas-button" >
< img src = "/images/ideas/bulb-icon.svg" / >
< FormattedMessage id = "ideas.headerButtonMessage" / >
< / Button >
< / a >
< / div >
< / TitleBanner >
2020-08-31 17:00:50 -04:00
< / div >
2020-09-03 11:11:43 -04:00
< div
2020-09-03 16:01:16 -04:00
className = "mission section"
2020-09-03 11:11:43 -04:00
id = "mission"
ref = { this . setMissionRef }
>
< div className = "inner" >
2020-08-10 16:43:07 -04:00
< / div >
2020-08-31 17:00:50 -04:00
< / div >
2020-09-03 11:11:43 -04:00
< div
2020-09-03 16:01:16 -04:00
className = "milestones-section section"
2020-09-03 11:11:43 -04:00
id = "milestones"
2020-09-03 16:01:16 -04:00
ref = { this . setMilestonesRef }
2020-09-03 11:11:43 -04:00
>
< div className = "inner" >
< div className = "milestones-intro" >
< h2 >
< FormattedMessage id = "annualReport.milestonesTitle" / >
< / h2 >
< p >
< FormattedMessage id = "annualReport.milestonesDescription" / >
< / p >
2020-08-25 16:47:11 -04:00
< / div >
2020-09-03 11:11:43 -04:00
< div className = "milestones-boxes" >
< div className = "milestone-box first" >
< h4 >
2003
{ /* TODO should this be localized? */ }
< / h4 >
2020-08-25 16:47:11 -04:00
< p >
2020-09-03 11:11:43 -04:00
< FormattedMessage id = "annualReport.milestones2003Message" / >
2020-08-25 16:47:11 -04:00
< / p >
< / div >
2020-09-03 11:11:43 -04:00
< div className = "milestone-box" >
< h4 >
2004
{ /* TODO should this be localized? */ }
< / h4 >
2020-08-25 16:47:11 -04:00
< p >
2020-09-03 11:11:43 -04:00
< FormattedMessage id = "annualReport.milestones2004Message" / >
2020-08-25 16:47:11 -04:00
< / p >
2020-09-03 11:11:43 -04:00
< img src = "/images/annual-report/milestones/2004_Clubhouse.jpg" / >
2020-08-25 16:47:11 -04:00
< / div >
2020-09-03 11:11:43 -04:00
< div className = "milestone-box last" >
< h4 >
2007
{ /* TODO should this be localized? */ }
< / h4 >
2020-08-25 16:47:11 -04:00
< p >
2020-09-03 11:11:43 -04:00
< FormattedMessage id = "annualReport.milestones2007Message" / >
2020-08-25 16:47:11 -04:00
< / p >
2020-09-03 11:11:43 -04:00
< img src = "/images/annual-report/milestones/2007_EarlyScratch.png" / >
2020-08-25 16:47:11 -04:00
< / div >
< / div >
< / div >
< / div >
2020-09-03 11:11:43 -04:00
< div
2020-09-03 16:01:16 -04:00
className = "our-reach section"
2020-09-03 11:11:43 -04:00
id = "reach"
2020-09-03 16:01:16 -04:00
ref = { this . setReachRef }
2020-09-03 11:11:43 -04:00
>
< div className = "inner" >
< section className = "ttt-section" >
< div className = "ttt-head" >
< h2 >
< FormattedMessage id = "ideas.activityGuidesTitle" / >
< / h2 >
2020-08-25 16:47:11 -04:00
< p >
2020-09-03 11:11:43 -04:00
< FormattedHTMLMessage id = "ideas.activityGuidesText" / >
2020-08-25 16:47:11 -04:00
< / p >
< / div >
2020-09-03 11:11:43 -04:00
< a
className = "wide-button"
href = "/projects/editor/?tutorial=all"
>
< Button className = "ideas-button wide-button" >
< FormattedMessage id = "ideas.seeAllTutorials" / >
< / Button >
< / a >
< / section >
< / div >
< / div >
< div
2020-09-03 16:01:16 -04:00
className = "initiatives section"
id = "initiatives"
ref = { this . setInitiativesRef }
2020-09-03 11:11:43 -04:00
>
< div className = "inner" >
< section className = "ttt-section" >
< div className = "ttt-head" >
< h2 >
< FormattedMessage id = "ideas.activityGuidesTitle" / >
< / h2 >
2020-08-25 16:47:11 -04:00
< p >
2020-09-03 11:11:43 -04:00
< FormattedHTMLMessage id = "ideas.activityGuidesText" / >
2020-08-25 16:47:11 -04:00
< / p >
< / div >
2020-09-03 11:11:43 -04:00
< a
className = "wide-button"
href = "/projects/editor/?tutorial=all"
>
< Button className = "ideas-button wide-button" >
< FormattedMessage id = "ideas.seeAllTutorials" / >
< / Button >
< / a >
< / section >
2020-08-10 16:43:07 -04:00
< / div >
2020-08-24 10:25:18 -04:00
< / div >
2020-09-03 11:11:43 -04:00
< div
2020-09-03 16:01:16 -04:00
className = "financials-section section"
2020-09-03 11:11:43 -04:00
id = "financials"
2020-09-03 16:01:16 -04:00
ref = { this . setFinancialsRef }
2020-09-03 11:11:43 -04:00
>
< div className = "inner" >
< h2 className = "financials-h2" >
< FormattedMessage id = "annualReport.financialsTitle" / >
< / h2 >
< h3 >
< FormattedMessage id = "annualReport.financialsRevenue" / >
< / h3 >
< hr / >
< div className = "financials-content" >
< div className = "financials-table" >
< div className = "circle-and-words" >
< img src = "/images/annual-report/blue-circle.svg" / >
< div className = "key-and-money" >
< p className = "key" >
< FormattedMessage id = "annualReport.financialsGrants" / >
< / p >
< p >
$3 , 898 , 078
< span className = "percentage" > ( 82.7 % ) < / span >
< / p >
< / div >
< / div >
< div className = "circle-and-words" >
< img src = "/images/annual-report/yellow-circle.svg" / >
< div className = "key-and-money" >
< p className = "key" >
< FormattedMessage id = "annualReport.financialsEvents" / >
< / p >
< p >
$700 , 000
< span className = "percentage" > ( 14.8 % ) < / span >
< / p >
< / div >
< / div >
< div className = "circle-and-words" >
< img src = "/images/annual-report/green-circle.svg" / >
< div className = "key-and-money" >
< p className = "key" >
< FormattedMessage id = "annualReport.financialsOther" / >
< / p >
< p >
$114 , 982
< span className = "percentage" > ( 2.4 % ) < / span >
< / p >
< / div >
< / div >
< div className = "circle-and-words" >
< div className = "key-and-money total" >
< p className = "key" >
< FormattedMessage id = "annualReport.financialsTotal" / >
< / p >
< p >
$4 , 713 , 060
< / p >
< / div >
< / div >
< / div >
2020-08-25 16:47:11 -04:00
< img
2020-09-03 11:11:43 -04:00
className = "graph"
src = "/images/annual-report/revenue-graph.svg"
2020-08-25 16:47:11 -04:00
/ >
2020-09-03 11:11:43 -04:00
< / div >
2020-08-31 17:00:50 -04:00
< h3 >
2020-09-03 11:11:43 -04:00
< FormattedMessage id = "annualReport.financialsExpenses" / >
2020-08-31 17:00:50 -04:00
< / h3 >
2020-09-03 11:11:43 -04:00
< hr / >
< div className = "financials-content" >
< div className = "financials-table" >
< div className = "circle-and-words" >
< img src = "/images/annual-report/blue-circle.svg" / >
< div className = "key-and-money" >
< p className = "key" >
< FormattedMessage id = "annualReport.financialsProgram" / >
< / p >
< p >
$1 , 135 , 767
< span className = "percentage" > ( 48.8 % ) < / span >
< / p >
< / div >
< / div >
< div className = "circle-and-words" >
< img src = "/images/annual-report/yellow-circle.svg" / >
< div className = "key-and-money" >
< p className = "key" >
< FormattedMessage id = "annualReport.financialsGeneral" / >
< / p >
< p >
$224 , 104
< span className = "percentage" > ( 9.6 % ) < / span >
< / p >
< / div >
< / div >
< div className = "circle-and-words" >
< img src = "/images/annual-report/green-circle.svg" / >
< div className = "key-and-money" >
< p className = "key" >
< FormattedMessage id = "annualReport.financialsFundraising" / >
< / p >
< p >
$962 , 958
< span className = "percentage" > ( 41.4 % ) < / span >
< / p >
< / div >
< / div >
< div className = "circle-and-words" >
< div className = "key-and-money total" >
< p className = "key" >
< FormattedMessage id = "annualReport.financialsTotal" / >
< / p >
< p >
$2 , 322 , 829
< / p >
< / div >
< / div >
2020-09-03 09:51:10 -04:00
< / div >
2020-09-03 11:11:43 -04:00
< img
className = "graph"
src = "/images/annual-report/expenses-graph.svg"
/ >
2020-08-27 16:54:21 -04:00
< / div >
2020-09-03 11:11:43 -04:00
< div className = "financials-button-wrapper" >
< a href = "https://secure.donationpay.org/scratchfoundation/" >
< Button className = "financials-button" >
< FormattedMessage id = "annualReport.financialsButton" / >
< img
className = "download-icon"
src = "/images/annual-report/download-icon.svg"
/ >
< / Button >
< / a >
2020-08-27 16:54:21 -04:00
< / div >
< / div >
< / div >
2020-09-03 11:11:43 -04:00
< div
2020-09-03 16:01:16 -04:00
className = "supporters-section section"
2020-09-03 11:11:43 -04:00
id = "supporters"
2020-09-03 16:01:16 -04:00
ref = { this . setSupportersRef }
2020-09-03 11:11:43 -04:00
>
< div className = "inner" >
< div className = "supporters-heading" >
< h2 >
< FormattedMessage id = "annualReport.supportersTitle" / >
< / h2 >
< p >
< FormattedHTMLMessage id = "annualReport.supportersIntro" / >
< / p >
2020-09-03 09:51:10 -04:00
< / div >
2020-09-03 11:11:43 -04:00
< div className = "subsection-tag" >
< FormattedHTMLMessage id = "annualReport.supportersSpotlightTitle" / >
2020-09-03 09:51:10 -04:00
< / div >
2020-09-03 11:11:43 -04:00
< div className = "supporters-subsection" >
< div className = "supporters-blurb" >
< h3 >
< FormattedMessage id = "annualReport.supportersSFETitle" / >
< / h3 >
< p >
< FormattedMessage id = "annualReport.supportersSFEDescription" / >
< / p >
< / div >
< div className = "david-siegel" >
< div className = "ds-info" >
< img src = "/images/annual-report/david-siegel-photo.svg" / >
< div >
< h3 > David Siegel < / h3 >
< div > Co - Founder and < br / > Co - Chairman < br / > Two Sigma < / div >
< / div >
< / div >
< div className = "ds-quote" >
{ /* eslint-disable-next-line */ }
< Comment comment = "Making sure that Scratch remains free and accessible for kids everywhere is one of the most impactful ways we can help young learners engage and thrive in an increasingly digital world. Supporting Scratch is more important today than ever before." / >
< / div >
< / div >
2020-09-03 09:51:10 -04:00
< / div >
2020-09-03 11:11:43 -04:00
< div className = "supporters-subsection" >
< div className = "supporters-blurb" >
< h4 >
< FormattedHTMLMessage id = "annualReport.supportersTitle" / >
< / h4 >
< p >
< FormattedHTMLMessage id = "annualReport.supportersAllDescription" / >
< / p >
< / div >
< div className = "supporters-level" >
< h5 > Founding Partners — $10 , 00 , 000 + < / h5 >
< hr / >
< p > We are especially grateful to our Founding Partners who supported us from the early days of Scratch , each providing at least $10 , 000 , 000 of cumulative support , in various forms . < / p >
< div className = "supporters-list" >
< ul className = "supporters-list-side" >
< li > National Science Foundation < / li >
< li > Massachusetts Institute of Technology < / li >
< / ul >
< ul className = "supporters-list-side" >
< li > Siegel Family Endowment < / li >
< li > LEGO Foundation < / li >
< / ul >
< / div >
< / div >
< div className = "supporters-level" >
< h5 > Innovation Circle — $5 , 00 , 000 + < / h5 >
< hr / >
< div className = "supporters-list" >
< ul className = "supporters-list-side" >
< li > Google < / li >
< / ul >
< / div >
< / div >
< div className = "supporters-level" >
< h5 > Creativity Circle — $1 , 00 , 000 ++ < / h5 >
< hr / >
< div className = "supporters-list" >
< ul className = "supporters-list-side" >
< li > Little Bluebridge Foundation < / li >
< li > Smilegate Foundation < / li >
< li > TAL Education < / li >
< / ul >
< ul className = "supporters-list-side" >
< li > Turner Broadcasting System / Cartoon Network ( ? ) < / li >
< / ul >
< / div >
< / div >
< div className = "supporters-level" >
< h5 > Imagination Circle — $200 , 000 + < / h5 >
< hr / >
< div className = "supporters-list" >
< ul className = "supporters-list-side" >
< li > BrainPOP < / li >
< li > Cindy and Evan Goldberg < / li >
< li > Kahn - Rowe Family Fund < / li >
< li > LEGO Education < / li >
< / ul >
< ul className = "supporters-list-side" >
< li > Mark Dalton < / li >
< li > Morgan Stanley < / li >
< li > Paul T . Jones < / li >
< li > Two Sigma < / li >
< / ul >
< / div >
< / div >
< div className = "supporters-level" >
< h5 > Inspiration Circle — $50 , 000 + < / h5 >
< hr / >
< div className = "supporters-list" >
< ul className = "supporters-list-side" >
< li > BrainPOP < / li >
< li > Cindy and Evan Goldberg < / li >
< li > Kahn - Rowe Family Fund < / li >
< li > LEGO Education < / li >
< / ul >
< ul className = "supporters-list-side" >
< li > Mark Dalton < / li >
< li > Morgan Stanley < / li >
< li > Paul T . Jones < / li >
< li > Two Sigma < / li >
< / ul >
< / div >
< / div >
< div className = "supporters-level" >
< h5 > Collaboration Circle — $20 , 000 + < / h5 >
< hr / >
< div className = "supporters-list" >
< ul className = "supporters-list-side" >
< li > BrainPOP < / li >
< li > Cindy and Evan Goldberg < / li >
< li > Kahn - Rowe Family Fund < / li >
< li > LEGO Education < / li >
< / ul >
< ul className = "supporters-list-side" >
< li > Mark Dalton < / li >
< li > Morgan Stanley < / li >
< li > Paul T . Jones < / li >
< li > Two Sigma < / li >
< / ul >
< / div >
< / div >
< div className = "supporters-level" >
< h5 > Tinkering Circle — $5 , 000 + < / h5 >
< hr / >
< div className = "supporters-list" >
< ul className = "supporters-list-side" >
< li > BrainPOP < / li >
< li > Cindy and Evan Goldberg < / li >
< li > Kahn - Rowe Family Fund < / li >
< li > LEGO Education < / li >
< / ul >
< ul className = "supporters-list-side" >
< li > Mark Dalton < / li >
< li > Morgan Stanley < / li >
< li > Paul T . Jones < / li >
< li > Two Sigma < / li >
< / ul >
< / div >
< / div >
2020-09-03 09:51:10 -04:00
< / div >
2020-09-03 11:11:43 -04:00
< div className = "supporters-subsection" >
< div className = "supporters-level" >
< h3 >
< FormattedHTMLMessage id = "annualReport.supportersInKindTitle" / >
< / h3 >
< p >
Lorem ipsum dolor sit amet , consectetur adipiscing elit . Praesent vitae commodo orci , quis ultricies nisi
< / p >
< div className = "supporters-list" >
< ul className = "supporters-list-side" >
< li > Amazon Web Services < / li >
< li > Cindy and Evan Goldberg < / li >
< li > Kahn - Rowe Family Fund < / li >
< li > LEGO Education < / li >
< / ul >
< ul className = "supporters-list-side" >
< li > Mark Dalton < / li >
< li > Morgan Stanley < / li >
< li > Paul T . Jones < / li >
< li > Two Sigma < / li >
< / ul >
< / div >
< / div >
2020-09-03 09:51:10 -04:00
< / div >
< / div >
< / div >
2020-09-03 11:11:43 -04:00
< div
2020-09-03 16:01:16 -04:00
className = "donate-section section"
2020-09-03 11:11:43 -04:00
id = "donate"
2020-09-03 16:01:16 -04:00
ref = { this . setDonateRef }
2020-09-03 11:11:43 -04:00
>
< FlexRow className = "donate-info" >
< img src = "/images/annual-report/donate-illustration.svg" / >
< div className = "donate-content" >
< h2 className = "donate-h2" >
< FormattedMessage id = "annualReport.donateTitle" / >
< / h2 >
< p className = "donate-p" >
< FormattedMessage id = "annualReport.donateMessage" / >
< / p >
< a href = "https://secure.donationpay.org/scratchfoundation/" >
< Button className = "donate-button" >
< FormattedMessage id = "annualReport.donateButton" / >
< / Button >
< / a >
2020-09-03 09:51:10 -04:00
< / div >
2020-09-03 11:11:43 -04:00
< / FlexRow >
2020-09-03 09:51:10 -04:00
< / div >
2020-08-17 12:04:38 -04:00
< / div >
2020-09-03 11:11:43 -04:00
) ;
}
}
2020-08-10 16:43:07 -04:00
render (
2020-09-03 09:51:10 -04:00
< Page > < AnnualReport / > < / Page > , document . getElementById ( 'app' )
) ;