@jmarcelof/leaflet-ng2
Version:
Angular2 module for Leaflet
245 lines (240 loc) • 8.14 kB
text/typescript
import {
Directive,
EventEmitter,
Input,
Output,
} from "@angular/core";
import {
Icon,
LeafletEvent,
Point,
} from "leaflet";
import { TRANSPARENT_PIXEL } from "./consts";
import { MarkerProvider } from "./marker.provider";
/**
* Angular2 directive for Leaflet icons.
*
* *You can use this directive in an Angular2 template after importing `YagaModule`.*
*
* How to use in a template:
* ```html
* <yaga-map>
* <yaga-marker>
* <yaga-icon
* [iconAnchor]="..."
* [iconSize]="..."
* [popupAnchor]="..."
* [className]="..."
* [iconUrl]="..."
* [iconRetinaUrl]="..."
* [iconSize]="..."
* [iconAnchor]="..."
* [popupAnchor]="..."
* [tooltipAnchor]="..."
* [shadowUrl]="..."
* [shadowRetinaUrl]="..."
* [shadowSize]="..."
* [shadowAnchor]="...">
* </yaga-icon>
* </yaga-marker>
* </yaga-map>
* ```
*
* @link http://leafletjs.com/reference-1.2.0.html#icon Original Leaflet documentation
* @link https://leaflet-ng2.yagajs.org/latest/browser-test?grep=Icon%20Directive Unit-Test
* @link https://leaflet-ng2.yagajs.org/latest/coverage/lcov-report/lib/icon.directive.js.html Test coverage
* @link https://leaflet-ng2.yagajs.org/latest/typedoc/classes/icondirective.html API documentation
* @example https://leaflet-ng2.yagajs.org/latest/examples/icon-directive/
*/
export class IconDirective extends Icon {
/**
* This is an EventEmitter used to notify on any change in this object. It is mainly created to provide reactions
* of the marker directive on changes.
*/
public updateEvent: EventEmitter<LeafletEvent> = new EventEmitter();
constructor(public markerProvider: MarkerProvider) {
super({
iconUrl: TRANSPARENT_PIXEL,
});
this.markerProvider.ref!.setIcon(this);
}
/**
* Input for the DOM class name.
* Use it with `<yaga-icon [className]="someValue">`
* @link http://leafletjs.com/reference-1.2.0.html#icon-classname Original Leaflet documentation
*/
public set className(val: string | undefined) {
this.options.className = val;
this.markerProvider.ref!.setIcon(this);
this.updateEvent.emit({
target: this,
type: "update",
});
}
public get className(): string | undefined {
return this.options.className;
}
/**
* Input for the icon-url.
* Use it with `<yaga-icon [iconUrl]="someValue">`
* @link http://leafletjs.com/reference-1.2.0.html#icon-iconurl Original Leaflet documentation
*/
public set iconUrl(val: string) {
this.options.iconUrl = val;
this.markerProvider.ref!.setIcon(this);
this.updateEvent.emit({
target: this,
type: "update",
});
}
public get iconUrl(): string {
return this.options.iconUrl;
}
/**
* Input for the icon-retina-url.
* Use it with `<yaga-icon [iconRetinaUrl]="someValue">`
* @link http://leafletjs.com/reference-1.2.0.html#icon-iconretinaurl Original Leaflet documentation
*/
public set iconRetinaUrl(val: string | undefined) {
this.options.iconRetinaUrl = val;
this.markerProvider.ref!.setIcon(this);
this.updateEvent.emit({
target: this,
type: "update",
});
}
public get iconRetinaUrl(): string | undefined {
return this.options.iconRetinaUrl;
}
/**
* Input for the icon-size.
* Use it with `<yaga-icon [iconSize]="someValue">`
* @link http://leafletjs.com/reference-1.2.0.html#icon-iconsize Original Leaflet documentation
*/
public set iconSize(val: Point) {
this.options.iconSize = val;
this.markerProvider.ref!.setIcon(this);
this.updateEvent.emit({
target: this,
type: "update",
});
}
public get iconSize(): Point {
return (this.options.iconSize as Point);
}
/**
* Input for the icon-anchor.
* Use it with `<yaga-icon [iconAnchor]="someValue">`
* @link http://leafletjs.com/reference-1.2.0.html#icon-iconanchor Original Leaflet documentation
*/
public set iconAnchor(val: Point) {
this.options.iconAnchor = val;
this.markerProvider.ref!.setIcon(this);
this.updateEvent.emit({
target: this,
type: "update",
});
}
public get iconAnchor(): Point {
return (this.options.iconAnchor as Point);
}
/**
* Input for the popup-anchor.
* Use it with `<yaga-icon [popupAnchor]="someValue">`
* @link http://leafletjs.com/reference-1.2.0.html#icon-popupanchor Original Leaflet documentation
*/
public set popupAnchor(val: Point) {
this.options.popupAnchor = val;
this.markerProvider.ref!.setIcon(this);
this.updateEvent.emit({
target: this,
type: "update",
});
}
public get popupAnchor(): Point {
return (this.options.popupAnchor as Point);
}
/**
* Input for the tooltip-anchor.
* Use it with `<yaga-icon [tooltipAnchor]="someValue">`
* @link http://leafletjs.com/reference-1.2.0.html#icon-tooltipanchor Original Leaflet documentation
*/
public set tooltipAnchor(val: Point) {
this.options.tooltipAnchor = val;
this.markerProvider.ref!.setIcon(this);
this.updateEvent.emit({
target: this,
type: "update",
});
}
public get tooltipAnchor(): Point {
return this.options.tooltipAnchor as Point;
}
/**
* Input for the shadow-url.
* Use it with `<yaga-icon [shadowUrl]="someValue">`
* @link http://leafletjs.com/reference-1.2.0.html#icon-shadowurl Original Leaflet documentation
*/
public set shadowUrl(val: string | undefined) {
this.options.shadowUrl = val;
this.markerProvider.ref!.setIcon(this);
this.updateEvent.emit({
target: this,
type: "update",
});
}
public get shadowUrl(): string | undefined {
return this.options.shadowUrl;
}
/**
* Input for the shadow-url for retina displays.
* Use it with `<yaga-icon [shadowUrl]="someValue">`
* @link http://leafletjs.com/reference-1.2.0.html#icon-shadowretinaurl Original Leaflet documentation
*/
public set shadowRetinaUrl(val: string | undefined) {
this.options.shadowRetinaUrl = val;
this.markerProvider.ref!.setIcon(this);
this.updateEvent.emit({
target: this,
type: "update",
});
}
public get shadowRetinaUrl(): string | undefined {
return this.options.shadowRetinaUrl;
}
/**
* Input for the shadow-size.
* Use it with `<yaga-icon [shadowSize]="someValue">`
* @link http://leafletjs.com/reference-1.2.0.html#icon-shadowsize Original Leaflet documentation
*/
public set shadowSize(val: Point) {
this.options.shadowSize = val;
this.markerProvider.ref!.setIcon(this);
this.updateEvent.emit({
target: this,
type: "update",
});
}
public get shadowSize(): Point {
return (this.options.shadowSize as Point);
}
/**
* Input for the shadow-anchor.
* Use it with `<yaga-icon [shadowAnchor]="someValue">`
* @link http://leafletjs.com/reference-1.2.0.html#icon-shadowanchor Original Leaflet documentation
*/
public set shadowAnchor(val: Point) {
this.options.shadowAnchor = val;
this.markerProvider.ref!.setIcon(this);
this.updateEvent.emit({
target: this,
type: "update",
});
}
public get shadowAnchor(): Point {
return (this.options.shadowAnchor as Point);
}
}