/ / Angular @Output emit działa tylko za pierwszym razem - angular, eventemitter, angular-components

Angular @Output emituje działa tylko po raz pierwszy - kątowe, eventemitter, elementy kątowe

Cóż ... mam to na elemencie potomnym:

this.event.emit(true);
this.calendarProviderService.addEvent(newEvent).subscribe(
finished => {
if (finished == true) {
console.log (finished);
this.event.emit(false);
}
}
)

Sprawdź, czy emisja „True” działa dobrze. W moim komponencie nadrzędnym mam:

  <add-event *ngIf="currentActionArea == "addevent"" (event)="addNewEvent($event)"></add-event>

addNewEvent(event){
console.log("Emit recibido: " + event);
if(event == true){
this.loaderMessage = "Guardando Evento...";
this.loadingEvents = true;
} else {
this.switchButtonModel = "0";
this.currentActionArea = null;
this.getEvents();
}
}

Ale kiedy subskrypcja jest zakończona, wówczas „fałszywa” emisja nie działa.

Możesz mi pomóc?

Odpowiedzi:

1 dla odpowiedzi № 1

Problem polegał na tym, że korzystam z usługi, aby ustawić wartość emitera. To nie jest najlepsza praktyka. Rozwiązałem to za pomocą tematu:

import { Subject } from "rxjs/Subject";

@Injectable()
export class CalendarProviderService {

/**
* To emit getActivityWork between two components
*/
private _activityWorkSubject = new Subject<calendarActivityWork>();
public getActivityWork = this._activityWorkSubject.asObservable();

constructor() { }

/**
* To set the activity work value
* @param calendarActivity the activity to show
*/
doActivityWork(calendarActivity : calendarActivityWork){
return this._activityWorkSubject.next(calendarActivity);
}
.
.
.

Mam nadzieję, że to może pomóc każdemu.