columbus3 0.4.0 → 0.5.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/.gitignore +1 -1
- data/README.md +122 -0
- data/bin/console +0 -0
- data/bin/setup +0 -0
- data/bower.json +25 -0
- data/bower_components/jquery/.bower.json +7 -20
- data/bower_components/jquery/AUTHORS.txt +301 -0
- data/bower_components/jquery/{MIT-LICENSE.txt → LICENSE.txt} +17 -2
- data/bower_components/jquery/README.md +67 -0
- data/bower_components/jquery/bower.json +2 -16
- data/bower_components/jquery/dist/core.js +476 -0
- data/bower_components/jquery/dist/jquery.js +3861 -2818
- data/bower_components/jquery/dist/jquery.min.js +4 -5
- data/bower_components/jquery/dist/jquery.min.map +1 -1
- data/bower_components/jquery/dist/jquery.slim.js +8160 -0
- data/bower_components/jquery/dist/jquery.slim.min.js +4 -0
- data/bower_components/jquery/dist/jquery.slim.min.map +1 -0
- data/bower_components/jquery/external/sizzle/LICENSE.txt +36 -0
- data/bower_components/jquery/{src → external}/sizzle/dist/sizzle.js +445 -240
- data/bower_components/jquery/external/sizzle/dist/sizzle.min.js +3 -0
- data/bower_components/jquery/external/sizzle/dist/sizzle.min.map +1 -0
- data/bower_components/jquery/src/.eslintrc.json +5 -0
- data/bower_components/jquery/src/ajax.js +174 -105
- data/bower_components/jquery/src/ajax/jsonp.js +27 -14
- data/bower_components/jquery/src/ajax/load.js +24 -23
- data/bower_components/jquery/src/ajax/parseXML.js +8 -6
- data/bower_components/jquery/src/ajax/script.js +25 -12
- data/bower_components/jquery/src/ajax/var/location.js +5 -0
- data/bower_components/jquery/src/ajax/var/nonce.js +4 -2
- data/bower_components/jquery/src/ajax/var/rquery.js +5 -3
- data/bower_components/jquery/src/ajax/xhr.js +76 -43
- data/bower_components/jquery/src/attributes.js +4 -2
- data/bower_components/jquery/src/attributes/attr.js +60 -60
- data/bower_components/jquery/src/attributes/classes.js +87 -71
- data/bower_components/jquery/src/attributes/prop.js +81 -32
- data/bower_components/jquery/src/attributes/support.js +11 -13
- data/bower_components/jquery/src/attributes/val.js +66 -37
- data/bower_components/jquery/src/callbacks.js +119 -90
- data/bower_components/jquery/src/core.js +108 -134
- data/bower_components/jquery/src/core/DOMEval.js +16 -0
- data/bower_components/jquery/src/core/access.js +21 -11
- data/bower_components/jquery/src/core/init.js +33 -28
- data/bower_components/jquery/src/core/nodeName.js +13 -0
- data/bower_components/jquery/src/core/parseHTML.js +39 -13
- data/bower_components/jquery/src/core/ready-no-deferred.js +96 -0
- data/bower_components/jquery/src/core/ready.js +40 -51
- data/bower_components/jquery/src/core/readyException.js +13 -0
- data/bower_components/jquery/src/core/stripAndCollapse.js +14 -0
- data/bower_components/jquery/src/core/support.js +20 -0
- data/bower_components/jquery/src/core/var/rsingleTag.js +5 -3
- data/bower_components/jquery/src/css.js +146 -158
- data/bower_components/jquery/src/css/addGetHookIf.js +7 -3
- data/bower_components/jquery/src/css/adjustCSS.js +71 -0
- data/bower_components/jquery/src/css/curCSS.js +22 -14
- data/bower_components/jquery/src/css/hiddenVisibleSelectors.js +8 -8
- data/bower_components/jquery/src/css/showHide.js +105 -0
- data/bower_components/jquery/src/css/support.js +69 -76
- data/bower_components/jquery/src/css/var/cssExpand.js +4 -2
- data/bower_components/jquery/src/css/var/getStyles.js +11 -6
- data/bower_components/jquery/src/css/var/isHiddenWithinTree.js +34 -0
- data/bower_components/jquery/src/css/var/rmargin.js +5 -3
- data/bower_components/jquery/src/css/var/rnumnonpx.js +4 -2
- data/bower_components/jquery/src/css/{swap.js → var/swap.js} +5 -7
- data/bower_components/jquery/src/data.js +67 -66
- data/bower_components/jquery/src/data/Data.js +87 -107
- data/bower_components/jquery/src/data/{accepts.js → var/acceptData.js} +6 -7
- data/bower_components/jquery/src/data/var/{data_priv.js → dataPriv.js} +4 -2
- data/bower_components/jquery/src/data/var/{data_user.js → dataUser.js} +4 -2
- data/bower_components/jquery/src/deferred.js +314 -72
- data/bower_components/jquery/src/deferred/exceptionHook.js +21 -0
- data/bower_components/jquery/src/deprecated.js +36 -9
- data/bower_components/jquery/src/dimensions.js +16 -10
- data/bower_components/jquery/src/effects.js +257 -206
- data/bower_components/jquery/src/effects/Tween.js +18 -9
- data/bower_components/jquery/src/effects/animatedSelector.js +7 -5
- data/bower_components/jquery/src/event.js +297 -419
- data/bower_components/jquery/src/event/ajax.js +13 -4
- data/bower_components/jquery/src/event/alias.js +13 -23
- data/bower_components/jquery/src/event/focusin.js +55 -0
- data/bower_components/jquery/src/event/support.js +5 -3
- data/bower_components/jquery/src/event/trigger.js +185 -0
- data/bower_components/jquery/src/exports/amd.js +5 -3
- data/bower_components/jquery/src/exports/global.js +8 -6
- data/bower_components/jquery/src/jquery.js +6 -2
- data/bower_components/jquery/src/manipulation.js +218 -310
- data/bower_components/jquery/src/manipulation/_evalUrl.js +9 -4
- data/bower_components/jquery/src/manipulation/buildFragment.js +104 -0
- data/bower_components/jquery/src/manipulation/getAll.js +32 -0
- data/bower_components/jquery/src/manipulation/setGlobalEval.js +22 -0
- data/bower_components/jquery/src/manipulation/support.js +11 -8
- data/bower_components/jquery/src/manipulation/var/rcheckableType.js +5 -3
- data/bower_components/jquery/src/manipulation/var/rscriptType.js +5 -0
- data/bower_components/jquery/src/manipulation/var/rtagName.js +5 -0
- data/bower_components/jquery/src/manipulation/wrapMap.js +29 -0
- data/bower_components/jquery/src/offset.js +75 -53
- data/bower_components/jquery/src/queue.js +26 -23
- data/bower_components/jquery/src/queue/delay.js +8 -6
- data/bower_components/jquery/src/selector-native.js +133 -68
- data/bower_components/jquery/src/selector-sizzle.js +10 -5
- data/bower_components/jquery/src/selector.js +3 -1
- data/bower_components/jquery/src/serialize.js +52 -33
- data/bower_components/jquery/src/traversing.js +61 -69
- data/bower_components/jquery/src/traversing/findFilter.js +37 -31
- data/bower_components/jquery/src/traversing/var/dir.js +22 -0
- data/bower_components/jquery/src/traversing/var/rneedsContext.js +4 -2
- data/bower_components/jquery/src/traversing/var/siblings.js +17 -0
- data/bower_components/jquery/src/var/ObjectFunctionString.js +7 -0
- data/bower_components/jquery/src/var/arr.js +4 -2
- data/bower_components/jquery/src/var/class2type.js +4 -2
- data/bower_components/jquery/src/var/concat.js +4 -2
- data/bower_components/jquery/src/var/document.js +5 -0
- data/bower_components/jquery/src/var/documentElement.js +7 -0
- data/bower_components/jquery/src/var/fnToString.js +7 -0
- data/bower_components/jquery/src/var/getProto.js +5 -0
- data/bower_components/jquery/src/var/hasOwn.js +4 -2
- data/bower_components/jquery/src/var/indexOf.js +4 -2
- data/bower_components/jquery/src/var/pnum.js +5 -3
- data/bower_components/jquery/src/var/push.js +4 -2
- data/bower_components/jquery/src/var/rcssNum.js +9 -0
- data/bower_components/jquery/src/var/rnothtmlwhite.js +8 -0
- data/bower_components/jquery/src/var/slice.js +4 -2
- data/bower_components/jquery/src/var/support.js +4 -2
- data/bower_components/jquery/src/var/toString.js +4 -2
- data/bower_components/jquery/src/wrap.js +24 -26
- data/bower_components/leaflet-providers/.bower.json +6 -7
- data/bower_components/leaflet-providers/CHANGELOG.md +62 -0
- data/bower_components/leaflet-providers/README.md +12 -3
- data/bower_components/leaflet-providers/bower.json +1 -1
- data/bower_components/leaflet-providers/leaflet-providers.js +133 -92
- data/bower_components/leaflet-providers/package.json +14 -7
- data/bower_components/leaflet/.bower.json +10 -14
- data/bower_components/leaflet/CHANGELOG.md +648 -3
- data/bower_components/leaflet/CONTRIBUTING.md +88 -33
- data/bower_components/leaflet/ISSUE_TEMPLATE.md +25 -0
- data/bower_components/leaflet/Jakefile.js +73 -14
- data/bower_components/leaflet/LICENSE +1 -1
- data/bower_components/leaflet/PLUGIN-GUIDE.md +97 -3
- data/bower_components/leaflet/README.md +6 -8
- data/bower_components/leaflet/bower.json +3 -9
- data/bower_components/leaflet/dist/images/layers-2x.png +0 -0
- data/bower_components/leaflet/dist/images/layers.png +0 -0
- data/bower_components/leaflet/dist/images/marker-icon-2x.png +0 -0
- data/bower_components/leaflet/dist/images/marker-icon.png +0 -0
- data/bower_components/leaflet/dist/images/marker-shadow.png +0 -0
- data/bower_components/leaflet/dist/leaflet-src.js +12301 -7898
- data/bower_components/leaflet/dist/leaflet-src.js.map +1 -0
- data/bower_components/leaflet/dist/leaflet.css +196 -43
- data/bower_components/leaflet/dist/leaflet.js +6 -9
- data/bower_components/leaflet/dist/leaflet.js.map +1 -0
- data/bower_components/leaflet/docs/CNAME +1 -0
- data/bower_components/leaflet/docs/Gemfile +4 -0
- data/bower_components/leaflet/docs/_config.yml +19 -0
- data/bower_components/leaflet/docs/_includes/frame.html +9 -0
- data/bower_components/leaflet/docs/_includes/tutorial_link.html +8 -0
- data/bower_components/leaflet/docs/_layouts/post.html +30 -0
- data/bower_components/leaflet/docs/_layouts/redirected.html +14 -0
- data/bower_components/leaflet/docs/_layouts/tutorial.html +9 -0
- data/bower_components/leaflet/docs/_layouts/tutorial_frame.html +32 -0
- data/bower_components/leaflet/docs/_layouts/tutorial_v2.html +9 -0
- data/bower_components/leaflet/docs/_layouts/v2.html +159 -0
- data/bower_components/leaflet/docs/_posts/2012-07-30-leaflet-0-4-released.md +240 -0
- data/bower_components/leaflet/docs/_posts/2012-08-07-leaflet-0-4-3-and-a-new-tutorial.md +47 -0
- data/bower_components/leaflet/docs/_posts/2012-08-20-guest-post-markerclusterer-0-1-released.md +112 -0
- data/bower_components/leaflet/docs/_posts/2012-10-25-leaflet-0-4-5-bugfix-release-and-plans-for-0.5.md +36 -0
- data/bower_components/leaflet/docs/_posts/2013-01-17-leaflet-0-5-released.md +24 -0
- data/bower_components/leaflet/docs/_posts/2013-02-20-guest-post-draw.md +146 -0
- data/bower_components/leaflet/docs/_posts/2013-06-26-leaflet-0-6-released-dc-code-sprint-mapbox.md +31 -0
- data/bower_components/leaflet/docs/_posts/2013-06-28-leaflet-plugin-authoring-guide.md +111 -0
- data/bower_components/leaflet/docs/_posts/2013-11-18-leaflet-0-7-released-plans-for-future.md +56 -0
- data/bower_components/leaflet/docs/_posts/2015-07-01-leaflet-is-alive-and-kicking.md +21 -0
- data/bower_components/leaflet/docs/_posts/2015-07-15-leaflet-1.0-beta1-released.md +60 -0
- data/bower_components/leaflet/docs/_posts/2015-09-01-leaflet-0.7.4-released.md +29 -0
- data/bower_components/leaflet/docs/_posts/2015-10-14-leaflet-1.0-beta2-released.md +35 -0
- data/bower_components/leaflet/docs/_posts/2016-03-20-debugging-touch-interactions.md +101 -0
- data/bower_components/leaflet/docs/_posts/2016-04-18-leaflet-1.0-rc1.md +78 -0
- data/bower_components/leaflet/docs/_posts/2016-07-16-leaflet-1.0-rc2.md +60 -0
- data/bower_components/leaflet/docs/_posts/2016-08-05-leaflet-1.0-rc3.md +53 -0
- data/bower_components/leaflet/docs/_posts/2016-09-27-leaflet-1.0-final.md +50 -0
- data/bower_components/leaflet/docs/_posts/2016-11-21-leaflet-1.0.2.md +25 -0
- data/bower_components/leaflet/docs/_posts/2017-01-23-leaflet-1.0.3.md +27 -0
- data/bower_components/leaflet/docs/atom.xml +29 -0
- data/bower_components/leaflet/docs/blog.md +24 -0
- data/bower_components/leaflet/docs/docs/css/main.css +1092 -0
- data/bower_components/leaflet/docs/docs/css/normalize.css +426 -0
- data/bower_components/leaflet/docs/docs/highlight/LICENSE +24 -0
- data/bower_components/leaflet/docs/docs/highlight/highlight.pack.js +1 -0
- data/bower_components/leaflet/docs/docs/highlight/styles/github-gist.css +211 -0
- data/bower_components/leaflet/docs/docs/images/2016-03-20-prosthetic-hand-zooming.gif +0 -0
- data/bower_components/leaflet/docs/docs/images/2016-04-18-inheritances.gif +0 -0
- data/bower_components/leaflet/docs/docs/images/2016-04-18-leaflet-toilet-paper.jpeg +0 -0
- data/bower_components/leaflet/docs/docs/images/2016-04-18-madrid-leaflet-864px.jpg +0 -0
- data/bower_components/leaflet/docs/docs/images/2016-07-18-remote-session.png +0 -0
- data/bower_components/leaflet/docs/docs/images/2016-07-18-tooltip.png +0 -0
- data/bower_components/leaflet/docs/docs/images/2016-08-03-iraq-hacking.jpg +0 -0
- data/bower_components/leaflet/docs/docs/images/favicon.ico +0 -0
- data/bower_components/leaflet/docs/docs/images/forum-round.png +0 -0
- data/bower_components/leaflet/docs/docs/images/github-round.png +0 -0
- data/bower_components/leaflet/docs/docs/images/logo.png +0 -0
- data/bower_components/leaflet/docs/docs/images/logos.png +0 -0
- data/bower_components/leaflet/docs/docs/images/sprite.png +0 -0
- data/bower_components/leaflet/docs/docs/images/sprite.svg +75 -0
- data/bower_components/leaflet/docs/docs/images/twitter-round.png +0 -0
- data/bower_components/leaflet/docs/docs/images/twitter.png +0 -0
- data/bower_components/leaflet/docs/docs/js/docs.js +52 -0
- data/bower_components/leaflet/docs/download.md +95 -0
- data/bower_components/leaflet/docs/examples.md +125 -0
- data/bower_components/leaflet/docs/examples/choropleth-example.md +5 -0
- data/bower_components/leaflet/docs/examples/choropleth.md +5 -0
- data/bower_components/leaflet/docs/examples/choropleth/example-basic.md +20 -0
- data/bower_components/leaflet/docs/examples/choropleth/example-color.md +46 -0
- data/bower_components/leaflet/docs/examples/choropleth/example.md +159 -0
- data/bower_components/leaflet/docs/examples/choropleth/index.md +232 -0
- data/bower_components/leaflet/docs/examples/choropleth/thumbnail.png +0 -0
- data/bower_components/leaflet/docs/examples/choropleth/us-states.js +54 -0
- data/bower_components/leaflet/docs/examples/crs-simple/crs-simple-example1.md +16 -0
- data/bower_components/leaflet/docs/examples/crs-simple/crs-simple-example2.md +20 -0
- data/bower_components/leaflet/docs/examples/crs-simple/crs-simple-example3.md +38 -0
- data/bower_components/leaflet/docs/examples/crs-simple/crs-simple.md +117 -0
- data/bower_components/leaflet/docs/examples/crs-simple/thumbnail.png +0 -0
- data/bower_components/leaflet/docs/examples/crs-simple/uqm_map_400px.png +0 -0
- data/bower_components/leaflet/docs/examples/crs-simple/uqm_map_detail.png +0 -0
- data/bower_components/leaflet/docs/examples/crs-simple/uqm_map_full.png +0 -0
- data/bower_components/leaflet/docs/examples/custom-icons-example.md +5 -0
- data/bower_components/leaflet/docs/examples/custom-icons.md +5 -0
- data/bower_components/leaflet/docs/examples/custom-icons/example-one-icon.md +27 -0
- data/bower_components/leaflet/docs/examples/custom-icons/example.md +31 -0
- data/bower_components/leaflet/docs/examples/custom-icons/index.md +79 -0
- data/bower_components/leaflet/docs/examples/custom-icons/leaf-green.png +0 -0
- data/bower_components/leaflet/docs/examples/custom-icons/leaf-orange.png +0 -0
- data/bower_components/leaflet/docs/examples/custom-icons/leaf-red.png +0 -0
- data/bower_components/leaflet/docs/examples/custom-icons/leaf-shadow.png +0 -0
- data/bower_components/leaflet/docs/examples/custom-icons/thumbnail.png +0 -0
- data/bower_components/leaflet/docs/examples/extending/canvascircles.md +37 -0
- data/bower_components/leaflet/docs/examples/extending/class-diagram.md +24 -0
- data/bower_components/leaflet/docs/examples/extending/class-diagram.png +0 -0
- data/bower_components/leaflet/docs/examples/extending/class-diagram.txt +100 -0
- data/bower_components/leaflet/docs/examples/extending/extending-1-classes.md +196 -0
- data/bower_components/leaflet/docs/examples/extending/extending-2-layers.md +210 -0
- data/bower_components/leaflet/docs/examples/extending/extending-3-controls.md +100 -0
- data/bower_components/leaflet/docs/examples/extending/gridcoords.md +32 -0
- data/bower_components/leaflet/docs/examples/extending/kittenlayer.md +29 -0
- data/bower_components/leaflet/docs/examples/extending/pixelorigin.md +90 -0
- data/bower_components/leaflet/docs/examples/extending/thumbnail-1.png +0 -0
- data/bower_components/leaflet/docs/examples/extending/thumbnail-2.png +0 -0
- data/bower_components/leaflet/docs/examples/extending/thumbnail-3.png +0 -0
- data/bower_components/leaflet/docs/examples/extending/tilt.md +59 -0
- data/bower_components/leaflet/docs/examples/extending/watermark.md +36 -0
- data/bower_components/leaflet/docs/examples/geojson-example.md +5 -0
- data/bower_components/leaflet/docs/examples/geojson.md +5 -0
- data/bower_components/leaflet/docs/examples/geojson/baseball-marker.png +0 -0
- data/bower_components/leaflet/docs/examples/geojson/example.md +78 -0
- data/bower_components/leaflet/docs/examples/geojson/geojson-example.html +89 -0
- data/bower_components/leaflet/docs/examples/geojson/geojson.html +281 -0
- data/bower_components/leaflet/docs/examples/geojson/index.md +205 -0
- data/bower_components/leaflet/docs/examples/geojson/sample-geojson.js +248 -0
- data/bower_components/leaflet/docs/examples/geojson/thumbnail.png +0 -0
- data/bower_components/leaflet/docs/examples/layers-control-example.md +5 -0
- data/bower_components/leaflet/docs/examples/layers-control.md +5 -0
- data/bower_components/leaflet/docs/examples/layers-control/example.md +38 -0
- data/bower_components/leaflet/docs/examples/layers-control/index.md +72 -0
- data/bower_components/leaflet/docs/examples/layers-control/thumbnail.png +0 -0
- data/bower_components/leaflet/docs/examples/map-panes-example.md +5 -0
- data/bower_components/leaflet/docs/examples/map-panes.md +5 -0
- data/bower_components/leaflet/docs/examples/map-panes/eu-countries.js +79 -0
- data/bower_components/leaflet/docs/examples/map-panes/example.md +38 -0
- data/bower_components/leaflet/docs/examples/map-panes/index.md +105 -0
- data/bower_components/leaflet/docs/examples/map-panes/thumbnail.png +0 -0
- data/bower_components/leaflet/docs/examples/mobile-example.md +5 -0
- data/bower_components/leaflet/docs/examples/mobile.md +5 -0
- data/bower_components/leaflet/docs/examples/mobile/example.md +42 -0
- data/bower_components/leaflet/docs/examples/mobile/index.md +72 -0
- data/bower_components/leaflet/docs/examples/mobile/thumbnail.png +0 -0
- data/bower_components/leaflet/docs/examples/quick-start-example.md +5 -0
- data/bower_components/leaflet/docs/examples/quick-start.md +5 -0
- data/bower_components/leaflet/docs/examples/quick-start/example-basic.md +19 -0
- data/bower_components/leaflet/docs/examples/quick-start/example-overlays.md +35 -0
- data/bower_components/leaflet/docs/examples/quick-start/example-popups.md +37 -0
- data/bower_components/leaflet/docs/examples/quick-start/example.md +46 -0
- data/bower_components/leaflet/docs/examples/quick-start/index.md +143 -0
- data/bower_components/leaflet/docs/examples/quick-start/thumbnail.png +0 -0
- data/bower_components/leaflet/docs/examples/video-overlay/example-bounds.md +23 -0
- data/bower_components/leaflet/docs/examples/video-overlay/example-nocontrols.md +31 -0
- data/bower_components/leaflet/docs/examples/video-overlay/example.md +58 -0
- data/bower_components/leaflet/docs/examples/video-overlay/index.md +122 -0
- data/bower_components/leaflet/docs/examples/video-overlay/thumbnail.gif +0 -0
- data/bower_components/leaflet/docs/examples/wms/qgis-wms-layers.png +0 -0
- data/bower_components/leaflet/docs/examples/wms/thumbnail.png +0 -0
- data/bower_components/leaflet/docs/examples/wms/wms-example-crs.md +18 -0
- data/bower_components/leaflet/docs/examples/wms/wms-example1.md +16 -0
- data/bower_components/leaflet/docs/examples/wms/wms-example2.md +16 -0
- data/bower_components/leaflet/docs/examples/wms/wms-example3.md +34 -0
- data/bower_components/leaflet/docs/examples/wms/wms-example4.md +29 -0
- data/bower_components/leaflet/docs/examples/wms/wms.md +157 -0
- data/bower_components/leaflet/docs/examples/zoom-levels/example-delta.md +40 -0
- data/bower_components/leaflet/docs/examples/zoom-levels/example-fractional.md +56 -0
- data/bower_components/leaflet/docs/examples/zoom-levels/example-scale.md +29 -0
- data/bower_components/leaflet/docs/examples/zoom-levels/example-setzoom.md +44 -0
- data/bower_components/leaflet/docs/examples/zoom-levels/example-zero.md +19 -0
- data/bower_components/leaflet/docs/examples/zoom-levels/index.md +275 -0
- data/bower_components/leaflet/docs/examples/zoom-levels/thumbnail.png +0 -0
- data/bower_components/leaflet/docs/index.html +218 -0
- data/bower_components/leaflet/docs/plugins.md +3854 -0
- data/bower_components/leaflet/docs/reference-0.7.7.html +6424 -0
- data/bower_components/leaflet/docs/reference-1.0.0.html +22889 -0
- data/bower_components/leaflet/docs/reference-1.0.2.html +23382 -0
- data/bower_components/leaflet/docs/reference-1.0.3.html +23495 -0
- data/bower_components/leaflet/docs/reference-tpl.html +89 -0
- data/bower_components/leaflet/docs/reference-versions.html +16 -0
- data/bower_components/leaflet/docs/reference.html +3 -0
- data/bower_components/leaflet/package.json +77 -16
- data/columbus3.gemspec +1 -1
- data/doc/ChangeLog.org +10 -0
- data/doc/manual.txt +122 -0
- data/doc/todo.org +63 -0
- data/exe/columbus3 +2 -246
- data/lib/columbus3.rb +12 -7
- data/lib/columbus3/cli/command_semantics.rb +352 -0
- data/lib/columbus3/cli/command_syntax.rb +103 -0
- data/lib/columbus3/metadata/query_parser.racc +21 -7
- data/lib/columbus3/metadata/query_parser.tab.rb +34 -34
- data/lib/columbus3/metadata/sidecar.rb +1 -1
- data/lib/columbus3/renderer/flot_renderer.rb +3 -8
- data/lib/columbus3/renderer/leaflet_renderer.rb +18 -29
- data/lib/columbus3/renderer/sanitizer.rb +8 -0
- data/lib/columbus3/v900track/gpx2v900.rb +31 -0
- data/lib/columbus3/v900track/v900track.rb +34 -8
- data/lib/columbus3/v900track/v900waypoint.rb +9 -0
- data/lib/columbus3/version.rb +1 -1
- data/lib/html/flot.html.erb +6 -6
- data/lib/html/show.html.erb +53 -76
- data/lib/html/track.js.erb +58 -12
- metadata +222 -23
- data/README.textile +0 -67
- data/bower_components/jquery/src/ajax/parseJSON.js +0 -13
- data/bower_components/jquery/src/css/defaultDisplay.js +0 -70
- data/bower_components/jquery/src/css/var/isHidden.js +0 -13
- data/bower_components/jquery/src/intro.js +0 -44
- data/bower_components/jquery/src/outro.js +0 -1
- data/bower_components/jquery/src/sizzle/dist/sizzle.min.js +0 -3
- data/bower_components/jquery/src/sizzle/dist/sizzle.min.map +0 -1
- data/bower_components/jquery/src/var/rnotwhite.js +0 -3
- data/bower_components/jquery/src/var/strundefined.js +0 -3
- data/bower_components/leaflet/component.json +0 -20
@@ -0,0 +1,100 @@
|
|
1
|
+
---
|
2
|
+
layout: tutorial_v2
|
3
|
+
title: Extending Leaflet, New Handlers and Controls
|
4
|
+
---
|
5
|
+
|
6
|
+
<br>
|
7
|
+
|
8
|
+
This tutorial assumes you've read the [theory of Leaflet class inheritance](./extending-1-classes.html).
|
9
|
+
|
10
|
+
In Leaflet, a "layer" is anything that moves with the map. In contraposition to that, a "control" is a HTML element that remains static relative to the map container, and a "handler" is a piece of invisible code that changes the map's behaviour.
|
11
|
+
|
12
|
+
## Handlers
|
13
|
+
|
14
|
+
Map handlers are a new concept in Leaflet 1.0, and their function is to process DOM events from the browser (like `click`, `dblclick` or `mousewheel`) and change the state of the map.
|
15
|
+
|
16
|
+
Handlers are relatively simple: they just need a `addHooks()` method (which runs when the handler is enabled in a map) and a `removeHooks()`, which runs when the handler is disabled. A skeleton for handlers is:
|
17
|
+
|
18
|
+
L.CustomHandler = L.Handler.extend({
|
19
|
+
addHooks: function() {
|
20
|
+
L.DomEvent.on(document, 'eventname', this._doSomething, this);
|
21
|
+
},
|
22
|
+
|
23
|
+
removeHooks: function() {
|
24
|
+
L.DomEvent.off(document, 'eventname', this._doSomething, this);
|
25
|
+
},
|
26
|
+
|
27
|
+
_doSomething: function(event) { … }
|
28
|
+
});
|
29
|
+
|
30
|
+
This can be illustrated with a simple handler to pan the map when a mobile device is tilted, through [`deviceorientation` events](https://developer.mozilla.org/en-US/docs/Web/API/Detecting_device_orientation):
|
31
|
+
|
32
|
+
L.TiltHandler = L.Handler.extend({
|
33
|
+
addHooks: function() {
|
34
|
+
L.DomEvent.on(window, 'deviceorientation', this._tilt, this);
|
35
|
+
},
|
36
|
+
|
37
|
+
removeHooks: function() {
|
38
|
+
L.DomEvent.off(window, 'deviceorientation', this._tilt, this);
|
39
|
+
},
|
40
|
+
|
41
|
+
_tilt: function(ev) {
|
42
|
+
// Treat Gamma angle as horizontal pan (1 degree = 1 pixel) and Beta angle as vertical pan
|
43
|
+
this._map.panBy( L.point( ev.gamma, ev.beta ) );
|
44
|
+
}
|
45
|
+
});
|
46
|
+
|
47
|
+
The handler can be attached to the map using `map.addHandler('tilt', L.TiltHandler)` - this will store an instance of `L.TiltHandler` as `map.tilt`. However, it's more usual to attach handlers to all maps with the `addInitHook` syntax:
|
48
|
+
|
49
|
+
L.Map.addInitHook('addHandler', 'tilt', L.TiltHandler);
|
50
|
+
|
51
|
+
Our handler can now be enabled by running `map.tilt.enable()` and disabled by `map.tilt.disable()`
|
52
|
+
|
53
|
+
Moreover, if the map has a property named the same as the handler, then that handler will be enabled by default if that options is `true`, so this will enable our handler by default:
|
54
|
+
|
55
|
+
var map = L.map('mapDiv', { tilt: true });
|
56
|
+
|
57
|
+
To see this example, you'll need a mobile browser which [supports the `deviceorientation` event](http://caniuse.com/#search=deviceorientation) - and even so, this event is particularly flaky and ill-specified, so beware.
|
58
|
+
|
59
|
+
{% include frame.html url="tilt.html" %}
|
60
|
+
|
61
|
+
Depending on the type of event, a map handler can attach event listeners to the `document`, the `window`, or the container of the `L.Map` it's attached to.
|
62
|
+
|
63
|
+
## Controls
|
64
|
+
|
65
|
+
You already know controls - the zoom control in the top left corner, the scale at the bottom left, the layer switcher at the top right. At their core, an `L.Control` is an HTML Element that is at a static position in the map container.
|
66
|
+
|
67
|
+
To make a control, simply inherit from `L.Control` and implement `onAdd()` and `onRemove()`. These methods work in a similar way to their `L.Layer` counterparts (they run whenever the control is added to or removed from the map), except that `onAdd()` must return an instance of `HTMLElement` representing the control. Adding the element to the map is done automatically, and so is removing it.
|
68
|
+
|
69
|
+
The simplest example of a custom control would be a watermark, which is just an image:
|
70
|
+
|
71
|
+
L.Control.Watermark = L.Control.extend({
|
72
|
+
onAdd: function(map) {
|
73
|
+
var img = L.DomUtil.create('img');
|
74
|
+
|
75
|
+
img.src = '../../docs/images/logo.png';
|
76
|
+
img.style.width = '200px';
|
77
|
+
|
78
|
+
return img;
|
79
|
+
},
|
80
|
+
|
81
|
+
onRemove: function(map) {
|
82
|
+
// Nothing to do here
|
83
|
+
}
|
84
|
+
});
|
85
|
+
|
86
|
+
L.control.watermark = function(opts) {
|
87
|
+
return new L.Control.Watermark(opts);
|
88
|
+
}
|
89
|
+
|
90
|
+
L.control.watermark({ position: 'bottomleft' }).addTo(map);
|
91
|
+
|
92
|
+
{% include frame.html url="watermark.html" %}
|
93
|
+
|
94
|
+
If your custom control has interactive elements such as clickable buttons, remember to use `L.DomEvent.on()` inside `onAdd()` and `L.DomEvent.off()` inside `onRemove()`.
|
95
|
+
|
96
|
+
If your custom control consists of more than one HTML element (like `L.Control.Zoom`, which has two buttons), you'll have to create the whole hierarchy of elements and return the topmost container.
|
97
|
+
|
98
|
+
## Publishing your plugin
|
99
|
+
|
100
|
+
If you have understood everything so far, you're ready to make som Leaflet plugins! But make sure to read the [`PLUGIN-GUIDE.md` file](https://github.com/Leaflet/Leaflet/blob/master/PLUGIN-GUIDE.md), as it contains some tips and good practices about naming and publishing your plugin.
|
@@ -0,0 +1,32 @@
|
|
1
|
+
---
|
2
|
+
layout: tutorial_frame
|
3
|
+
title: Grid coordinates
|
4
|
+
---
|
5
|
+
<script type='text/javascript'>
|
6
|
+
|
7
|
+
var map = L.map('map', {
|
8
|
+
center: [0, 0],
|
9
|
+
zoom: 0
|
10
|
+
});
|
11
|
+
|
12
|
+
L.GridLayer.DebugCoords = L.GridLayer.extend({
|
13
|
+
createTile: function (coords, done) {
|
14
|
+
var tile = document.createElement('div');
|
15
|
+
tile.innerHTML = [coords.x, coords.y, coords.z].join(', ');
|
16
|
+
tile.style.outline = '1px solid red';
|
17
|
+
|
18
|
+
setTimeout(function () {
|
19
|
+
done(null, tile); // Syntax is 'done(error, tile)'
|
20
|
+
}, 500 + Math.random() * 1500);
|
21
|
+
|
22
|
+
return tile;
|
23
|
+
}
|
24
|
+
});
|
25
|
+
|
26
|
+
L.gridLayer.debugCoords = function(opts) {
|
27
|
+
return new L.GridLayer.DebugCoords(opts);
|
28
|
+
};
|
29
|
+
|
30
|
+
map.addLayer( L.gridLayer.debugCoords() );
|
31
|
+
|
32
|
+
</script>
|
@@ -0,0 +1,29 @@
|
|
1
|
+
---
|
2
|
+
layout: tutorial_frame
|
3
|
+
title: KittenLayer
|
4
|
+
---
|
5
|
+
<script type='text/javascript'>
|
6
|
+
|
7
|
+
var map = L.map('map', {
|
8
|
+
crs: L.CRS.Simple,
|
9
|
+
center: [0, 0],
|
10
|
+
zoom: 5
|
11
|
+
});
|
12
|
+
|
13
|
+
L.TileLayer.Kitten = L.TileLayer.extend({
|
14
|
+
getTileUrl: function(coords) {
|
15
|
+
var i = Math.ceil( Math.random() * 4 );
|
16
|
+
return "http://placekitten.com/256/256?image=" + i;
|
17
|
+
},
|
18
|
+
getAttribution: function() {
|
19
|
+
return "<a href='http://placekitten.com/attribution.html'>PlaceKitten</a>"
|
20
|
+
}
|
21
|
+
});
|
22
|
+
|
23
|
+
L.tileLayer.kitten = function() {
|
24
|
+
return new L.TileLayer.Kitten();
|
25
|
+
}
|
26
|
+
|
27
|
+
map.addLayer( L.tileLayer.kitten() );
|
28
|
+
|
29
|
+
</script>
|
@@ -0,0 +1,90 @@
|
|
1
|
+
---
|
2
|
+
layout: tutorial_frame
|
3
|
+
title: Grid coordinates
|
4
|
+
---
|
5
|
+
<style>
|
6
|
+
|
7
|
+
#info {
|
8
|
+
position:absolute;
|
9
|
+
top:0;
|
10
|
+
right:0;
|
11
|
+
width: 20em;
|
12
|
+
height: 7.5em;
|
13
|
+
background: rgba(255,255,255,.5);
|
14
|
+
z-index:500;
|
15
|
+
font: 12px Sans;
|
16
|
+
}
|
17
|
+
|
18
|
+
.crsMarker {
|
19
|
+
border-top: 2px green solid;
|
20
|
+
border-left: 2px green solid;
|
21
|
+
}
|
22
|
+
</style>
|
23
|
+
|
24
|
+
<div id='info' style=''></div>
|
25
|
+
|
26
|
+
|
27
|
+
<script type='text/javascript'>
|
28
|
+
|
29
|
+
var trd = [63.41, 10.41];
|
30
|
+
|
31
|
+
|
32
|
+
var map = L.map('map', {
|
33
|
+
center: [40, 0],
|
34
|
+
zoom: 1
|
35
|
+
});
|
36
|
+
|
37
|
+
var positron = L.tileLayer('http://{s}.basemaps.cartocdn.com/light_all/{z}/{x}/{y}.png', {
|
38
|
+
attribution: "CartoDB"
|
39
|
+
}).addTo(map);
|
40
|
+
|
41
|
+
var marker = L.marker(trd).addTo(map);
|
42
|
+
|
43
|
+
var pane = map.getPane('markerPane')
|
44
|
+
|
45
|
+
var paneCorner = document.createElement('div');
|
46
|
+
paneCorner.style.width = '12px';
|
47
|
+
paneCorner.style.height = '12px';
|
48
|
+
paneCorner.style.borderTop = '2px red solid';
|
49
|
+
paneCorner.style.borderLeft = '2px red solid';
|
50
|
+
|
51
|
+
pane.appendChild(paneCorner);
|
52
|
+
|
53
|
+
marker._icon.style.border = '1px solid blue';
|
54
|
+
|
55
|
+
var crsMarker = L.marker( map.unproject([0, 0]), {
|
56
|
+
icon: L.divIcon({
|
57
|
+
className: 'crsMarker',
|
58
|
+
iconAnchor: [0, 0]
|
59
|
+
})
|
60
|
+
} ).addTo(map);
|
61
|
+
|
62
|
+
|
63
|
+
var markerOffsetLine = L.polyline([[0, 0], [0, 0]], {color: 'skyblue'}).addTo(map);
|
64
|
+
var iconOffsetLine = L.polyline([[0, 0], [0, 0]], {color: 'blue'}).addTo(map);
|
65
|
+
|
66
|
+
function info() {
|
67
|
+
|
68
|
+
var pixelOrigin = map.getPixelOrigin();
|
69
|
+
var markerPixelCoords = map.project(trd, map.getZoom());
|
70
|
+
var markerAnchor = marker.options.icon.options.iconAnchor;
|
71
|
+
var markerOffset = marker._icon._leaflet_pos;
|
72
|
+
|
73
|
+
document.getElementById('info').innerHTML =
|
74
|
+
'<div style="color: green">CRS origin: 0,0</div>' +
|
75
|
+
'<div style="color: red">px origin: Δ' + pixelOrigin.x + ',' + pixelOrigin.y + '</div>' +
|
76
|
+
'<div style="color: blue">marker px coords:' + markerPixelCoords.x.toFixed(2) + ',' + markerPixelCoords.y.toFixed(2) + '</div>' +
|
77
|
+
'<div style="color: blue">marker anchor: Δ' + markerAnchor[0] + ',' + markerAnchor[1] + '</div>' +
|
78
|
+
'<div style="color: skyblue">marker pane offset: Δ' + markerOffset.x + ',' + markerOffset.y + '</div>';
|
79
|
+
|
80
|
+
markerOffsetLine.setLatLngs([ map.unproject(pixelOrigin), map.unproject(pixelOrigin.add(markerOffset))]);
|
81
|
+
iconOffsetLine.setLatLngs([ map.unproject(pixelOrigin.add(markerOffset)), map.unproject(pixelOrigin.add(markerOffset).subtract(markerAnchor))]);
|
82
|
+
}
|
83
|
+
|
84
|
+
|
85
|
+
map.on('load move moveend zoomend viewreset', info)
|
86
|
+
|
87
|
+
info();
|
88
|
+
|
89
|
+
|
90
|
+
</script>
|
Binary file
|
Binary file
|
Binary file
|
@@ -0,0 +1,59 @@
|
|
1
|
+
---
|
2
|
+
layout: tutorial_frame
|
3
|
+
title: Tilt handler
|
4
|
+
---
|
5
|
+
<style>
|
6
|
+
|
7
|
+
#info {
|
8
|
+
position:absolute;
|
9
|
+
top:0;
|
10
|
+
right:0;
|
11
|
+
width: 20em;
|
12
|
+
height: 7.5em;
|
13
|
+
background: rgba(255,255,255,.5);
|
14
|
+
z-index:500;
|
15
|
+
font: 12px Sans;
|
16
|
+
}
|
17
|
+
|
18
|
+
.crsMarker {
|
19
|
+
border-top: 2px green solid;
|
20
|
+
border-left: 2px green solid;
|
21
|
+
}
|
22
|
+
</style>
|
23
|
+
|
24
|
+
<div id='info' style=''></div>
|
25
|
+
|
26
|
+
|
27
|
+
<script type='text/javascript'>
|
28
|
+
|
29
|
+
var trd = [63.41, 10.41];
|
30
|
+
|
31
|
+
L.TiltHandler = L.Handler.extend({
|
32
|
+
addHooks: function() {
|
33
|
+
L.DomEvent.on(window, 'deviceorientation', this._tilt, this);
|
34
|
+
},
|
35
|
+
|
36
|
+
removeHooks: function() {
|
37
|
+
L.DomEvent.off(window, 'deviceorientation', this._tilt, this);
|
38
|
+
},
|
39
|
+
|
40
|
+
_tilt: function(ev) {
|
41
|
+
// Treat Gamma angle as horizontal pan (1 degree = 1 pixel) and Beta angle as vertical pan
|
42
|
+
this._map.panBy( L.point( ev.gamma, ev.beta ) );
|
43
|
+
document.getElementById('info').innerHTML = ev.gamma + ',' + ev.beta;
|
44
|
+
}
|
45
|
+
});
|
46
|
+
|
47
|
+
L.Map.addInitHook('addHandler', 'tilt', L.TiltHandler);
|
48
|
+
|
49
|
+
var map = L.map('map', {
|
50
|
+
center: [0, 0],
|
51
|
+
zoom: 1,
|
52
|
+
tilt: true
|
53
|
+
});
|
54
|
+
|
55
|
+
var positron = L.tileLayer('http://{s}.basemaps.cartocdn.com/light_all/{z}/{x}/{y}.png', {
|
56
|
+
attribution: "CartoDB"
|
57
|
+
}).addTo(map);
|
58
|
+
|
59
|
+
</script>
|
@@ -0,0 +1,36 @@
|
|
1
|
+
---
|
2
|
+
layout: tutorial_frame
|
3
|
+
title: Watermark control
|
4
|
+
---
|
5
|
+
<script type='text/javascript'>
|
6
|
+
var map = L.map('map', {
|
7
|
+
center: [40, 0],
|
8
|
+
zoom: 1
|
9
|
+
});
|
10
|
+
|
11
|
+
var positron = L.tileLayer('http://{s}.basemaps.cartocdn.com/light_all/{z}/{x}/{y}.png', {
|
12
|
+
attribution: "CartoDB"
|
13
|
+
}).addTo(map);
|
14
|
+
|
15
|
+
L.Control.Watermark = L.Control.extend({
|
16
|
+
onAdd: function(map) {
|
17
|
+
var img = L.DomUtil.create('img');
|
18
|
+
|
19
|
+
img.src = '../../docs/images/logo.png';
|
20
|
+
img.style.width = '200px';
|
21
|
+
|
22
|
+
return img;
|
23
|
+
},
|
24
|
+
|
25
|
+
onRemove: function(map) {
|
26
|
+
// Nothing to do here
|
27
|
+
}
|
28
|
+
});
|
29
|
+
|
30
|
+
L.control.watermark = function(opts) {
|
31
|
+
return new L.Control.Watermark(opts);
|
32
|
+
}
|
33
|
+
|
34
|
+
L.control.watermark({ position: 'bottomleft' }).addTo(map);
|
35
|
+
|
36
|
+
</script>
|
Binary file
|
@@ -0,0 +1,78 @@
|
|
1
|
+
---
|
2
|
+
layout: tutorial_frame
|
3
|
+
title: GeoJSON tutorial
|
4
|
+
---
|
5
|
+
<script src="sample-geojson.js" type="text/javascript"></script>
|
6
|
+
|
7
|
+
<script>
|
8
|
+
var map = L.map('map').setView([39.74739, -105], 13);
|
9
|
+
|
10
|
+
L.tileLayer('https://api.tiles.mapbox.com/v4/{id}/{z}/{x}/{y}.png?access_token=pk.eyJ1IjoibWFwYm94IiwiYSI6ImNpejY4NXVycTA2emYycXBndHRqcmZ3N3gifQ.rJcFIG214AriISLbB6B5aw', {
|
11
|
+
maxZoom: 18,
|
12
|
+
attribution: 'Map data © <a href="http://openstreetmap.org">OpenStreetMap</a> contributors, ' +
|
13
|
+
'<a href="http://creativecommons.org/licenses/by-sa/2.0/">CC-BY-SA</a>, ' +
|
14
|
+
'Imagery © <a href="http://mapbox.com">Mapbox</a>',
|
15
|
+
id: 'mapbox.light'
|
16
|
+
}).addTo(map);
|
17
|
+
|
18
|
+
var baseballIcon = L.icon({
|
19
|
+
iconUrl: 'baseball-marker.png',
|
20
|
+
iconSize: [32, 37],
|
21
|
+
iconAnchor: [16, 37],
|
22
|
+
popupAnchor: [0, -28]
|
23
|
+
});
|
24
|
+
|
25
|
+
function onEachFeature(feature, layer) {
|
26
|
+
var popupContent = "<p>I started out as a GeoJSON " +
|
27
|
+
feature.geometry.type + ", but now I'm a Leaflet vector!</p>";
|
28
|
+
|
29
|
+
if (feature.properties && feature.properties.popupContent) {
|
30
|
+
popupContent += feature.properties.popupContent;
|
31
|
+
}
|
32
|
+
|
33
|
+
layer.bindPopup(popupContent);
|
34
|
+
}
|
35
|
+
|
36
|
+
L.geoJSON([bicycleRental, campus], {
|
37
|
+
|
38
|
+
style: function (feature) {
|
39
|
+
return feature.properties && feature.properties.style;
|
40
|
+
},
|
41
|
+
|
42
|
+
onEachFeature: onEachFeature,
|
43
|
+
|
44
|
+
pointToLayer: function (feature, latlng) {
|
45
|
+
return L.circleMarker(latlng, {
|
46
|
+
radius: 8,
|
47
|
+
fillColor: "#ff7800",
|
48
|
+
color: "#000",
|
49
|
+
weight: 1,
|
50
|
+
opacity: 1,
|
51
|
+
fillOpacity: 0.8
|
52
|
+
});
|
53
|
+
}
|
54
|
+
}).addTo(map);
|
55
|
+
|
56
|
+
L.geoJSON(freeBus, {
|
57
|
+
|
58
|
+
filter: function (feature, layer) {
|
59
|
+
if (feature.properties) {
|
60
|
+
// If the property "underConstruction" exists and is true, return false (don't render features under construction)
|
61
|
+
return feature.properties.underConstruction !== undefined ? !feature.properties.underConstruction : true;
|
62
|
+
}
|
63
|
+
return false;
|
64
|
+
},
|
65
|
+
|
66
|
+
onEachFeature: onEachFeature
|
67
|
+
}).addTo(map);
|
68
|
+
|
69
|
+
var coorsLayer = L.geoJSON(coorsField, {
|
70
|
+
|
71
|
+
pointToLayer: function (feature, latlng) {
|
72
|
+
return L.marker(latlng, {icon: baseballIcon});
|
73
|
+
},
|
74
|
+
|
75
|
+
onEachFeature: onEachFeature
|
76
|
+
}).addTo(map);
|
77
|
+
|
78
|
+
</script>
|