fuse-angular/src/app/main/apps/mail/mail.component.ts

121 lines
3.3 KiB
TypeScript
Raw Normal View History

2017-07-20 15:12:09 +00:00
import { Component, OnDestroy, OnInit } from '@angular/core';
2017-07-18 16:34:12 +00:00
import { MailService } from './mail.service';
2017-07-20 15:12:09 +00:00
import { Subscription } from 'rxjs/Subscription';
import { FormControl } from '@angular/forms';
import { FuseUtils } from '../../../core/fuseUtils';
@Component({
selector : 'fuse-mail',
templateUrl: './mail.component.html',
styleUrls : ['./mail.component.scss']
})
2017-07-20 15:12:09 +00:00
export class MailComponent implements OnInit, OnDestroy
{
2017-07-20 15:12:09 +00:00
hasSelectedMails: boolean;
isIndeterminate: boolean;
folders: any[];
2017-07-26 09:43:45 +00:00
filters: any[];
2017-07-20 15:12:09 +00:00
labels: any[];
mails: any[];
searchInput: FormControl;
2017-07-20 15:12:09 +00:00
onSelectedMailsChanged: Subscription;
2017-07-26 09:43:45 +00:00
onFoldersChanged: Subscription;
onFiltersChanged: Subscription;
onLabelsChanged: Subscription;
onMailsChanged: Subscription;
constructor(private mailService: MailService)
{
this.searchInput = new FormControl('');
}
ngOnInit()
{
// Subscribe to update mails on changes
this.onMailsChanged =
this.mailService.onMailsChanged
.subscribe(mails => {
this.mails = mails;
});
2017-07-20 15:12:09 +00:00
this.onSelectedMailsChanged =
this.mailService.onSelectedMailsChanged
.subscribe(selectedMails => {
setTimeout(() => {
this.hasSelectedMails = selectedMails.length > 0;
this.isIndeterminate = (selectedMails.length !== this.mailService.mails.length && selectedMails.length > 0);
}, 0);
});
2017-07-26 09:43:45 +00:00
this.onFoldersChanged =
this.mailService.onFoldersChanged
.subscribe(folders => {
this.folders = this.mailService.folders;
});
this.onFiltersChanged =
this.mailService.onFiltersChanged
.subscribe(folders => {
this.filters = this.mailService.filters;
});
this.onLabelsChanged =
this.mailService.onLabelsChanged
.subscribe(labels => {
this.labels = this.mailService.labels;
});
this.searchInput.valueChanges
.debounceTime(300)
.distinctUntilChanged()
.subscribe(searchText => {
if ( searchText !== '' )
{
const newArr = FuseUtils.filterArrayByString(this.mails, searchText);
this.mailService.onMailsChanged.next(newArr);
}
else
{
this.mailService.getMails();
}
});
2017-07-20 15:12:09 +00:00
}
ngOnDestroy()
{
this.onSelectedMailsChanged.unsubscribe();
2017-07-26 09:43:45 +00:00
this.onFoldersChanged.unsubscribe();
this.onFiltersChanged.unsubscribe();
this.onLabelsChanged.unsubscribe();
2017-07-20 15:12:09 +00:00
}
toggleSelectAll()
{
this.mailService.toggleSelectAll();
}
selectMails(filterParameter?, filterValue?)
{
this.mailService.selectMails(filterParameter, filterValue);
}
deselectMails()
{
this.mailService.deselectMails();
}
2017-07-17 15:11:34 +00:00
2017-07-20 15:12:09 +00:00
toggleLabelOnSelectedMails(labelId)
{
this.mailService.toggleLabelOnSelectedMails(labelId);
}
setFolderOnSelectedMails(folderId)
{
this.mailService.setFolderOnSelectedMails(folderId);
}
}