Replacement for spatial-portal with Grails, AngularJS and Leaflet.
See also: Integration Tests
Modify configurations in
/data/spatial-hub/config/spatial-hub-config.yml
The default production url is https://spatial.ala.org.au
The default develop url is http://devt.ala.org.au:8079
The dependent services point to other production servers by default
api_key: xxxxxxxxx-d184-4276-afc2-6ece17176d7c
google:
apikey: xxxxxxxx
####Example: grails.serverURL: "https://spatial-test.ala.org.au" grails.app.context: "/"
googleAnalyticsId: "xxxxxxxx"
google:
apikey: "xxxxxxxxxxxxxx"
api_key: xxxxxxxxxxxxxxxxx
layersService:
url: "https://spatial-test.ala.org.au/ws"
geoserver:
url: "https://spatial-test.ala.org.au/geoserver"
- The main menu is overridden with
/data/spatial-hub/menu-config.json
.
/* Example */
[
{
"name": "Add to map", /* Dropdown menu label */
"width": 110, /* Dropdown menu button width in pixels. The left hand panel is a fixed width. */
"items": [ /* Dropdown menu items */
{
"name": "Species", /* Button label */
"open": "ToolAddSpeciesService" /* Open a service based tool. Compatible services are found in grails-app/assets/javascripts/spApp/services/tool*Service.js
},
{
"name": "Area", /* Button label */
"open": "addArea" /* Open a controller based tool. Compatible controllers are found in grails-app/assets/javascripts/spApp/controller/*Ctrl.js
},
{
"name": "Detailed Area Report (PDF)", /* Button label */
"open": "AreaReport" /* Open a spatial-service based tool. Available tools are found in spatial-service /admin/capabilities.
},
{
"name": "Getting Started", /* Button label */
"open": "https://www.ala.org.au/spatial-portal-help/getting-started" /* Open a https:// or http:// url */
}
]
},
- Templated dialog appearance can be overridden with
/data/spatial-hub/view-config.json
.
/* Example */
{
"Maxent": { /* Name of tool in spatial-service capabilities */
"view": [ /* List of input sections in the order to displa */
{
"name": "Area to restrict prediction", /* Title of first input section */
"inputs": [ /* List of inputs from tool capabilities for this section */
"area"
]
},
{
"name": "MaxEnt options", /* Title of the second input section */
"inputs": [ /* List of inputs from tool capabilities for this section */
"testPercentage",
"resolution"
]
}
],
"input": { /* Override input specifications */
"testPercentage": { /* Input name */
"description": "Percentage of records used for testing model?", /* new description */
"constraints": {
"default": 0.2 /* New default value */
}
}
}
}
Configure ala-bootstrap3
-
This is recommended since it can be reused by all components that use ala-bootstrap3
-
Fork commonui-bs3, modify and deploy
-
Configure to use the deployed commonui-bs3
# edit /data/spatial-hub/config/spatial-hub-config.properties skin.layout=generic headerAndFooter.baseURL=<URL to deployed commonui-bs3>
-
Fork spatial-hub, modify and deploy
- Use when development of spatial-hub is expected. It can be used with with the other methods.
-
Adding files local to deployment can add new layouts and resources.
-
Add a new layout gsp to the
/data/spatial-hub/views/layouts
directory./data/spatial-hub/views/layouts/myLayout.gsp
-
Additional assets can be added to the
/data/spatial-hub/assets
directory./data/spatial-hub/assets/css/externalCss.css /data/spatial-hub/assets/js/externalJs.js /data/spatial-hub/assets/img/externalImage.png
-
Assets can be referenced within the new layout gsp.
<asset:stylesheet src="css/externalCss.css" /> <asset:javascript src="js/externalJs.js" /> <asset:image src="img/externalImg.png" />
-
Change config to use the new layout gsp.
# edit /data/spatial-hub/config/spatial-hub-config.properties skin.layout=myLayout
-
Note:
A forked commonui-bs3 can be deployed to
/data/spatial-hub/assets/
and used with the config# edit /data/spatial-hub/config/spatial-hub-config.properties skin.layout=generic headerAndFooter.baseURL=<URL to this spatial-hub instance>/assets
Additional map views can be created and served from urls hub/{{hub_name}}. This is done by creating additional files in the /data/spatial-hub directory.
Files required to create a new hub view.
Files required | Overrides /data/spatial-hub/config/ |
Overrides grailsApp/conf/ |
---|---|---|
/data/spatial-hub/config/{{hub_name}}/app-config.json |
spatial-hub-config.yml |
application.yml |
/data/spatial-hub/config/{{hub_name}}/view-config.json |
view-config.json |
view-config.json |
/data/spatial-hub/config/{{hub_name}}/menu-config.json |
menu-config.json |
menu-config.json |
An additional css can be included with /data/spatial-hub/assets/css/{{hub_name}}.css
when using skin.layout
portal
or generic
. This may not be used by a local layout gsp file.
Example embedExample.html (TODO: finish implementation)
The build is setup to work with Firefox and Chrome.
Have a look at the build.gradle
and the src/test/resources/GebConfig.groovy
file.
From line 200 in build.gradle, you will find how we pass different test servers and authentication into tests.
Skip integration test in building process
./gradlew build -x integrationTest
./gradlew :integrationTest -Dusername=xxxx -Dpassword=xxxxx
Or
./gradlew :integrationTest
when authentication is stored into the default file:
/data/spatial-hub/test/default.properties
See more: How to pass authentication
This solution is not requried by M2 MBP
./gradlew :integrationTest -Ddriver=chrome
Chrome driver > 89 is not available for webdirver Use npm to set the chrome driver version and reference the lib path from node_modules.
Add "chromedriver": "89.0.0"
to package.json
Run npm install
In ./gebConfig.groovy
if (!System.getProperty("webdriver.chrome.driver")) {
System.setProperty("webdriver.chrome.driver", "node_modules/chromedriver/bin/chromedriver")
}
./gradlew :integrationTest -DbaseUrl=http://spatial-test.ala.org.au/
Authentication info can be passed through with -Dusername and -Dpassword
/gradlew :integrationTest -Dusername=xxxx -Dpassword=xxxxx
Or stored in a config file. The default config file is located in
/data/spatial-hub/test/default.properties
username="xxxx@csiro.au"
password="xxxxx"
We can change the config file with -DconfigFile
/gradlew :integrationTest -DconfigFile="myconfig.properties"
Layers required to be imported to Spatial Service:
Koppen Climate Classification (Major Classes)
Precipitation - annual (Bio12)
Temperature - annual mean (Bio01)
GEOMACS - geometric mean
ASGS Australian States and Territories
IBRA 7 Subregions
Williams 2030 best 5 - for predict and classify
el1002, el1019, el1037, el1036, el1013
Libs
GDAL: gdal_translate
Koppen.kml and Koppen.zip are stored in ./test/resources
Code structure of functional tests:
./test/resources/Functional_Test_Module.png