Socket
Socket
Sign inDemoInstall

google-maps-angular2

Package Overview
Dependencies
1
Maintainers
1
Versions
6
Alerts
File Explorer

Advanced tools

Install Socket

Detect and block malicious and high-risk dependencies

Install

    google-maps-angular2

Google Maps Api for Angular 2


Version published
Weekly downloads
26
decreased by-36.59%
Maintainers
1
Install size
307 kB
Created
Weekly downloads
 

Readme

Source

google-maps-angular2

Google Maps Api for Angular2

The library provides access to the google maps api.

Google Maps Api examples: Link

Demo

Video demonstation
Plunker Demo

Installation

npm install --save google-maps-angular2

SystemJS configuration

Adapt your systemjs.config.js (or another place where you configure SystemJS) file with the following:

System.config({
  ...
  map: {
    ...
    'google-maps-angular2':      'npm:google-maps-angular2/dist'
    ...
  },
  packages: {
    ...
    rxjs: {
      main: 'Rx.js',
      defaultExtension: 'js'
    },
    'google-maps-angular2': {
      defaultExtension: 'js',
      main: 'index.js',
      format: 'cjs'
    }
    ...
  }
})

Usage

First, import GoogleMapsModule into the angular module where you want to use it:

import {GoogleMapsModule} from 'google-maps-angular2';

imports: [
  ...
    @NgModule({
        ...
        imports: [
            ...
            GoogleMapsModule.forRoot({
                url: 'You google api link without callback'
            })
        ]

    })
  ...
]

Insert into component template

<input type="text" class="input" placeholder="Поиск..." #inputElement>
<div class="map" #mapElement></div>

Default styles

body {
    margin: 0;
    padding: 0;
}
.map {
    width: 100%;
    height: 100vh;
}
.input {
    position: absolute;
        top: 30px;
        left: 30px;

    border: 1px solid silver;
        border-radius: 15px;

    font-family: Roboto;
        font-size: 15px;
        font-weight: lighter;
        text-align: center;

    padding: 10px;
    z-index: 100;
    width: 250px;
}

Component configuration

import {GoogleMapsService} from 'google-maps-angular2';

export class AppComponent implements AfterViewInit {
    @ViewChild('mapElement') mapElement: ElementRef;
    @ViewChild('inputElement') inputElement: ElementRef;

    private map: any;

    constructor(private gapi: GoogleMapsService) {
    }

    ngAfterViewInit(): void {
        /**
         * Init map api [google.maps]
         */
        this.gapi.init.then((maps: any) => {
            const loc = new maps.LatLng(55.81800989, 49.09815408);

            this.map = new maps.Map(this.mapElement.nativeElement, {
                zoom: 13,
                center: loc,
                scrollwheel: false,
                panControl: false,
                mapTypeControl: false,
                zoomControl: true,
                streetViewControl: false,
                scaleControl: true,
                zoomControlOptions: {
                    style: maps.ZoomControlStyle.LARGE,
                    position: maps.ControlPosition.RIGHT_BOTTOM
                }
            });

            const input = this.inputElement.nativeElement;
            const options = {
                componentRestrictions: {country: 'ru'}
            };

            const autocomplete = new maps.places.Autocomplete(input, options);

            autocomplete.addListener('place_changed', () => {
                const place = autocomplete.getPlace();
                const location = place.geometry.location;

                this.map.setZoom(13);
                this.map.setCenter({
                    lat: location.lat(),
                    lng: location.lng()
                });
            });
        });
    }
}

Keywords

FAQs

Last updated on 09 Apr 2017

Did you know?

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc