Builder Angular SDK
Usage
Install
npm install @builder.io/angular
Add the module
import { BuilderModule } from '@builder.io/angular';
@NgModule({
...
imports: [ BuilderModule.forRoot('YOUR_API_KEY') ],
...
})
export class MyAppModule { }
NOTE: You can get YOUR_API_KEY
from https://builder.io/account/space.
And then add the component wherever you like
<builder-component model="page" (load)="contentLoaded($event)" (error)="contentError($event)">
<div class="spinner"></div>
</builder-component>
Then, update your model's preview URL to enable on-site editing like in this guide, and you are done!
Next, see the below info for more advanced usage, as well as this guide for creating custom models,
and this guide for SEO optimizing your content (for angular use the data from the load
output to get the custom field data)
Custom landing pages in your code
Simply replace your 404 component with something like the below to allow creating new pages in Builder easily
<builder-component
*ngIf="!noBuilderPageForUrl"
model="page"
(load)="noBuilderPageForUrl = $event ? false : true"
(error)="noBuilderPageForUrl = true"
>
<div class="spinner"></div>
</builder-component>
<my-404-component *ngIf="noBuilderPageForUrl"> </my-404-component>
Use your angular components in your Builder pages
You can drag and drop to add your angular components in the Builder editor with a simple tag like below:
import { BuilderBlock } from '@builder.io/angular';
import { Component, Input } from '@angular/core';
@BuilderBlock({
tag: 'custom-thing',
name: 'Custom thing',
inputs: [
{
name: 'name',
type: 'string',
},
],
})
@Component({
selector: 'custom-thing',
template: 'Hello: {{name}}',
})
export class CustomThing {
@Input()
name = '';
}
Note that custom Angular components use angular elements. This means they can only accept primitive inputs (string, boolean, number) and not complex ones (object, array, etc), and render in the browser only (no server-side rendering).
If you need complex inputs or server-side rendering in reusable components with Builder, consider using symbols
See here for full detail on input types available.
Using custom fields
Custom fields are a powerful feature when using custom models, for all sorts of customization, such as SEO optimization of your content
<builder-component model="page" (load)="contentLoaded($event)">
<div class="spinner"></div>
</builder-component>
contentLoaded(data) {
document.title = data.data.title
}
Builder components within existing pages
With component models you can also use Builder.io components in/around existing pages (aka it doesn't have to control the whole page). See info on making custom models for this here
<builder-component model="my-section">Loading..</builder-component>
You can then use queries and targeting to customize what content loads where
Example projects
To see a full example integration see here for a simple Angular + Builder.io example project,
or here for an Angular universal example