Skip to content

Commit

Permalink
feat(seo): add canonical tag (#5580)
Browse files Browse the repository at this point in the history
  • Loading branch information
yggg authored Dec 20, 2019
1 parent c046c0d commit d25cc1a
Show file tree
Hide file tree
Showing 4 changed files with 65 additions and 1 deletion.
2 changes: 2 additions & 0 deletions src/app/@core/core.module.ts
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,7 @@ import {
AnalyticsService,
LayoutService,
PlayerService,
SeoService,
StateService,
} from './utils';
import { UserData } from './data/users';
Expand Down Expand Up @@ -141,6 +142,7 @@ export const NB_CORE_PROVIDERS = [
AnalyticsService,
LayoutService,
PlayerService,
SeoService,
StateService,
AbService,
];
Expand Down
1 change: 1 addition & 0 deletions src/app/@core/utils/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -2,3 +2,4 @@ export { LayoutService } from './layout.service';
export { AnalyticsService } from './analytics.service';
export { PlayerService } from './player.service';
export { StateService } from './state.service';
export { SeoService } from './seo.service';
58 changes: 58 additions & 0 deletions src/app/@core/utils/seo.service.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,58 @@
import { Injectable, Inject, PLATFORM_ID, OnDestroy } from '@angular/core';
import { isPlatformBrowser } from '@angular/common';
import { NavigationEnd, Router } from '@angular/router';
import { NB_DOCUMENT } from '@nebular/theme';
import { filter, takeUntil } from 'rxjs/operators';
import { Subject } from 'rxjs';

@Injectable()
export class SeoService implements OnDestroy {

private readonly destroy$ = new Subject<void>();
private readonly dom: Document;
private readonly isBrowser: boolean;
private linkCanonical: HTMLLinkElement;

constructor(
private router: Router,
@Inject(NB_DOCUMENT) document,
@Inject(PLATFORM_ID) platformId,
) {
this.isBrowser = isPlatformBrowser(platformId);
this.dom = document;

if (this.isBrowser) {
this.createCanonicalTag();
}
}

ngOnDestroy() {
this.destroy$.next();
this.destroy$.complete();
}

createCanonicalTag() {
this.linkCanonical = this.dom.createElement('link');
this.linkCanonical.setAttribute('rel', 'canonical');
this.dom.head.appendChild(this.linkCanonical);
this.linkCanonical.setAttribute('href', this.getCanonicalUrl());
}

trackCanonicalChanges() {
if (!this.isBrowser) {
return;
}

this.router.events.pipe(
filter((event) => event instanceof NavigationEnd),
takeUntil(this.destroy$),
)
.subscribe(() => {
this.linkCanonical.setAttribute('href', this.getCanonicalUrl());
});
}

private getCanonicalUrl(): string {
return this.dom.location.origin + this.dom.location.pathname;
}
}
5 changes: 4 additions & 1 deletion src/app/app.component.ts
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,7 @@ import { NbThemeService } from '@nebular/theme';
import { AnalyticsService } from './@core/utils/analytics.service';
import { AbService } from './@core/utils/ab.service';
import { withLatestFrom, filter } from 'rxjs/operators';
import { SeoService } from './@core/utils/seo.service';

@Component({
selector: 'ngx-app',
Expand All @@ -22,7 +23,8 @@ export class AppComponent implements OnInit {
constructor(private analytics: AnalyticsService,
private activatedRoute: ActivatedRoute,
private abService: AbService,
private themeService: NbThemeService) {
private themeService: NbThemeService,
private seoService: SeoService) {

this.themeService.onThemeChange()
.subscribe((theme: any) => {
Expand Down Expand Up @@ -58,5 +60,6 @@ export class AppComponent implements OnInit {
this.themeService.changeTheme(themeName);
}
});
this.seoService.trackCanonicalChanges();
}
}

0 comments on commit d25cc1a

Please sign in to comment.