1. Installing Carbon
Starting with the Carbon Angular, there are two ways to begin working with Carbon components. By the end, these two methods will produce the same result.
- Prerequisites
- Install Angular CLI
- Create an Angular App
- Install Carbon
- Run the app
- Add UI Shell
- Create pages
- Add routing
- Submit pull request
Preview
A preview of what you will build:
Prerequisites
Fork, clone and branch
This tutorial has an accompanying GitHub repository called carbon-tutorial-angular that we’ll use as a starting point for each step.
Fork
To begin, fork carbon-tutorial-angular using your GitHub account.
Clone
Go to your forked repository, copy the SSH or HTTPS URL and in your terminal run the two commands to get the repository in your local file system and enter that directory.
git clone [your fork SSH/HTTPS]cd carbon-tutorial-angular
Add upstream remote
Add a remote called
upstream
SSH:
git remote add upstream git@github.com:carbon-design-system/carbon-tutorial-angular.git
Or, if you prefer to use HTTPS instead of SSH with your remotes:
HTTPS:
git remote add upstream https://github.com/carbon-design-system/carbon-tutorial-angular.git
Verify that your forked repository remotes are correct:
git remote -v
Your terminal should output something like this:
origin [your forked repo] (fetch)origin [your forked repo] (push)upstream git@github.com:carbon-design-system/carbon-tutorial-angular.git (fetch)upstream git@github.com:carbon-design-system/carbon-tutorial-angular.git (push)
Branch
Now that we have our repository set up, let’s check out the branch for this tutorial step’s starting point. Run the two commands:
git fetch upstreamgit checkout -b angular-step-1 upstream/angular-step-1
Install Angular CLI
Since we are starting from scratch, we need to first install Angular CLI. Currently you need to install Angular CLI Version 8.x to work through this tutorial.
npm install -g @angular/cli
Create an Angular App
Now that we have our environment set up, starting a new Angular app is easy! If you haven’t set up the environment yet, please do so using the steps provided in Prerequisites (above). We will be using the Angular CLI to create and generate our components. It can also generate services, router, components, and directives.
To create a new Angular project with Angular CLI, just run:
ng new carbon-angular-tutorial
This will create the new project within the current directory. Make sure you do this within the cloned fork of the project. When you get prompted, enter the following.
? Would you like to add Angular routing? Yes? Which stylesheet format would you like to use? SCSS
This command will install the Angular app with all the configurations needed. Within the project folder
carbon-angular-tutorial
src
carbon-angular-tutorial...├── src├── app│  ├─ ─ app-routing.module.ts│  ├── app.component.html│  ├── app.component.scss│  ├── app.component.spec.ts│  ├── app.component.ts
Install Carbon
Even though we installed some dependencies while creating the new app, we’ve yet to install the Carbon packages.
- - Component stylescarbon-components
- - Angular componentscarbon-components-angular
- - Carbon icons@carbon/icons
npm install carbon-components carbon-components-angular @carbon/icons
Import carbon-components styles
In
src/styles.scss
@import '~carbon-components/scss/globals/scss/styles';
Run the app
Now we can run our app for a quick preview inside the browser.
npm start
Your app should now be running with the message:
** Angular Live Development Server is listening on localhost:4200, open your browser on http://localhost:4200/ **
Before we start adding components we want to start with an empty project, so delete everything in
app.component.html
router-outler
app.component.spec.ts
should render title
should have as title 'carbon-angular-tutorial'
Add UI Shell
Next, we’re going to create an Angular component called
Header
src/app
ng g component header --lint-fix
Folder structure
src/app/header├── header.component.html├── header.component.scss├── header.component.spec.ts└── header.component.ts
Import UI Shell
Next we’ll import our Carbon UI Shell components into
app.module.ts
app.component.spec.ts
header.component.spec.ts
import { BrowserModule } from '@angular/platform-browser';import { NgModule } from '@angular/core';import { AppRoutingModule } from './app-routing.module';import { AppComponent } from './app.component';import { HeaderComponent } from './header/header.component';// carbon-components-angular default importsimport { UIShellModule, IconModule } from 'carbon-components-angular';
import { UIShellModule } from 'carbon-components-angular/ui-shell/ui-shell.module';
TestBed.configureTestingModule({declarations: [HeaderComponent],imports: [UIShellModule]});
Import and register icons
Now let’s import the icons from our
@carbon/icons
Notification20
UserAvatar20
AppSwitcher20
app.module.ts
import Notification20 from '@carbon/icons/es/notification/20';import UserAvatar20 from '@carbon/icons/es/user--avatar/20';import AppSwitcher20 from '@carbon/icons/es/app-switcher/20';
Now you need to register the icon via
IconService
carbon-components-angular
.register()
.registerAll()
import { IconService } from "carbon-components-angular";...constructor(protected iconService: IconService) {}ngOnInit() {this.iconService.registerAll([Notification20]);}
Next step is to import the
IconModule
AppModule
HeaderComponent
import { IconModule } from "carbon-components-angular";...imports: [...IconModule]
Now the icon is ready to be used in template code. Template in
header.component.html
<ibm-header name="Carbon Tutorial Angular"><ibm-header-navigation ariaLabel="Carbon Tutorial Angular"><ibm-header-item href="/repos">Repositories</ibm-header-item></ibm-header-navigation><ibm-header-global><ibm-header-action title="action"><svg ibmIcon="notification" size="20"></svg></ibm-header-action><ibm-header-action title="action">
Notice that the icon names are the same as their file path. This how the directive queries the service for the icon.
Next import the header component in
app.component.spec.ts
app.component.html
import { HeaderComponent } from './header/header.component';
declarations: [HeaderComponent];
<app-header></app-header><main class="cds--content"><router-outlet></router-outlet></main>
Let’s add some padding to the top of the document, so the content is below the header. We are going to do this by using the
cds--header
header.component.ts
import { Component, HostBinding } from '@angular/core';...@HostBinding('class.cds--header') headerClass = true;
Create pages
Next thing we need to do is create the files for our content. These files will be located in the
app
src
header
Our app will have two pages. First, we need a landing page. Go ahead and stop your development server (with
CTRL-C
ng g module home --routing --lint-fixng g component home/landing-page --lint-fix
Folder structure
src/app/home├── landing-page│  ├── landing-page.component.html│  ├── landing-page.component.scss│  ├── landing-page.component.spec.ts│  └── landing-page.component.ts├── home-routing.module.ts└── home-page.module.ts
And a repo page:
ng g module repositories --routing --lint-fixng g component repositories/repo-page --lint-fix
Folder structure
src/app/repositories├── repo-page│  ├── repo-page.component.html│  ├── repo-page.component.scss│  ├── repo-page.component.spec.ts│  └── repo-page.component.ts├── repositories-routing.module.ts└── repositories.module.ts
Now you can restart your server with
npm start
Add routing
We need to update routing functionality to enable the loading of
repositories
app-routing.module.ts
const routes: Routes = [{path: '',loadChildren: () => import('./home/home.module').then((m) => m.HomeModule),},{path: 'repos',loadChildren: () =>import('./repositories/repositories.module').then(
And modify the
NgModule
@NgModule({imports: [RouterModule.forRoot(routes, { useHash: true })],exports: [RouterModule],})export class AppRoutingModule {}
And add routes for the landing and repo pages:
import { LandingPageComponent } from './landing-page/landing-page.component';const routes: Routes = [{path: '',component: LandingPageComponent,},];
import { RepoPageComponent } from './repo-page/repo-page.component';const routes: Routes = [{path: '',component: RepoPageComponent}];
After that we need to do a couple quick fixes to the UI Shell to have it route to the repo page.
<ibm-header-item [route]="['/repos']">Repositories</ibm-header-item>
You should now have a working header that routes to the repos pages without full page reload!
Submit pull request
We’re going to submit a pull request to verify completion of this tutorial step and demonstrate a couple related concepts.
Continuous integration (CI) check
We have
lint
test
package.json
ng lint --fixnpm run lint && npm test
Git commit and push
Before we can create a pull request, we need to stage and commit all of our changes:
git add --all && git commit -m "feat(tutorial): complete step 1"
Then, push to your repository:
git push origin angular-step-1
Pull request (PR)
Finally, visit carbon-tutorial-angular to “Compare & pull request”. In doing so, make sure that you are comparing to
angular-step-1
base: angular-step-1