Прямо сейчас это моя реализация для раскрывающегося списка:
cust.component. html -
<p-dropdown #dd1 [options]="custList" [ngModel]="selectedCust" placeholder="Select Account Id"
[style]="{'width':'200px'}" name="selectDropDown" optionLabel="userName"
(onChange)="dd1.value = changeCust($event.value)"></p-dropdown>
cust.component.ts -
private currentVal:Customer;
..
..
changeDEA(cust: Customer) {
var cfg = confirm("This action will stop the file upload. Do you still want to continue? ");
if(cfg){
this.currentVal = cust;
// Proceed with normal change event
}else{
console.log("user cancelled skip..");
this.selectedCust = this.currentVal;
// Should revert back to original value
return this.selectedCust;
}
Проблема в том, что отображаемое на экране значение не возвращается к исходному значению.
Ожидаемый результат -
Раскрывающийся список изменяется со значения A на значение B. Подтверждение пользователя - выберите «Отмена». На странице все еще должно отображаться старое значение, т.е. значение A.
Фактический результат -
Раскрывающийся список изменяется со значения A на значение B. Подтверждение пользователя - выберите «Отмена». Страница должна отображать новое значение B. (без начального значения, пустое значение - https://stackblitz.com/edit/angular-dropwdown-confirmation-issue)
Добавление GIF -
Наткнулся на этот код, который отлично работает с собственным angular, но не работает, если параметры заполняются динамически с * ngFor - https://stackblitz.com/edit/angular-dropwdown-confirmation-issue
FYI, пробовал разные посты на github, но ни один из них не оказался полезным.
Angular Версия - "@ angular / core": "^ 5.2.0" PrimeNG - "primeng": "^ 5.2.4"