@ciag/ngx-leaflet-draw-injector
TypeScript icon, indicating that this package has built-in type declarations

1.0.10 • Public • Published

NgxLeafletDrawInjector

A angular Lib npm version

Objective: a simplyfied way to add draw features to your leaflet map.

API

Table of contents

  1. Installation
  2. Usage

Installation

Intall the NgxLeafletDrawInjector via NPM

NPM

    npm i @ciag/ngx-leaflet-draw-injector

Usage

app.module.ts

import {NgxLeafletDrawInjectorModule} from '@ciag/ngx-leaflet-draw-injector';



@NgModule({
  //...
  imports: [
    //...
    NgxLeafletDrawInjectorModule
  ],
  //...
})
export class AppModule { }

my.component.ts

import { Component, OnInit } from '@angular/core';

@Component({
    //...
})
export class AppComponent implements OnInit {
    //...
    
    constructor(private drawInjectorService: NgxLeafletDrawInjectorService) { }

    ngOnInit() { 
        // normal leaflet setup
        this.map = L.map('map').setView([51.505, -0.09], 13);
        L.tileLayer('https://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png', {
    attribution: '&copy; <a href="https://www.openstreetmap.org/copyright">OpenStreetMap</a> contributors'
}).addTo(map);

        // Adding drawbar
        this.drawControl = this.drawInjectorService.addDrawToMap(this.map);

    }
}

To intercept the attempt to create a new Layer and even cancel the creation, just add a promise

this goes to to the after create as well

my.component.ts

import { Component, OnInit } from '@angular/core';

@Component({
    //...
})
export class AppComponent implements OnInit {
    //...
    // conformation modal
    @ViewChild('newShapeModal') newShapeModal: ElementRef;

    constructor(private drawInjectorService: NgxLeafletDrawInjectorService) { }

    ngOnInit() {
        //...
        this.drawControl = this.drawInjectorService.addDrawToMap(this.map);
        this.drawControl.beforeCreate = () => {
            return new Promise(async (r) => {
                const result = await this.open(this.newShapeModal)
                r(result)
            });
        };
        this.drawControl.afterCreate = () => {
            return new Promise(async (r) => {
                console.log("new layer :)")
                r()
            });
        };
    }
    open(content): Promise<boolean> {
        return new Promise(r => {
            this.modalService.open(content, { ariaLabelledBy: 'modal-basic-title' }).result.then(() => {
                r(true);
            }, () => {
                r(false);
            });
        });
    }
}

Package Sidebar

Install

npm i @ciag/ngx-leaflet-draw-injector

Weekly Downloads

1

Version

1.0.10

License

Apache 2.0

Unpacked Size

235 kB

Total Files

34

Last publish

Collaborators

  • borba.victor
  • ciag.dev
  • raacavalieri
  • leonardortlima
  • carlosbenedetti
  • tiecoo
  • ettoreleandrotognoli
  • rafael.lima