From 04c81ad2f705827944009ca7142a57f7d32b6835 Mon Sep 17 00:00:00 2001 From: Al-Mothafar Al-Hasan Date: Mon, 16 Sep 2024 17:58:13 +0300 Subject: [PATCH] RxJS 7 migration --- CHANGELOG.md | 1 + .../src/lib/auto-complete.component.ts | 43 ++++++++++--------- 2 files changed, 23 insertions(+), 21 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index f43019b..353767f 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,6 +1,7 @@ ## [18.0.0] Major Update - Upgraded to support Angular 18 +- Migration for deprecated Observable params - Adding e2e smock test for the project removing deprecated protractor adding cypress ## [17.0.0] Major Update diff --git a/projects/auto-complete/src/lib/auto-complete.component.ts b/projects/auto-complete/src/lib/auto-complete.component.ts index 75ce8d2..0ff8402 100644 --- a/projects/auto-complete/src/lib/auto-complete.component.ts +++ b/projects/auto-complete/src/lib/auto-complete.component.ts @@ -1,5 +1,6 @@ import { Component, ElementRef, EventEmitter, Input, OnInit, Output, ViewChild, ViewEncapsulation } from '@angular/core'; import { NguiAutoCompleteService } from './auto-complete.service'; +import { Observable } from 'rxjs'; @Component({ selector: 'ngui-auto-complete', @@ -132,39 +133,39 @@ export class NguiAutoCompleteComponent implements OnInit { this.filteredList = this.filteredList.slice(0, this.maxNumList); } - } else { // remote source + } else {// remote source this.isLoading = true; if (typeof this.source === 'function') { // custom function that returns observable - this.source(keyword).subscribe( - (resp) => { - - if (this.pathToData) { - const paths = this.pathToData.split('.'); - paths.forEach((prop) => resp = resp[prop]); - } - - this.filteredList = resp; - if (this.maxNumList) { - this.filteredList = this.filteredList.slice(0, this.maxNumList); - } - }, - (error) => console.warn(error), - () => this.isLoading = false // complete + (this.source(keyword) as Observable).subscribe({ + next: (resp) => { + if (this.pathToData) { + const paths = this.pathToData.split('.'); + paths.forEach((prop) => resp = resp[prop]); + } + + this.filteredList = resp; + if (this.maxNumList) { + this.filteredList = this.filteredList.slice(0, this.maxNumList); + } + }, + error: (error) => console.warn(error), + complete: () => this.isLoading = false + } ); } else { // remote source - - this.autoComplete.getRemoteData(keyword).subscribe((resp) => { + this.autoComplete.getRemoteData(keyword).subscribe({ + next: (resp) => { this.filteredList = resp ? resp : []; if (this.maxNumList) { this.filteredList = this.filteredList.slice(0, this.maxNumList); } }, - (error) => console.warn(error), - () => this.isLoading = false // complete - ); + error: (error) => console.warn(error), + complete: () => this.isLoading = false + }); } } }