This module is a wrapper for Google Places Autocomplete js library.
npm install ngx-google-places-autocomplete
yarn add ngx-google-places-autocomplete
- Add google library in your index.html file :
<script src="https://maps.googleapis.com/maps/api/js?key=<Your API KEY>&libraries=places&language=en"></script>
- Replace with google places api key. Ref - https://developers.google.com/places/web-service/get-api-key
- Add a module into your application (as a rule app.module.ts)
import { GooglePlaceModule } from "ngx-google-places-autocomplete";
@NgModule({
imports: [GooglePlaceModule, BrowserModule, FormsModule, ...],
....
})
- Add directive ngx-google-places-autocomplete to your input field (options is an optional parammeter)
<input ngx-google-places-autocomplete [options]='options' #placesRef="ngx-places" (onAddressChange)="handleAddressChange($event)"/>
- Additionally you can reference directive in your component
@ViewChild("placesRef") placesRef : GooglePlaceDirective;
public handleAddressChange(address: Address) {
// Do some stuff
}
In order to use under angular universal please check that comment skynet2#15 (comment)
Refer to original google maps api - https://developers.google.com/maps/documentation/javascript/places-autocomplete Options object - https://github.com/skynet2/ngx-google-places-autocomplete/blob/master/src/objects/options/options.ts Google doc for Options : https://developers.google.com/maps/documentation/javascript/reference/places-widget#AutocompleteOptions Example :
[options]="{
types: [],
componentRestrictions: { country: 'UA' }
}"
Please feel free to declare issues or contribute: https://github.com/skynet2/ngx-google-places-autocomplete