Skip to content

Commit

Permalink
feat(InfoWindow): component with example
Browse files Browse the repository at this point in the history
  • Loading branch information
yhsiang committed Oct 30, 2014
1 parent 365941c commit e227edf
Show file tree
Hide file tree
Showing 7 changed files with 101 additions and 4 deletions.
15 changes: 13 additions & 2 deletions client/scripts/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@ require("../styles/index.scss");
var React = require("react/addons");
var {update} = React.addons;

var {GoogleMapsMixin, Map, Marker, Polygon, Polyline} = require("../../src");
var {GoogleMapsMixin, Map, Marker, Polygon, Polyline, InfoWindow} = require("../../src");

function geometryToComponentWithLatLng (geometry) {
var typeFromThis = Array.isArray(geometry);
Expand All @@ -27,6 +27,7 @@ function geometryToComponentWithLatLng (geometry) {
coordinates = new google.maps.LatLng(coordinates[1], coordinates[0]);
return typeFromThis ? coordinates : {
Component: Marker,
ChildComponent: InfoWindow,
position: coordinates
};
default:
Expand All @@ -50,10 +51,15 @@ var Body = React.createClass({
onZoomChanged: this._handle_map_zoom_changed
},
1: {
ref: "centerMarker",
visible: true,
draggable: true,
onDragend: this._handle_marker_dragend,
onClick: this._handle_marker_click
onClick: this._handle_marker_click,
child: {
content: "Bermuda Triangle",
owner: "centerMarker"
}
},
3: {
onRightclick: this._handle_polygon_rightclick
Expand Down Expand Up @@ -172,6 +178,11 @@ var Body = React.createClass({
$merge: geoStatesOfFeature
});
}
if (style.child) {
var {ChildComponent} = result;
delete result.ChildComponent;
return Component(style, ChildComponent(style.child));
}
return Component(style);
});

Expand Down
3 changes: 2 additions & 1 deletion package.json
Original file line number Diff line number Diff line change
Expand Up @@ -55,7 +55,8 @@
"webpack-dev-server": "^1.6.5"
},
"dependencies": {
"react": "^0.11.0"
"react": "^0.11.0",
"deep-equal": "^0.2.1"
},
"jest": {
"scriptPreprocessor": "<rootDir>/test/__preprocessor__.js",
Expand Down
6 changes: 6 additions & 0 deletions src/GoogleMapsMixin.js
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,7 @@ module.exports = {
getMap: React.PropTypes.func,
getApi: React.PropTypes.func,
hasMap: React.PropTypes.func,
getRef: React.PropTypes.func,
_set_map: React.PropTypes.func
},

Expand All @@ -23,6 +24,7 @@ module.exports = {
getMap: this._get_map,
getApi: this._get_api,
hasMap: this._has_map,
getRef: this._get_ref,
_set_map: this._set_map
};
},
Expand All @@ -39,6 +41,10 @@ module.exports = {
return !!this._get_map();
},

_get_ref (key) {
return this.refs[key];
},

_set_map (map) {
this.setState({ map });
return map;
Expand Down
73 changes: 73 additions & 0 deletions src/InfoWindow.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,73 @@
/** @jsx React.DOM */
"use strict";
var React = require("react/addons");

var ChildMixin = require("./mixins/ChildMixin");
var EventBindingMixin = require("./mixins/EventBindingMixin");

module.exports = React.createClass({
displayName: "InfoWindow",

mixins: [ChildMixin, EventBindingMixin],

getInitialState () {
return {
infowindow: null
};
},

componentDidMount () {
var infowindow = this._init_infowindow();
if (!infowindow) return;
this.add_listeners(infowindow);
},

componentWillUpdate () {
var {infowindow} = this.state;
if (!infowindow) return;
this.clear_listeners(infowindow);
},

componentDidUpdate () {
var infowindow = this._init_infowindow();
if (!infowindow) return;
this.add_listeners(infowindow);
infowindow.setOptions(this.props);
},

componentWillUnmount () {
var {infowindow} = this.state;
if(!infowindow) return;
this.clear_listeners(infowindow);
this.setState({ infowindow: null });
},

render () {
return this._render(this.props, this.state);
},

get_event_names () {
return "click dblclick drag dragend dragstart mousedown mousemove mouseout mouseover mouseup rightclick";
},

_init_infowindow () {
var {context} = this;
var {infowindow} = this.state;
if(infowindow || !context.hasMap() || !context.getApi()) {
return infowindow;
}
var {InfoWindow} = context.getApi();
if (this.props.owner) {
var {marker} = context.getRef(this.props.owner).state;
}
infowindow = new InfoWindow(this.props);
infowindow.open(context.getMap(), marker);
this.expose_getters_from(InfoWindow.prototype, infowindow);
this.setState({ infowindow });
return infowindow;
},

_render (props, state) {
return null;
}
});
2 changes: 1 addition & 1 deletion src/Marker.js
Original file line number Diff line number Diff line change
Expand Up @@ -66,6 +66,6 @@ module.exports = React.createClass({
},

_render (props, state) {
return null;
return (props.children)? props.children : null;
}
});
1 change: 1 addition & 0 deletions src/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -5,3 +5,4 @@ exports.Map = require("./Map");
exports.Marker = require("./Marker");
exports.Polygon = require("./Polygon");
exports.Polyline = require("./Polyline");
exports.InfoWindow = require("./InfoWindow");
5 changes: 5 additions & 0 deletions src/mixins/ChildMixin.js
Original file line number Diff line number Diff line change
@@ -1,17 +1,22 @@
/** @jsx React.DOM */
"use strict";
var React = require("react/addons");
var deepEqual = require("deep-equal");

module.exports = {

shouldComponentUpdate(nextProps, nextState) {
if (this.props.children) {
return deepEqual(nextProps, this.props);
}
return JSON.stringify(nextProps) !== JSON.stringify(this.props);
},

contextTypes: {
getMap: React.PropTypes.func,
getApi: React.PropTypes.func,
hasMap: React.PropTypes.func,
getRef: React.PropTypes.func
},

expose_getters_from (prototype, instance) {
Expand Down

0 comments on commit e227edf

Please sign in to comment.