-
Notifications
You must be signed in to change notification settings - Fork 818
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
feat(core): add rectangle support (#1450)
add rectangle functionality closes #570
- Loading branch information
1 parent
9c76e7e
commit 2e4878b
Showing
9 changed files
with
768 additions
and
3 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,296 @@ | ||
import { | ||
Directive, | ||
EventEmitter, | ||
OnChanges, | ||
OnDestroy, | ||
OnInit, | ||
SimpleChange, | ||
Input, | ||
Output | ||
} from '@angular/core'; | ||
import { Subscription } from 'rxjs'; | ||
import { MouseEvent } from '../map-types'; | ||
import { | ||
LatLngBounds, | ||
LatLngBoundsLiteral | ||
} from '../services/google-maps-types'; | ||
import { MouseEvent as MapMouseEvent } from '../services/google-maps-types'; | ||
import { RectangleManager } from '../services/managers/rectangle-manager'; | ||
|
||
@Directive({ | ||
selector: 'agm-rectangle' | ||
}) | ||
export class AgmRectangle implements OnInit, OnChanges, OnDestroy { | ||
/** | ||
* The north position of the rectangle (required). | ||
*/ | ||
@Input() north: number; | ||
|
||
/** | ||
* The east position of the rectangle (required). | ||
*/ | ||
@Input() east: number; | ||
|
||
/** | ||
* The south position of the rectangle (required). | ||
*/ | ||
@Input() south: number; | ||
|
||
/** | ||
* The west position of the rectangle (required). | ||
*/ | ||
@Input() west: number; | ||
|
||
/** | ||
* Indicates whether this Rectangle handles mouse events. Defaults to true. | ||
*/ | ||
@Input() clickable: boolean = true; | ||
|
||
/** | ||
* If set to true, the user can drag this rectangle over the map. Defaults to false. | ||
*/ | ||
// tslint:disable-next-line:no-input-rename | ||
@Input('rectangleDraggable') draggable: boolean = false; | ||
|
||
/** | ||
* If set to true, the user can edit this rectangle by dragging the control points shown at | ||
* the center and around the circumference of the rectangle. Defaults to false. | ||
*/ | ||
@Input() editable: boolean = false; | ||
|
||
/** | ||
* The fill color. All CSS3 colors are supported except for extended named colors. | ||
*/ | ||
@Input() fillColor: string; | ||
|
||
/** | ||
* The fill opacity between 0.0 and 1.0. | ||
*/ | ||
@Input() fillOpacity: number; | ||
|
||
/** | ||
* The stroke color. All CSS3 colors are supported except for extended named colors. | ||
*/ | ||
@Input() strokeColor: string; | ||
|
||
/** | ||
* The stroke opacity between 0.0 and 1.0 | ||
*/ | ||
@Input() strokeOpacity: number; | ||
|
||
/** | ||
* The stroke position. Defaults to CENTER. | ||
* This property is not supported on Internet Explorer 8 and earlier. | ||
*/ | ||
@Input() strokePosition: 'CENTER' | 'INSIDE' | 'OUTSIDE' = 'CENTER'; | ||
|
||
/** | ||
* The stroke width in pixels. | ||
*/ | ||
@Input() strokeWeight: number = 0; | ||
|
||
/** | ||
* Whether this rectangle is visible on the map. Defaults to true. | ||
*/ | ||
@Input() visible: boolean = true; | ||
|
||
/** | ||
* The zIndex compared to other polys. | ||
*/ | ||
@Input() zIndex: number; | ||
|
||
/** | ||
* This event is fired when the rectangle's is changed. | ||
*/ | ||
@Output() | ||
boundsChange: EventEmitter<LatLngBoundsLiteral> = new EventEmitter< | ||
LatLngBoundsLiteral | ||
>(); | ||
|
||
/** | ||
* This event emitter gets emitted when the user clicks on the rectangle. | ||
*/ | ||
@Output() | ||
rectangleClick: EventEmitter<MouseEvent> = new EventEmitter<MouseEvent>(); | ||
|
||
/** | ||
* This event emitter gets emitted when the user clicks on the rectangle. | ||
*/ | ||
@Output() | ||
rectangleDblClick: EventEmitter<MouseEvent> = new EventEmitter<MouseEvent>(); | ||
|
||
/** | ||
* This event is repeatedly fired while the user drags the rectangle. | ||
*/ | ||
@Output() drag: EventEmitter<MouseEvent> = new EventEmitter<MouseEvent>(); | ||
|
||
/** | ||
* This event is fired when the user stops dragging the rectangle. | ||
*/ | ||
@Output() dragEnd: EventEmitter<MouseEvent> = new EventEmitter<MouseEvent>(); | ||
|
||
/** | ||
* This event is fired when the user starts dragging the rectangle. | ||
*/ | ||
@Output() | ||
dragStart: EventEmitter<MouseEvent> = new EventEmitter<MouseEvent>(); | ||
|
||
/** | ||
* This event is fired when the DOM mousedown event is fired on the rectangle. | ||
*/ | ||
@Output() | ||
mouseDown: EventEmitter<MouseEvent> = new EventEmitter<MouseEvent>(); | ||
|
||
/** | ||
* This event is fired when the DOM mousemove event is fired on the rectangle. | ||
*/ | ||
@Output() | ||
mouseMove: EventEmitter<MouseEvent> = new EventEmitter<MouseEvent>(); | ||
|
||
/** | ||
* This event is fired on rectangle mouseout. | ||
*/ | ||
@Output() mouseOut: EventEmitter<MouseEvent> = new EventEmitter<MouseEvent>(); | ||
|
||
/** | ||
* This event is fired on rectangle mouseover. | ||
*/ | ||
@Output() | ||
mouseOver: EventEmitter<MouseEvent> = new EventEmitter<MouseEvent>(); | ||
|
||
/** | ||
* This event is fired when the DOM mouseup event is fired on the rectangle. | ||
*/ | ||
@Output() mouseUp: EventEmitter<MouseEvent> = new EventEmitter<MouseEvent>(); | ||
|
||
/** | ||
* This event is fired when the rectangle is right-clicked on. | ||
*/ | ||
@Output() | ||
rightClick: EventEmitter<MouseEvent> = new EventEmitter<MouseEvent>(); | ||
|
||
private _rectangleAddedToManager: boolean = false; | ||
|
||
private static _mapOptions: string[] = [ | ||
'fillColor', | ||
'fillOpacity', | ||
'strokeColor', | ||
'strokeOpacity', | ||
'strokePosition', | ||
'strokeWeight', | ||
'visible', | ||
'zIndex', | ||
'clickable' | ||
]; | ||
|
||
private _eventSubscriptions: Subscription[] = []; | ||
|
||
constructor(private _manager: RectangleManager) {} | ||
|
||
/** @internal */ | ||
ngOnInit() { | ||
this._manager.addRectangle(this); | ||
this._rectangleAddedToManager = true; | ||
this._registerEventListeners(); | ||
} | ||
|
||
/** @internal */ | ||
ngOnChanges(changes: { [key: string]: SimpleChange }) { | ||
if (!this._rectangleAddedToManager) { | ||
return; | ||
} | ||
if ( | ||
changes['north'] || | ||
changes['east'] || | ||
changes['south'] || | ||
changes['west'] | ||
) { | ||
this._manager.setBounds(this); | ||
} | ||
if (changes['editable']) { | ||
this._manager.setEditable(this); | ||
} | ||
if (changes['draggable']) { | ||
this._manager.setDraggable(this); | ||
} | ||
if (changes['visible']) { | ||
this._manager.setVisible(this); | ||
} | ||
this._updateRectangleOptionsChanges(changes); | ||
} | ||
|
||
private _updateRectangleOptionsChanges(changes: { | ||
[propName: string]: SimpleChange; | ||
}) { | ||
let options: { [propName: string]: any } = {}; | ||
let optionKeys = Object.keys(changes).filter( | ||
k => AgmRectangle._mapOptions.indexOf(k) !== -1 | ||
); | ||
optionKeys.forEach(k => { | ||
options[k] = changes[k].currentValue; | ||
}); | ||
if (optionKeys.length > 0) { | ||
this._manager.setOptions(this, options); | ||
} | ||
} | ||
|
||
private _registerEventListeners() { | ||
let events: Map<string, EventEmitter<any>> = new Map< | ||
string, | ||
EventEmitter<any> | ||
>(); | ||
events.set('bounds_changed', this.boundsChange); | ||
events.set('click', this.rectangleClick); | ||
events.set('dblclick', this.rectangleDblClick); | ||
events.set('drag', this.drag); | ||
events.set('dragend', this.dragEnd); | ||
events.set('dragStart', this.dragStart); | ||
events.set('mousedown', this.mouseDown); | ||
events.set('mousemove', this.mouseMove); | ||
events.set('mouseout', this.mouseOut); | ||
events.set('mouseover', this.mouseOver); | ||
events.set('mouseup', this.mouseUp); | ||
events.set('rightclick', this.rightClick); | ||
|
||
events.forEach((eventEmitter, eventName) => { | ||
this._eventSubscriptions.push( | ||
this._manager | ||
.createEventObservable<MapMouseEvent>(eventName, this) | ||
.subscribe(value => { | ||
switch (eventName) { | ||
case 'bounds_changed': | ||
this._manager.getBounds(this).then(bounds => | ||
eventEmitter.emit(<LatLngBoundsLiteral>{ | ||
north: bounds.getNorthEast().lat(), | ||
east: bounds.getNorthEast().lng(), | ||
south: bounds.getSouthWest().lat(), | ||
west: bounds.getSouthWest().lng() | ||
}) | ||
); | ||
break; | ||
default: | ||
eventEmitter.emit(<MouseEvent>{ | ||
coords: { lat: value.latLng.lat(), lng: value.latLng.lng() } | ||
}); | ||
} | ||
}) | ||
); | ||
}); | ||
} | ||
|
||
/** @internal */ | ||
ngOnDestroy() { | ||
this._eventSubscriptions.forEach(function(s: Subscription) { | ||
s.unsubscribe(); | ||
}); | ||
this._eventSubscriptions = null; | ||
this._manager.removeRectangle(this); | ||
} | ||
|
||
/** | ||
* Gets the LatLngBounds of this Rectangle. | ||
*/ | ||
getBounds(): Promise<LatLngBounds> { | ||
return this._manager.getBounds(this); | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.