import { EventEmitter, OnDestroy } from "@angular/core"; import { Feature as GeoJSONFeature, Polygon as GeoJSONPolygon } from "geojson"; import { FillRule, LatLng, LatLngExpression, LatLngTuple, LeafletEvent, LeafletMouseEvent, LineCapShape, LineJoinShape, PathOptions, Polygon, PolylineOptions, PopupEvent, TooltipEvent } from "leaflet"; import { LayerGroupProvider } from "./layer-group.provider"; import { LayerProvider } from "./layer.provider"; import * as i0 from "@angular/core"; /** * Angular2 directive for Leaflet polygons. * * *You can use this directive in an Angular2 template after importing `YagaModule`.* * * How to use in a template: * ```html * * * * * ``` * * @link http://leafletjs.com/reference-1.2.0.html#polygon Original Leaflet documentation * @link https://leaflet-ng2.yagajs.org/latest/browser-test?grep=Rectangle%20Directive Unit-Test * @link https://leaflet-ng2.yagajs.org/latest/coverage/lcov-report/lib/polygon.directive.js.html Test coverage * @link https://leaflet-ng2.yagajs.org/latest/typedoc/classes/polygondirective.html API documentation * @example https://leaflet-ng2.yagajs.org/latest/examples/polygon-directive */ export declare class PolygonDirective extends Polygon implements OnDestroy { protected layerGroupProvider: LayerGroupProvider; /** * Two-Way bound property for the display status of the geometry. * Use it with `` * or `` */ displayChange: EventEmitter; /** * Two-Way bound property for the stroke state of the geometry. * Use it with `` * or `` * @link http://leafletjs.com/reference-1.2.0.html#polygon-stroke Original Leaflet documentation */ strokeChange: EventEmitter; /** * Two-Way bound property for the line-color of the geometry. * Use it with `` * or `` * @link http://leafletjs.com/reference-1.2.0.html#polygon-color Original Leaflet documentation */ colorChange: EventEmitter; /** * Two-Way bound property for the weight of the geometry. * Use it with `` * or `` * @link http://leafletjs.com/reference-1.2.0.html#polygon-weight Original Leaflet documentation */ weightChange: EventEmitter; /** * Two-Way bound property for the opacity of the geometry. * Use it with `` * or `` * @link http://leafletjs.com/reference-1.2.0.html#polygon-opacity Original Leaflet documentation */ opacityChange: EventEmitter; /** * Two-Way bound property for the lineCap of the geometry. * Use it with `` * or `` * @link http://leafletjs.com/reference-1.2.0.html#polygon-linecap Original Leaflet documentation */ lineCapChange: EventEmitter; /** * Two-Way bound property for the lineJoin of the geometry. * Use it with `` * or `` * @link http://leafletjs.com/reference-1.2.0.html#polygon-linejoin Original Leaflet documentation */ lineJoinChange: EventEmitter; /** * Two-Way bound property for the dashArray of the geometry. * Use it with `` * or `` * @link http://leafletjs.com/reference-1.2.0.html#polygon-dasharray Original Leaflet documentation */ dashArrayChange: EventEmitter; /** * Two-Way bound property for the dashOffset of the geometry. * Use it with `` * or `` * @link http://leafletjs.com/reference-1.2.0.html#polygon-dashoffset Original Leaflet documentation */ dashOffsetChange: EventEmitter; /** * Two-Way bound property for the fill state of the geometry. * Use it with `` * or `` * @link http://leafletjs.com/reference-1.2.0.html#polygon-fill Original Leaflet documentation */ fillChange: EventEmitter; /** * Two-Way bound property for the fill-color of the geometry. * Use it with `` * or `` * @link http://leafletjs.com/reference-1.2.0.html#polygon-fillcolor Original Leaflet documentation */ fillColorChange: EventEmitter; /** * Two-Way bound property for the fill-opacity of the geometry. * Use it with `` * or `` * @link http://leafletjs.com/reference-1.2.0.html#polygon-fillopacity Original Leaflet documentation */ fillOpacityChange: EventEmitter; /** * Two-Way bound property for the fill-rule of the geometry. * Use it with `` * or `` * @link http://leafletjs.com/reference-1.2.0.html#polygon-fillrule Original Leaflet documentation */ fillRuleChange: EventEmitter; /** * Two-Way bound property for the className of the geometry. * Use it with `` * or `` * @link http://leafletjs.com/reference-1.2.0.html#polygon-classname Original Leaflet documentation */ classNameChange: EventEmitter; /** * Two-Way bound property for the css-style of the geometry. * Use it with `` * or `` * @link http://leafletjs.com/reference-1.2.0.html#polygon-setstyle Original Leaflet documentation */ styleChange: EventEmitter; /** * Two-Way bound property for the array of LatLngs of the geometry. * Use it with `` * or `` * @link http://leafletjs.com/reference-1.3.0.html#polygon-setlatlngs Original Leaflet documentation */ latLngsChange: EventEmitter; /** * Two-Way bound property for the corresponding GeoJSON. * Use it with `` * or `` * @link http://leafletjs.com/reference-1.3.0.html#polygon-togeojson Original Leaflet documentation */ geoJSONChange: EventEmitter>; /** * From leaflet fired add event. * Use it with `` * @link http://leafletjs.com/reference-1.2.0.html#polygon-add Original Leaflet documentation */ addEvent: EventEmitter; /** * From leaflet fired remove event. * Use it with `` * @link http://leafletjs.com/reference-1.2.0.html#polygon-remove Original Leaflet documentation */ removeEvent: EventEmitter; /** * From leaflet fired popupopen event. * Use it with `` * @link http://leafletjs.com/reference-1.2.0.html#polygon-popupopen Original Leaflet documentation */ popupopenEvent: EventEmitter; /** * From leaflet fired popupclose event. * Use it with `` * @link http://leafletjs.com/reference-1.2.0.html#polygon-popupclose Original Leaflet documentation */ popupcloseEvent: EventEmitter; /** * From leaflet fired tooltipopen event. * Use it with `` * @link http://leafletjs.com/reference-1.2.0.html#polygon-tooltipopen Original Leaflet documentation */ tooltipopenEvent: EventEmitter; /** * From leaflet fired tooltipclose event. * Use it with `` * @link http://leafletjs.com/reference-1.2.0.html#polygon-tooltipclose Original Leaflet documentation */ tooltipcloseEvent: EventEmitter; /** * From leaflet fired click event. * Use it with `` * @link http://leafletjs.com/reference-1.2.0.html#polygon-click Original Leaflet documentation */ clickEvent: EventEmitter; /** * From leaflet fired dblclick event. * Use it with `` * @link http://leafletjs.com/reference-1.2.0.html#polygon-dblclick Original Leaflet documentation */ dblclickEvent: EventEmitter; /** * From leaflet fired mousedown event. * Use it with `` * @link http://leafletjs.com/reference-1.2.0.html#polygon-mousedown Original Leaflet documentation */ mousedownEvent: EventEmitter; /** * From leaflet fired mouseover event. * Use it with `` * @link http://leafletjs.com/reference-1.2.0.html#polygon-mouseover Original Leaflet documentation */ mouseoverEvent: EventEmitter; /** * From leaflet fired mouseout event. * Use it with `` * @link http://leafletjs.com/reference-1.2.0.html#polygon-mouseout Original Leaflet documentation */ mouseoutEvent: EventEmitter; /** * From leaflet fired contextmenu event. * Use it with `` * @link http://leafletjs.com/reference-1.2.0.html#polygon-contextmenu Original Leaflet documentation */ contextmenuEvent: EventEmitter; feature: GeoJSONFeature; constructor(layerGroupProvider: LayerGroupProvider, layerProvider: LayerProvider); /** * Internal method to provide the removal of the layer in Leaflet, when removing it from the Angular template */ ngOnDestroy(): void; /** * Derived method fof the original LatLngs. * @link http://leafletjs.com/reference-1.2.0.html#polygon-addlatlngs Original Leaflet documentation */ setLatLngs(val: (Array<(LatLng | LatLngTuple | LatLngExpression)> | Array> | Array>>)): this; /** * Derived method of the original addLatLng. * @link http://leafletjs.com/reference-1.2.0.html#polygon-addlatlngs Original Leaflet documentation */ addLatLng(val: (LatLng | LatLngTuple | LatLngExpression) | Array<(LatLng | LatLngTuple | LatLngExpression)>): this; /** * Two-Way bound property for the array of LatLngs for the geometry. * Use it with `` or `` * @link http://leafletjs.com/reference-1.2.0.html#polygon-setbounds Original Leaflet documentation */ set latLngs(val: LatLng[] | LatLng[][] | LatLng[][][]); get latLngs(): LatLng[] | LatLng[][] | LatLng[][][]; /** * Two-Way bound property for the corresponding GeoJSON. * Use it with `` or `` * @link http://leafletjs.com/reference-1.2.0.html#polygon-togeojson Original Leaflet documentation */ set geoJSON(val: GeoJSONFeature); get geoJSON(): GeoJSONFeature; /** * Derived method of the original setStyle. * @link http://leafletjs.com/reference-1.2.0.html#polygon-setstyle Original Leaflet documentation */ setStyle(style: PathOptions): this; /** * Two-Way bound property for the opacity. * Use it with `` or `` * @link http://leafletjs.com/reference-1.2.0.html#polygon-opacity Original Leaflet documentation */ set opacity(val: number | undefined); get opacity(): number | undefined; /** * Two-Way bound property for the stroke. * Use it with `` or `` * @link http://leafletjs.com/reference-1.2.0.html#polygon-stroke Original Leaflet documentation */ set stroke(val: boolean); get stroke(): boolean; /** * Two-Way bound property for the color. * Use it with `` or `` * @link http://leafletjs.com/reference-1.2.0.html#polygon-color Original Leaflet documentation */ set color(val: string | undefined); get color(): string | undefined; /** * Two-Way bound property for the weight. * Use it with `` or `` * @link http://leafletjs.com/reference-1.2.0.html#polygon-weight Original Leaflet documentation */ set weight(val: number | undefined); get weight(): number | undefined; /** * Two-Way bound property for the lineCap. * Use it with `` or `` * @link http://leafletjs.com/reference-1.2.0.html#polygon-linecap Original Leaflet documentation */ set lineCap(val: LineCapShape | undefined); get lineCap(): LineCapShape | undefined; /** * Two-Way bound property for the lineJoin. * Use it with `` or `` * @link http://leafletjs.com/reference-1.2.0.html#polygon-linejoin Original Leaflet documentation */ set lineJoin(val: LineJoinShape | undefined); get lineJoin(): LineJoinShape | undefined; /** * Two-Way bound property for the dashArray. * Use it with `` or `` * @link http://leafletjs.com/reference-1.2.0.html#polygon-dasharray Original Leaflet documentation */ set dashArray(val: string | undefined); get dashArray(): string | undefined; /** * Two-Way bound property for the dashOffset. * Use it with `` or `` * @link http://leafletjs.com/reference-1.2.0.html#polygon-dashoffset Original Leaflet documentation */ set dashOffset(val: string | undefined); get dashOffset(): string | undefined; /** * Two-Way bound property for the fill. * Use it with `` or `` * @link http://leafletjs.com/reference-1.2.0.html#polygon-fill Original Leaflet documentation */ set fill(val: boolean); get fill(): boolean; /** * Two-Way bound property for the fillColor. * Use it with `` or `` * @link http://leafletjs.com/reference-1.2.0.html#polygon-fillcolor Original Leaflet documentation */ set fillColor(val: string | undefined); get fillColor(): string | undefined; /** * Two-Way bound property for the fillOpacity. * Use it with `` or `` * @link http://leafletjs.com/reference-1.2.0.html#polygon-fillopacity Original Leaflet documentation */ set fillOpacity(val: number | undefined); get fillOpacity(): number | undefined; /** * Two-Way bound property for the fillRule. * Use it with `` or `` * @link http://leafletjs.com/reference-1.2.0.html#polygon-fillrule Original Leaflet documentation */ set fillRule(val: FillRule | undefined); get fillRule(): FillRule | undefined; /** * Two-Way bound property for the className. * Use it with `` or `` * @link http://leafletjs.com/reference-1.2.0.html#polygon-classname Original Leaflet documentation */ set className(val: string | undefined); get className(): string | undefined; /** * Two-Way bound property for the opacity. * Use it with `` or `` * @link http://leafletjs.com/reference-1.2.0.html#polygon-style Original Leaflet documentation */ set style(val: PolylineOptions); get style(): PolylineOptions; /** * Two-Way bound property for the display state. * Use it with `` or `` */ set display(val: boolean); get display(): boolean; /** * Input for the interactive state. * Use it with `` * @link http://leafletjs.com/reference-1.2.0.html#polygon-interactive Original Leaflet documentation */ set interactive(val: boolean); get interactive(): boolean; /** * Input for the smoothFactor. * Use it with `` * @link http://leafletjs.com/reference-1.2.0.html#polygon-smoothfactor Original Leaflet documentation */ set smoothFactor(val: number | undefined); get smoothFactor(): number | undefined; /** * Input for the noClip state. * Use it with `` * @link http://leafletjs.com/reference-1.2.0.html#polygon-noclip Original Leaflet documentation */ set noClip(val: boolean); get noClip(): boolean; /** * Input for the GeoJSON properties. * Use it with `` */ set properties(val: T); get properties(): T; static ɵfac: i0.ɵɵFactoryDeclaration, never>; static ɵdir: i0.ɵɵDirectiveDeclaration, "yaga-polygon", never, { "latLngs": "latLngs"; "geoJSON": "geoJSON"; "opacity": "opacity"; "stroke": "stroke"; "color": "color"; "weight": "weight"; "lineCap": "lineCap"; "lineJoin": "lineJoin"; "dashArray": "dashArray"; "dashOffset": "dashOffset"; "fill": "fill"; "fillColor": "fillColor"; "fillOpacity": "fillOpacity"; "fillRule": "fillRule"; "className": "className"; "style": "style"; "display": "display"; "interactive": "interactive"; "smoothFactor": "smoothFactor"; "noClip": "noClip"; "properties": "properties"; }, { "displayChange": "displayChange"; "strokeChange": "strokeChange"; "colorChange": "colorChange"; "weightChange": "weightChange"; "opacityChange": "opacityChange"; "lineCapChange": "lineCapChange"; "lineJoinChange": "lineJoinChange"; "dashArrayChange": "dashArrayChange"; "dashOffsetChange": "dashOffsetChange"; "fillChange": "fillChange"; "fillColorChange": "fillColorChange"; "fillOpacityChange": "fillOpacityChange"; "fillRuleChange": "fillRuleChange"; "classNameChange": "classNameChange"; "styleChange": "styleChange"; "latLngsChange": "latLngsChange"; "geoJSONChange": "geoJSONChange"; "addEvent": "add"; "removeEvent": "remove"; "popupopenEvent": "popupopen"; "popupcloseEvent": "popupclose"; "tooltipopenEvent": "tooltipopen"; "tooltipcloseEvent": "tooltipclose"; "clickEvent": "click"; "dblclickEvent": "dblclick"; "mousedownEvent": "mousedown"; "mouseoverEvent": "mouseover"; "mouseoutEvent": "mouseout"; "contextmenuEvent": "contextmenu"; }, never>; }