UNPKG

@syncromatics/react-google-maps

Version:
521 lines (435 loc) 8.82 kB
/* * ----------------------------------------------------------------------------- * This file is auto-generated from the corresponding file at `src/macros/`. * Please **DO NOT** edit this file directly when creating PRs. * ----------------------------------------------------------------------------- */ /* global google */ import React from "react"; import PropTypes from "prop-types" import { construct, componentDidMount, componentDidUpdate, componentWillUnmount, } from "../utils/MapChildHelper" import { MAP, MARKER, ANCHOR, MARKER_CLUSTERER } from "../constants" /** * A wrapper around `google.maps.Marker` * * @see https://developers.google.com/maps/documentation/javascript/3.exp/reference#Marker */ export class Marker extends React.PureComponent { static propTypes = { /** * For the 2nd argument of `MarkerCluster#addMarker` * @see https://github.com/mikesaidani/marker-clusterer-plus */ noRedraw: PropTypes.bool, /** * @type Animation */ defaultAnimation: PropTypes.any, /** * @type boolean */ defaultClickable: PropTypes.bool, /** * @type string */ defaultCursor: PropTypes.string, /** * @type boolean */ defaultDraggable: PropTypes.bool, /** * @type string|Icon|Symbol */ defaultIcon: PropTypes.any, /** * @type string|MarkerLabel */ defaultLabel: PropTypes.any, /** * @type number */ defaultOpacity: PropTypes.number, /** * @type MarkerOptions */ defaultOptions: PropTypes.any, /** * @type LatLng|LatLngLiteral */ defaultPosition: PropTypes.any, /** * @type MarkerShape */ defaultShape: PropTypes.any, /** * @type string */ defaultTitle: PropTypes.string, /** * @type boolean */ defaultVisible: PropTypes.bool, /** * @type number */ defaultZIndex: PropTypes.number, /** * @type Animation */ animation: PropTypes.any, /** * @type boolean */ clickable: PropTypes.bool, /** * @type string */ cursor: PropTypes.string, /** * @type boolean */ draggable: PropTypes.bool, /** * @type string|Icon|Symbol */ icon: PropTypes.any, /** * @type string|MarkerLabel */ label: PropTypes.any, /** * @type number */ opacity: PropTypes.number, /** * @type MarkerOptions */ options: PropTypes.any, /** * @type LatLng|LatLngLiteral */ position: PropTypes.any, /** * @type MarkerShape */ shape: PropTypes.any, /** * @type string */ title: PropTypes.string, /** * @type boolean */ visible: PropTypes.bool, /** * @type number */ zIndex: PropTypes.number, /** * function */ onDblClick: PropTypes.func, /** * function */ onDragEnd: PropTypes.func, /** * function */ onDragStart: PropTypes.func, /** * function */ onMouseDown: PropTypes.func, /** * function */ onMouseOut: PropTypes.func, /** * function */ onMouseOver: PropTypes.func, /** * function */ onMouseUp: PropTypes.func, /** * function */ onRightClick: PropTypes.func, /** * function */ onAnimationChanged: PropTypes.func, /** * function */ onClick: PropTypes.func, /** * function */ onClickableChanged: PropTypes.func, /** * function */ onCursorChanged: PropTypes.func, /** * function */ onDrag: PropTypes.func, /** * function */ onDraggableChanged: PropTypes.func, /** * function */ onFlatChanged: PropTypes.func, /** * function */ onIconChanged: PropTypes.func, /** * function */ onPositionChanged: PropTypes.func, /** * function */ onShapeChanged: PropTypes.func, /** * function */ onTitleChanged: PropTypes.func, /** * function */ onVisibleChanged: PropTypes.func, /** * function */ onZindexChanged: PropTypes.func } static contextTypes = { [MAP]: PropTypes.object, [MARKER_CLUSTERER]: PropTypes.object, } static childContextTypes = { [ANCHOR]: PropTypes.object, } /* * @see https://developers.google.com/maps/documentation/javascript/3.exp/reference#Marker */ constructor(props, context) { super(props, context) const marker = new google.maps.Marker() construct(Marker.propTypes, updaterMap, this.props, marker) const markerClusterer = this.context[MARKER_CLUSTERER] if (markerClusterer) { markerClusterer.addMarker(marker, !!this.props.noRedraw) } else { marker.setMap(this.context[MAP]) } this.state = { [MARKER]: marker, } } getChildContext() { return { [ANCHOR]: this.context[ANCHOR] || this.state[MARKER], } } componentDidMount() { componentDidMount(this, this.state[MARKER], eventMap) } componentDidUpdate(prevProps) { componentDidUpdate( this, this.state[MARKER], eventMap, updaterMap, prevProps ) } componentWillUnmount() { componentWillUnmount(this) const marker = this.state[MARKER] if (marker) { const markerClusterer = this.context[MARKER_CLUSTERER] if (markerClusterer) { markerClusterer.removeMarker(marker, !!this.props.noRedraw) } marker.setMap(null) } } render() { const { children } = this.props return <div>{children}</div> } /** * * @type Animation * @public */ getAnimation() { return this.state[MARKER].getAnimation(); } /** * * @type boolean * @public */ getClickable() { return this.state[MARKER].getClickable(); } /** * * @type string * @public */ getCursor() { return this.state[MARKER].getCursor(); } /** * * @type boolean * @public */ getDraggable() { return this.state[MARKER].getDraggable(); } /** * * @type string|Icon|Symbol * @public */ getIcon() { return this.state[MARKER].getIcon(); } /** * * @type MarkerLabel * @public */ getLabel() { return this.state[MARKER].getLabel(); } /** * * @type number * @public */ getOpacity() { return this.state[MARKER].getOpacity(); } /** * * @type LatLng * @public */ getPosition() { return this.state[MARKER].getPosition(); } /** * * @type MarkerShape * @public */ getShape() { return this.state[MARKER].getShape(); } /** * * @type string * @public */ getTitle() { return this.state[MARKER].getTitle(); } /** * * @type boolean * @public */ getVisible() { return this.state[MARKER].getVisible(); } /** * * @type number * @public */ getZIndex() { return this.state[MARKER].getZIndex(); } } export default Marker const eventMap = { onDblClick: "dblclick", onDragEnd: "dragend", onDragStart: "dragstart", onMouseDown: "mousedown", onMouseOut: "mouseout", onMouseOver: "mouseover", onMouseUp: "mouseup", onRightClick: "rightclick", onAnimationChanged: "animation_changed", onClick: "click", onClickableChanged: "clickable_changed", onCursorChanged: "cursor_changed", onDrag: "drag", onDraggableChanged: "draggable_changed", onFlatChanged: "flat_changed", onIconChanged: "icon_changed", onPositionChanged: "position_changed", onShapeChanged: "shape_changed", onTitleChanged: "title_changed", onVisibleChanged: "visible_changed", onZindexChanged: "zindex_changed" } const updaterMap = { animation(instance, animation) { instance.setAnimation(animation); }, clickable(instance, clickable) { instance.setClickable(clickable); }, cursor(instance, cursor) { instance.setCursor(cursor); }, draggable(instance, draggable) { instance.setDraggable(draggable); }, icon(instance, icon) { instance.setIcon(icon); }, label(instance, label) { instance.setLabel(label); }, opacity(instance, opacity) { instance.setOpacity(opacity); }, options(instance, options) { instance.setOptions(options); }, position(instance, position) { instance.setPosition(position); }, shape(instance, shape) { instance.setShape(shape); }, title(instance, title) { instance.setTitle(title); }, visible(instance, visible) { instance.setVisible(visible); }, zIndex(instance, zIndex) { instance.setZIndex(zIndex); } }