Open Graph
Open Graph is a protocol developed by Facebook that allows web pages to become rich objects in a social graph. It enables developers to control how their content appears when shared on social media platforms, such as Facebook, Twitter, LinkedIn, and others. Open Graph tags are added to the HTML of a web page as <meta name="og:x">
elements and provide metadata that helps social platforms understand and display the content more effectively.
When a link is shared on social media, Open Graph tags influence the appearance of the link preview or social card. Social cards are the visual representations of links that include a title, description, and image. These cards enhance the user experience by providing a snapshot of the linked content.
This module will help you set those tags to provide metadata to social networks and also customize link previews / social cards
Setup
Depending on what metadata you need to set, add one of more of the Open Graph modules / providers.
Main
Contains the essential to set up Open Graph metadata. They will allow you to set up social cards / link previews for platforms that read Open Graph metadata.
Specifically, manages basic and optional metadata
This is the default for apps generated with Angular CLI before v17
Add NgxMetaOpenGraphModule
to your module-based app's app.module.ts
file. Check out get started setup for more details.
import {NgxMetaOpenGraphModule} from '@davidlj95/ngx-meta/open-graph';
@NgModule({
// ...
imports: [
// ...
NgxMetaCoreModule.forRoot(),
NgxMetaRoutingModule.forRoot(),
NgxMetaOpenGraphModule,
// ...
],
// ...
})
export class AppModule {}
This is the default for apps generated with Angular CLI v17 and above
Add provideNgxMetaOpenGraph()
to your standalone app's app.config.ts
file providers. Check out get started setup for more details.
import {provideNgxMetaOpenGraph} from '@davidlj95/ngx-meta/open-graph';
export const appConfig: ApplicationConfig = {
// ...
providers: [
// ...
provideNgxMetaCore(),
provideNgxMetaRouting(),
provideNgxMetaOpenGraph(),
// ...
],
}
Profile
Manages profile non-vertical metadata. Manages metadata under OpenGraph.profile
This is the default for apps generated with Angular CLI before v17
Add NgxMetaOpenGraphProfileModule
to your module-based app's app.module.ts
file. Check out get started setup for more details.
import {NgxMetaOpenGraphProfileModule} from '@davidlj95/ngx-meta/open-graph';
@NgModule({
// ...
imports: [
// ...
NgxMetaCoreModule.forRoot(),
NgxMetaRoutingModule.forRoot(),
NgxMetaOpenGraphProfileModule,
// ...
],
// ...
})
export class AppModule {}
This is the default for apps generated with Angular CLI v17 and above
Add provideNgxMetaOpenGraphProfile()
to your standalone app's app.config.ts
file providers. Check out get started setup for more details.
import {provideNgxMetaOpenGraphProfile} from '@davidlj95/ngx-meta/open-graph';
export const appConfig: ApplicationConfig = {
// ...
providers: [
// ...
provideNgxMetaCore(),
provideNgxMetaRouting(),
provideNgxMetaOpenGraphProfile(),
// ...
],
}
Type
Following Typescript type provides you with all implemented metadata you can set:
import { OpenGraphMetadata } from '@davidlj95/ngx-meta/open-graph'
OpenGraphMetadata
API Reference
Platforms reading Open Graph metadata
At the moment of writing this document, Open Graph metadata is read by many popular sites to display social cards / link previews:
- Facebook Messenger
- Slack
- Telegram
- Twitter (you can set more details using Twitter Cards)