Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/derhuerst/svg-world-map
Show a location on a world map.
https://github.com/derhuerst/svg-world-map
dataviz svg virtual-dom
Last synced: about 1 month ago
JSON representation
Show a location on a world map.
- Host: GitHub
- URL: https://github.com/derhuerst/svg-world-map
- Owner: derhuerst
- License: isc
- Created: 2016-11-01T00:31:45.000Z (over 8 years ago)
- Default Branch: master
- Last Pushed: 2020-05-12T04:55:46.000Z (almost 5 years ago)
- Last Synced: 2024-10-03T23:57:52.332Z (5 months ago)
- Topics: dataviz, svg, virtual-dom
- Language: JavaScript
- Homepage: http://jannisr.de/svg-world-map/
- Size: 359 KB
- Stars: 19
- Watchers: 3
- Forks: 6
- Open Issues: 9
-
Metadata Files:
- Readme: readme.md
- License: license.md
Awesome Lists containing this project
README
# [svg-world-map](https://derhuerst.github.io/svg-world-map/)
**Render a world map with a pin at a specific location.** Fiddle with it on [the website](https://derhuerst.github.io/svg-world-map/).
data:image/s3,"s3://crabby-images/37d24/37d244d18660d0594f2fdf5a8e4a28e438e23887" alt="map with pin at Berlin"
[data:image/s3,"s3://crabby-images/bc0bf/bc0bf99883656bfc8e6e0abdf7aba413491aa1f6" alt="npm version"](https://www.npmjs.com/package/svg-world-map)
[data:image/s3,"s3://crabby-images/74d51/74d51fa8509fd08bd1f8f4fb6235f87ceed1a171" alt="build status"](https://travis-ci.org/derhuerst/svg-world-map)
[data:image/s3,"s3://crabby-images/f52df/f52df95fcb2172cf168acb5ac18a009821e19049" alt="dependency status"](https://david-dm.org/derhuerst/svg-world-map)
[data:image/s3,"s3://crabby-images/5e980/5e98094a7203fdcd5dd94348b23b31cc39dfc513" alt="dev dependency status"](https://david-dm.org/derhuerst/svg-world-map#info=devDependencies)
data:image/s3,"s3://crabby-images/bd326/bd32645e5d84994bd0e4c0b254b495d668e9d100" alt="ISC-licensed"
[data:image/s3,"s3://crabby-images/25cb6/25cb67195bb52ce9090f00dc4e395466c9769b2f" alt="chat on gitter"](https://gitter.im/derhuerst)
[data:image/s3,"s3://crabby-images/8094b/8094b83d635c22e8af9b931cfd2cb06f18faffbc" alt="support me on Patreon"](https://patreon.com/derhuerst)`svg-world-map` returns a [virtual-dom](https://github.com/Matt-Esch/virtual-dom#dom-model) `` node. You can either stringify it into a file or embed it into your Frontend stack.
Note that because shapes of all countries are quite a lot of data, this module weighs **roughly `43k`** when [browserified](http://browserify.org), [minified](https://github.com/mishoo/UglifyJS2#uglifyjs-2) and gzipped.
The data is from [world.geo.json](https://github.com/johan/world.geo.json).
## Installing
```shell
npm install svg-world-map
```## Usage
```js
const map = require('svg-world-map')
const stringify = require('virtual-dom-stringify')const myMap = map(81.8, 28.4) // Nepal
process.stdout.write(stringify(myMap))
```## API
```
map(longitude, latitude, [opt])
````opt` is optional and has the following default values:
```js
const defaults = {
ocean: '#8df', // color of the ocean
land: 'white', // color of the land
mapWidth: 500, // width of the ``
pin, // virtual dom node with the pin
pinHeight: 8 // relative to map viewBox
}
```## See also
- [`svg-patterns`](https://github.com/derhuerst/svg-patterns) – Create SVG patterns programmatically to visualize data.
- [`svg-radar-chart`](https://github.com/derhuerst/svg-radar-chart) – A reusable radar chart in SVG.## Contributing
`npm test` is a regression test: It compares the generated output, to a `example/berlin.svg`, which has been manually checked by me. If you introduce a change that changes the output, *check it manually* and commit it as `example/berlin.svg`.
If you **have a question**, **found a bug** or want to **propose a feature**, have a look at [the issues page](https://github.com/derhuerst/svg-world-map/issues).