Each housing location has specific details that should be displayed when a user navigates to the details page for that item. To accomplish this goal, you will need to use route parameters.
Route parameters enable you to include dynamic information as a part of your route URL. To identify which housing location a user has clicked on you will use the `id` property of the `HousingLocation` type.
In this case, `:id` is dynamic and will change based on how the route is requested by the code.
1. In `src/app/housing-location/housing-location.component.ts`, add an anchor tag to the `section` element and include the `routerLink` directive:
<code-exampleheader="Add anchor with a routerLink directive to housing-location.component.ts"path="first-app-lesson-11/src/app/housing-location/housing-location.component.ts"region="add-router-link"></code-example>
The `routerLink` directive enables Angular's router to create dynamic links in the application. The value assigned to the `routerLink` is an array with two entries: the static portion of the path and the dynamic data.
For the `routerLink` to work in the template, add a file level import of `RouterLink` and `RouterOutlet` from '@angular/router', then update the component `imports` array to include both `RouterLink` and `RouterOutlet`.
1. At this point you can confirm that the routing is working in your app. In the browser, refresh the home page and click the "Learn More" button for a housing location.
In this step, you will get the route parameter in the `DetailsComponent`. Currently, the app displays `details works!`. Next you'll update the code to display the `id` value passed using the route parameters.
1. In `src/app/details/details.component.ts` update the template to import the functions, classes and services that you'll need to use in the `DetailsComponent`:
This code gives the `DetailsComponent` access to the `ActivatedRoute` router feature that enables you to have access to the data about the current route. In the `constructor`, the code converts the `id` parameter acquired from the route from a string to a number.
1. In the browser, click on one of the housing location's "Learn More" links and confirm that the numeric value displayed on the page matches the `id` property for that location in the data.
Now that routing is working properly in the application this is a great time to update the template of the `DetailsComponent` to display the specific data represented by the housing location for the route parameter.
To access the data you will add a call to the `HousingService`.
1. Update the template code to match the following code:
<code-exampleheader="Update the DetailsComponent template in src/app/details/details.component.ts"path="first-app-lesson-11/src/app/details/details.component.ts"region="update-details-template"></code-example>
Notice that the `housingLocation` properties are being accessed with the optional chaining operator `?`. This ensures that if the `housingLocation` value is null or undefined the application doesn't crash.
1. Update the body of the `DetailsComponent` class to match the following code:
<code-exampleheader="Update the DetailsComponent class in src/app/details/details.component.ts"path="first-app-lesson-11/src/app/details/details.component.ts"region="get-housing-details"></code-example>
Now the component has the code to display the correct information based on the selected housing location. The `constructor` now includes a call to the `HousingService` to pass the route parameter as an argument to the `getHousingLocationById` service function.
1. Copy the following styles into the `src/app/details/details.component.css` file:
<code-exampleheader="Add styles for the DetailsComponent"path="first-app-lesson-11/src/app/details/details.component.css"region="add-details-styles"></code-example>
1. In the browser refresh the page and confirm that when you click on the "Learn More" link for a given housing location the details page displays the correct information based on the data for that selected item.
In a previous lesson you updated the `AppComponent` template to include a `routerLink`. Adding that code updated your app to enable navigation back to the `HomeComponent` whenever the logo is clicked.
<code-exampleheader="Add routerLink to AppComponent"path="first-app-lesson-11/src/app/app.component.ts"region="add-router-link-to-header"></code-example>
Your code may already be up-to-date but confirm to be sure.