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
JavaScript
(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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"}