Skip to content

Commit

Permalink
Step 6.20: Add group by date to the UI
Browse files Browse the repository at this point in the history
  • Loading branch information
dotansimha authored and darkbasic committed Oct 16, 2017
1 parent 813adcd commit b6f5e51
Showing 1 changed file with 45 additions and 16 deletions.
61 changes: 45 additions & 16 deletions src/pages/messages/messages.ts
Original file line number Diff line number Diff line change
@@ -1,9 +1,10 @@
import { Component, OnInit, OnDestroy, ElementRef } from '@angular/core';
import { NavParams } from 'ionic-angular';
import { Chat, Message, MessageType } from 'api/models';
import { Observable } from 'rxjs';
import { Messages } from 'api/collections';
import { MeteorObservable } from 'meteor-rxjs';
import * as moment from 'moment';
import * as _ from 'lodash';

@Component({
selector: 'messages-page',
Expand All @@ -13,7 +14,7 @@ export class MessagesPage implements OnInit, OnDestroy {
selectedChat: Chat;
title: string;
picture: string;
messages: Observable<Message[]>;
messagesDayGroups;
message: string = '';
autoScroller: MutationObserver;
scrollOffset = 0;
Expand Down Expand Up @@ -41,26 +42,54 @@ export class MessagesPage implements OnInit, OnDestroy {

ngOnInit() {
this.autoScroller = this.autoScroll();

let isEven = false;

this.messages = Messages.find(
{chatId: this.selectedChat._id},
{sort: {createdAt: 1}}
).map((messages: Message[]) => {
messages.forEach((message: Message) => {
message.ownership = isEven ? 'mine' : 'other';
isEven = !isEven;
});

return messages;
});
this.subscribeMessages();
}

ngOnDestroy() {
this.autoScroller.disconnect();
}

subscribeMessages() {
this.scrollOffset = this.scroller.scrollHeight;
this.messagesDayGroups = this.findMessagesDayGroups();
}

findMessagesDayGroups() {
let isEven = false;

return Messages.find({
chatId: this.selectedChat._id
}, {
sort: { createdAt: 1 }
})
.map((messages: Message[]) => {
const format = 'D MMMM Y';

// Compose missing data that we would like to show in the view
messages.forEach((message) => {
message.ownership = isEven ? 'mine' : 'other';
isEven = !isEven;

return message;
});

// Group by creation day
const groupedMessages = _.groupBy(messages, (message) => {
return moment(message.createdAt).format(format);
});

// Transform dictionary into an array since Angular's view engine doesn't know how
// to iterate through it
return Object.keys(groupedMessages).map((timestamp: string) => {
return {
timestamp: timestamp,
messages: groupedMessages[timestamp],
today: moment().format(format) === timestamp
};
});
});
}

autoScroll(): MutationObserver {
const autoScroller = new MutationObserver(this.scrollDown.bind(this));

Expand Down

0 comments on commit b6f5e51

Please sign in to comment.