Skip to content
Snippets Groups Projects
Commit 03181f41 authored by Tor-Einar Skog's avatar Tor-Einar Skog
Browse files

Making the GIS map self contained, ready to insert into any form

parent 139ccc0b
No related branches found
No related tags found
No related merge requests found
Showing
with 146 additions and 55 deletions
......@@ -58,7 +58,39 @@ public class ResourceBundleJSServlet extends HttpServlet {
else output.append(",");
output.append("\n\"").append(key).append("\":\"").append(StringEscapeUtils.escapeJavaScript(i18nTexts.getString(key))).append("\"");
}
output.append("\n};");
output.append("\n};\n\n");
// Adding the methods needed to utilize the i18Texts dictionary
output.append(
"/**\n" +
"* Gets a message by key. The message should be translated\n" +
"* Depends on /js/resourcebundle.js for the dictionary i18Texts\n" +
"* @param {String} msgKey\n" +
"* @param {Array} positionalArguments - for string substitution in message\n" +
"* @returns {String} the message\n" +
"*/\n" +
"function getI18nMsg(msgKey,positionalArguments)\n" +
"{\n" +
" if(i18Texts[msgKey] === undefined)\n" +
" {\n" +
" return getI18nMsg(\"unknownTranslationKey\",[msgKey]);\n" +
" }\n" +
" return replaceParams(i18Texts[msgKey], positionalArguments);\n" +
"}\n" +
" \n" +
"/**\n" +
" * Mimic of the MessageFormat.format method in Java.\n" +
" * Very nicely explained here: http://stackoverflow.com/questions/1353408/messageformat-in-javascript-parameters-in-localized-ui-strings\n" +
" * @param {String} string\n" +
" * @param {Array} replacements\n" +
" * @returns {String}\n" +
" */\n" +
"function replaceParams(string, replacements) {\n" +
" return string.replace(/\\{(\\d+)\\}/g, function() {\n" +
" return replacements[arguments[1]];\n" +
" });\n" +
"}\n");
out.print(output.toString());
}
......
......@@ -287,3 +287,10 @@ rememberLogin=Remember login
task_DeleteAllExpiredUserUuidsTask_name=Delete all expired user UUIDs
task_DeleteAllExpiredUserUuidsTask_description=Cleaning up the database of UUIDs, which is used for remembering client logins
mapDataIsRequired=Map data is required
showMeWhereIAm=Show me where I am
unknownTranslationKey=Unknown translation key: {0}
mapDrawTypeLabel=What do you want to draw
point=Point
polygon=Polygon
clearAll=Clear all
clearOne=Clear one
......@@ -287,3 +287,10 @@ rememberLogin=Remember login
task_DeleteAllExpiredUserUuidsTask_name=Delete all expired user UUIDs
task_DeleteAllExpiredUserUuidsTask_description=Cleaning up the database of UUIDs, which is used for remembering client logins
mapDataIsRequired=Map data is required
showMeWhereIAm=Show me where I Am
unknownTranslationKey=Unknown translation key: {0}
mapDrawTypeLabel=What do you want to draw
point=point
polygon=Polygon
clearAll=Clear all
clearOne=Clear one
......@@ -286,3 +286,10 @@ rememberLogin=Remember login
task_DeleteAllExpiredUserUuidsTask_name=Delete all expired user UUIDs
task_DeleteAllExpiredUserUuidsTask_description=Cleaning up the database of UUIDs, which is used for remembering client logins
mapDataIsRequired=Map data is required
showMeWhereIAm=Show me where I Am
unknownTranslationKey=Unknown translation key: {0}
mapDrawTypeLabel=What do you want to draw
point=point
polygon=Polygon
clearAll=Clear all
clearOne=Clear one
......@@ -287,3 +287,10 @@ rememberLogin=Husk innlogging
task_DeleteAllExpiredUserUuidsTask_name=Slett alle utdaterte brukerUUIDer
task_DeleteAllExpiredUserUuidsTask_description=Rydder opp i tabellen over brukerUUIDer, som brukes til \u00e5 huske klientinnlogginger
mapDataIsRequired=Kartdata m\u00e5 registreres
showMeWhereIAm=Vis meg hvor jeg er
unknownTranslationKey=Ukjent oversettelsesn\u00f8kkel: {0}
mapDrawTypeLabel=Jeg vil tegne
point=Punkt
polygon=Omr\u00e5de
clearAll=Slett alt
clearOne=Slett ett element
......@@ -287,3 +287,10 @@ rememberLogin=Remember login
task_DeleteAllExpiredUserUuidsTask_name=Delete all expired user UUIDs
task_DeleteAllExpiredUserUuidsTask_description=Cleaning up the database of UUIDs, which is used for remembering client logins
mapDataIsRequired=Map data is required
showMeWhereIAm=Show me where I Am
unknownTranslationKey=Unknown translation key: {0}
mapDrawTypeLabel=What do you want to draw
point=point
polygon=Polygon
clearAll=Clear all
clearOne=Clear one
/*
* Copyright (c) 2014 NIBIO <http://www.nibio.no/>.
* Copyright (c) 2016 NIBIO <http://www.nibio.no/>.
*
* This file is part of VIPSLogic.
* VIPSLogic is free software: you can redistribute it and/or modify
......@@ -18,10 +18,9 @@
*/
/*
Document : stylesheet
Created on : Aug 28, 2013, 10:55:15 AM
Author : Viggo Lunde <viggo.lunde@nibio.no>
Author : Viggo Lunde <viggo.lunde@nibio.no>, Tor-Einar Skog <tor-einar.skog@nibio.no>
Description:
Main stylesheet of the VIPSLogic web app. Cusomizes the bootstrap.css
Stylesheet for the objectGISInfoMap. Cusomizes the bootstrap.css
*/
#toolbox {
......@@ -66,7 +65,7 @@
float: right;
width: 22px;
height: 22px;
background-image: url('../images/geoloc3.png');
background-image: url();
background-size: 20px 20px;
background-repeat: no-repeat;
background-position: 1px;
......
......@@ -70,7 +70,7 @@ legend {
display: block;
}
#observationFormMap, #weatherStationListMap, #weatherStationFormMap, #weatherStationViewMap{
#objectGISInfoMap, #weatherStationListMap, #weatherStationFormMap, #weatherStationViewMap {
height: 400px;
width: 100%;
}
......
/*
* Copyright (c) 2014 NIBIO <http://www.nibio.no/>.
* Copyright (c) 2015-2016 NIBIO <http://www.nibio.no/>.
*
* This file is part of VIPSLogic.
* VIPSLogic is free software: you can redistribute it and/or modify
......@@ -18,22 +18,76 @@
*/
/**
* Logic for registering location of an observation using an OpenLayers v3 map
* Logic for GIS information about an object
*
* To get the current registered GIS as GEOJson, call getFeatures();
*
* @author Viggo Lunde <viggo.lunde@nibio.no>
* @author Tor-Einar Skog <tor-einar.skog@nibio.no>
*/
var featureOverlay, map;
var olMapDivId = "objectGISInfoMap";
/**
*
* @param {string} containerId - DOM id of the div where we can intialize the map
* @param {ol.Coordinate} center - coordinates for the map's center (WGS84)
* @param {int} zoomLevel - the zoom level (1-15, 1 is world wide view, 15 is greatest zoom)
* @param {boolean} displayMarker - show observation marker in center location
* @param {string} drawnObjs - GeoJSON with geometries to display
* @param {string} chooseLayersObj Which polygon layers to choose from. Sample:
* <pre>
* {
* "chooseFromMapLayers":[
* {
* "mapLayerId":1,
* "mapLayerTitle":"Kommunegrenser",
* "description":"Norske kommunegrenser",
* "mapLayerType":"overlay",
* "defaultVisible":false,
* "hoverAttribute":"navn",
* "url":"http://kart13.skogoglandskap.no/geoserver/ows?srsname=EPSG:3857&format_options=decimals:0&service=WFS&version=1.0.0&outputFormat=json&request=GetFeature&typeName=sl:n2000_komm_flate&"
* },
* {
* "mapLayerId":2,
* "mapLayerTitle":"Fylkesgrenser",
* "description":"Norske fylkesgrenser",
* "mapLayerType":"overlay",
* "defaultVisible":false,
* "hoverAttribute":null,
* "url":"http://kart13.skogoglandskap.no/geoserver/ows?srsname=EPSG:3857&format_options=decimals:0&service=WFS&version=1.0.0&outputFormat=json&request=GetFeature&typeName=sl:n5_forv_fylke_mv&"
* }
* ]
* }
* </pre>
*
* @returns {void}
*/
function initMap(center, zoomLevel, displayMarker, drawnObjs, chooseLayersObj) {
function initMap(containerId, center, zoomLevel, displayMarker, drawnObjs, chooseLayersObj) {
// Create the DOM structure
var theContainer = el(containerId);
theContainer.innerHTML = [
"<div>",
" <label>",getI18nMsg("mapDrawTypeLabel"),"</label>",
" <select id='type'>",
" <option value='Point'>",getI18nMsg("point"),"</option>",
" <option value='Polygon'>",getI18nMsg("polygon"),"</option>",
" </select>",
" <button id='delete' type='button'>",getI18nMsg("clearAll"),"</button>",
" <button id='deleteOne' type='button'>",getI18nMsg("clearOne"),"</button>",
"</div>",
"<div id='", olMapDivId ,"' class='map'></div>",
"<div id='alert_placeholder'></div>"
].join("");
// Adding standard base layers
//
// TODO: Make this configurable per organization (input base layers as function parameter)
// OpenStreetMap
var osm = new ol.layer.Tile({
'title': 'OSM',
type: 'base',
......@@ -47,6 +101,7 @@ function initMap(center, zoomLevel, displayMarker, drawnObjs, chooseLayersObj) {
})
});
// Satellite photo map from Microsoft/Bing
var bingArial = new ol.layer.Tile({
title: 'Bing Arial',
type: 'base',
......@@ -57,7 +112,7 @@ function initMap(center, zoomLevel, displayMarker, drawnObjs, chooseLayersObj) {
})
});
// Detailed map of Norway in shades of grey
var topo2graatone = new ol.layer.Tile({
title: "Gråtone",
type: 'base',
......@@ -130,7 +185,7 @@ app.geoLocationControl = function(opt_options) {
var button = document.createElement('button');
//button.innerHTML = 'O';
button.title = 'Show me where I am'
button.title = getI18nMsg("showMeWhereIAm");
var this_ = this;
......@@ -166,7 +221,7 @@ ol.inherits(app.geoLocationControl, ol.control.Control);
// Creating the map
map = new ol.Map({
target: 'observationFormMap',
target: olMapDivId, // Defined at the top of this file
controls: ol.control.defaults({
attributionOptions: /** @type {olx.control.AttributionOptions} */ ({
collapsible: true
......@@ -545,7 +600,9 @@ ol.inherits(app.geoLocationControl, ol.control.Control);
}
/**
* Listen for changes in the user's location
*/
geolocation.on('change:position', function() {
removeFeature('geoLoc');
......@@ -618,6 +675,9 @@ ol.inherits(app.geoLocationControl, ol.control.Control);
}*/
}
/**
* @return {GEOJson} returns all features currently on the map in GEOJson format
*/
function getFeatures() {
var features = featureOverlay.getSource().getFeatures();
var format = new ol.format.GeoJSON();
......
......@@ -20,6 +20,7 @@
* This validator has its Java counterpart in no.nibio.web.forms.FormValidator.java
* (for server side validation). They use the same JSON file for form validation.
* Changes in logic client side should be reflected server side
* Depends on /js/resourcebundle.js for the dictionary i18Texts
*/
// Constant defs for field types. Also found in no.nibio.web.forms.FormField
......@@ -559,28 +560,3 @@ function styleValid(inputEl)
{
$(inputEl.parentNode).removeClass("has-error");
}
/**
* Gets a message by key. The message should be translated
* Depends on /js/resourcebundle.js for the dictionary i18Texts
* @param {String} msgKey
* @param {Array} positionalArguments - for string substitution in message
* @returns {String} the message
*/
function getI18nMsg(msgKey,positionalArguments)
{
return replaceParams(i18Texts[msgKey], positionalArguments);
}
/**
* Mimic of the MessageFormat.format method in Java.
* Very nicely explained here: http://stackoverflow.com/questions/1353408/messageformat-in-javascript-parameters-in-localized-ui-strings
* @param {String} string
* @param {Array} replacements
* @returns {String}
*/
function replaceParams(string, replacements) {
return string.replace(/\{(\d+)\}/g, function() {
return replacements[arguments[1]];
});
}
\ No newline at end of file
......@@ -33,7 +33,7 @@
<script type="text/javascript" src="/js/constants.js"></script>
<script type="text/javascript" src="/js/resourcebundle.js"></script>
<script type="text/javascript" src="/js/validateForm.js"></script>
<script type="text/javascript" src="/js/observationFormMap.js"></script>
<script type="text/javascript" src="/js/objectGISInfoMap.js"></script>
<script type="text/javascript">
$(document).ready(function() {
// Make sure that there is a datetime picker present for HTML5
......@@ -57,7 +57,7 @@
<#else>
var geoInfo = <#if observation.geoinfo?has_content>${observation.geoinfo}<#else>{}</#if>;
var chooseFromMapLayers = {"chooseFromMapLayers":<#if mapLayers?has_content>${mapLayers}<#else>[]</#if>};
initMap([${defaultMapCenter.x?c},${defaultMapCenter.y?c}],${defaultMapZoom},false, geoInfo, chooseFromMapLayers);
initMap("observationFormMap",[${defaultMapCenter.x?c},${defaultMapCenter.y?c}],${defaultMapZoom},false, geoInfo, chooseFromMapLayers);
</#if>
});
</script>
......@@ -128,20 +128,9 @@
</form>
</div>
<div class="col-md-6">
<div>
<label>What do you want to draw</label>
<select id="type">
<option value="Point">Point</option>
<option value="Polygon">Polygon</option>
</select>
<button id="delete" type="button">Clear all</button>
<button id="deleteOne" type="button">Clear one</button>
</div>
<div id="observationFormMap" class="map">
</div>
<div id="alert_placeholder"></div>
<div id="observationFormMap"></div> <!-- Contents is added dynamically by objectGISInfoMap -->
</div>
</div>
<div style="display: none;"><div id="marker" title="Marker"><img src="/images/bug_medium.png"/></div></div>
<!--div style="display: none;"><div id="marker" title="Marker"><img src="/images/bug_medium.png"/></div></div-->
</#macro>
<@page_html/>
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Please register or to comment