Skip to content
Karl Kim edited this page May 6, 2015 · 8 revisions

Mr. Mr. Mappy Start Up Guide

1. Branch Specification

  1. master branch is for Typescript project. Visual Studio project file is uploaded together. To use Typescript version, install Visual Studio 2013 (Community version is possible), and install Typescript through http://www.typescriptlang.org/. Also you might want to install Web Essentials through http://vswebessentials.com/.
  2. JavaScript branch is for pure JavaScript project. It's the same branch as master branch, I just take out Typescript files, and import JavaScript files separately in index.html file. You can edit JavaScript files in any text editor.

2. Basic Setup

  1. Download or clone either (master branch / JavaScript branch). You can see [DIR]/mr.mappy/ folder which has 'index.html' file and other folders, such as 'content', 'core', 'favicons', etc. This is your root folder of application.
  2. Go to [DIR]/mr.mappy/core/php/ folder, and open 'database.php' file with text editor, or Visual Studio. There are four variables; '$host', '$username', '$password', '$db_name'. Usually php server blocks cross domain, you may not need to change '$host' variable. However, you need to change other variables into the server information that you have. For '$db_name', you can put the database name that you already have, or put a new one. Database creation code will generate automatically if there is no database in your server.
  3. Upload [DIR]/mr.mappy/ folders into your server.
  4. type this in your browser address box. [HOST]/mr.mappy/core/php/_createdatabase.php You will see the message that database and tables are created. If you get an error message, check again the 'database.php' and make sure you put the right server information. (Sometimes, server doesn't let certain user create new database.)
  5. If you got an error, or for some other reason, you might want to delete tables that you created. If you put [HOST]/mr.mappy/core/php/_dropdatabase.php, all tables will be dropped.
  6. After you setup database, enter [HOST]/mr.mappy in your browser address box, and check the map and data will be shown correctly.
  7. make sure change the permission of [HOST]/mr.mappy/content/picture folder into 777, unless the picture file will not be uploaded.
  8. When the basic setup is done, I seriously recommend you to delete '_createdatabase.php', '_dropdatabase.php', and '_mappy.sql' under [HOST]/mr.mappy/core/php/ folder. Since those files can manipulate server data easily, it's better idea to remove from your server.

3. Program Structure

Mr. Mappy Class Diagram

4. Useful Reference

  1. http://backbonejs.org/ - Ajax communication between client and server performed through backbone.js structure.
  2. http://wiki.openstreetmap.org/wiki/Tile_servers - I use OpenStreepMap, and there are several tile maps that you can use. To change tile map, find the tile map server from the link and change 'tileMapAddress' value in [DIR]/core/json/setting.json file.
  3. https://github.com/makinacorpus/Leaflet.TextPath - I use TextPath plug-in for leaflet to render arrow path for showing donation flows.
  4. http://leafletjs.com/ - Leaflet (version 0.7.3) (I used version 0.7.3 even though version 0.8-dev is more stable in mobile environment since TextPath plug-in only works in 0.7.3 for now. So think carefully if you decided to change the version of leaflet.)
Clone this wiki locally