home.ts 2.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110
  1. import { Component } from "@angular/core";
  2. import {
  3. IonicPage,
  4. NavController,
  5. MenuController,
  6. InfiniteScroll,
  7. Refresher,
  8. LoadingController
  9. } from "ionic-angular";
  10. import { Storage } from "@ionic/storage";
  11. import { WriteTweetPage } from "../write-tweet/write-tweet";
  12. import { MockProvider } from "../../providers/mock-provider/mock-provider";
  13. @IonicPage()
  14. @Component({
  15. selector: "page-home",
  16. templateUrl: "home.html"
  17. })
  18. export class HomePage {
  19. menuController: MenuController;
  20. tweets;
  21. mock;
  22. constructor(
  23. public navCtrl: NavController,
  24. private menuCtrl: MenuController,
  25. private mockProv: MockProvider,
  26. private storage: Storage,
  27. private loadingCtrl: LoadingController
  28. ) {
  29. }
  30. ionViewDidLoad() {
  31. this.menuCtrl.enable(true, "sideNav");
  32. }
  33. async ionViewDidEnter() {
  34. const loading = this.loadingCtrl.create();
  35. loading.present();
  36. await this.loadTimeline();
  37. loading.dismiss();
  38. }
  39. async loadTimeline(){
  40. this.mockProv
  41. .loadHomeTimeline()
  42. .then(tweets => {
  43. this.tweets=[];
  44. Object.assign(this.tweets, tweets);
  45. console.log("HOME tweets are: ", tweets);
  46. // this.tweets = tweets;
  47. })
  48. .catch(err => console.error('error in timeline', err));
  49. }
  50. doRefresh(refresher: Refresher) {
  51. console.log('mock refresher called',refresher);
  52. this.mockProv.loadHomeTimeline().then(tweets => {
  53. this.tweets = tweets;
  54. refresher.complete();
  55. });
  56. }
  57. loadMore(infiniteScroll: InfiniteScroll) {
  58. // this.mockProv
  59. // .loadHomeTimeline(this.oldestPublicTweet, this.oldestPrivateTweet)
  60. // .then(tweets => {
  61. // this.tweets = this.tweets.concat(tweets);
  62. // infiniteScroll.complete();
  63. // });
  64. infiniteScroll.complete();
  65. }
  66. writeTweet() {
  67. console.log('Writing the tweet');
  68. this.navCtrl.push(WriteTweetPage);
  69. }
  70. get publicTweets() {
  71. return this.tweets.filter(tweet => !tweet.private_tweet);
  72. }
  73. get privateTweets() {
  74. return this.tweets.filter(tweet => tweet.private_tweet);
  75. // return null;
  76. }
  77. get oldestPublicTweet() {
  78. // return null;
  79. if (this.publicTweets.length > 0) {
  80. return this.publicTweets.reduce((acc, cur) =>
  81. acc.id < cur.id ? acc : cur
  82. );
  83. } else {
  84. return undefined;
  85. }
  86. }
  87. get oldestPrivateTweet() {
  88. if (this.privateTweets.length > 0) {
  89. return this.privateTweets.reduce((acc, cur) =>
  90. new Date(acc.created_at) < new Date(cur.created_at) ? acc : cur
  91. );
  92. } else {
  93. return undefined;
  94. }
  95. }
  96. }