Skip to content

Latest commit

 

History

History
101 lines (67 loc) · 4.77 KB

README.md

File metadata and controls

101 lines (67 loc) · 4.77 KB

A weather app to show weather forecasting using Dark Sky, reactjs, and plotly.js.

Note Dark Sky server doesn't enable CORS. So there are two options to request data from its API:

  • JSONP
  • Proxy API Server (to proxy client requests to Dark Sky server)

The Proxy API Server option (implemented by this project) has the advantage of not only bypassing CORS issue but also hiding the Dark Sky API secret key.

Here's a screenshot:

alt text

As soon as the application loads, it will attempt to request the Geolocation information, and show weather forecasting for the location.

End user can also enter a location (e.g. a city or a zipcode) and hit enter key, the application will first look up the coordinates(latitude/longitude) from Google Maps Geocoding API, and then request the Dark Sky weather data via the Proxy API Server.

Technologies used:

Getting Started

Thanks to create-react-app, we will have a configuration-free dev experience.

To get started, please clone this git repository and then run npm install once under the project top-level directory.

git clone https://github.com/cloudmu/darksky.git
cd darksky
npm install

This will install the dependencies for the client side.

You’ll need to have Node installed on your machine. (Node >= 6 and npm >= 3 are recommended).

While You're Developing...

Whenever you want to run/test the program, cd to the project top-level directory. Use these commands:

npm start

Runs the app in the development mode, using the Webpack-provided "development server".
Open http://localhost:3000 to view it in the browser.

The page will reload if you make edits.
You will also see any lint errors in the console.

Note The web app is up and running now, but the weather data requests rely on the Proxy API Server. Be sure to run the Proxy API Server as well.

npm run build

Builds the app for production to the build folder.
It correctly bundles React in production mode and optimizes the build for the best performance.

The build is minified and the filenames include the hashes.
Your app is ready to be deployed!

npm run eject

Note: eject is an advanced create-react-app tool. Read the how-to for details.

An API Server

The text and scripts above describe the client-side code that is displayed in the web browser. They rely on the Webpack-provided development server that runs on port 3000.

This project also contains a separate Proxy API server that runs on a different port (3001). The Proxy API server will be listening to the client requests for weather, and proxying the requests to Dark Sky API.

First you need to open a separate command line window, and run npm install under the project's server directory.

cd darksky
cd server
npm install

Then you can start the API server (under the project's server directory):

npm run server

This starts the API server on port 3001, which listens for requests from the client, and proxies to Dark Sky API. This approach has several benefits, for example: hide the Dark Sky API key, and avoid CORS issues as well.

Note you need to sign up a free Dark Sky API secret key, and replace the one in server.js.

How Do I ... ?

This project was created with create-react-app for handling all assets. Many questions are answered in its how-to.