Объединение сплющенных данных

Я хотел бы объединить данные по init из моей таблицы клиентов в список проектов.

Модель такая:

проектов

ключимя: строкаcustomer: customerKey

клиенты

ключимя: строка

У вас есть пример, как я могу сделать это из компонента angular2, используя angularfire2?

мой контроллер выглядит так:

import { Component, OnInit } from '@angular/core';
import { Project } from '../project';
import { Router } from '@angular/router';
import { FirebaseAuth } from 'angularfire2';
import { AngularFire, FirebaseListObservable, FirebaseObjectObservable } from 'angularfire2';
import { Observable } from 'rxjs';

@Component({
  moduleId: module.id,
  selector: 'app-projects',
  templateUrl: 'projects.component.html',
  styleUrls: ['projects.component.css']
})
export class ProjectsComponent implements OnInit {

  projects: FirebaseListObservable<any[]>;
  customers: FirebaseListObservable<any[]>;
  projectName: string;
  constructor(
    private router: Router,
    private af: AngularFire
  ) { };

  ngOnInit() {
    this.projects = this.af.database.list('projects');
  }

  add(projectName: string) {
    this.af.database.list('projects')
      .push({ name: projectName, id: '123' });
    this.projectName = null;
  }
}

Обновить

Я изменил тип this.projects на Observable из FirebaseListObservable. Метод my on ngOnInit () теперь выглядит следующим образом:

ngOnInit() {
this.projects = this.af.database.list(`projects`)
  .map(projects => {
    projects.map(project => {
      this.af.database.object('customer/' + project.customer + '/name')
        .subscribe(customer => {
          project.customer = customer;
        })
      return project;
    })
    return projects;
  });
}

теперь я могу получить доступ не к свойству name клиента из шаблона внутри

<li *ngFor="let project of projects | async">

project.customer.$value

Ответы на вопрос(1)

Ваш ответ на вопрос