UNPKG

@stratio/egeo

Version:
191 lines 15.6 kB
/** * @fileoverview added by tsickle * Generated from: lib/st-docs/st-docs.component.ts * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ /* * © 2017 Stratio Big Data Inc., Sucursal en España. * * This software is licensed under the Apache License, Version 2.0. * This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; * without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. * See the terms of the License for more details. * * SPDX-License-Identifier: Apache-2.0. */ import { ChangeDetectorRef, Component, Input } from '@angular/core'; import { StDocsService } from './st-docs.service'; import { zip } from 'rxjs/operators'; var StDocsComponent = /** @class */ (function () { function StDocsComponent(cd, docsService) { this.cd = cd; this.docsService = docsService; this.options = [ { id: 'demo', text: 'Overview' }, { id: 'html', text: 'Html' }, { id: 'implementation', text: 'Implementation' }, { id: 'component', text: 'Component' } ]; this.active = this.options[0]; } /** * @return {?} */ StDocsComponent.prototype.ngOnInit = /** * @return {?} */ function () { var _this = this; this.subscription = this.getFile(this.htmlFile).pipe(zip(this.getFile(this.tsFile), this.getFile(this.componentFile), (/** * @param {?} htmlCode * @param {?} tsCode * @param {?} componentCode * @return {?} */ function (htmlCode, tsCode, componentCode) { return ({ htmlCode: htmlCode, tsCode: tsCode, componentCode: componentCode }); }))).subscribe((/** * @param {?} data * @return {?} */ function (data) { _this.htmlCode = (data && ((/** @type {?} */ (data))).htmlCode) ? ((/** @type {?} */ (data))).htmlCode : null; _this.demoTsCode = (data && ((/** @type {?} */ (data))).tsCode) ? ((/** @type {?} */ (data))).tsCode : null; _this.componentTsCode = (data && ((/** @type {?} */ (data))).componentCode) ? ((/** @type {?} */ (data))).componentCode : null; _this.disableTabOption(_this.htmlCode === null, _this.demoTsCode === null, _this.componentTsCode === null); _this.cd.markForCheck(); })); }; /** * @return {?} */ StDocsComponent.prototype.ngOnDestroy = /** * @return {?} */ function () { this.subscription.unsubscribe(); }; /** * @param {?} event * @return {?} */ StDocsComponent.prototype.onChangeOption = /** * @param {?} event * @return {?} */ function (event) { this.active = (/** @type {?} */ (event)); }; /** * @private * @param {?=} file * @return {?} */ StDocsComponent.prototype.getFile = /** * @private * @param {?=} file * @return {?} */ function (file) { return this.docsService.getFile(file); }; /** * @private * @param {?} html * @param {?} demoCode * @param {?} componentCode * @return {?} */ StDocsComponent.prototype.disableTabOption = /** * @private * @param {?} html * @param {?} demoCode * @param {?} componentCode * @return {?} */ function (html, demoCode, componentCode) { if (html) { this.options = this.filterOption(this.options, 'html'); } if (demoCode) { this.options = this.filterOption(this.options, 'implementation'); } if (componentCode) { this.options = this.filterOption(this.options, 'component'); } }; /** * @private * @param {?} options * @param {?} name * @return {?} */ StDocsComponent.prototype.filterOption = /** * @private * @param {?} options * @param {?} name * @return {?} */ function (options, name) { return options.filter((/** * @param {?} element * @return {?} */ function (element) { return element.id !== name; })); }; StDocsComponent.decorators = [ { type: Component, args: [{ selector: 'st-docs', template: "<!--\n\n \u00A9 2017 Stratio Big Data Inc., Sucursal en Espa\u00F1a.\n\n This software is licensed under the Apache License, Version 2.0.\n This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;\n without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.\n See the terms of the License for more details.\n\n SPDX-License-Identifier: Apache-2.0.\n\n-->\n<div>\n <st-horizontal-tabs [options]=\"options\" [(activeOption)]=\"active\" qaTag=\"horizontal-tabs-demo\" (changedOption)=\"onChangeOption($event)\">\n </st-horizontal-tabs>\n <div class=\"st-docs\">\n <div *ngIf=\"active.id === 'demo'\">\n <ng-content></ng-content>\n </div>\n <div *ngIf=\"active.id === 'html'\">\n <st-prism-highlight [language]=\"'html'\" id=\"codeinput\">{{htmlCode}}</st-prism-highlight>\n </div>\n <div *ngIf=\"active.id === 'implementation'\">\n <st-prism-highlight [language]=\"'javascript'\" id=\"codeinput\">{{demoTsCode}}</st-prism-highlight>\n </div>\n\n <div *ngIf=\"active.id === 'component'\">\n <st-prism-highlight [language]=\"'javascript'\" id=\"codeinput\">{{componentTsCode}}</st-prism-highlight>\n </div>\n </div>\n</div>\n", styles: ["@charset \"UTF-8\";.st-docs{width:100%;margin-top:22px}.st-docs__header{display:flex;flex-direction:row;background-color:rgba(0,0,0,.03);min-height:50px;align-items:center}.st-docs__header__icon-code{display:flex;flex-direction:row;margin-left:auto;align-items:center;margin-right:15px}.st-docs__header__copy-code{display:flex;flex-direction:row;align-items:center;margin-right:15px}.st-docs__content__component{min-height:100px;display:flex;justify-content:center;align-items:center}"] }] } ]; /** @nocollapse */ StDocsComponent.ctorParameters = function () { return [ { type: ChangeDetectorRef }, { type: StDocsService } ]; }; StDocsComponent.propDecorators = { htmlFile: [{ type: Input }], tsFile: [{ type: Input }], componentFile: [{ type: Input }] }; return StDocsComponent; }()); export { StDocsComponent }; if (false) { /** @type {?} */ StDocsComponent.prototype.htmlFile; /** @type {?} */ StDocsComponent.prototype.tsFile; /** @type {?} */ StDocsComponent.prototype.componentFile; /** @type {?} */ StDocsComponent.prototype.htmlCode; /** @type {?} */ StDocsComponent.prototype.demoTsCode; /** @type {?} */ StDocsComponent.prototype.componentTsCode; /** @type {?} */ StDocsComponent.prototype.options; /** @type {?} */ StDocsComponent.prototype.active; /** * @type {?} * @private */ StDocsComponent.prototype.subscription; /** * @type {?} * @private */ StDocsComponent.prototype.cd; /** * @type {?} * @private */ StDocsComponent.prototype.docsService; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"st-docs.component.js","sourceRoot":"ng://@stratio/egeo/","sources":["lib/st-docs/st-docs.component.ts"],"names":[],"mappings":"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","sourcesContent":["/*\n * © 2017 Stratio Big Data Inc., Sucursal en España.\n *\n * This software is licensed under the Apache License, Version 2.0.\n * This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;\n * without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.\n * See the terms of the License for more details.\n *\n * SPDX-License-Identifier: Apache-2.0.\n */\n\nimport { ChangeDetectorRef, Component, Input, OnInit, OnDestroy } from '@angular/core';\nimport { StDocsService } from './st-docs.service';\nimport { StHorizontalTab } from '../st-horizontal-tabs/st-horizontal-tabs.model';\nimport { zip } from 'rxjs/operators';\nimport { Observable, Subscription } from 'rxjs';\n\n@Component({\n   selector: 'st-docs',\n   templateUrl: './st-docs.component.html',\n   styleUrls: ['./st-docs.component.scss']\n})\nexport class StDocsComponent implements OnInit, OnDestroy {\n\n   @Input() htmlFile?: string;\n   @Input() tsFile?: string;\n   @Input() componentFile?: string;\n\n   public htmlCode: string;\n   public demoTsCode: string;\n   public componentTsCode: string;\n\n   public options: StHorizontalTab[] = [\n      {id: 'demo', text: 'Overview'},\n      {id: 'html', text: 'Html'},\n      {id: 'implementation', text: 'Implementation'},\n      {id: 'component', text: 'Component'}\n   ];\n\n   public active: StHorizontalTab = this.options[0];\n\n   private subscription: Subscription;\n\n   constructor(private cd: ChangeDetectorRef, private docsService: StDocsService) {}\n\n   ngOnInit(): void {\n      this.subscription = this.getFile(this.htmlFile).pipe(zip(this.getFile(this.tsFile), this.getFile(this.componentFile), (htmlCode, tsCode, componentCode) =>\n      ({ htmlCode, tsCode, componentCode }))\n      ).subscribe((data) => {\n         this.htmlCode = (data && (<any>data).htmlCode) ? (<any>data).htmlCode : null ;\n         this.demoTsCode = (data && (<any>data).tsCode) ? (<any>data).tsCode : null ;\n         this.componentTsCode = (data && (<any>data).componentCode) ? (<any>data).componentCode : null ;\n         this.disableTabOption(this.htmlCode === null, this.demoTsCode === null, this.componentTsCode === null);\n         this.cd.markForCheck();\n      });\n   }\n\n   ngOnDestroy(): void {\n      this.subscription.unsubscribe();\n   }\n\n   onChangeOption(event: Event): void {\n      this.active = <any> event;\n   }\n\n   private getFile(file?: string): Observable<any> {\n      return this.docsService.getFile(file);\n   }\n\n   private disableTabOption(html: boolean, demoCode: boolean, componentCode: boolean): void {\n      if (html) {\n         this.options = this.filterOption(this.options, 'html');\n      }\n\n      if (demoCode) {\n         this.options = this.filterOption(this.options, 'implementation');\n      }\n\n      if (componentCode) {\n\n         this.options = this.filterOption(this.options, 'component');\n      }\n   }\n\n   private filterOption(options: StHorizontalTab[], name: string): StHorizontalTab[] {\n      return options.filter((element: any) => {\n         return element.id !== name;\n      });\n   }\n\n}\n"]}