UNPKG

ngx-ice-tweet

Version:

tweeter component to show tweets by a hashtag given, it can be order by text, date, or user name

255 lines (246 loc) 23.7 kB
(function (global, factory) { typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports, require('@angular/core'), require('@angular/common/http'), require('rxjs'), require('rxjs/operators'), require('@angular/platform-browser'), require('@angular/platform-browser/animations'), require('@angular/forms'), require('@angular/material')) : typeof define === 'function' && define.amd ? define('ngx-ice-tweet', ['exports', '@angular/core', '@angular/common/http', 'rxjs', 'rxjs/operators', '@angular/platform-browser', '@angular/platform-browser/animations', '@angular/forms', '@angular/material'], factory) : (factory((global['ngx-ice-tweet'] = {}),global.ng.core,global.ng.common.http,global.rxjs,global.rxjs.operators,global.ng.platformBrowser,global.ng.platformBrowser.animations,global.ng.forms,global.ng.material)); }(this, (function (exports,i0,http,rxjs,operators,platformBrowser,animations,forms,material) { 'use strict'; /** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ var TweetService = /** @class */ (function () { function TweetService() { } TweetService.decorators = [ { type: i0.Injectable, args: [{ providedIn: 'root' },] } ]; /** @nocollapse */ TweetService.ctorParameters = function () { return []; }; /** @nocollapse */ TweetService.ngInjectableDef = i0.defineInjectable({ factory: function TweetService_Factory() { return new TweetService(); }, token: TweetService, providedIn: "root" }); return TweetService; }()); /** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ /** @type {?} */ var TweetConfig = { tokenUrl: 'https://api.twitter.com/oauth2/token', tweetSearchUrl: 'https://api.twitter.com/1.1/search/tweets.json' }; var TweetComponent = /** @class */ (function () { function TweetComponent(http$$1) { this.http = http$$1; this.errorMesage = new i0.EventEmitter(); this.filterBy = 'created_at'; this.filterOptions = ['created_at', 'text', 'user.name']; this._unsubscribeAll = new rxjs.Subject(); } /** * @return {?} */ TweetComponent.prototype.ngOnInit = /** * @return {?} */ function () { if (this.evalData()) { this.getToken(); } else { this.sendErrorMesage('No Public, Privite Key'); this.ngOnDestroy(); } }; /** * @return {?} */ TweetComponent.prototype.setFilterBy = /** * @return {?} */ function () { var _this = this; return this.tweets.sort(function (a, b) { return a[_this.filterBy] > b[_this.filterBy] ? 1 : a[_this.filterBy] === b[_this.filterBy] ? 0 : -1; }); }; /** * @private * @return {?} */ TweetComponent.prototype.evalData = /** * @private * @return {?} */ function () { return (this.keyPublic && this.keyPrivate && this.keyPublic !== null && this.keyPrivate !== null && this.keyPublic !== '' && this.keyPrivate !== ''); }; /** * @private * @return {?} */ TweetComponent.prototype.evaHash = /** * @private * @return {?} */ function () { return (this.hashTag && this.hashTag !== null && this.hashTag !== ''); }; /** * @private * @param {?} token * @return {?} */ TweetComponent.prototype.evalToken = /** * @private * @param {?} token * @return {?} */ function (token) { return (token.token_type && token.access_token && token.token_type !== null && token.access_token !== null && token.token_type !== '' && token.access_token !== ''); }; /** * @private * @return {?} */ TweetComponent.prototype.getToken = /** * @private * @return {?} */ function () { var _this = this; if (this.evaHash()) { /** @type {?} */ var basic = btoa(this.keyPublic + ":" + this.keyPrivate); /** @type {?} */ var headers = new http.HttpHeaders({ 'Content-Type': 'application/x-www-form-urlencoded', 'Authorization': "Basic " + basic }); /** @type {?} */ var payload = new FormData(); payload.append('grant_type', 'client_credentials'); this.http.post(TweetConfig.tokenUrl, payload, { headers: headers }) .pipe(operators.takeUntil(this._unsubscribeAll)) .subscribe(function (token) { return _this.getTweetList(token); }, function (error) { return _this.sendErrorMesage(error); }); } else { this.sendErrorMesage('No HasgTag set For Searching'); } }; /** * @private * @param {?} token * @return {?} */ TweetComponent.prototype.getTweetList = /** * @private * @param {?} token * @return {?} */ function (token) { var _this = this; if (this.evalToken(token)) { /** @type {?} */ var headers = new http.HttpHeaders({ 'Authorization': token.token_type + " " + token.access_token }); /** @type {?} */ var params = new http.HttpParams().set('q', "%23" + this.hashTag); this.http.get(TweetConfig.tweetSearchUrl, { headers: headers, params: params }) .pipe(operators.takeUntil(this._unsubscribeAll)) .subscribe(function (_a) { var statuses = _a.statuses; return _this.tweets = ( /** @type {?} */(statuses)); }, function (error) { return _this.sendErrorMesage(error); }); } else { this.sendErrorMesage('Error Tweeter Token'); } }; /** * @private * @param {?} men * @return {?} */ TweetComponent.prototype.sendErrorMesage = /** * @private * @param {?} men * @return {?} */ function (men) { this.errorMesage.emit(men); }; /** * @return {?} */ TweetComponent.prototype.ngOnDestroy = /** * @return {?} */ function () { this._unsubscribeAll.next(); this._unsubscribeAll.complete(); }; TweetComponent.decorators = [ { type: i0.Component, args: [{ selector: 'tweet', template: "<div class=\"container\" *ngIf=\"tweets && tweets.length > 0\">\n <div>\n <h4>filter by:</h4>\n <mat-form-field>\n <mat-select [(value)]=\"filterBy\">\n <mat-option *ngFor=\"let opt of filterOptions\" value=\"opt\">{{opt}}</mat-option>\n </mat-select>\n </mat-form-field>\n </div>\n <mat-card\n *ngFor=\"let tt of setFilterBy()\"\n >\n <mat-card-header>\n <mat-card-title>{{tt.user.screen_name}}</mat-card-title>\n <mat-card-subtitle>@{{tt.user.name}}</mat-card-subtitle>\n </mat-card-header>\n <img matCardImage [src]=\"tt.user.profile_image_url\">\n <mat-card-content>\n {{tt.text}}\n </mat-card-content>\n <mat-card-actions align=\"start\">\n <!--<button mat-button (click)=\"onAction1\">Action1</button>-->\n </mat-card-actions>\n <mat-card-footer>\n\n </mat-card-footer>\n </mat-card>\n </div>", encapsulation: i0.ViewEncapsulation.Native, styles: ["\n .container {\n width: 100%;\n margin: 2rem;\n display: flex;\n flex-direction: column;\n }\n mat-card {\n margin-bottom: 2rem;\n flex: 1 1 100%;\n }"] }] } ]; /** @nocollapse */ TweetComponent.ctorParameters = function () { return [ { type: http.HttpClient } ]; }; TweetComponent.propDecorators = { keyPublic: [{ type: i0.Input }], keyPrivate: [{ type: i0.Input }], hashTag: [{ type: i0.Input }], errorMesage: [{ type: i0.Output }] }; return TweetComponent; }()); /** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ var TweetModule = /** @class */ (function () { function TweetModule() { } TweetModule.decorators = [ { type: i0.NgModule, args: [{ declarations: [TweetComponent], imports: [ platformBrowser.BrowserModule, http.HttpClientModule, animations.BrowserAnimationsModule, material.MatCardModule, material.MatSelectModule, forms.FormsModule ], exports: [TweetComponent] },] } ]; return TweetModule; }()); /** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ /** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ exports.TweetService = TweetService; exports.TweetComponent = TweetComponent; exports.TweetModule = TweetModule; Object.defineProperty(exports, '__esModule', { value: true }); }))); //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"ngx-ice-tweet.umd.js.map","sources":["ng://ngx-ice-tweet/lib/tweet.service.ts","ng://ngx-ice-tweet/lib/tweet.component.ts","ng://ngx-ice-tweet/lib/tweet.module.ts"],"sourcesContent":["import { Injectable } from '@angular/core';\n\n@Injectable({\n  providedIn: 'root'\n})\nexport class TweetService {\n\n  constructor() { }\n}\n","import {Component, EventEmitter, Input, OnDestroy, OnInit, Output, ViewEncapsulation} from '@angular/core';\nimport {HttpClient, HttpHeaders, HttpParams} from '@angular/common/http';\nimport {Subject} from 'rxjs';\nimport {takeUntil} from 'rxjs/operators';\n\nconst TweetConfig = {\n  tokenUrl: 'https://api.twitter.com/oauth2/token',\n  tweetSearchUrl: 'https://api.twitter.com/1.1/search/tweets.json'\n};\n\ninterface Token {\n  token_type: string;\n  access_token: string;\n}\n\ninterface Tweets {\n  created_at: Date;\n  id: number;\n  id_str: string;\n  text: string;\n  user: any;\n  entities: any;\n}\n\n@Component({\n  selector: 'tweet',\n  template: `<div class=\"container\" *ngIf=\"tweets && tweets.length > 0\">\n    <div>\n      <h4>filter by:</h4>\n      <mat-form-field>\n        <mat-select [(value)]=\"filterBy\">\n          <mat-option *ngFor=\"let opt of filterOptions\" value=\"opt\">{{opt}}</mat-option>\n        </mat-select>\n      </mat-form-field>\n    </div>\n  <mat-card\n    *ngFor=\"let tt of setFilterBy()\"\n  >\n    <mat-card-header>\n      <mat-card-title>{{tt.user.screen_name}}</mat-card-title>\n      <mat-card-subtitle>@{{tt.user.name}}</mat-card-subtitle>\n    </mat-card-header>\n    <img matCardImage [src]=\"tt.user.profile_image_url\">\n    <mat-card-content>\n      {{tt.text}}\n    </mat-card-content>\n    <mat-card-actions align=\"start\">\n      <!--<button mat-button (click)=\"onAction1\">Action1</button>-->\n    </mat-card-actions>\n    <mat-card-footer>\n\n    </mat-card-footer>\n  </mat-card>\n  </div>`,\n  styles: [`\n    .container {\n      width: 100%;\n      margin: 2rem;\n      display: flex;\n      flex-direction: column;\n    }\n  mat-card {\n    margin-bottom: 2rem;\n    flex: 1 1 100%;\n  }`],\n  encapsulation: ViewEncapsulation.Native\n})\nexport class TweetComponent implements OnInit, OnDestroy {\n  @Input() keyPublic: string;\n  @Input() keyPrivate: string;\n  @Input() hashTag: string;\n  @Output() errorMesage = new EventEmitter<string>();\n  private _unsubscribeAll: Subject<any>;\n  tweets: Tweets[];\n  filterBy = 'created_at';\n  filterOptions = ['created_at', 'text', 'user.name'];\n\n  constructor(private http: HttpClient) {\n    this._unsubscribeAll = new Subject();\n  }\n  ngOnInit(): void {\n    if (this.evalData()) {\n      this.getToken();\n    } else {\n      this.sendErrorMesage('No Public, Privite Key');\n      this.ngOnDestroy();\n    }\n  }\n  setFilterBy() {\n    return this.tweets.sort((a, b) => a[this.filterBy] > b[this.filterBy] ? 1 : a[this.filterBy] === b[this.filterBy] ? 0 : -1);\n  }\n  private evalData(): boolean {\n    return (\n      this.keyPublic && this.keyPrivate\n      && this.keyPublic !== null && this.keyPrivate !== null\n      && this.keyPublic !== '' && this.keyPrivate !== ''\n    );\n  }\n  private evaHash(): boolean {\n    return (\n      this.hashTag\n      && this.hashTag !== null\n      && this.hashTag !== ''\n    );\n  }\n  private evalToken (token: Token) {\n    return (\n      token.token_type && token.access_token\n      && token.token_type !== null && token.access_token !== null\n      && token.token_type !== '' && token.access_token !== ''\n    );\n  }\n  private getToken(): void {\n    if (this.evaHash()) {\n      const basic = btoa(`${this.keyPublic}:${this.keyPrivate}`);\n      const headers = new HttpHeaders({\n        'Content-Type'  : 'application/x-www-form-urlencoded',\n        'Authorization'   : `Basic  ${basic}`\n      });\n      const payload = new FormData();\n      payload.append('grant_type', 'client_credentials');\n      this.http.post<Token>(TweetConfig.tokenUrl, payload, { headers: headers})\n        .pipe(takeUntil(this._unsubscribeAll))\n        .subscribe(\n          token => this.getTweetList(token),\n          error => this.sendErrorMesage(error)\n        );\n    } else {\n      this.sendErrorMesage('No HasgTag set For Searching');\n    }\n  }\n  private getTweetList(token: Token) {\n    if (this.evalToken(token)) {\n      const headers = new HttpHeaders({\n        'Authorization'   : `${token.token_type} ${token.access_token}`\n      });\n      const params = new HttpParams().set('q', `%23${this.hashTag}`);\n      this.http.get<any>(TweetConfig.tweetSearchUrl, {headers: headers, params: params})\n        .pipe(takeUntil(this._unsubscribeAll))\n        .subscribe(\n          ({statuses}) => this.tweets = <Tweets[]>statuses,\n          error => this.sendErrorMesage(error)\n        );\n    } else {\n      this.sendErrorMesage('Error Tweeter Token');\n    }\n  }\n  private sendErrorMesage(men: string): void {\n    this.errorMesage.emit(men);\n  }\n  ngOnDestroy(): void {\n    this._unsubscribeAll.next();\n    this._unsubscribeAll.complete();\n  }\n}\n","import { NgModule } from '@angular/core';\nimport { TweetComponent } from './tweet.component';\nimport {BrowserModule} from '@angular/platform-browser';\nimport {HttpClientModule} from '@angular/common/http';\nimport {BrowserAnimationsModule} from '@angular/platform-browser/animations';\nimport {FormsModule} from '@angular/forms';\nimport {MatCardModule, MatSelectModule} from '@angular/material';\n\n@NgModule({\n  declarations: [TweetComponent],\n  imports: [\n    BrowserModule,\n    HttpClientModule,\n    BrowserAnimationsModule,\n    MatCardModule,\n    MatSelectModule,\n    FormsModule\n  ],\n  exports: [TweetComponent]\n})\nexport class TweetModule { }\n"],"names":["Injectable","http","EventEmitter","Subject","HttpHeaders","takeUntil","HttpParams","Component","ViewEncapsulation","HttpClient","Input","Output","NgModule","BrowserModule","HttpClientModule","BrowserAnimationsModule","MatCardModule","MatSelectModule","FormsModule"],"mappings":"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"}