From 1d0efc758bc9404eebbc8b8d592de9dbb329899e Mon Sep 17 00:00:00 2001
From: François Frisch
Date: Sat, 17 Mar 2012 11:21:22 -0700
Subject: Adding feed reader and map
---
.../ui/feed-reader/feed-entry.reel/feed-entry.html | 90 +++++++
.../ui/feed-reader/feed-entry.reel/feed-entry.js | 13 +
.../feed-reader/feed-reader.reel/feed-reader.html | 83 ++++++
.../ui/feed-reader/feed-reader.reel/feed-reader.js | 82 ++++++
node_modules/montage/ui/map.reel/map.css | 9 +
node_modules/montage/ui/map.reel/map.html | 58 +++++
node_modules/montage/ui/map.reel/map.js | 283 +++++++++++++++++++++
node_modules/montage/ui/template.js | 6 +-
8 files changed, 621 insertions(+), 3 deletions(-)
create mode 100644 node_modules/montage/ui/feed-reader/feed-entry.reel/feed-entry.html
create mode 100644 node_modules/montage/ui/feed-reader/feed-entry.reel/feed-entry.js
create mode 100644 node_modules/montage/ui/feed-reader/feed-reader.reel/feed-reader.html
create mode 100644 node_modules/montage/ui/feed-reader/feed-reader.reel/feed-reader.js
create mode 100644 node_modules/montage/ui/map.reel/map.css
create mode 100644 node_modules/montage/ui/map.reel/map.html
create mode 100644 node_modules/montage/ui/map.reel/map.js
(limited to 'node_modules/montage/ui')
diff --git a/node_modules/montage/ui/feed-reader/feed-entry.reel/feed-entry.html b/node_modules/montage/ui/feed-reader/feed-entry.reel/feed-entry.html
new file mode 100644
index 00000000..213b4602
--- /dev/null
+++ b/node_modules/montage/ui/feed-reader/feed-entry.reel/feed-entry.html
@@ -0,0 +1,90 @@
+
+
+
+
+ Feed Entry
+
+
+
+
+
+
+
+
+
+
+
diff --git a/node_modules/montage/ui/feed-reader/feed-entry.reel/feed-entry.js b/node_modules/montage/ui/feed-reader/feed-entry.reel/feed-entry.js
new file mode 100644
index 00000000..3d97eec7
--- /dev/null
+++ b/node_modules/montage/ui/feed-reader/feed-entry.reel/feed-entry.js
@@ -0,0 +1,13 @@
+/*
+ This file contains proprietary software owned by Motorola Mobility, Inc.
+ No rights, expressed or implied, whatsoever to this software are provided by Motorola Mobility, Inc. hereunder.
+ (c) Copyright 2011 Motorola Mobility, Inc. All Rights Reserved.
+ */
+var Montage = require("montage").Montage,
+ Component = require("ui/component").Component;
+
+exports.FeedEntry = Montage.create(Component, {
+
+ entry: {value: null}
+
+});
diff --git a/node_modules/montage/ui/feed-reader/feed-reader.reel/feed-reader.html b/node_modules/montage/ui/feed-reader/feed-reader.reel/feed-reader.html
new file mode 100644
index 00000000..a3523001
--- /dev/null
+++ b/node_modules/montage/ui/feed-reader/feed-reader.reel/feed-reader.html
@@ -0,0 +1,83 @@
+
+
+
+
+ Feed Reader
+
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/node_modules/montage/ui/feed-reader/feed-reader.reel/feed-reader.js b/node_modules/montage/ui/feed-reader/feed-reader.reel/feed-reader.js
new file mode 100644
index 00000000..838a957d
--- /dev/null
+++ b/node_modules/montage/ui/feed-reader/feed-reader.reel/feed-reader.js
@@ -0,0 +1,82 @@
+/*
+ This file contains proprietary software owned by Motorola Mobility, Inc.
+ No rights, expressed or implied, whatsoever to this software are provided by Motorola Mobility, Inc. hereunder.
+ (c) Copyright 2011 Motorola Mobility, Inc. All Rights Reserved.
+ */
+var Montage = require("montage").Montage,
+ Component = require("ui/component").Component;
+ //Notifier = require("ui/popup/notifier.reel").Notifier;
+
+exports.FeedReader = Montage.create(Component, {
+
+ didCreate: {
+ value: function() {
+ var self = this;
+ var apiInit = function() {
+ console.log('google api initialized');
+
+ google.load("feeds", "1", {
+ callback: function() {
+ console.log('google feeds api loaded');
+ self.needsDraw = true;
+ window.initGoogleAPI = null;
+ }
+ });
+ };
+
+ // set up a global function
+ window.initGoogleAPI = apiInit;
+ }
+ },
+
+ _feedURL: {value: null},
+ feedURL: {
+ get: function() {
+ return this._feedURL;
+ },
+ set: function(value) {
+ this._feedURL = value;
+ // execute the search and get the entries
+ this._fetchFeed();
+ }
+ },
+
+ entries: {value: null},
+
+
+ _startLoading: {
+ value: function() {
+ //Notifier.show('Loading ... please wait', null, {top: this.element.style.top, left: this.element.style.left + 20});
+ }
+ },
+
+ _stopLoading: {
+ value: function() {
+ //Notifier.hide();
+ }
+ },
+
+ _fetchFeed: {
+ value: function() {
+ var url = this.feedURL;
+ var feed = new google.feeds.Feed(url);
+ feed.setNumEntries(10);
+
+ var self = this;
+
+ this._startLoading();
+ self.entries = [];
+
+ feed.load(function(result) {
+ self._stopLoading();
+ if(result.error) {
+ self.entries = [];
+ } else {
+ //console.log('entries: ', result.feed.entries);
+ self.entries = result.feed.entries;
+ }
+ });
+ }
+ }
+
+});
diff --git a/node_modules/montage/ui/map.reel/map.css b/node_modules/montage/ui/map.reel/map.css
new file mode 100644
index 00000000..45307593
--- /dev/null
+++ b/node_modules/montage/ui/map.reel/map.css
@@ -0,0 +1,9 @@
+/*
+ This file contains proprietary software owned by Motorola Mobility, Inc.
+ No rights, expressed or implied, whatsoever to this software are provided by Motorola Mobility, Inc. hereunder.
+ (c) Copyright 2011 Motorola Mobility, Inc. All Rights Reserved.
+ */
+.montage-google-map {
+ width: 100%;
+ height: 100%;
+}
\ No newline at end of file
diff --git a/node_modules/montage/ui/map.reel/map.html b/node_modules/montage/ui/map.reel/map.html
new file mode 100644
index 00000000..a6ac5303
--- /dev/null
+++ b/node_modules/montage/ui/map.reel/map.html
@@ -0,0 +1,58 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ Show:
+
+
+
MAP
+
+
+
+
+
diff --git a/node_modules/montage/ui/map.reel/map.js b/node_modules/montage/ui/map.reel/map.js
new file mode 100644
index 00000000..1e4f452c
--- /dev/null
+++ b/node_modules/montage/ui/map.reel/map.js
@@ -0,0 +1,283 @@
+/*
+ This file contains proprietary software owned by Motorola Mobility, Inc.
+ No rights, expressed or implied, whatsoever to this software are provided by Motorola Mobility, Inc. hereunder.
+ (c) Copyright 2011 Motorola Mobility, Inc. All Rights Reserved.
+ */
+/**
+
+ @requires montage/core/core
+ @requires montage/ui/component
+*/
+var Montage = require("montage").Montage,
+ Component = require("ui/component").Component;
+
+/**
+ @class module:"montage/ui/google/map.reel".Map
+ @extends module:montage/ui/component.Component
+ */
+var Map = exports.Map = Montage.create(Component, /** @lends module:"montage/ui/toggle-switch.reel".ToggleSwitch# */ {
+
+ didCreate: {
+ value: function() {
+ var self = this;
+ window.initialize = function initialize() {
+ console.log('google maps api loaded');
+ self._mapLoaded = true;
+ self._geoCoder = new google.maps.Geocoder();
+ self.needsDraw = true;
+ };
+ }
+ },
+
+ _geoCoder: {value: null},
+
+ // HTMLElement to load the Map into
+ mapEl: {value: null},
+
+ _mapLoaded: {
+ enumerable: false,
+ value: false
+ },
+ _map: {
+ enumerable: false,
+ value: false
+ },
+ _latitude: {
+ enumerable: false,
+ value: -34.397
+ },
+ latitude: {
+ enumerable: false,
+ set: function(value) {
+ this._latitude = value;
+ this.needsDraw = true;
+ },
+ get: function() {
+ return this._latitude;
+ }
+ },
+ _longitude: {
+ enumerable: false,
+ value: -34.397
+ },
+ longitude: {
+ enumerable: false,
+ set: function(value) {
+ this._longitude = value;
+ this.needsDraw = true;
+ },
+ get: function() {
+ return this._longitude;
+ }
+ },
+
+ defaultLatLng: {
+ value: {lat: -34.397, lng: 150.644}
+ },
+
+ _latLng: {
+ value: this.defaultLatLng,
+ distinct: true
+ },
+ latLng: {
+ get: function() {
+ return this._latLng;
+ },
+ set: function(value) {
+ if(value) {
+ this._latLng = value;
+ // refresh the map
+ this.needsDraw = true;
+ }
+ }
+ },
+
+ // {lat, lon} Or a String representing the location (eg: Paris, France)
+ center: {
+ get: function() {
+ return this._center;
+ },
+ set: function(value) {
+ if(value) {
+ var self = this, geocoder = this._geoCoder;
+ this._center = value;
+ if(this._mapLoaded) {
+
+ if(String.isString(value)) {
+ // geocode
+ geocoder.geocode( { 'address': value}, function(results, status) {
+ if (status == google.maps.GeocoderStatus.OK) {
+ var loc = results[0].geometry.location;
+ self.latLng = {lat: loc.lat(), lng: loc.lng()};
+ } else {
+ console.log('Geocode was not successful : ' + status);
+ }
+ });
+ } else if(value.lat && value.lng) {
+ this.latLng = value;
+ } else {
+ // default location
+ this.latLng = this.defaultLatLng;
+ }
+
+ }
+
+ }
+
+ }
+ },
+
+ category: {
+ get: function() {
+ return this._category;
+ },
+ set: function(value) {
+ if(value) {
+ this._category = value;
+ this._getPlaces(this._category);
+ this.needsDraw = true;
+ }
+ }
+ },
+
+ zoom: {
+ value: 8
+ },
+
+ __places: {value: null},
+ _places: {
+ get: function() {
+ return this.__places;
+ },
+ set: function(value) {
+ if(value) {
+ this.__places = value;
+ this.needsDraw = true;
+ }
+ }
+ },
+
+ _getPlaces: {
+ value: function(type, keyword) {
+ var self = this;
+ var request = {
+ location: new window.google.maps.LatLng(this.latLng.lat, this.latLng.lng),
+ radius: 5000,
+ types: [type]
+ };
+ if(!this._infoWindow) {
+ this._infoWindow = new google.maps.InfoWindow();
+ }
+ var service = new google.maps.places.PlacesService(this._map);
+ service.search(request, function(results, status) {
+ if (status == google.maps.places.PlacesServiceStatus.OK) {
+ self._places = results;
+ } else {
+ self._places = [];
+ }
+ });
+ }
+ },
+
+ _infoWindow: {value: null},
+ _markers: {value: null},
+ _createMarker: {
+ value: function(place) {
+ var placeLoc = place.geometry.location, map = this._map;
+ var icon, image;
+ switch(this.category) {
+ case 'restaurant':
+ icon = '48-fork-and-knife.png';
+ break;
+ case 'hospital':
+ icon = '10-medical.png';
+ break;
+ case 'cafe':
+ icon = '34-coffee.png';
+ break;
+ case 'museum':
+ icon = '41-picture-frame.png';
+ break;
+ };
+ if(icon) {
+ image = new google.maps.MarkerImage('images/' + icon);
+ }
+ var options = {
+ map: map,
+ position: place.geometry.location
+ };
+ if(image) {
+ options.icon = image;
+ }
+
+ var marker = new google.maps.Marker(options);
+ if(!this._markers) {
+ this._markers = [];
+ }
+ this._markers.push(marker);
+
+ var infoWindow = this._infoWindow;
+ google.maps.event.addListener(marker, 'click', function() {
+ infoWindow.setContent(place.name + '
' + place.vicinity);
+ infoWindow.open(map, this);
+ });
+ }
+ },
+
+ _removeAllMarkers: {
+ value: function() {
+ if(this._markers && this._markers.length > 0) {
+ var i=0, len = this._markers.length;
+ for(i; i< len; i++) {
+ this._markers[i].setMap(null);
+ }
+ this._markers = [];
+ }
+ }
+ },
+
+
+/**
+ Description TODO
+ @function
+ */
+ draw: {
+ enumerable: false,
+ value: function () {
+
+ if(this._mapLoaded) {
+ var latLng = this.latLng || this.defaultLatLng;
+ if(!this._map) {
+ var map;
+ var myOptions = {
+ zoom: this.zoom,
+ center: new window.google.maps.LatLng(latLng.lat, latLng.lng),
+ mapTypeId: window.google.maps.MapTypeId.ROADMAP
+ };
+
+ this._map = new window.google.maps.Map(this.mapEl, myOptions);
+ } else {
+ var map = this._map;
+ map.setZoom(12);
+ var latLng = new window.google.maps.LatLng(latLng.lat, latLng.lng);
+ map.setCenter(latLng);
+ var marker = new google.maps.Marker({
+ map: map,
+ position: latLng
+ });
+
+ var places = this._places;
+ if(places && places.length > 0) {
+ this._removeAllMarkers();
+ for (var i = 0; i < places.length; i++) {
+ this._createMarker(places[i]);
+ }
+ }
+ }
+
+ }
+
+ //window.google.maps.event.addDomListener(window, 'load', initialize);
+ }
+ }
+});
diff --git a/node_modules/montage/ui/template.js b/node_modules/montage/ui/template.js
index c6589b35..210d8cb7 100755
--- a/node_modules/montage/ui/template.js
+++ b/node_modules/montage/ui/template.js
@@ -438,7 +438,7 @@ var Template = exports.Template = Montage.create(Montage, /** @lends module:mont
for (var i = 0, cssTag; (cssTag = cssTags[i]); i++) {
if ((url = cssTag.getAttribute("href"))) {
- if (! /^http:\/\/|^\//.test(url)) { // TODO: look into base links...
+ if (! /^https?:\/\/|^\//.test(url)) { // TODO: look into base links...
url = rootUrl + url;
}
@@ -547,7 +547,7 @@ var Template = exports.Template = Montage.create(Montage, /** @lends module:mont
src = script.getAttribute("src");
scriptNode = doc.importNode(script, true);
if (src) {
- if (! /^http:\/\/|^\//.test(src)) { // TODO: look into base links...
+ if (! /^https?:\/\/|^\//.test(src)) { // TODO: look into base links...
scriptNode.src = src = rootUrl + src;
}
if (src in externalScriptsLoaded) continue;
@@ -688,7 +688,7 @@ var Template = exports.Template = Montage.create(Montage, /** @lends module:mont
url = link.getAttribute("href"),
rootUrl = this._rootUrl ? this._rootUrl[0] : "";
- if (! /^http:\/\/|^\//.test(url)) {
+ if (! /^https?:\/\/|^\//.test(url)) {
url = rootUrl + url;
}
--
cgit v1.2.3