Modifier was not working as when the data came late, it would display blank.

This commit is contained in:
Amritanshu Agrawal 2024-12-17 22:26:35 +05:30
parent 50846ace3f
commit b46fd10f5a
2 changed files with 15 additions and 6 deletions

View File

@ -1,6 +1,6 @@
<mat-dialog-content> <mat-dialog-content>
<mat-tab-group> <mat-tab-group>
@for (item of list; track item) { @for (item of list | async; track item.id) {
<mat-tab> <mat-tab>
<ng-template matTabLabel> <ng-template matTabLabel>
<span>{{ item.name }}</span> <span>{{ item.name }}</span>

View File

@ -1,4 +1,5 @@
import { CdkScrollable } from '@angular/cdk/scrolling'; import { CdkScrollable } from '@angular/cdk/scrolling';
import { AsyncPipe } from '@angular/common';
import { Component, Inject } from '@angular/core'; import { Component, Inject } from '@angular/core';
import { MatBadge } from '@angular/material/badge'; import { MatBadge } from '@angular/material/badge';
import { MatButton } from '@angular/material/button'; import { MatButton } from '@angular/material/button';
@ -16,10 +17,20 @@ import { ModifierCategory } from '../../core/modifier-category';
selector: 'app-modifiers', selector: 'app-modifiers',
templateUrl: './modifiers.component.html', templateUrl: './modifiers.component.html',
styleUrls: ['./modifiers.component.css'], styleUrls: ['./modifiers.component.css'],
imports: [CdkScrollable, MatDialogModule, MatTabsModule, MatChipsModule, MatBadge, MatCard, MatRipple, MatButton], imports: [
CdkScrollable,
MatDialogModule,
MatTabsModule,
MatChipsModule,
MatBadge,
MatCard,
MatRipple,
MatButton,
AsyncPipe,
],
}) })
export class ModifiersComponent { export class ModifiersComponent {
list: ModifierCategory[] = []; list: Observable<ModifierCategory[]>;
selected: Modifier[]; selected: Modifier[];
selectedIds: (string | undefined)[]; selectedIds: (string | undefined)[];
@ -27,9 +38,7 @@ export class ModifiersComponent {
@Inject(MAT_DIALOG_DATA) @Inject(MAT_DIALOG_DATA)
public data: { list: Observable<ModifierCategory[]>; selected: Modifier[] }, public data: { list: Observable<ModifierCategory[]>; selected: Modifier[] },
) { ) {
this.data.list.subscribe((list: ModifierCategory[]) => { this.list = data.list;
this.list = list;
});
this.selected = data.selected; this.selected = data.selected;
this.selectedIds = this.selected.map((e) => e.id); this.selectedIds = this.selected.map((e) => e.id);
} }