UNPKG

ngx-gist-runkit

Version:

Gist RunKit combines the power of Github Gist with RunKit.

232 lines (223 loc) 18.1 kB
(function (global, factory) { typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports, require('@angular/core'), require('rxjs'), require('@angular/common/http')) : typeof define === 'function' && define.amd ? define('ngx-gist-runkit', ['exports', '@angular/core', 'rxjs', '@angular/common/http'], factory) : (factory((global['ngx-gist-runkit'] = {}),global.ng.core,global.rxjs,global.ng.common.http)); }(this, (function (exports,i0,rxjs,http) { 'use strict'; /** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,uselessCode} checked by tsc */ var NgxGistRunkitService = (function () { function NgxGistRunkitService() { this.TWITTER_OBJECT = 'RunKit'; this.TWITTER_SCRIPT_ID = 'RunKit-js'; this.TWITTER_WIDGET_URL = 'https://embed.runkit.com'; } /** * @return {?} */ NgxGistRunkitService.prototype.loadScript = /** * @return {?} */ function () { var _this = this; return rxjs.Observable.create(function (observer) { _this._startScriptLoad(); window[_this.TWITTER_OBJECT].ready(_this._onTwitterScriptLoadedFactory(observer)); }); }; /** * @return {?} */ NgxGistRunkitService.prototype._startScriptLoad = /** * @return {?} */ function () { /** @type {?} */ var twitterData = window[this.TWITTER_OBJECT] || {}; if (this._twitterScriptAlreadyExists()) { window[this.TWITTER_OBJECT] = twitterData; return; } this._appendTwitterScriptToDOM(); twitterData._e = []; twitterData.ready = function (callback) { twitterData._e.push(callback); }; window[this.TWITTER_OBJECT] = twitterData; }; /** * @return {?} */ NgxGistRunkitService.prototype._twitterScriptAlreadyExists = /** * @return {?} */ function () { /** @type {?} */ var twitterScript = document.getElementById(this.TWITTER_SCRIPT_ID); return (twitterScript !== null || typeof twitterScript !== 'object'); }; /** * @return {?} */ NgxGistRunkitService.prototype._appendTwitterScriptToDOM = /** * @return {?} */ function () { /** @type {?} */ var firstJSScript = document.getElementsByTagName('script')[0]; /** @type {?} */ var js = document.createElement('script'); js.id = this.TWITTER_SCRIPT_ID; js.src = this.TWITTER_WIDGET_URL; firstJSScript.parentNode.insertBefore(js, firstJSScript); }; /** * @param {?} observer * @return {?} */ NgxGistRunkitService.prototype._onTwitterScriptLoadedFactory = /** * @param {?} observer * @return {?} */ function (observer) { return function (twitterData) { observer.next(twitterData); observer.complete(); }; }; NgxGistRunkitService.decorators = [ { type: i0.Injectable, args: [{ providedIn: 'root' },] } ]; /** @nocollapse */ NgxGistRunkitService.ngInjectableDef = i0.defineInjectable({ factory: function NgxGistRunkitService_Factory() { return new NgxGistRunkitService(); }, token: NgxGistRunkitService, providedIn: "root" }); return NgxGistRunkitService; }()); /** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,uselessCode} checked by tsc */ var NgxGistRunkitComponent = (function () { function NgxGistRunkitComponent(http$$1, ngxGistRunkitService) { this.http = http$$1; this.ngxGistRunkitService = ngxGistRunkitService; this.gistId = undefined; this.gistFileName = undefined; } /** * @return {?} */ NgxGistRunkitComponent.prototype.ngAfterViewInit = /** * @return {?} */ function () { var _this = this; if (window['RunKit'] && this.gistId !== undefined && this.gistFileName !== undefined) { /** @type {?} */ var runKit = window['RunKit']; this.fetchGithubGist(runKit, this.gistId, this.gistFileName); } else { this.ngxGistRunkitService.loadScript().subscribe(function (gistData) { /** @type {?} */ var runKit = window['RunKit']; _this.fetchGithubGist(runKit, _this.gistId, _this.gistFileName); }); } }; /** * @param {?} runKit * @param {?} data * @return {?} */ NgxGistRunkitComponent.prototype.createNotebook = /** * @param {?} runKit * @param {?} data * @return {?} */ function (runKit, data) { this.notebook = window['RunKit'].createNotebook({ element: this.embed.nativeElement, source: data }); }; /** * @param {?} runKit * @param {?} gistId * @param {?} fileName * @return {?} */ NgxGistRunkitComponent.prototype.fetchGithubGist = /** * @param {?} runKit * @param {?} gistId * @param {?} fileName * @return {?} */ function (runKit, gistId, fileName) { var _this = this; this.http .get('https://api.github.com/gists/' + gistId) .subscribe(function (response) { if (response) { _this.createNotebook(runKit, response['files'][fileName].content); } }); }; NgxGistRunkitComponent.decorators = [ { type: i0.Component, args: [{ selector: 'app-ngx-gist-runkit', template: "<div #runKit></div>\n" }] } ]; /** @nocollapse */ NgxGistRunkitComponent.ctorParameters = function () { return [ { type: http.HttpClient }, { type: NgxGistRunkitService } ]; }; NgxGistRunkitComponent.propDecorators = { embed: [{ type: i0.ViewChild, args: ['runKit',] }], gistId: [{ type: i0.Input }], gistFileName: [{ type: i0.Input }] }; return NgxGistRunkitComponent; }()); /** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,uselessCode} checked by tsc */ var NgxGistRunkitModule = (function () { function NgxGistRunkitModule() { } NgxGistRunkitModule.decorators = [ { type: i0.NgModule, args: [{ imports: [ http.HttpClientModule ], declarations: [NgxGistRunkitComponent], providers: [NgxGistRunkitService], exports: [ NgxGistRunkitComponent ] },] } ]; return NgxGistRunkitModule; }()); /** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,uselessCode} checked by tsc */ /** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,uselessCode} checked by tsc */ exports.NgxGistRunkitModule = NgxGistRunkitModule; exports.ɵa = NgxGistRunkitComponent; exports.ɵb = NgxGistRunkitService; Object.defineProperty(exports, '__esModule', { value: true }); }))); //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"ngx-gist-runkit.umd.js.map","sources":["ng://ngx-gist-runkit/app/ngx-gist-runkit/services/ngx-gist-runkit.service.ts","ng://ngx-gist-runkit/app/ngx-gist-runkit/components/ngx-gist-runkit.component.ts","ng://ngx-gist-runkit/app/ngx-gist-runkit/ngx-gist-runkit.module.ts"],"sourcesContent":["import { Injectable } from '@angular/core';\nimport { Observable, Observer } from 'rxjs';\n\n@Injectable({\n  providedIn: 'root'\n})\nexport class NgxGistRunkitService {\n  private readonly TWITTER_OBJECT = 'RunKit';\n  private readonly TWITTER_SCRIPT_ID = 'RunKit-js';\n  private readonly TWITTER_WIDGET_URL = 'https://embed.runkit.com';\n\n  public loadScript(): Observable<any> {\n      return Observable.create((observer: Observer<any>) => {\n          this._startScriptLoad();\n          window[ this.TWITTER_OBJECT ].ready(this._onTwitterScriptLoadedFactory(observer));\n      });\n  }\n\n  private _startScriptLoad() {\n      const twitterData = window[ this.TWITTER_OBJECT ] || {};\n\n      if (this._twitterScriptAlreadyExists()) {\n          window[ this.TWITTER_OBJECT ] = twitterData;\n          return;\n      }\n\n      this._appendTwitterScriptToDOM();\n\n      twitterData._e = [];\n\n      twitterData.ready = (callback: Function) => {\n          twitterData._e.push(callback);\n      };\n\n      window[ this.TWITTER_OBJECT ] = twitterData;\n  }\n\n  private _twitterScriptAlreadyExists(): boolean {\n      const twitterScript = document.getElementById(this.TWITTER_SCRIPT_ID);\n      return (twitterScript !== null || typeof twitterScript !== 'object');\n  }\n\n  private _appendTwitterScriptToDOM(): void {\n      const firstJSScript = document.getElementsByTagName('script')[ 0 ];\n      const js = document.createElement('script');\n      js.id = this.TWITTER_SCRIPT_ID;\n      js.src = this.TWITTER_WIDGET_URL;\n      firstJSScript.parentNode.insertBefore(js, firstJSScript);\n  }\n\n  private _onTwitterScriptLoadedFactory(observer: Observer<any>): Function {\n      return (twitterData: any) => {\n          observer.next(twitterData);\n          observer.complete();\n      };\n  }\n}\n","import { ViewChild, Component, AfterViewInit } from '@angular/core';\nimport { Input } from '@angular/core';\nimport { HttpClient } from '@angular/common/http';\nimport { NgxGistRunkitService } from '../services/ngx-gist-runkit.service';\n\n@Component({\n  selector: 'app-ngx-gist-runkit',\n  templateUrl: './ngx-gist-runkit.component.html',\n})\nexport class NgxGistRunkitComponent implements AfterViewInit {\n  @ViewChild('runKit') embed;\n  @Input() gistId = undefined;\n  @Input() gistFileName = undefined;\n\n  constructor(\n    private http: HttpClient,\n    private ngxGistRunkitService: NgxGistRunkitService\n  ) {}\n  notebook: any;\n  ngAfterViewInit() {\n    if (\n      window['RunKit'] &&\n      this.gistId !== undefined &&\n      this.gistFileName !== undefined\n    ) {\n      const runKit = window['RunKit'];\n      this.fetchGithubGist(runKit, this.gistId, this.gistFileName);\n    } else {\n      this.ngxGistRunkitService.loadScript().subscribe((gistData: any) => {\n        const runKit = window['RunKit'];\n        this.fetchGithubGist(runKit, this.gistId, this.gistFileName);\n      });\n    }\n  }\n\n  public createNotebook(runKit, data) {\n    this.notebook = window['RunKit'].createNotebook({\n      element: this.embed.nativeElement,\n      source: data\n    });\n  }\n\n  public fetchGithubGist(runKit, gistId, fileName) {\n    this.http\n      .get('https://api.github.com/gists/' + gistId)\n      .subscribe(response => {\n        if (response) {\n          this.createNotebook(runKit, response['files'][fileName].content);\n        }\n      });\n  }\n}\n","import { NgModule } from '@angular/core';\nimport { NgxGistRunkitComponent } from './components/ngx-gist-runkit.component';\nimport { NgxGistRunkitService } from './services/ngx-gist-runkit.service';\nimport { HttpClientModule } from '@angular/common/http';\n\n@NgModule({\n  imports: [\n    HttpClientModule\n  ],\n  declarations: [NgxGistRunkitComponent],\n  providers: [NgxGistRunkitService],\n  exports: [\n    NgxGistRunkitComponent\n  ]\n})\nexport class NgxGistRunkitModule { }\n"],"names":["Observable","Injectable","http","Component","HttpClient","ViewChild","Input","NgModule","HttpClientModule"],"mappings":"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"}