Skip to content

🗺 Maps is the MediaWiki extension that enables visualization of geographic data with dynamic embedded maps.

License

Notifications You must be signed in to change notification settings

ProfessionalWiki/Maps

Folders and files

NameName
Last commit message
Last commit date

Latest commit

ed9f469 Â· Dec 13, 2019
Dec 12, 2019
Dec 13, 2019
Dec 13, 2019
Dec 9, 2019
May 17, 2018
Mar 27, 2014
Aug 1, 2019
Oct 18, 2019
May 15, 2012
Dec 11, 2019
Dec 13, 2019
Oct 11, 2017
Jul 27, 2018
Dec 16, 2018
Dec 16, 2018
Oct 6, 2019
Dec 13, 2019
Dec 11, 2019
Dec 13, 2019
Nov 21, 2018

Repository files navigation

Maps

Maps is the MediaWiki extension to visualize and work with geographical information. It has been maintained since 2009 and is installed on 1000+ wikis.

Features:

  • Powerful #display_map parser hook for embedding highly customizable dynamic maps into wiki pages.
  • Support for multiple mapping services: Leaflet, Google Maps and OpenStreetMap.
  • Integration with Semantic MediaWiki via a coordinate datatype
    • Query your stored coordinates and visualize them on dynamic maps, as tables or as lists
    • Export your coordinates as KML or RDF
    • Combine coordinates with other structured data stored in your wiki
  • Geocoding via several supported services with the #geocode parser function.
  • GeoJson support including a basic visual editor
  • Coordinate formatting and format conversion via the #coordinates parser function.
  • Geospatial operations
    • Calculating the distance between two points with #geodistance
    • Finding a destination given a starting point, bearing and distance with #finddestination
  • Distance formatting and format conversion via the #distance parser function.
  • Visual map editor (Special:MapEditor) to edit #display_map wikitext (requires Google Maps).

Missing a feature? Professional.Wiki does custom development at a discount if it is open sourced.

User manual

For administrators

For wiki users

Getting support

Project status

Contributing

Project structure

The src/ contains the PHP code and follows PSR-4 autoloading.

  • src/DataAccess - implementations of services that use the network, read from disk or persistence services
  • src/Elements - Value Objects representing geographical elements (should be devoid of MediaWiki binding)
  • src/MediaWiki - MediaWiki hook points, including API modules, special pages and MediaWiki hooks
  • src/Presentation - presentation layer code (all code dealing with HTML etc should be here)
  • src/SemanticMW - Semantic MediaWiki hook points, including result printers and value descriptions

JavaScript, CSS and other web resources go into resources/.

Tests for PHP go into tests/ where they are grouped by test type (ie unit, integration). Within those test type directories the tests should mirror the directory structure in src/.

Running the tests

As setup, run composer install inside of the Maps root directory.

You can run the MediaWiki independent tests by executing phpunit in the root directory of maps:

phpunit

This is possible without having a MediaWiki installation or webserver. A clone of the Maps code suffices.

If you do not have PHPUnit installed, you can download the .phar into the root directory and execute it there:

wget -O phpunit.phar https://phar.phpunit.de/phpunit-7.phar
php phpunit.phar

To run the tests with MediaWiki, change into tests/phpunit of your MediaWiki installation and run

php phpunit.php --wiki wiki -c ../../extensions/Maps/phpunit.xml.dist

Where you either update wiki to match your wikis name, or drop the parameter. The above command works without modification if you are using the MediaWiki Vagrant.

Beware that due to technical debt, some tests access the network.

Links