This library supports the implementation of customer tracking with Tealium in Angular applications.
Tealium provides an Angular Integration Guide already, but their approach require the consumer to create their own service. This library uses the developer friendly NgModule approach to make an Angular Integration.
npm install ngx-tealium --save
For Angular standalone support add
provideTealiumTracking()
to your app providers.
After installation you can use the ngx-tealium library in your Angular project. You have to
import TealiumTrackingModule.forRoot()
in the root NgModule of your application.
The forRoot
static method is a convention that provides and configures services at the same time. Make sure you only
call this method in the root module of your application, most of the time called AppModule. This method allows you to
configure the TealiumTrackingModule by defining a configLoader
provider.
@NgModule({
imports: [
BrowserModule,
TealiumTrackingModule.forRoot({
configLoader: {
provide: TealiumConfigLoader,
useValue: new TealiumConfigStaticLoader({ account: 'test', profile: 'test', environment: 'dev' }),
},
}),
],
bootstrap: [AppComponent],
})
export class AppModule {}
If you want to use a configuration from a HTTP or other async source, you need to provide a TealiumConfigHttpLoader
class created in a factory function.
// AoT requires an exported function for factories
export function tealiumConfigLoaderFactory(httpClient: HttpClient): TealiumConfigLoader {
const config$ = httpClient.get<TealiumConfig>('http://localhost:3000/config');
return new TealiumConfigHttpLoader(config$);
}
@NgModule({
imports: [
BrowserModule,
HttpClientModule,
TealiumTrackingModule.forRoot({
configLoader: {
provide: TealiumConfigLoader,
useFactory: tealiumConfigLoaderFactory,
deps: [HttpClient],
},
}),
],
bootstrap: [AppComponent],
})
export class AppModule {}
The tealium config is provided when importing the TealiumTrackingModule
with forRoot
by providing an account
, profile
and environment
.
Inject the TealiumTrackingService
to send tealium tracking events to your profile. Check the API of the
Service in the Module for more information.
The TealiumTrackingService
is an injectable Angular service to be used in your components. It provides the most common
tracking methods specified in a customer tracking concept.
trackCustomEvent(event: TealiumEvent)
: Tracks a generic tealium link event.trackPageView(event: TealiumEvent)
: Tracks a generic tealium view event.addVolatile(key: string, value: string | string[])
: Adds data to the stateful volatile store that is sent with every tracking request.removeVolatile(key: string)
: Removes data from the stateful volatile store.
Thanks for your interest in contributing! Read up on our guidelines for contributing and then look through our issues with a help wanted label.