Skip to content

A container for quickstarting Leaflet projects for learners

Notifications You must be signed in to change notification settings

palermog/leaflet-quickstart

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

18 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

leaflet-quickstart

Project Demo Screenshot

A container for quickstarting Leaflet projects for learners, leaflet-quickstart provides a single webpage, index.html, that is a full-page map that can be controlled via the JavaScript file scripts.js.

The webpage loads the following extensions and makes them available to scripts.js:

  • Bootstrap for styling popups and the cards that float above the map in the #above-map container.
  • Full jQuery to provide access to the $.getJSON() method, should the learner want to download GeoJSON data from somewhere else.
  • d3, for parsing CSV files and being awesome.
  • Turf.js, an advanced geospatial analysis tool for analyzing data inside the browser.
  • Leaflet-Providers, which provides quick, configurable basemaps for Leaflet
  • Markdown-it, a Markdown parser.
  • FontAwesome, to provide icons.

Installation with Atom

  1. Fork this repository by clicking on the fork button in the top right.

  2. Next, clone your copy of this repository by clicking on the “Clone or download” button and copying the url in “Clone with HTTPS.”

  3. In Atom, open the Command palette (cmd-shift-p or ctrl-shift-p) and type in “clone.”

  4. Choose “GitHub: Clone” and paste in the url you copied above.

  5. The repository will now be cloned onto your computer. By default, on the Mac it will be saved as /Users/yourusername/github/leaflet-quickstart. On Windows, it will be in \Users\yourusername\documents\github\leaflet-quickstart. Those are important paths to keep track of for when you spin up your tiny web server below.

For questions regarding installing Atom or installing Git, see this list of installers.

Uploading and Sharing

When you commit changes and push them to GitHub, you will automatically be making a website you can share with your friends and colleagues. To do so, you must enable it, however.

  1. Click on the Settings tab at the top of this window.

  2. Scroll down to “GitHub Pages.”

  3. Change the “None” dropdown to “master branch” and click “Save.”

Now you have a url you can share along the lines of http://githubusername.github.io/leaflet-quickstart/.

Using $.getJSON() Locally

This repository is wired out of the box for you to use the $.getJSON() method to access JSON files on the internet. The signature for that method is pretty straightforward, and you can read more about it from jQuery. If you want to access files in the same folder as your index.html and scripts.js files, however, you will need to spin up a local webserver.

Note: Once your JSON files are pushed to GitHub, you can access them using the GitHub url above and stop using a local webserver, if you like.

  • On a Mac, you can spin up a web server quickishly with Python:

    1. Open up Terminal.app

    2. Find out what version of Python you have by typing: python -V (with a capital V!).

    3. If the response is 2.x, launch a server by typing python -m SimpleHTTPServer 8888

    4. If the response is 3.x, launch a server by typing python -m http:server 8888

  • On Windows,

    1. First you have to install Python. I recommend the “Windows x86-64 web-based installer.”

    2. The install takes about ten minutes.

    3. Once the install is done, you can launch the command prompt (search for “Command Prompt”) and change into the directory where you cloned the project, ...something\something\leaflet-quickstart\. Inside there, run py -m http.server 8888

Now you can access your index.html file by pointing a browser at http://localhost:8888/.

Using Markdown Files (Locally)

Using local Markdown files falls under the same rubric as using $.getJSON() above, except you have to use the more verbose $.ajax() method. Given a local Markdown file loremipsum.md in the same folder as index.html, you can have it fill the overlay card’s body by using:

const md = markdownit({html: true}).use(markdownitFootnote);
$.ajax({
  url: "loremipsum.md",
  success(bodyMarkdown) {
    $("#outlet-card-body").html(md.render(bodyMarkdown));
  }
});

Audience

This template was written in preparation for teaching a workshop at the NYU PSL Spatial Humanities Partnership workshop in 2018, “Exploring the Geographic Information of Literature and Art History” / “Cartographie numérique en littérature et en histoire de l’art”, but it also builds on the techniques demonstrated in the later chapters of The JavaScripting English Major. In other words, it is written for humanities and social sciences students eager to learn how to make web maps.

© 2018 Moacir P. de Sá Pereira. Content CC BY-SA-NC 4.0

About

A container for quickstarting Leaflet projects for learners

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • JavaScript 54.8%
  • HTML 45.2%