Implementazione di chat in angolare

0

Domanda

Attualmente ho un genitore componente chiamato chat e due figli componente denominato barra laterale(che consistono in elenco utenti) e la conversazione dettaglio(consistente in chat con ogni utente).. la funzionalità voglio è che se clicco su un qualsiasi utente presente nella barra laterale voglio la chat per aprire di quell'utente sul lato destro, proprio come in WhatsApp web.. di seguito è riportato un codice di strutturazione dei miei componenti

Chat componente(componente principale)

<div class="container-fluid">
<div class="row">
    <div class="col-5">
        <app-sidebar></app-sidebar>
    </div>

    <div class="col-7">
        <app-conversation-detail></app-conversation-detail>
    </div>
</div>
angular chat typescript whatsapp
2021-11-24 06:31:06
1

Migliore risposta

0

È possibile gestire lo stato del genitore componente stesso e passare solo i dati per il sidebar e conversation-detail via @Input().

Per cominciare, si potrebbe fare qualcosa di simile a questo.

@Component({
  selector: 'my-app',
  template: `
  <div class="row">
    <div class="col-5">
        <app-sidebar [convoList]="convoList" (userSelected)="selectUser($event)"></app-sidebar>
    </div>
    <div class="col-7">
        <app-conversation-detail [conversation]="conversation">
        </app-conversation-detail>
    </div>
</div>`,
  styleUrls: ['./app.component.css'],
})
export class AppComponent {
  selectedUser = null;
  conversation = null;
  convoList = [];

  constructor(private conversationService: ConversationService) {}

  selectUser(user: string) {
    this.selectedUser = user;
    this.conversation = this.getConversationsOfUser(user);
  }

  getConversationsOfUser(user: string) {
    return this.conversationService.getConversationOfUser(user);
  }
}

È inoltre possibile utilizzare un più approccio reattivo utilizzando Osservabili.

2021-11-24 07:44:56

In altre lingue

Questa pagina è in altre lingue

Русский
..................................................................................................................
Polski
..................................................................................................................
Română
..................................................................................................................
한국어
..................................................................................................................
हिन्दी
..................................................................................................................
Français
..................................................................................................................
Türk
..................................................................................................................
Česk
..................................................................................................................
Português
..................................................................................................................
ไทย
..................................................................................................................
中文
..................................................................................................................
Español
..................................................................................................................
Slovenský
..................................................................................................................