Autocomplete component for Angular6+
Works only with HTTPClient.
Works only with reactive forms.
Static array and API call support.
Highlight matches (case insensitive).
Keyboard support.
AOT compatible.
npm install @avas/ngx-autocomplete --save
- type<string> - The input field type (text by default).
- placeholder<string> - The input field placeholder.
- apiString<string> - API URL to be called.
- paramName<string> - The keyword string will be attached as query string parameter with the given name. For example "https://yourURL?paramName=keyword"
- suggestionPropName<string> - By default the response coming from the API is handled as an array of string. If suggestionPropName is provided then response will be handled as an array of objects and the given property will be mapped on the suggestion list.
- payloadPropName<string> - The property name of the response payload. If not provided then the response will be handled as the payload itself.
- staticDataSource<any[]> - Array of string or objects. If second then suggestionPropName must be provided.
- control - The ngx-autocomplete selector must be part of a reactive form.
- selected<string> - Emits an event once the item is selected.
First import NgxAutocompleteModule to your module:
import { BrowserModule } from '@angular/platform-browser';
import { NgModule } from '@angular/core';
import { AppComponent } from './app.component';
import { NgxAutocompleteModule } from './ngx-autocomplete/ngx-autocomplete.module';
import { FormsModule, ReactiveFormsModule } from '@angular/forms';
import { HttpClientModule } from '@angular/common/http';
@NgModule({
declarations: [
AppComponent
],
imports: [
BrowserModule,
HttpClientModule,
FormsModule,
ReactiveFormsModule,
NgxAutocompleteModule
],
providers: [],
bootstrap: [AppComponent]
})
export class AppModule { }
Then create a reactive form:
import { Component } from '@angular/core';
import { FormGroup, FormBuilder } from '@angular/forms';
export class AppComponent {
myForm: FormGroup;
weekdays: any[] = [
{
name: 'Monday'
},
{
name: 'Tuesday'
},
{
name: 'wednesday'
}
];
constructor(
private formBuilder: FormBuilder
) {
this.createForm();
}
createForm() {
this.myForm = this.formBuilder.group({
keyword: ''
});
}
}
Add seletor with static array source:
<form [formGroup]="myForm">
<ngx-autocomplete formControlName="keyword"
[control]="myForm.controls.keyword"
[staticDataSource]="weekdays"
suggestionPropName="name"
(selected)="onSelected($event)"></ngx-autocomplete>
</form>
Add seletor with API call:
<form [formGroup]="myForm">
<ngx-autocomplete formControlName="keyword"
[control]="myForm.controls.keyword"
apiString="http://localhost:3000/api/ascent/queryascents"
paramName="keyword"
payloadPropName="payload"
suggestionPropName="name"
(selected)="onSelected($event)"></ngx-autocomplete>
</form>
Use ::ng-deep selector to override built-in element or class styles. For example:
ngx-autocomplete ::ng-deep input {
/* your style comes here */
}
ngx-autocomplete ::ng-deep .highlighted {
/* your style comes here */
}