In this guide, we'll explore the library and documentation code base and create a new component of our own. How to create a new Fundamental Library for Angular component
This repository contains two separate projects - the component library and the documentation application. Different build tasks are used, depending on which project we're building. However, the documentation app consumes the library source directly, so there's no need to compile the library to test changes you're making to a component - simply running the documentation app locally will serve changes to the library immediately.
The documentation code base lies in the docs
directory and the library source is in the libs
directory.
First, let's generate an empty module in the library. Each library component gets its own module, so end users can import only the modules for specific components they intend to use, if they don't want to import the entire library.
The library's source lies in the libs
directory. From the root of the repo, cd into the library source:
cd libs
We're going to be building a component called 'Poster' that displays images. Generate a new 'poster' module in the src/lib
directory.
ng generate module core/src/lib/poster
Then, generate a 'poster' component in the new module:
ng generate component /core/src/lib/poster --module=core/src/lib/poster/poster.module
Create an exports
array in the poster module and add the poster component, like so:
import { NgModule } from '@angular/core';
import { CommonModule } from '@angular/common';
import { PosterComponent } from './poster.component';
@NgModule({
declarations: [PosterComponent],
imports: [
CommonModule
],
exports: [
PosterComponent
]
})
export class PosterModule { }
Add a new file in the poster lib called public_api.ts
and add the following:
export * from './poster.module'; export * from './poster.component';
Open libs/core/src/index.ts
and add export * from './lib/poster/public_api';
Now let's create a new documentation component so we can see our new Poster component in action. Change directories back to the root of the repository, then change into the 'component-docs' directory:
cd apps/docs/src/app/core/component-docs
The directory structure for the documentation is different than the standard structure Angular apps typically use, so we won't utilize the Angular CLI to generate documentation modules.
Next let's create a directory for our poster docs.
mkdir poster
Create two new files in the poster
directory, poster-docs.component.ts
and poster-docs.component.html
. Then create the directory examples
as well.
Next, from the documentation poster directory, create the component poster-header
.
ng g c poster-header
The components we create in this directory will not only be rendered on their example page, but the raw source from these files will be used for the code examples.
In poster-header.component.html Copy/paste the code here:
<header>Poster</header>
<description>
<p>The poster shows an image</p>
</description>
<import module="PosterModule"></import>
<fd-header-tabs></fd-header-tabs>
<router-outlet></router-outlet>
In examples
, create the file poster-example.component.ts
. Copy/paste the code here:
import { Component } from '@angular/core';
@Component({
selector: 'fd-poster-example',
template: '<fd-poster></fd-poster>'
})
export class PosterExampleComponent {}
Then copy/paste this block to poster-docs.component.ts
:
import { Component } from '@angular/core';
import * as posterHtml from '!raw-loader!./examples/poster-example.component.ts';
@Component({
selector: 'app-poster',
templateUrl: './poster-docs.component.html'
})
export class PosterDocsComponent {
posterHtml = posterHtml;
}
Note that we're using raw-loader to import the poster example code as raw text. This text will be rendered as the example source.
In poster-docs.component.html
, we'll provide a brief explanation of the poster component, and we'll add the poster component itself, along with the code example.
<h2>Poster</h2>
<description>
The Poster component displays a photograph taken from an image placeholder site.
</description>
<component-example>
<fd-poster-example></fd-poster-example>
</component-example>
<code-example [exampleFiles]="posterHtml"></code-example>
Create a new file called poster-docs.module.ts
in the poster documentation directory and copy/paste the following:
import { NgModule } from '@angular/core';
import { RouterModule, Routes } from '@angular/router';
import { ApiComponent } from '../../../documentation/core-helpers/api/api.component';
import { API_FILES } from '../../api-files';
import { SharedDocumentationModule } from '../../../documentation/shared-documentation.module';
import { PosterDocsComponent } from './poster-docs.component';
import { PosterExampleComponent } from './examples/poster-example.component';
import { PosterHeaderComponent } from './poster-header/poster-header.component';
import { PosterModule } from '@fundamental-ngx/core';
const routes: Routes = [
{
path: '',
component: PosterHeaderComponent,
children: [
{ path: '', component: PosterDocsComponent },
{ path: 'api', component: ApiComponent, data: { content: API_FILES.poster } }
]
}
];
@NgModule({
imports: [RouterModule.forChild(routes), SharedDocumentationModule, PosterModule],
exports: [RouterModule],
declarations: [
PosterHeaderComponent,
PosterDocsComponent,
PosterExampleComponent
]
})
export class PosterDocsModule {}
Open apps/docs/src/app/core/api-files.ts
and add the following to the API_FILES
array:
poster: ['PosterComponent']
In the same directory, open core-documentation.routes.ts
and add the following to the children
in the ROUTES
array:
{
path: 'poster',
loadChildren: () =>
import('./component-docs/poster/poster-docs.module').then(
(m) => m.PosterDocsModule
)
},
PosterHeaderComponent may have been added automatically to core-documentation.module.ts
, so we'll need to remove that.
Then from this directory, navigate to the documentation
directory and open core-documentation.component.ts
and add:
{ url: 'core/poster', name: 'Poster' }
You should see 'Poster' appear in the side navigation under 'Components'. Clicking the link will load a page that says poster works!
In the library source, open poster.component.html
, remove the default code and add an image with a placeholder.
<img src="https://placeimg.com/400/600/nature'"/>
Follow the instructions at https://github.com/SAP/fundamental-ngx/wiki/Stackblitz-support-instructions
Now, when you navigate to the Poster docs through the side navigation, you'll see our new Poster component!
Refer to other component's documentation source to see how docs-related info is presented.