Skip to content

Latest commit

 

History

History
106 lines (91 loc) · 6.4 KB

STEPS.md

File metadata and controls

106 lines (91 loc) · 6.4 KB

Step 1: bootstraping your first component

  1. clone branch: https://github.com/manekinekko/angular2-codelab/tree/step-1
  2. create and add a root component
  • name it Ng2CodelabApp
  • store it in src/app/ng2-codelab.ts
  • use selector <app></app>
  • create the template src/app/ng2codelab.html
  1. bootstrap your application in src/app.ts
  2. check solution: https://github.com/manekinekko/angular2-codelab/tree/step-1-solution
  3. diff: https://github.com/manekinekko/angular2-codelab/compare/step-1...step-1-solution

Step 2: home and theme-card components

  1. clone branch: https://github.com/manekinekko/angular2-codelab/tree/step-2
  2. create and add a dump component
  • name it ThemeCard
  • store it in src/app/components/theme-card/theme-card.ts
  • use selector <theme-card></theme-card>
  • use template src/app/components/theme-card/theme-card.html
  1. update the smart component Home
  • you can find this component in src/app/components/home/home.ts
  • use template src/app/components/home/home.html
    • Hint: use the dump <theme-card></theme-card>
  • use the provided service src/app/services/technologies-store/technologies-store.ts
  1. check solution: https://github.com/manekinekko/angular2-codelab/tree/step-2-solution
  2. diff: https://github.com/manekinekko/angular2-codelab/compare/step-2...step-2-solution

Step 3: setting up the router and question component

  1. clone branch: https://github.com/manekinekko/angular2-codelab/tree/step-3
  2. create and add a dump component
  • name it QuestionCard
  • store it in src/app/components/question-card/question-card.ts
  • use selector <question-card></question-card>
  • use template src/app/components/question-card/question-card.html
  1. add a route configuration to the root component Ng2CodelabApp
  • add two routes: Home and QuestionCard
  1. update the ThemeCard and it template to use the router
  2. update the Ng2CodelabApp template with the router directive
  3. check the necessary router providers included in src/app.ts
  • we injected for you the router dependencies in app.tsL5-L6
  1. check solution: https://github.com/manekinekko/angular2-codelab/tree/step-3-solution
  2. diff: https://github.com/manekinekko/angular2-codelab/compare/step-3...step-3-solution

Step 4: technology component

In this step, you are provided with all the necessary files containing the heavy work so you can focus on the basics. You can still take a momment and read this commit diff to understand what's really happening https://github.com/manekinekko/angular2-codelab/commit/39b9f0e6748825b51456d18dcd1cdd8d280fec7f

  1. clone branch: https://github.com/manekinekko/angular2-codelab/tree/step-4
  2. update the QuestionCard component and its template so it can display and navigate the questions correctly
  • use @Input() and @Output() in order to receive a question (which will be the current question) property and send an checked event.
  • use the elvis operator to allow parsing undefined values, ie: {{question?.title}}
  1. if you like challenges, you can re-implement these files:
  • src/app/components/technology/technology.ts
  • src/app/services/question-store/question-store.ts
  • src/app/services/session-store/session-store.ts
  1. check solution: https://github.com/manekinekko/angular2-codelab/tree/step-4-solution
  2. diff: https://github.com/manekinekko/angular2-codelab/compare/step-4...step-4-solution

Step 5: summary component

  1. clone branch: https://github.com/manekinekko/angular2-codelab/tree/step-5
  2. create and add a smart component
  • name it Summary
  • store it in src/app/components/summary/summary.ts
  • use an inline template
  1. use a factory provider to get a new instance of the QuestionsStore
  • read the stored session using SessionStore.read()
  1. use the QuestionCard component to display the saved answers
  2. update the router configuration in src/app/ng2-codelab.ts
  3. check solution: https://github.com/manekinekko/angular2-codelab/tree/step-5-solution
  4. diff: https://github.com/manekinekko/angular2-codelab/compare/step-5...step-5-solution

Step 6: add a Pipe

  1. clone branch: https://github.com/manekinekko/angular2-codelab/tree/step-6
  2. add an input property (boolean) to the QuestionCard to enable/disable a "preview mode"
  • name it preview
  • in preview mode, the checkboxes must be disabled
  • in preview mode, the status of a choice is shown (see pipe below)
  1. add a pipe that shows a ✔ or ✘ if the given choice is correct or wrong, in the QuestionCard component
  • name the class MarkPipe
  • name the pipe mark
  • store it in src/app/pipes/mark-pipe/mark-pipe.ts
  1. check solution: https://github.com/manekinekko/angular2-codelab/tree/step-6-solution
  2. diff: https://github.com/manekinekko/angular2-codelab/compare/step-6...step-6-solution

Step 7: add a directive

  1. clone branch: https://github.com/manekinekko/angular2-codelab/tree/step-7
  2. update the content of the directive StatusDirective that sets the color of a choice
  • use selector [status]
  • use the existing <span></span> in question-card.html#L27
  • if the choice is correct, set the color to green, otherwise set it to red
    • use an @Input() property to get a choice status (choice.isCorrect())
  • use the Renderer to set the style this.renderer.setElementStyle(nativeElement, styleProperty, value)
  • the directive is stored in src/app/directives/status-directive/status-directive.ts
  1. check solution: https://github.com/manekinekko/angular2-codelab/tree/step-7-solution
  2. diff: https://github.com/manekinekko/angular2-codelab/compare/step-7...step-7-solution