home.ts 2.9 KB

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