add the nonprofit projects guide view and change all our nonbreaking spaces to smaller, more natural looking spaces
This commit is contained in:
1
app.js
1
app.js
@ -224,6 +224,7 @@ app.get('/chat', resourcesController.chat);
|
|||||||
app.get('/live-pair-programming', resourcesController.livePairProgramming);
|
app.get('/live-pair-programming', resourcesController.livePairProgramming);
|
||||||
app.get('/install-screenhero', resourcesController.installScreenHero);
|
app.get('/install-screenhero', resourcesController.installScreenHero);
|
||||||
app.get('/javascript-in-your-inbox', resourcesController.javaScriptInYourInbox);
|
app.get('/javascript-in-your-inbox', resourcesController.javaScriptInYourInbox);
|
||||||
|
app.get('/guide-to-our-nonprofit-projects', resourcesController.guideToOurNonprofitProjects);
|
||||||
app.get('/chromebook', resourcesController.chromebook);
|
app.get('/chromebook', resourcesController.chromebook);
|
||||||
app.get('/deploy-a-website', resourcesController.deployAWebsite);
|
app.get('/deploy-a-website', resourcesController.deployAWebsite);
|
||||||
app.get('/gmail-shortcuts', resourcesController.gmailShortcuts);
|
app.get('/gmail-shortcuts', resourcesController.gmailShortcuts);
|
||||||
|
@ -83,6 +83,12 @@ module.exports = {
|
|||||||
});
|
});
|
||||||
},
|
},
|
||||||
|
|
||||||
|
guideToOurNonprofitProjects: function guideToOurNonprofitProjects(req, res) {
|
||||||
|
res.render('resources/guide-to-our-nonprofit-projects', {
|
||||||
|
title: 'A guide to our Nonprofit Projects'
|
||||||
|
});
|
||||||
|
},
|
||||||
|
|
||||||
controlShortcuts: function controlShortcuts(req, res) {
|
controlShortcuts: function controlShortcuts(req, res) {
|
||||||
res.render('resources/control-shortcuts', {
|
res.render('resources/control-shortcuts', {
|
||||||
title: 'These Control Shortcuts will save you Hours'
|
title: 'These Control Shortcuts will save you Hours'
|
||||||
|
@ -317,9 +317,9 @@ block content
|
|||||||
a.close(href='#', data-dismiss='modal', aria-hidden='true') ×
|
a.close(href='#', data-dismiss='modal', aria-hidden='true') ×
|
||||||
h3 Are you really leaving us?
|
h3 Are you really leaving us?
|
||||||
.modal-body
|
.modal-body
|
||||||
p Pro Tip: If you tweet feedback to
|
p Pro Tip: If you tweet feedback to 
|
||||||
a(href="https://twitter.com/intent/tweet?text=Hey%20@freecodecamp") @FreeCodeCamp
|
a(href="https://twitter.com/intent/tweet?text=Hey%20@freecodecamp") @FreeCodeCamp
|
||||||
| , we'll act quickly on it!
|
| , we'll act quickly on it!
|
||||||
.modal-footer
|
.modal-footer
|
||||||
a.btn.btn-success.btn-block(href='#', data-dismiss='modal', aria-hidden='true')
|
a.btn.btn-success.btn-block(href='#', data-dismiss='modal', aria-hidden='true')
|
||||||
span.ion-happy
|
span.ion-happy
|
||||||
|
@ -14,7 +14,7 @@ block content
|
|||||||
button.btn.btn-primary(type='submit')
|
button.btn.btn-primary(type='submit')
|
||||||
span.ion-android-hand
|
span.ion-android-hand
|
||||||
| Login
|
| Login
|
||||||
span
|
span   
|
||||||
a.btn.btn-info(href='/forgot') Forgot your password?
|
a.btn.btn-info(href='/forgot') Forgot your password?
|
||||||
br
|
br
|
||||||
br
|
br
|
||||||
|
@ -23,7 +23,7 @@ block content
|
|||||||
#testCreatePanel
|
#testCreatePanel
|
||||||
h1.text-center= name
|
h1.text-center= name
|
||||||
h2.text-center
|
h2.text-center
|
||||||
.bonfire-flames Difficulty:
|
.bonfire-flames Difficulty: 
|
||||||
if (difficulty == "0")
|
if (difficulty == "0")
|
||||||
i.ion-ios-flame-outline
|
i.ion-ios-flame-outline
|
||||||
i.ion-ios-flame-outline
|
i.ion-ios-flame-outline
|
||||||
@ -127,7 +127,7 @@ block content
|
|||||||
|
|
||||||
- if (points && points > 2)
|
- if (points && points > 2)
|
||||||
a.animated.fadeIn.btn.btn-lg.btn-block.btn-twitter(target="_blank")
|
a.animated.fadeIn.btn.btn-lg.btn-block.btn-twitter(target="_blank")
|
||||||
i.fa.fa-twitter
|
i.fa.fa-twitter  
|
||||||
= phrase
|
= phrase
|
||||||
- else
|
- else
|
||||||
a.animated.fadeIn.btn.btn-lg.signup-btn.btn-block(href='/login') Sign in so you can save your progress
|
a.animated.fadeIn.btn.btn-lg.signup-btn.btn-block(href='/login') Sign in so you can save your progress
|
||||||
|
@ -32,7 +32,7 @@ block content
|
|||||||
a.animated.fadeIn.btn.btn-lg.btn-primary.btn-block.next-challenge-button(name='_csrf', value=_csrf, aria-hidden='true') Take me to my next challenge
|
a.animated.fadeIn.btn.btn-lg.btn-primary.btn-block.next-challenge-button(name='_csrf', value=_csrf, aria-hidden='true') Take me to my next challenge
|
||||||
- if (points && points > 2)
|
- if (points && points > 2)
|
||||||
a.animated.fadeIn.btn.btn-lg.btn-block.btn-twitter(target="_blank")
|
a.animated.fadeIn.btn.btn-lg.btn-block.btn-twitter(target="_blank")
|
||||||
i.fa.fa-twitter
|
i.fa.fa-twitter  
|
||||||
= phrase
|
= phrase
|
||||||
- else
|
- else
|
||||||
a.animated.fadeIn.btn.btn-lg.signup-btn.btn-block(href='/login') Sign in so you can save your progress
|
a.animated.fadeIn.btn.btn-lg.signup-btn.btn-block(href='/login') Sign in so you can save your progress
|
||||||
|
@ -4,7 +4,7 @@ block content
|
|||||||
.jumbotron
|
.jumbotron
|
||||||
h1.animated.lightSpeedIn.text-center.hug-top We'll code software solutions for your nonprofit, for free!
|
h1.animated.lightSpeedIn.text-center.hug-top We'll code software solutions for your nonprofit, for free!
|
||||||
.animated.fadeIn.delay-2.landing-panel-body
|
.animated.fadeIn.delay-2.landing-panel-body
|
||||||
h3 Our students will help you build that donor tracking system, community message board, or whatever your organization needs,
|
h3 Our students will help you build that donor tracking system, community message board, or whatever your organization needs, 
|
||||||
strong at no cost.
|
strong at no cost.
|
||||||
h3 In exchange, we ask only that you:
|
h3 In exchange, we ask only that you:
|
||||||
h4
|
h4
|
||||||
|
@ -68,7 +68,7 @@ block content
|
|||||||
a.animated.fadeIn.btn.btn-lg.btn-primary.btn-block.next-courseware-button(name='_csrf', value=_csrf, ng-disabled='completedWithForm.$invalid && existingUser.length > 0') Go to my next challenge (ctrl + enter)
|
a.animated.fadeIn.btn.btn-lg.btn-primary.btn-block.next-courseware-button(name='_csrf', value=_csrf, ng-disabled='completedWithForm.$invalid && existingUser.length > 0') Go to my next challenge (ctrl + enter)
|
||||||
- if (points && points > 2)
|
- if (points && points > 2)
|
||||||
a.animated.fadeIn.btn.btn-lg.btn-block.btn-twitter(href="https://twitter.com/intent/tweet?text=I%20just%20#{verb}%20%40FreeCodeCamp%20Bonfire:%20#{name}&url=http%3A%2F%2Ffreecodecamp.com/bonfires/#{dashedName}&hashtags=LearnToCode, JavaScript" target="_blank")
|
a.animated.fadeIn.btn.btn-lg.btn-block.btn-twitter(href="https://twitter.com/intent/tweet?text=I%20just%20#{verb}%20%40FreeCodeCamp%20Bonfire:%20#{name}&url=http%3A%2F%2Ffreecodecamp.com/bonfires/#{dashedName}&hashtags=LearnToCode, JavaScript" target="_blank")
|
||||||
i.fa.fa-twitter
|
i.fa.fa-twitter  
|
||||||
= phrase
|
= phrase
|
||||||
- else
|
- else
|
||||||
a.animated.fadeIn.btn.btn-lg.signup-btn.btn-block(href='/login') Sign in so you can save your progress
|
a.animated.fadeIn.btn.btn-lg.signup-btn.btn-block(href='/login') Sign in so you can save your progress
|
@ -39,7 +39,7 @@ block content
|
|||||||
a.animated.fadeIn.btn.btn-lg.btn-primary.btn-block.next-courseware-button(name='_csrf', value=_csrf, ng-disabled='completedWithForm.$invalid && existingUser.length > 0') Go to my next challenge (ctrl + enter)
|
a.animated.fadeIn.btn.btn-lg.btn-primary.btn-block.next-courseware-button(name='_csrf', value=_csrf, ng-disabled='completedWithForm.$invalid && existingUser.length > 0') Go to my next challenge (ctrl + enter)
|
||||||
- if (points && points > 2)
|
- if (points && points > 2)
|
||||||
a.animated.fadeIn.btn.btn-lg.btn-block.btn-twitter(href="https://twitter.com/intent/tweet?text=I%20just%20#{verb}%20%40FreeCodeCamp%20Bonfire:%20#{name}&url=http%3A%2F%2Ffreecodecamp.com/bonfires/#{dashedName}&hashtags=LearnToCode, JavaScript" target="_blank")
|
a.animated.fadeIn.btn.btn-lg.btn-block.btn-twitter(href="https://twitter.com/intent/tweet?text=I%20just%20#{verb}%20%40FreeCodeCamp%20Bonfire:%20#{name}&url=http%3A%2F%2Ffreecodecamp.com/bonfires/#{dashedName}&hashtags=LearnToCode, JavaScript" target="_blank")
|
||||||
i.fa.fa-twitter
|
i.fa.fa-twitter  
|
||||||
= phrase
|
= phrase
|
||||||
- else
|
- else
|
||||||
a.animated.fadeIn.btn.btn-lg.signup-btn.btn-block(href='/login') Sign in so you can save your progress
|
a.animated.fadeIn.btn.btn-lg.signup-btn.btn-block(href='/login') Sign in so you can save your progress
|
||||||
|
@ -74,15 +74,15 @@ block content
|
|||||||
h2 Why you should join our community right now:
|
h2 Why you should join our community right now:
|
||||||
h3.col-xs-offset-0.col-sm-offset-1
|
h3.col-xs-offset-0.col-sm-offset-1
|
||||||
ul.text-left
|
ul.text-left
|
||||||
li.ion-code We're thousands of professionals, all learning to code together
|
li.ion-code   We're thousands of professionals, all learning to code together
|
||||||
li.ion-code We're building projects for dozens of nonprofits
|
li.ion-code   We're building projects for dozens of nonprofits
|
||||||
li.ion-code Our community is 100% free and open source
|
li.ion-code   Our community is 100% free and open source
|
||||||
li.ion-code You'll learn Full Stack JavaScript and become a Software Engineer
|
li.ion-code   You'll learn Full Stack JavaScript and become a Software Engineer
|
||||||
li.ion-code You'll work through our focused, interactive courses and tutorials
|
li.ion-code   You'll work through our focused, interactive courses and tutorials
|
||||||
li.ion-code You'll learn to code at your own pace, in your browser or on your phone
|
li.ion-code   You'll learn to code at your own pace, in your browser or on your phone
|
||||||
li.ion-code You'll become qualified for thousands of jobs currently going unfilled
|
li.ion-code   You'll become qualified for thousands of jobs currently going unfilled
|
||||||
li.ion-code You can get help in real time from our community chat rooms and forum
|
li.ion-code   You can get help in real time from our community chat rooms and forum
|
||||||
li.ion-code We all share one common goal: to boost our careers with code
|
li.ion-code   We all share one common goal: to boost our careers with code
|
||||||
.big-break
|
.big-break
|
||||||
a.btn.btn-cta.signup-btn(href="/login") Learn to code today (it's free)
|
a.btn.btn-cta.signup-btn(href="/login") Learn to code today (it's free)
|
||||||
script.
|
script.
|
||||||
|
@ -3,5 +3,5 @@ h3
|
|||||||
for bonfire in bonfires
|
for bonfire in bonfires
|
||||||
li
|
li
|
||||||
a(href="/bonfires/#{bonfire.bonfireNumber}", class="#{ (cc && cc[bonfire.bonfireNumber] > 0) ? 'strikethrough' : '' }") #{bonfire.name}
|
a(href="/bonfires/#{bonfire.bonfireNumber}", class="#{ (cc && cc[bonfire.bonfireNumber] > 0) ? 'strikethrough' : '' }") #{bonfire.name}
|
||||||
| (Level #{bonfire.difficulty})
|
|   (Level #{bonfire.difficulty})
|
||||||
a.btn.btn-lg.btn-primary.btn-block(href="/done-with-first-100-hours", class="#{ ((cc && cc[53] === 0) || (!cc)) ? 'disabled' : '' }") I'm done with all the challenges!
|
a.btn.btn-lg.btn-primary.btn-block(href="/done-with-first-100-hours", class="#{ ((cc && cc[53] === 0) || (!cc)) ? 'disabled' : '' }") I'm done with all the challenges!
|
@ -3,6 +3,6 @@ h3
|
|||||||
for challenge in challenges
|
for challenge in challenges
|
||||||
li
|
li
|
||||||
a(href="/challenges/#{challenge.challengeNumber}", class="#{ (cc && cc[challenge.challengeNumber] > 0) ? 'strikethrough' : '' }") #{challenge.name}
|
a(href="/challenges/#{challenge.challengeNumber}", class="#{ (cc && cc[challenge.challengeNumber] > 0) ? 'strikethrough' : '' }") #{challenge.name}
|
||||||
| (#{challenge.time} mins)
|
|   (#{challenge.time} mins)
|
||||||
|
|
||||||
a.btn.btn-lg.btn-primary.btn-block(href="/done-with-first-100-hours", class="#{ ((points && points < 54) || (!points)) ? 'disabled' : '' }") I'm done with all the challenges!
|
a.btn.btn-lg.btn-primary.btn-block(href="/done-with-first-100-hours", class="#{ ((points && points < 54) || (!points)) ? 'disabled' : '' }") I'm done with all the challenges!
|
@ -1,11 +1,11 @@
|
|||||||
.fcc-footer
|
.fcc-footer
|
||||||
.col-xs-12.hidden-xs.hidden-sm
|
.col-xs-12.hidden-xs.hidden-sm
|
||||||
a.ion-speakerphone(href='http://blog.freecodecamp.com', target='_blank') Blog
|
a.ion-speakerphone(href='http://blog.freecodecamp.com', target='_blank')  Blog  
|
||||||
a.ion-social-twitch-outline(href="http://www.twitch.tv/freecodecamp", target='_blank') Twitch
|
a.ion-social-twitch-outline(href="http://www.twitch.tv/freecodecamp", target='_blank')  Twitch  
|
||||||
a.ion-social-github(href="http://github.com/freecodecamp", target='_blank') Github
|
a.ion-social-github(href="http://github.com/freecodecamp", target='_blank')  Github  
|
||||||
a.ion-social-twitter(href="http://twitter.com/freecodecamp", target='_blank') Twitter
|
a.ion-social-twitter(href="http://twitter.com/freecodecamp", target='_blank')  Twitter  
|
||||||
a.ion-information-circled(href="/learn-to-code") About
|
a.ion-information-circled(href="/learn-to-code")  About  
|
||||||
a.ion-locked(href="/privacy") Privacy
|
a.ion-locked(href="/privacy")  Privacy  
|
||||||
.col-xs-12.visible-xs.visible-sm
|
.col-xs-12.visible-xs.visible-sm
|
||||||
a.ion-speakerphone(href='http://blog.freecodecamp.com', target='_blank')
|
a.ion-speakerphone(href='http://blog.freecodecamp.com', target='_blank')
|
||||||
span.sr-only Free Code Camp's Blog
|
span.sr-only Free Code Camp's Blog
|
||||||
|
@ -20,15 +20,15 @@
|
|||||||
li
|
li
|
||||||
a(href='/bonfires') Bonfires
|
a(href='/bonfires') Bonfires
|
||||||
if !user
|
if !user
|
||||||
li
|
li      
|
||||||
li
|
li
|
||||||
a.btn.signup-btn.signup-btn-nav(href='/login') Sign in
|
a.btn.signup-btn.signup-btn-nav(href='/login') Sign in
|
||||||
else
|
else
|
||||||
li
|
li
|
||||||
if (user.profile.username)
|
if (user.profile.username)
|
||||||
a(href='/' + user.profile.username) [ #{user.points} ]
|
a(href='/' + user.profile.username) [ #{user.points} ]
|
||||||
else
|
else
|
||||||
a(href='/account') [ #{user.points} ]
|
a(href='/account') [ #{user.points} ]
|
||||||
.hidden-xs
|
.hidden-xs
|
||||||
if user.profile.picture
|
if user.profile.picture
|
||||||
if (user.profile.username)
|
if (user.profile.username)
|
||||||
|
@ -2,18 +2,18 @@ extends ../layout-wide
|
|||||||
block content
|
block content
|
||||||
h3
|
h3
|
||||||
ol.col-md-offset-2
|
ol.col-md-offset-2
|
||||||
li Create a GitHub Account
|
li Create a GitHub Account 
|
||||||
a(href="http://github.com/join", target='_blank') here
|
a(href="http://github.com/join", target='_blank') here
|
||||||
| .
|
| .
|
||||||
li Download the chat room app on
|
li Download the chat room app on  
|
||||||
a(href="https://update.gitter.im/win/latest") Windows
|
a(href="https://update.gitter.im/win/latest") Windows
|
||||||
| ,
|
| , 
|
||||||
a(href="https://update.gitter.im/osx/latest") Mac
|
a(href="https://update.gitter.im/osx/latest") Mac
|
||||||
| ,
|
| , 
|
||||||
a(href="http://appstore.com/gitter") iPhone
|
a(href="http://appstore.com/gitter") iPhone
|
||||||
| , or
|
| ,  or  
|
||||||
a(href="https://play.google.com/store/apps/details?id=im.gitter.gitter&hl=en_GB") Android
|
a(href="https://play.google.com/store/apps/details?id=im.gitter.gitter&hl=en_GB") Android
|
||||||
| , or go
|
|  , or go  
|
||||||
a(href="http://chat.freecodecamp.com") here
|
a(href="http://chat.freecodecamp.com") here
|
||||||
| .
|
| .
|
||||||
li Keep the chat room open while you code so that you can meet friends and ask for help.
|
li Keep the chat room open while you code so that you can meet friends and ask for help.
|
||||||
|
@ -11,15 +11,15 @@ block content
|
|||||||
ul
|
ul
|
||||||
li
|
li
|
||||||
a(href='http://www.atom.io' target='_blank') http://www.atom.io
|
a(href='http://www.atom.io' target='_blank') http://www.atom.io
|
||||||
| - free text editor
|
|   - free text editor
|
||||||
li
|
li
|
||||||
a(href='http://www.startbootstrap.com' target='_blank') http://www.startbootstrap.com
|
a(href='http://www.startbootstrap.com' target='_blank') http://www.startbootstrap.com
|
||||||
| - free responsive (Bootstrap) templates
|
|   - free responsive (Bootstrap) templates
|
||||||
li
|
li
|
||||||
a(href='http://www.powr.io' target='_blank') http://www.powr.io
|
a(href='http://www.powr.io' target='_blank') http://www.powr.io
|
||||||
| - great plugins
|
|   - great plugins
|
||||||
li
|
li
|
||||||
a(href='http://www.bitballoon.com' target='_blank') http://www.bitballoon.com
|
a(href='http://www.bitballoon.com' target='_blank') http://www.bitballoon.com
|
||||||
| - drag-and-drop deployment
|
|   - drag-and-drop deployment
|
||||||
a.btn.btn-cta.signup-btn.btn-primary(href="/login") Start learning to code (it's free)
|
a.btn.btn-cta.signup-btn.btn-primary(href="/login") Start learning to code (it's free)
|
||||||
br
|
br
|
||||||
|
96
views/resources/guide-to-our-nonprofit-projects.jade
Normal file
96
views/resources/guide-to-our-nonprofit-projects.jade
Normal file
@ -0,0 +1,96 @@
|
|||||||
|
extends ../layout
|
||||||
|
block content
|
||||||
|
.jumbotron
|
||||||
|
h1.hug-top.text-center A Guide to our Nonprofit Projects
|
||||||
|
br
|
||||||
|
p Building nonprofit projects is the main way that our campers learn full stack JavaScript and agile software development. Once you complete the Free Code Camp challenges and Bonfire challenges, you'll begin this process.
|
||||||
|
p Once you've finished all the challenges, click the "I'm done with all the challenges" button, which will become enabled. We will prompt you for your email address, then give you further instructions on our  
|
||||||
|
a(href="http://www.freecodecamp.com/nonprofit-project-instructions") Nonprofit Projects Instructions page
|
||||||
|
| .
|
||||||
|
p We will add you to our  
|
||||||
|
a(href="https://trello.com/b/BA3xVpz9/nonprofit-projects") Nonprofit Project Trello board
|
||||||
|
| .
|
||||||
|
h2 Starting with the end in mind
|
||||||
|
p Our goal at Free Code Camp is to help you land a job as a junior software developer (or, if you prefer, a 'pivot job' that leads your current career in a more technical direction).
|
||||||
|
p You'll continue to work on nonprofit projects until you've built a sufficiently impressive portfolio and references to start your job search. Your portfolio will ultimately have three to five nonprofit projects. We estimate that the 900 hours of nonprofit projects you're going to complete, in addition to the 100 hours of challenges you've already completed, will be enough to qualify you for your first coding job. This will produce a much broader portfolio than a traditional coding bootcamp, which generally only has one or two capstone projects.
|
||||||
|
h2 Choosing your first Nonprofit Project
|
||||||
|
p We've categorized all the nonprofit projects by estimated time investment per camper: 100 hours, 200 hours, and 300 hours. These are only rough estimates.
|
||||||
|
p Example: if you and the camper you're paired up with (your pair) each stated you could work 20 hours per week (on the  
|
||||||
|
a(href="http://goo.gl/forms/f61dLt67t8") form you filled out
|
||||||
|
| ). If the project is a 100 hour per camper project, you should be able to complete it in about 5 weeks.
|
||||||
|
p Our team of nonprofit project camp counselors will match you and your pair based on:
|
||||||
|
ol
|
||||||
|
li Your estimated time commitment (10, 20 or 40 hours per week)
|
||||||
|
li Your time zone
|
||||||
|
li The nonprofit projects you've chosen
|
||||||
|
li Prior coding experience (we'd like both campers to be able to contribute equally)
|
||||||
|
p We won't take age or gender into account. This will provide you with valuable experience in meshing with diverse teams, which is a reality of the contemporary workplace.
|
||||||
|
p You'll only work on one project at a time. Once you start a nonprofit project, we'll remove you from all other nonprofit project Trello cards. There's a good chance those projects will no longer be available when you finish your current project, anyway. Don't worry, though - we get new nonprofit project requests every day, so there will be plenty more projects for you to consider after you finish your current one.
|
||||||
|
h2 Finalizing the Project
|
||||||
|
p Before you can start working on the project, our team of Nonprofit Project Coordinators will go through the following process:
|
||||||
|
ol
|
||||||
|
li We'll wait until there are two campers who have chosen the same project and look like they're a good match for one another based on the factors mentioned above.
|
||||||
|
li We'll call the stakeholder to confirm once again that he or she agrees with our  
|
||||||
|
a(href="freecodecamp.com/nonprofits") terms  
|
||||||
|
| and has signed our  
|
||||||
|
a(href="http://goo.gl/forms/0YKkd9bpcR") Nonprofit Project Stakeholder Pledge
|
||||||
|
| .
|
||||||
|
li We'll set an initial meeting with representatives from Free Code Camp, the two campers, and the stakeholder.
|
||||||
|
li If the stakeholder and both campers shows up promptly, and seem enthusiastic and professional, we'll start the project.
|
||||||
|
p This lengthy process serves an important purpose: it reduces the likelihood that any of our campers or stakeholders will waste their precious time.
|
||||||
|
h2 Nonprofit Stakeholders
|
||||||
|
p Each nonprofit project was submitted by a nonprofit. A representative from this nonprofit has agreed to serve as a "stakeholder" - an authorative person who understands the organization and its needs for this particular project.
|
||||||
|
p Stakeholders have a deep understanding of their organizations' needs. Campers will work with them to figure out the best solutions to these needs.
|
||||||
|
p When you and your pair first speak with your nonprofit stakeholder, you'll:
|
||||||
|
ul
|
||||||
|
li talk at length to better understand their needs.
|
||||||
|
li create a new Trello board and use it to prioritize what needs to be built.
|
||||||
|
li and establish deadlines based on your weekly time commitment, and how long you think each task will take.
|
||||||
|
p It's notoriously difficult to estimate how long building software projects will take, so feel free to ask camp counselors for help.
|
||||||
|
p You'll continue to meet with your stakeholder regularly throughout this process.
|
||||||
|
p Ultimately, the project will be considered complete once both the stakeholder's needs have been met, and you and your pair are happy with the project. Then you can add it to your portfolio!
|
||||||
|
h2 Working with your Pair
|
||||||
|
p You and your pair will pair program (code together on the same computer virtually) about half of the time, and work independently the other half of the time.
|
||||||
|
p Here are our recommended ways of collaborating:
|
||||||
|
ul
|
||||||
|
li • Gitter has robust private messaging functionality. It's the main way our team communicates, and we recommend it over email.
|
||||||
|
li • Trello is great for managing projects. Work with your stakeholder to create Trello cards, and update these cards regularly as you make progress on them.
|
||||||
|
li • Screen Hero or Team Viewer - These are the ideal way to pair program. Tools like TMUX are good, but difficult to use. We discourage you from using screen sharing tools where only one person has control of the keyboard and mouse - that isn't real pair programming.
|
||||||
|
li • Write clear and readable code, commit messages, branch names, and pull request messages.
|
||||||
|
h2 Setting up your Development Environment
|
||||||
|
p We've created a custom virtual machine image with Ubuntu Linux, Git, Team Viewer, the MEAN Stack and all its dependencies. You can run this virtual image on any computer with at least 2 gigabytes of RAM and 16 gigabytes of hard drive space.
|
||||||
|
p The benefits of using this virtual machine are as follows:
|
||||||
|
ul
|
||||||
|
li • Everyone else on Free Code Camp is using this image, so we can all help you troubleshoot various problems that may arise.
|
||||||
|
li • When you pair program, you and your pair will have the exact same environment, which means you will both feel comfortable on each other's machines.
|
||||||
|
li • You can install the image on any computer without worrying about messing up the computer's original data or configuration.
|
||||||
|
li • Even if you end up using Windows or Mac OSX for development later, your server will almost certainly run Linux, so it's worth getting used to Linux.
|
||||||
|
li • Even experienced developers encounter hangups when setting up a development environment. This virtual machine image will remove this tedious process.
|
||||||
|
p Install a bit torrent client, then  
|
||||||
|
a(href="http://mgnet.me/ZOQk0rd") download our virtual machine image
|
||||||
|
| .
|
||||||
|
p Please note that even though Bit Torrent is often used to download content illegally, all the content on our image is open source and perfectly legal to redistribute.
|
||||||
|
p Once you've downloaded the file,  
|
||||||
|
a(href="https://www.virtualbox.org/wiki/Downloads") download VirtualBox  
|
||||||
|
| and follow  
|
||||||
|
a(href="http://techathlon.com/how-to-run-a-vmdk-file-in-oracle-virtualbox/") this tutorial  
|
||||||
|
| to open the image in VirtualBox. You'll want to assign the virtual machine at least two gigabytes of ram.
|
||||||
|
p Now you have your own Linux development environment. You can shut it down when you're not using it and it will save its state. Please continue to seed the file in bit torrent so that other campers can download it as well. Enjoy!
|
||||||
|
h2 Hosting Apps
|
||||||
|
p Unless your stakeholder has an existing modern host (AWS, Digital Ocean), you'll need to transition them over to a new platform. We believe Heroku is the best choice for a vast majority of web projects. It's free, easy to use, and has both browser and command line interfaces. It's owned by Salesforce and used by a ton of companies, so it's accountable and unlikely to go away.
|
||||||
|
p If you need help convincing your stakeholder that Heroku is the ideal platform, we'll be happy to talk with them.
|
||||||
|
h2 Maintaining Apps
|
||||||
|
p Once you complete a nonprofit project, your obligation to its stakeholder is finished. You goal is to leave behind a well documented solution that can be easily maintained by a contract JavaScript developer (or even a less-technical "super user").
|
||||||
|
p While you will no longer need to help with feature development, we encourage you to consider helping your stakeholder with occasional patches down the road. After all, this project will be an important piece of your portfolio, and you'll want it to remain in good shape for curious future employers.
|
||||||
|
h2 Office Hours
|
||||||
|
p Quincy Larson and/or Michael Johnson will be in the  
|
||||||
|
a(href="https://gitter.im/FreeCodeCamp/NonprofitProjects") Gitter Nonprofit Project Chatroom  
|
||||||
|
| every Monday and Thursday from 9 - 10 p.m. EST.
|
||||||
|
p Our goal is to make the discussion as public as possible so all our campers can benefit from each camper’s questions.
|
||||||
|
p If necessary, we can also hop on Screen Hero with you to help you with issues more specific to your project.
|
||||||
|
h2 Pledging to finish the project
|
||||||
|
p Your nonprofit stakeholder, your pair, and the volunteer camp counselor team are all counting on you to finish your nonprofit project. If you walk away from an unfinished nonprofit project, you'll become ineligible to ever be assigned another one.
|
||||||
|
p To confirm that you understand the seriousness of this commitment, we require that all campers  
|
||||||
|
a(href="http://goo.gl/forms/ZMn96z2QqY") sign this pledge  
|
||||||
|
| before starting on their nonprofit projects.
|
||||||
|
p There will likely be times of confusion or frustration. This is normal in software development. The most important thing is that you do not give up and instead persevere through these setbacks. As Steve Jobs famously said, "Real artists ship." And you are going to ship one successful nonprofit project after another until you feel ready to take the next step in your promising career.
|
@ -6,8 +6,8 @@ block content
|
|||||||
a(href="http://links.screenhero.com/e/c/eyJlbWFpbF9pZCI6Ik1qQTNNem9XQkNJQ1pBQUNjd0FYQVZrVEdnRkxNamtfX0JWZEdGVEpSZkVCWlRwbFpXRTBNamM0WVMxaE56SmlMVEV4WlRRdE9HUXpZUzFpWXpVNE1HRTJNalkxTldNNk1UUTJNVEEyQUE9PSIsInBvc2l0aW9uIjowLCJocmVmIjoiaHR0cDovL2RsLnNjcmVlbmhlcm8uY29tL3NtYXJ0ZG93bmxvYWQvZklYQU1UUUJBTEtQQkhQTC9TY3JlZW5oZXJvLnppcD9zb3VyY2U9d2ViIn0=") Download for Mac
|
a(href="http://links.screenhero.com/e/c/eyJlbWFpbF9pZCI6Ik1qQTNNem9XQkNJQ1pBQUNjd0FYQVZrVEdnRkxNamtfX0JWZEdGVEpSZkVCWlRwbFpXRTBNamM0WVMxaE56SmlMVEV4WlRRdE9HUXpZUzFpWXpVNE1HRTJNalkxTldNNk1UUTJNVEEyQUE9PSIsInBvc2l0aW9uIjowLCJocmVmIjoiaHR0cDovL2RsLnNjcmVlbmhlcm8uY29tL3NtYXJ0ZG93bmxvYWQvZklYQU1UUUJBTEtQQkhQTC9TY3JlZW5oZXJvLnppcD9zb3VyY2U9d2ViIn0=") Download for Mac
|
||||||
h2
|
h2
|
||||||
a(href="http://links.screenhero.com/e/c/eyJlbWFpbF9pZCI6Ik1qQTNNem9XQkNJQ1pBQUNjd0FYQVZrVEdnRkxNamtfX0JWZEdGVEpSZkVCWlRwbFpXRTBNamM0WVMxaE56SmlMVEV4WlRRdE9HUXpZUzFpWXpVNE1HRTJNalkxTldNNk1UUTJNVEEyQUE9PSIsInBvc2l0aW9uIjoxLCJocmVmIjoiaHR0cDovL2RsLnNjcmVlbmhlcm8uY29tL3NtYXJ0ZG93bmxvYWQvZklYQU1UUUJBTEtQQkhQTC9TY3JlZW5oZXJvLXNldHVwLmV4ZSJ9") Download for Windows
|
a(href="http://links.screenhero.com/e/c/eyJlbWFpbF9pZCI6Ik1qQTNNem9XQkNJQ1pBQUNjd0FYQVZrVEdnRkxNamtfX0JWZEdGVEpSZkVCWlRwbFpXRTBNamM0WVMxaE56SmlMVEV4WlRRdE9HUXpZUzFpWXpVNE1HRTJNalkxTldNNk1UUTJNVEEyQUE9PSIsInBvc2l0aW9uIjoxLCJocmVmIjoiaHR0cDovL2RsLnNjcmVlbmhlcm8uY29tL3NtYXJ0ZG93bmxvYWQvZklYQU1UUUJBTEtQQkhQTC9TY3JlZW5oZXJvLXNldHVwLmV4ZSJ9") Download for Windows
|
||||||
p You can learn more about using Screen Hero by taking
|
p You can learn more about using Screen Hero by taking  
|
||||||
a(href="http://www.freecodecamp.com/challenges/34") Challenge 34.
|
a(href="http://www.freecodecamp.com/challenges/34") Challenge 34.
|
||||||
p Screen Hero was recently acquired by a collaboration tool called Slack. It's still available and free, but will go away in the indefinite future. Discuss alternatives on our
|
p Screen Hero was recently acquired by a collaboration tool called Slack. It's still available and free, but will go away in the indefinite future. Discuss alternatives on our  
|
||||||
a(href="http://forum.freecodecamp.com/t/replacing-screen-hero/992") Screen Hero replacement thread
|
a(href="http://forum.freecodecamp.com/t/replacing-screen-hero/992") Screen Hero replacement thread
|
||||||
| .
|
| .
|
@ -7,7 +7,7 @@ block content
|
|||||||
|
|
||||||
h2#next-session
|
h2#next-session
|
||||||
|
|
||||||
h2 Watch the live stream below or on our
|
h2 Watch the live stream below or on our  
|
||||||
a(href="http://twitch.tv/freecodecamp", target='_blank') Twitch.tv channel
|
a(href="http://twitch.tv/freecodecamp", target='_blank') Twitch.tv channel
|
||||||
| .
|
| .
|
||||||
.row
|
.row
|
||||||
@ -25,23 +25,23 @@ block content
|
|||||||
.col-xs-12
|
.col-xs-12
|
||||||
.embed-responsive.embed-responsive-16by9.big-break
|
.embed-responsive.embed-responsive-16by9.big-break
|
||||||
iframe.embed-responsive-item(src='//www.youtube.com/embed/_BErpDdmBOw')
|
iframe.embed-responsive-item(src='//www.youtube.com/embed/_BErpDdmBOw')
|
||||||
h3.wrappable link:
|
h3.wrappable link:  
|
||||||
a(href="http://www.youtube.com/watch/_BErpDdmBOw") http://www.youtube.com/watch/_BErpDdmBOw
|
a(href="http://www.youtube.com/watch/_BErpDdmBOw") http://www.youtube.com/watch/_BErpDdmBOw
|
||||||
.embed-responsive.embed-responsive-16by9.big-break
|
.embed-responsive.embed-responsive-16by9.big-break
|
||||||
iframe.embed-responsive-item(src='//www.youtube.com/embed/Fn9HMn79KH0')
|
iframe.embed-responsive-item(src='//www.youtube.com/embed/Fn9HMn79KH0')
|
||||||
h3.wrappable link:
|
h3.wrappable link:  
|
||||||
a(href="http://www.youtube.com/watch/Fn9HMn79KH0") http://www.youtube.com/watch/Fn9HMn79KH0
|
a(href="http://www.youtube.com/watch/Fn9HMn79KH0") http://www.youtube.com/watch/Fn9HMn79KH0
|
||||||
.embed-responsive.embed-responsive-16by9.big-break
|
.embed-responsive.embed-responsive-16by9.big-break
|
||||||
iframe.embed-responsive-item(src='//www.youtube.com/embed/S7iRBZJwOAs')
|
iframe.embed-responsive-item(src='//www.youtube.com/embed/S7iRBZJwOAs')
|
||||||
h3.wrappable link:
|
h3.wrappable link:  
|
||||||
a(href="http://www.youtube.com/watch/S7iRBZJwOAs") http://www.youtube.com/watch/S7iRBZJwOAs
|
a(href="http://www.youtube.com/watch/S7iRBZJwOAs") http://www.youtube.com/watch/S7iRBZJwOAs
|
||||||
.embed-responsive.embed-responsive-16by9.big-break
|
.embed-responsive.embed-responsive-16by9.big-break
|
||||||
iframe.embed-responsive-item(src='//www.youtube.com/embed/BHNRg39ZblE')
|
iframe.embed-responsive-item(src='//www.youtube.com/embed/BHNRg39ZblE')
|
||||||
h3.wrappable link:
|
h3.wrappable link:  
|
||||||
a(href="http://www.youtube.com/watch/BHNRg39ZblE") http://www.youtube.com/watch/BHNRg39ZblE
|
a(href="http://www.youtube.com/watch/BHNRg39ZblE") http://www.youtube.com/watch/BHNRg39ZblE
|
||||||
.embed-responsive.embed-responsive-16by9.big-break
|
.embed-responsive.embed-responsive-16by9.big-break
|
||||||
iframe.embed-responsive-item(src='//www.youtube.com/embed/YDfkHlDmehA')
|
iframe.embed-responsive-item(src='//www.youtube.com/embed/YDfkHlDmehA')
|
||||||
h3.wrappable link:
|
h3.wrappable link:  
|
||||||
a(href="http://www.youtube.com/watch/YDfkHlDmehA") http://www.youtube.com/watch/YDfkHlDmehA
|
a(href="http://www.youtube.com/watch/YDfkHlDmehA") http://www.youtube.com/watch/YDfkHlDmehA
|
||||||
h3 Got 3 minutes? Learn to code with us!
|
h3 Got 3 minutes? Learn to code with us!
|
||||||
a.btn.btn-cta.signup-btn.btn-primary(href="/login") Start learning to code (it's free)
|
a.btn.btn-cta.signup-btn.btn-primary(href="/login") Start learning to code (it's free)
|
||||||
|
@ -8,16 +8,16 @@ block content
|
|||||||
h3 Please do the following immediately:
|
h3 Please do the following immediately:
|
||||||
h4
|
h4
|
||||||
ol
|
ol
|
||||||
li Complete this form:
|
li Complete this form:  
|
||||||
a(href="http://goo.gl/forms/f61dLt67t8" target="_blank") http://goo.gl/forms/f61dLt67t8
|
a(href="http://goo.gl/forms/f61dLt67t8" target="_blank") http://goo.gl/forms/f61dLt67t8
|
||||||
| .
|
| .
|
||||||
li Read this document, which will answer many questions you may have about our nonprofit projects:
|
li Read this document, which will answer many questions you may have about our nonprofit projects:  
|
||||||
a(href="http://forum.freecodecamp.com/t/an-introduction-to-our-nonprofit-projects/856" target="_blank") http://forum.freecodecamp.com/t/an-introduction-to-our-nonprofit-projects/856
|
a(href="/guide-to-our-nonprofit-projects" target="_blank") http://freecodecamp.com/guide-to-our-nonprofit-projects
|
||||||
| .
|
| .
|
||||||
li We'll send you an invite to our Nonprofit Projects Trello board. Once we do, go there and add yourself to at least 3 nonprofit projects that interest you.
|
li We'll send you an invite to our Nonprofit Projects Trello board. Once we do, go there and add yourself to at least 3 nonprofit projects that interest you.
|
||||||
li Finish any unfinished Bonfire challenges. These challenges serve as the Free Code Camp "exit test". You must complete these before you can start working on nonprofit projects. If you completed CoderByte or CodeWars challenges instead of Bonfire, email us and we'll take a look:
|
li Finish any unfinished Bonfire challenges. These challenges serve as the Free Code Camp "exit test". You must complete these before you can start working on nonprofit projects. If you completed CoderByte or CodeWars challenges instead of Bonfire, email us and we'll take a look: 
|
||||||
a(href="mailto:team@freecodecamp.com") team@freecodecamp.com
|
a(href="mailto:team@freecodecamp.com") team@freecodecamp.com
|
||||||
| .
|
| .
|
||||||
h4 Please email us if you have further questions:
|
h4 Please email us if you have further questions:  
|
||||||
a(href="mailto:team@freecodecamp.com") team@freecodecamp.com
|
a(href="mailto:team@freecodecamp.com") team@freecodecamp.com
|
||||||
| .
|
| .
|
@ -26,7 +26,7 @@ block content
|
|||||||
<h3>Contacting Us</h3>
|
<h3>Contacting Us</h3>
|
||||||
<p>If you have questions about Free Code Camp, or to correct, update, or remove personally identifiable information, please email us at <a href="mailto:team@freecodecamp.com" target="_blank">team@freecodecamp.com</a>.</p>
|
<p>If you have questions about Free Code Camp, or to correct, update, or remove personally identifiable information, please email us at <a href="mailto:team@freecodecamp.com" target="_blank">team@freecodecamp.com</a>.</p>
|
||||||
<h3>Links to Other Web sites</h3>
|
<h3>Links to Other Web sites</h3>
|
||||||
<p>The Free Code Camp sites each contain links to other Web sites. Free Code Camp is not responsible for the privacy practices or content of these third-party Web sites. We urge all FreeCodeCamp.com visitors to follow safe Internet practices: Do not supply Personally Identifiable Information to these Web sites unless you have verified their security and privacy policies.</p>
|
<p>Free Code Camp's sites each contain links to other Web sites. Free Code Camp is not responsible for the privacy practices or content of these third-party Web sites. We urge all FreeCodeCamp.com visitors to follow safe Internet practices: Do not supply Personally Identifiable Information to these Web sites unless you have verified their security and privacy policies.</p>
|
||||||
<h3>Data Retention</h3>
|
<h3>Data Retention</h3>
|
||||||
<p>We retain your information for as long as necessary to permit us to use it for the purposes that we have communicated to you and comply with applicable law or regulations.</p>
|
<p>We retain your information for as long as necessary to permit us to use it for the purposes that we have communicated to you and comply with applicable law or regulations.</p>
|
||||||
<h3>Business Transfers</h3>
|
<h3>Business Transfers</h3>
|
||||||
|
@ -17,19 +17,19 @@
|
|||||||
.btn-group.input-group.btn-group-justified(data-toggle='buttons')
|
.btn-group.input-group.btn-group-justified(data-toggle='buttons')
|
||||||
label.btn.btn-primary.btn-big(class="#{ page === 'hot' ? 'active' : '' }")
|
label.btn.btn-primary.btn-big(class="#{ page === 'hot' ? 'active' : '' }")
|
||||||
input#option1(href='/stories/hot', type='radio', name='options')
|
input#option1(href='/stories/hot', type='radio', name='options')
|
||||||
i.ion-ios-pulse-strong
|
i.ion-ios-pulse-strong  
|
||||||
| Hot
|
| Hot
|
||||||
label.btn.btn-primary.btn-big(class="#{ page === 'recent' ? 'active' : '' }")
|
label.btn.btn-primary.btn-big(class="#{ page === 'recent' ? 'active' : '' }")
|
||||||
input#option2(href='/stories/recent', type='radio', name='options')
|
input#option2(href='/stories/recent', type='radio', name='options')
|
||||||
i.ion-ios-clock
|
i.ion-ios-clock  
|
||||||
| New
|
| New
|
||||||
label.btn.btn-primary.btn-big(class="#{ page === 'submit' ? 'active' : page === 'storySubmission' ? 'active' : '' }")
|
label.btn.btn-primary.btn-big(class="#{ page === 'submit' ? 'active' : page === 'storySubmission' ? 'active' : '' }")
|
||||||
input#option3(href='/stories/submit', type='radio', name='options')
|
input#option3(href='/stories/submit', type='radio', name='options')
|
||||||
i.ion-plus-circled
|
i.ion-plus-circled  
|
||||||
| Submit
|
| Submit
|
||||||
label.btn.btn-primary.btn-big(class="#{ page === 'search' ? 'active' : '' }")
|
label.btn.btn-primary.btn-big(class="#{ page === 'search' ? 'active' : '' }")
|
||||||
input#option4(href='/stories/search', type='radio', name='options')
|
input#option4(href='/stories/search', type='radio', name='options')
|
||||||
i.ion-search
|
i.ion-search  
|
||||||
| Search
|
| Search
|
||||||
|
|
||||||
script.
|
script.
|
||||||
|
@ -25,7 +25,7 @@
|
|||||||
h6
|
h6
|
||||||
.col-xs-12.negative-15
|
.col-xs-12.negative-15
|
||||||
span Posted #{timeAgo}
|
span Posted #{timeAgo}
|
||||||
span by
|
span  by 
|
||||||
a(href="/" + author.username) @#{author.username}
|
a(href="/" + author.username) @#{author.username}
|
||||||
.col-xs-10.col-xs-offset-1
|
.col-xs-10.col-xs-offset-1
|
||||||
p= description
|
p= description
|
||||||
|
Reference in New Issue
Block a user