ngx-gist-runkit
Version:
Gist RunKit combines the power of Github Gist with RunKit.
232 lines (223 loc) • 18.1 kB
JavaScript
(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":";;;;;;;;;;AAAA;;kCAOoC,QAAQ;qCACL,WAAW;sCACV,0BAA0B;;;;;QAEzD,yCAAU;;;;;gBACb,OAAOA,eAAU,CAAC,MAAM,CAAC,UAAC,QAAuB;oBAC7C,KAAI,CAAC,gBAAgB,EAAE,CAAC;oBACxB,MAAM,CAAE,KAAI,CAAC,cAAc,CAAE,CAAC,KAAK,CAAC,KAAI,CAAC,6BAA6B,CAAC,QAAQ,CAAC,CAAC,CAAC;iBACrF,CAAC,CAAC;;;;;QAGC,+CAAgB;;;;;gBACpB,IAAM,WAAW,GAAG,MAAM,CAAE,IAAI,CAAC,cAAc,CAAE,IAAI,EAAE,CAAC;gBAExD,IAAI,IAAI,CAAC,2BAA2B,EAAE,EAAE;oBACpC,MAAM,CAAE,IAAI,CAAC,cAAc,CAAE,GAAG,WAAW,CAAC;oBAC5C,OAAO;iBACV;gBAED,IAAI,CAAC,yBAAyB,EAAE,CAAC;gBAEjC,WAAW,CAAC,EAAE,GAAG,EAAE,CAAC;gBAEpB,WAAW,CAAC,KAAK,GAAG,UAAC,QAAkB;oBACnC,WAAW,CAAC,EAAE,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;iBACjC,CAAC;gBAEF,MAAM,CAAE,IAAI,CAAC,cAAc,CAAE,GAAG,WAAW,CAAC;;;;;QAGxC,0DAA2B;;;;;gBAC/B,IAAM,aAAa,GAAG,QAAQ,CAAC,cAAc,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC;gBACtE,QAAQ,aAAa,KAAK,IAAI,IAAI,OAAO,aAAa,KAAK,QAAQ,EAAE;;;;;QAGjE,wDAAyB;;;;;gBAC7B,IAAM,aAAa,GAAG,QAAQ,CAAC,oBAAoB,CAAC,QAAQ,CAAC,CAAE,CAAC,CAAE,CAAC;;gBACnE,IAAM,EAAE,GAAG,QAAQ,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC;gBAC5C,EAAE,CAAC,EAAE,GAAG,IAAI,CAAC,iBAAiB,CAAC;gBAC/B,EAAE,CAAC,GAAG,GAAG,IAAI,CAAC,kBAAkB,CAAC;gBACjC,aAAa,CAAC,UAAU,CAAC,YAAY,CAAC,EAAE,EAAE,aAAa,CAAC,CAAC;;;;;;QAGrD,4DAA6B;;;;sBAAC,QAAuB;gBACzD,OAAO,UAAC,WAAgB;oBACpB,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;oBAC3B,QAAQ,CAAC,QAAQ,EAAE,CAAC;iBACvB,CAAC;;;oBAnDPC,aAAU,SAAC;wBACV,UAAU,EAAE,MAAM;qBACnB;;;mCALD;;;;;;;ACAA;QAcE,gCACUC,SACA;YADA,SAAI,GAAJA,OAAI;YACJ,yBAAoB,GAApB,oBAAoB;0BALZ,SAAS;gCACH,SAAS;SAK7B;;;;QAEJ,gDAAe;;;YAAf;gBAAA,iBAcC;gBAbC,IACE,MAAM,CAAC,QAAQ,CAAC;oBAChB,IAAI,CAAC,MAAM,KAAK,SAAS;oBACzB,IAAI,CAAC,YAAY,KAAK,SACxB,EAAE;;oBACA,IAAM,MAAM,GAAG,MAAM,CAAC,QAAQ,CAAC,CAAC;oBAChC,IAAI,CAAC,eAAe,CAAC,MAAM,EAAE,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,YAAY,CAAC,CAAC;iBAC9D;qBAAM;oBACL,IAAI,CAAC,oBAAoB,CAAC,UAAU,EAAE,CAAC,SAAS,CAAC,UAAC,QAAa;;wBAC7D,IAAM,MAAM,GAAG,MAAM,CAAC,QAAQ,CAAC,CAAC;wBAChC,KAAI,CAAC,eAAe,CAAC,MAAM,EAAE,KAAI,CAAC,MAAM,EAAE,KAAI,CAAC,YAAY,CAAC,CAAC;qBAC9D,CAAC,CAAC;iBACJ;aACF;;;;;;QAEM,+CAAc;;;;;sBAAC,MAAM,EAAE,IAAI;gBAChC,IAAI,CAAC,QAAQ,GAAG,MAAM,CAAC,QAAQ,CAAC,CAAC,cAAc,CAAC;oBAC9C,OAAO,EAAE,IAAI,CAAC,KAAK,CAAC,aAAa;oBACjC,MAAM,EAAE,IAAI;iBACb,CAAC,CAAC;;;;;;;;QAGE,gDAAe;;;;;;sBAAC,MAAM,EAAE,MAAM,EAAE,QAAQ;;gBAC7C,IAAI,CAAC,IAAI;qBACN,GAAG,CAAC,+BAA+B,GAAG,MAAM,CAAC;qBAC7C,SAAS,CAAC,UAAA,QAAQ;oBACjB,IAAI,QAAQ,EAAE;wBACZ,KAAI,CAAC,cAAc,CAAC,MAAM,EAAE,QAAQ,CAAC,OAAO,CAAC,CAAC,QAAQ,CAAC,CAAC,OAAO,CAAC,CAAC;qBAClE;iBACF,CAAC,CAAC;;;oBA5CRC,YAAS,SAAC;wBACT,QAAQ,EAAE,qBAAqB;wBAC/B,iCAA+C;qBAChD;;;;;wBANQC,eAAU;wBACV,oBAAoB;;;;4BAO1BC,YAAS,SAAC,QAAQ;6BAClBC,QAAK;mCACLA,QAAK;;qCAZR;;;;;;;ACAA;;;;oBAKCC,WAAQ,SAAC;wBACR,OAAO,EAAE;4BACPC,qBAAgB;yBACjB;wBACD,YAAY,EAAE,CAAC,sBAAsB,CAAC;wBACtC,SAAS,EAAE,CAAC,oBAAoB,CAAC;wBACjC,OAAO,EAAE;4BACP,sBAAsB;yBACvB;qBACF;;kCAdD;;;;;;;;;;;;;;;;;;;;;;;;;"}