This project demonstrates how to build maintainable UI elements or widgets in your map.apps bundles. You may use this project as a blueprint for starting your own map.apps project.
This Maven project includes some of the core concepts for developing UI-driven bundles in map.apps. Use this readme as a guide for what to discover in this project. After studying this project, you should be able to answer the following questions:
- How can I use Vue.js to build widgets following the MVVM pattern?
- How does the MVVM pattern help to make UI components and models testable?
- How do I build widgets with ready-to-use UI components from Vuetify.js?
- How do I build a custom theme (theme-custom)?
- How can the view model interact via bindings with (Accessor) models from the Esri ArcGIS API for JavaScript?
- How is my layout integrated into map.apps templates?
- How do gulp processes modify my source code?
- map.apps 4.7.2
- all resources from
map.apps-VERSION/sdk/m2-repository
need to be copied manually to your local Maven repository (e.g.%UserProfile%/.m2/repository
for Windows,~/.m2/repository
for MacOS).
The project supports a 'remote project' and 'standalone project' mode.
In this mode a map.apps installation is available elsewhere and most JavaScript resources are fetched from this installation. This mode is recommended.
The URL of the map.apps server can be declared in the pom.xml.
Replace
<mapapps.remote.base>.</mapapps.remote.base>
with
<mapapps.remote.base>http://yourserver/mapapps</mapapps.remote.base>
As an alternative the URL can be declared in a file called build.properties
with the content
mapapps.remote.base=http://yourserver/mapapps
and enabling the "env-dev" Maven profile.
Append -P env-dev
or -Denv=dev
to any Maven execution or declare the profile as activated by default in your Maven settings.xml.
In this mode all JavaScript sources are added to this project during development. The drawback of this mode is that you can not test authentication and that the default settings are not read from the remote instance.
This mode requires that the profile include-mapapps-deps
is activated.
Append -P include-mapapps-deps
to any Maven execution or declare the profile as activated by default in your Maven settings.xml.
Start the integrated Jetty server with:
mvn clean jetty:run -P watch-all
Make sure that the watch-all
Maven profile is activated.
The profile will start a gulp task that watches for changes in your source code.
After a successfull start the Jetty server ist available at http://localhost:9090.
By appending -Denv=dev -Dlocal.configfile=./build.properties
to any Maven execution the development mode is activated.
This means:
- Node.js and npm are not installed
- watch-all profile is activated
- the build.properties file is loaded
To enforce the installation of Node.js and npm execute:
mvn initialize
This triggers the installation of Node.js and npm exclusively.
To develop line 3 bundles with mapapps-4-developers, some adaptations are required. This will only work with the 'remote project'
mode.
The map.apps remote base mentioned above should point to a map.apps 4 installation, which always includes the bundles of line 3 as well.
This should be the default after map.apps 4 was installed.
<mapapps.remote.base>http://yourserver/mapapps</mapapps.remote.base>
To force project based on mapapps-4-developers to use the correct apprt.version
for line 3 developement, the index.html
file in
src/main/webapp
has to be changed the following way:
$apprt.changeConfig({ct: {
amdPackages: ["apprt@^@@apprt.version@@"]
}});
should be replaced by
$apprt.changeConfig({ct: {
amdPackages: ["apprt@^3.10.0"]
}});
Make sure to use the intended target map.apps 3.x version.
To ensure that the correct bundle versions are loaded, the app.json
for a line 3 app needs to be configured with the correct versions:
{
"properties": {
"amdPackages": "apprt@^3.10.0"
},
"load": {
"bundleLocations" : ["localbundles","bundles"],
"allowedBundles" : [
"system@^3.10.0",
"splashscreen@^3.10.0",
"map@^3.10.0",
[...]
Since line 3 bundles are often coded in the old Dojo AMD style and not transpiled from ES6, it is necessary to exclude
them from the transpilation process. To achieve this, any line 3 app folder and any line 3 bundle folder has to contain a .babelrc
file in the directory root
with the following content.
{
"ignore":["**/*"]
}
With all these changes, the Jetty server can be started.
Note that this will only cover JS bundle development capabilities. To develop themes and templates, the old
sampleRemoteProj
should be used. To get a copy, contact [email protected]
For detailed development documentation have a look at conterra's developer network (account required).
To ensure that all files are compressed/minified and a dependencies.json is calculated execute:
mvn clean install -P compress
To upload your apps and bundles after compression append the upload
profile.
mvn clean install -P compress,upload
To execute the unit tests inside the project, run http://localhost:9090/js/tests/runTests.html.
If you run the project in 'remote project' mode, you will have to edit the
test-init.js
file located in the/src/test/webapp/js/tests/
folder.
- Interaction with ESRI map
- Use of Binding (e.g. with Accessor)
- Sample of minimum fileset needed to create a custom theme.
- Make sure bundle is loaded instead of theme-everlasting in sample app
- When renaming/copying the theme-custom bundle to e.g. theme-[projectname] make sure the adjustments (theme-name) have refelected to the following files.
- gulpfile.js
- theme-name/manifest.json
- theme-name/styles/styles.less
- The gulpfile that determines the build process can be found in the root directory:
/gulpfile.js
- package.json / npm
- adjust the
mapapps.version
property in./pom.xml
to4.7.2
- adjust the
ct.jsregistry.version
property in./pom.xml
to1.3.2
- add version hint
<version>${ct.jsrt-test.version}</version>
for dependenciesct-jsrt-test-intern
andct-jsrt-test-uitest
inpom.xml
- Update Gulpfile and remove dev dependencies from
gulpfile.js
. For details see commit
- adjust the
mapapps.version
property in./pom.xml
to4.7.1
- adjust the
ct.jsregistry.version
property in./pom.xml
to1.3.1
- adjust the
mapapps.version
property in./pom.xml
to4.7.0
- adjust the
ct.jsregistry.version
property in./pom.xml
to1.3.0
- adjust versions of devDependencies in
./package.json
according to the list below:- "eslint-config-ct-prodeng": "^1.0.5"
- "vue-template-compiler": "2.6.6"
- adjust the
mapapps.version
property in./pom.xml
to4.6.1
- adjust the
mapapps.version
property in./pom.xml
to4.6.0
- adjust versions of devDependencies in
./package.json
according to the list below:- "ct-mapapps-gulp-js": "~0.1.3"
- "vue-template-compiler": "2.5.17"
- Go to
./src/test/webapp/index.html
and replace thecorsEnabledServers: ["@@mapapps.remote.base@@"]
withtrustedServers: ["@@mapapps.remote.base@@"]
inside the apprt request configuration object.