diff --git a/src/main/java/no/nibio/vips/logic/i18n/ResourceBundleJSServlet.java b/src/main/java/no/nibio/vips/logic/i18n/ResourceBundleJSServlet.java index b17ca3f07677000a04ab62b467eb4bf66406c83f..8fe10c0021bc0162188a245c540c4680a66e8f07 100644 --- a/src/main/java/no/nibio/vips/logic/i18n/ResourceBundleJSServlet.java +++ b/src/main/java/no/nibio/vips/logic/i18n/ResourceBundleJSServlet.java @@ -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()); } diff --git a/src/main/resources/no/nibio/vips/logic/i18n/vipslogictexts.properties b/src/main/resources/no/nibio/vips/logic/i18n/vipslogictexts.properties index 3e5c09e293b8c3bf098743ccee15f2f347418d7d..add2ccfdfb098a3b77aac3a2a4f23ec7440915b3 100644 --- a/src/main/resources/no/nibio/vips/logic/i18n/vipslogictexts.properties +++ b/src/main/resources/no/nibio/vips/logic/i18n/vipslogictexts.properties @@ -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 diff --git a/src/main/resources/no/nibio/vips/logic/i18n/vipslogictexts_bs.properties b/src/main/resources/no/nibio/vips/logic/i18n/vipslogictexts_bs.properties index 7ae7ba080e9570038d97c8c612dd54b33f7e1481..8aea801067d3035ae89183bf5031315bb98a842a 100644 --- a/src/main/resources/no/nibio/vips/logic/i18n/vipslogictexts_bs.properties +++ b/src/main/resources/no/nibio/vips/logic/i18n/vipslogictexts_bs.properties @@ -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 diff --git a/src/main/resources/no/nibio/vips/logic/i18n/vipslogictexts_hr.properties b/src/main/resources/no/nibio/vips/logic/i18n/vipslogictexts_hr.properties index 8b56087dd472d1b317cc8e47fbe30eb7694b663f..d7988747ad07948ab6dfb7f22c296ddb81420fa4 100644 --- a/src/main/resources/no/nibio/vips/logic/i18n/vipslogictexts_hr.properties +++ b/src/main/resources/no/nibio/vips/logic/i18n/vipslogictexts_hr.properties @@ -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 diff --git a/src/main/resources/no/nibio/vips/logic/i18n/vipslogictexts_nb.properties b/src/main/resources/no/nibio/vips/logic/i18n/vipslogictexts_nb.properties index 13b3239f3a9ae4c6163d8c9dc66c1a088c39eeaa..e48c63d1d9204cc995e5c2a0dc28c06d770e7b7f 100644 --- a/src/main/resources/no/nibio/vips/logic/i18n/vipslogictexts_nb.properties +++ b/src/main/resources/no/nibio/vips/logic/i18n/vipslogictexts_nb.properties @@ -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 diff --git a/src/main/resources/no/nibio/vips/logic/i18n/vipslogictexts_sr.properties b/src/main/resources/no/nibio/vips/logic/i18n/vipslogictexts_sr.properties index 9d905c280aacdc8a8f4acb1ceff760c8a3408e81..88fc8bceb0c73aecdba1ced25121e8848978ae68 100644 --- a/src/main/resources/no/nibio/vips/logic/i18n/vipslogictexts_sr.properties +++ b/src/main/resources/no/nibio/vips/logic/i18n/vipslogictexts_sr.properties @@ -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 diff --git a/src/main/webapp/css/map.css b/src/main/webapp/css/map.css index 8c2103ad3c8b5d947fe2d944a50e0e19669c2994..735c709a49f64c9f7da2feeae9fa99557f94699d 100755 --- a/src/main/webapp/css/map.css +++ b/src/main/webapp/css/map.css @@ -1,5 +1,5 @@ /* - * 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; diff --git a/src/main/webapp/css/vipslogic.css b/src/main/webapp/css/vipslogic.css index 156bca2975a8797c4eca8b27ad39b11b5d4cd22e..bf71bed29801753b50ee94683a8199fbd2cc982b 100644 --- a/src/main/webapp/css/vipslogic.css +++ b/src/main/webapp/css/vipslogic.css @@ -70,7 +70,7 @@ legend { display: block; } -#observationFormMap, #weatherStationListMap, #weatherStationFormMap, #weatherStationViewMap{ +#objectGISInfoMap, #weatherStationListMap, #weatherStationFormMap, #weatherStationViewMap { height: 400px; width: 100%; } diff --git a/src/main/webapp/js/observationFormMap.js b/src/main/webapp/js/objectGISInfoMap.js similarity index 85% rename from src/main/webapp/js/observationFormMap.js rename to src/main/webapp/js/objectGISInfoMap.js index ef9b75f6940829dfe2f763d58e2f047652cf1540..9c91356e05854068b80a9714250ece279b41ebfc 100755 --- a/src/main/webapp/js/observationFormMap.js +++ b/src/main/webapp/js/objectGISInfoMap.js @@ -1,5 +1,5 @@ /* - * 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(); diff --git a/src/main/webapp/js/validateForm.js b/src/main/webapp/js/validateForm.js index a9315c10d91c48ddd2e3507c2016df0ab38cd23a..1545b80e3f2af535e753fb03761d112ed02547c4 100644 --- a/src/main/webapp/js/validateForm.js +++ b/src/main/webapp/js/validateForm.js @@ -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 diff --git a/src/main/webapp/templates/observationForm.ftl b/src/main/webapp/templates/observationForm.ftl index bef0cd52bfff9d60e2f953a793100d23538170c4..ffda393c465c1d9eb011da2d8fda344742c2ee30 100755 --- a/src/main/webapp/templates/observationForm.ftl +++ b/src/main/webapp/templates/observationForm.ftl @@ -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/>