angular-embed-video
Version:
> Get embed code for embedding youtube/vimeo/dailymotion/\* video in websites from URL or ID in Angular 6+. > Currently supports YouTube, Vimeo and Dailymotion. Feel free to make pull request to add others!
191 lines • 24.4 kB
JavaScript
import { Injectable } from '@angular/core';
import { map } from 'rxjs/operators';
import * as i0 from "@angular/core";
import * as i1 from "@angular/common/http";
import * as i2 from "@angular/platform-browser";
export class AngularEmbedVideoService {
constructor(http, sanitizer) {
this.http = http;
this.sanitizer = sanitizer;
this.validYouTubeOptions = [
'default',
'mqdefault',
'hqdefault',
'sddefault',
'maxresdefault'
];
this.validVimeoOptions = [
'thumbnail_small',
'thumbnail_medium',
'thumbnail_large'
];
this.validDailyMotionOptions = [
'thumbnail_60_url',
'thumbnail_120_url',
'thumbnail_180_url',
'thumbnail_240_url',
'thumbnail_360_url',
'thumbnail_480_url',
'thumbnail_720_url',
'thumbnail_1080_url'
];
}
embed(url, options) {
let id;
url = new URL(url);
id = this.detectYoutube(url);
if (id) {
return this.embed_youtube(id, options);
}
id = this.detectVimeo(url);
if (id) {
return this.embed_vimeo(id, options);
}
id = this.detectDailymotion(url);
if (id) {
return this.embed_dailymotion(id, options);
}
}
embed_youtube(id, options) {
options = this.parseOptions(options);
return this.sanitize_iframe('<iframe src="https://www.youtube.com/embed/'
+ id + options.query + '"' + options.attr
+ ' frameborder="0" allowfullscreen></iframe>');
}
embed_vimeo(id, options) {
options = this.parseOptions(options);
return this.sanitize_iframe('<iframe src="https://player.vimeo.com/video/'
+ id + options.query + '"' + options.attr
+ ' frameborder="0" webkitallowfullscreen mozallowfullscreen allowfullscreen></iframe>');
}
embed_dailymotion(id, options) {
options = this.parseOptions(options);
return this.sanitize_iframe('<iframe src="https://www.dailymotion.com/embed/video/'
+ id + options.query + '"' + options.attr
+ ' frameborder="0" allowfullscreen></iframe>');
}
embed_image(url, options) {
let id;
url = new URL(url);
id = this.detectYoutube(url);
if (id) {
return this.embed_youtube_image(id, options);
}
id = this.detectVimeo(url);
if (id) {
return this.embed_vimeo_image(id, options);
}
id = this.detectDailymotion(url);
if (id) {
return this.embed_dailymotion_image(id, options);
}
}
embed_youtube_image(id, options) {
if (typeof options === 'function') {
options = {};
}
options = options || {};
options.image = this.validYouTubeOptions.includes(options.image) ? options.image : 'default';
let src = 'https://img.youtube.com/vi/' + id + '/' + options.image + '.jpg';
let result = {
link: src,
html: '<img src="' + src + '"/>'
};
return Promise.resolve(result).then(value => value);
}
embed_vimeo_image(id, options) {
if (typeof options === 'function') {
options = {};
}
options = options || {};
options.image = this.validVimeoOptions.indexOf(options.image) >= 0 ? options.image : 'thumbnail_large';
return this.http.get('https://vimeo.com/api/v2/video/' + id + '.json').pipe(map((res) => {
return {
'link': res[0][options.image],
'html': '<img src="' + res[0][options.image] + '"/>'
};
}))
.toPromise()
.catch(error => console.log(error));
}
embed_dailymotion_image(id, options) {
if (typeof options === 'function') {
options = {};
}
options = options || {};
options.image = this.validDailyMotionOptions.indexOf(options.image) >= 0 ? options.image : 'thumbnail_480_url';
return this.http.get('https://api.dailymotion.com/video/' + id + '?fields=' + options.image)
.pipe(map((res) => {
return {
'link': res[options.image],
'html': '<img src="' + res[options.image] + '"/>'
};
}))
.toPromise()
.catch(error => console.log(error));
}
parseOptions(options) {
let queryString = '', attributes = '';
if (options && options.hasOwnProperty('query')) {
queryString = '?' + this.serializeQuery(options.query);
}
if (options && options.hasOwnProperty('attr')) {
let temp = [];
Object.keys(options.attr).forEach(function (key) {
temp.push(key + '="' + (options.attr[key]) + '"');
});
attributes = ' ' + temp.join(' ');
}
return {
query: queryString,
attr: attributes
};
}
serializeQuery(query) {
let queryString = [];
for (let p in query) {
if (query.hasOwnProperty(p)) {
queryString.push(encodeURIComponent(p) + '=' + encodeURIComponent(query[p]));
}
}
return queryString.join('&');
}
sanitize_iframe(iframe) {
return this.sanitizer.bypassSecurityTrustHtml(iframe);
}
detectVimeo(url) {
return (url.hostname === 'vimeo.com') ? url.pathname.split('/')[1] : null;
}
detectYoutube(url) {
if (url.hostname.indexOf('youtube.com') > -1) {
let video_id = url.search.split('v=')[1];
const ampersandPosition = video_id.indexOf('&');
if (ampersandPosition != -1) {
video_id = video_id.substring(0, ampersandPosition);
}
return video_id;
}
if (url.hostname === 'youtu.be') {
return url.pathname.split('/')[1];
}
return '';
}
detectDailymotion(url) {
if (url.hostname.indexOf('dailymotion.com') > -1) {
return url.pathname.split('/')[2].split('_')[0];
}
if (url.hostname === 'dai.ly') {
return url.pathname.split('/')[1];
}
return '';
}
}
AngularEmbedVideoService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.1.3", ngImport: i0, type: AngularEmbedVideoService, deps: [{ token: i1.HttpClient }, { token: i2.DomSanitizer }], target: i0.ɵɵFactoryTarget.Injectable });
AngularEmbedVideoService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "12.1.3", ngImport: i0, type: AngularEmbedVideoService, providedIn: 'root' });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.1.3", ngImport: i0, type: AngularEmbedVideoService, decorators: [{
type: Injectable,
args: [{
providedIn: 'root'
}]
}], ctorParameters: function () { return [{ type: i1.HttpClient }, { type: i2.DomSanitizer }]; } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"angular-embed-video.service.js","sourceRoot":"","sources":["../../../../projects/angular-embed-video/src/lib/angular-embed-video.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { HttpClient } from '@angular/common/http';\nimport { Injectable } from '@angular/core';\nimport { DomSanitizer } from '@angular/platform-browser';\nimport { map } from 'rxjs/operators'\n\n@Injectable({\n  providedIn: 'root'\n})\nexport class AngularEmbedVideoService {\n\n  private validYouTubeOptions = [\n    'default',\n    'mqdefault',\n    'hqdefault',\n    'sddefault',\n    'maxresdefault'\n  ];\n  private validVimeoOptions = [\n    'thumbnail_small',\n    'thumbnail_medium',\n    'thumbnail_large'\n  ];\n  private validDailyMotionOptions = [\n    'thumbnail_60_url',\n    'thumbnail_120_url',\n    'thumbnail_180_url',\n    'thumbnail_240_url',\n    'thumbnail_360_url',\n    'thumbnail_480_url',\n    'thumbnail_720_url',\n    'thumbnail_1080_url'\n  ];\n\n  constructor(\n    private http: HttpClient,\n    private sanitizer: DomSanitizer\n  ) {\n  }\n\n  public embed(url: any, options?: any): any {\n    let id;\n    url = new URL(url);\n\n    id = this.detectYoutube(url);\n    if (id) {\n      return this.embed_youtube(id, options);\n    }\n\n    id = this.detectVimeo(url);\n    if (id) {\n      return this.embed_vimeo(id, options);\n    }\n\n    id = this.detectDailymotion(url);\n    if (id) {\n      return this.embed_dailymotion(id, options);\n    }\n  }\n\n  public embed_youtube(id: string, options?: any): string {\n    options = this.parseOptions(options);\n\n    return this.sanitize_iframe('<iframe src=\"https://www.youtube.com/embed/'\n      + id + options.query + '\"' + options.attr\n      + ' frameborder=\"0\" allowfullscreen></iframe>');\n  }\n\n  public embed_vimeo(id: string, options?: any): string {\n    options = this.parseOptions(options);\n\n    return this.sanitize_iframe('<iframe src=\"https://player.vimeo.com/video/'\n      + id + options.query + '\"' + options.attr\n      + ' frameborder=\"0\" webkitallowfullscreen mozallowfullscreen allowfullscreen></iframe>');\n  }\n\n  public embed_dailymotion(id: string, options?: any): string {\n    options = this.parseOptions(options);\n\n    return this.sanitize_iframe('<iframe src=\"https://www.dailymotion.com/embed/video/'\n      + id + options.query + '\"' + options.attr\n      + ' frameborder=\"0\" allowfullscreen></iframe>');\n  }\n\n  public embed_image(url: any, options?: any): any {\n    let id;\n\n    url = new URL(url);\n\n    id = this.detectYoutube(url);\n    if (id) {\n      return this.embed_youtube_image(id, options);\n    }\n\n    id = this.detectVimeo(url);\n    if (id) {\n      return this.embed_vimeo_image(id, options);\n    }\n\n    id = this.detectDailymotion(url);\n    if (id) {\n      return this.embed_dailymotion_image(id, options);\n    }\n  }\n\n  private embed_youtube_image(id: string, options?: any): any {\n    if (typeof options === 'function') {\n      options = {};\n    }\n    options = options || {};\n\n    options.image = this.validYouTubeOptions.includes(options.image) ? options.image : 'default';\n\n    let src = 'https://img.youtube.com/vi/' + id + '/' + options.image + '.jpg';\n\n    let result = {\n      link: src,\n      html: '<img src=\"' + src + '\"/>'\n    };\n\n    return Promise.resolve(result).then(value => value);\n  }\n\n  private embed_vimeo_image(id: string, options?: any): any {\n    if (typeof options === 'function') {\n      options = {};\n    }\n\n    options = options || {};\n\n    options.image = this.validVimeoOptions.indexOf(options.image) >= 0 ? options.image : 'thumbnail_large';\n\n    return this.http.get('https://vimeo.com/api/v2/video/' + id + '.json').pipe(map((res: any) => {\n      return {\n        'link': res[0][options.image],\n        'html': '<img src=\"' + res[0][options.image] + '\"/>'\n      };\n    }))\n      .toPromise()\n      .catch(error => console.log(error));\n  }\n\n  private embed_dailymotion_image(id: string, options?: any): any {\n    if (typeof options === 'function') {\n      options = {};\n    }\n\n    options = options || {};\n\n    options.image = this.validDailyMotionOptions.indexOf(options.image) >= 0 ? options.image : 'thumbnail_480_url';\n\n    return this.http.get('https://api.dailymotion.com/video/' + id + '?fields=' + options.image)\n      .pipe(map((res: any) => {\n        return {\n          'link': res[options.image],\n          'html': '<img src=\"' + res[options.image] + '\"/>'\n        };\n      }))\n      .toPromise()\n      .catch(error => console.log(error));\n  }\n\n  private parseOptions(options: any): any {\n    let queryString = '',\n      attributes = '';\n\n    if (options && options.hasOwnProperty('query')) {\n      queryString = '?' + this.serializeQuery(options.query);\n    }\n\n    if (options && options.hasOwnProperty('attr')) {\n      let temp = <any>[];\n\n      Object.keys(options.attr).forEach(function (key) {\n        temp.push(key + '=\"' + (options.attr[key]) + '\"');\n      });\n\n      attributes = ' ' + temp.join(' ');\n    }\n    return {\n      query: queryString,\n      attr: attributes\n    };\n  }\n\n  private serializeQuery(query: any): any {\n    let queryString: any = [];\n\n    for (let p in query) {\n      if (query.hasOwnProperty(p)) {\n        queryString.push(encodeURIComponent(p) + '=' + encodeURIComponent(query[p]));\n      }\n    }\n\n    return queryString.join('&');\n  }\n\n  private sanitize_iframe(iframe: string): any {\n    return this.sanitizer.bypassSecurityTrustHtml(iframe);\n  }\n\n  private detectVimeo(url: any): string {\n    return (url.hostname === 'vimeo.com') ? url.pathname.split('/')[1] : null;\n  }\n\n  private detectYoutube(url: any): string {\n    if (url.hostname.indexOf('youtube.com') > -1) {\n\t\t\tlet video_id = url.search.split('v=')[1];\n\t\t\tconst ampersandPosition = video_id.indexOf('&');\n\t\t\tif(ampersandPosition != -1) {\n\t\t\t\tvideo_id = video_id.substring(0, ampersandPosition);\n\t\t\t}\n\n      return video_id;\n    }\n\n    if (url.hostname === 'youtu.be') {\n      return url.pathname.split('/')[1];\n    }\n\n    return '';\n  }\n\n  private detectDailymotion(url: any): string {\n    if (url.hostname.indexOf('dailymotion.com') > -1) {\n      return url.pathname.split('/')[2].split('_')[0];\n    }\n\n    if (url.hostname === 'dai.ly') {\n      return url.pathname.split('/')[1];\n    }\n\n    return '';\n  }\n}\n"]}