feat(seo): add canonical tag (#5580)

This commit is contained in:
Sergey Andrievskiy 2019-12-20 11:14:42 +03:00 committed by GitHub
parent c046c0d950
commit d25cc1a4fb
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
4 changed files with 65 additions and 1 deletions

View file

@ -9,6 +9,7 @@ import {
AnalyticsService,
LayoutService,
PlayerService,
SeoService,
StateService,
} from './utils';
import { UserData } from './data/users';
@ -141,6 +142,7 @@ export const NB_CORE_PROVIDERS = [
AnalyticsService,
LayoutService,
PlayerService,
SeoService,
StateService,
AbService,
];

View file

@ -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';

View file

@ -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;
}
}

View file

@ -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',
@ -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) => {
@ -58,5 +60,6 @@ export class AppComponent implements OnInit {
this.themeService.changeTheme(themeName);
}
});
this.seoService.trackCanonicalChanges();
}
}