Skip to content

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.

app.module.ts
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.

app.config.ts
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.

app.module.ts
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.

app.config.ts
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
  • Facebook Messenger
  • LinkedIn
  • Slack
  • Telegram
  • Twitter (you can set more details using Twitter Cards)
  • WhatsApp

Resources