Featuring examples of using TypeScript with Web AppBuilder.
There are 2 types of project examples in this repository, one if you want to use and test your custom widgets within a running version of Web AppBuilder (see builder section below) and one example of if you're developing a widget for a particular app (see developer section below).
Example using TypeScript and Grunt to copy files to your local Web AppBuilder Developer Edition so you can use your custom widgets in the builder interface. This is meant to be an example of what an output of generator-esri-appbuilder-js might look like if Typescript were integrated into the generator.
- Copy the files from the /builderfolder to your GitHub repo.
- Update the file paths at the beginning (line ~10) of Gruntfile.jsto point to your running Web AppBuilder instance.
- Install Node.js.
- npm install -g grunt-cli(see https://gruntjs.com/getting-started)
- npm install
- grunt
If you're not using the builder interface, this version extracts Web AppBuilder, copies the config files for your app, builds your widgets, and hosts the files. This workflow is less common, but can get you running quicker and easier.
- Install Node.js.
- npm install -g grunt-cli(see https://gruntjs.com/getting-started)
- Clone or download this repo.
- Download the Web AppBuilder Developer Edition zip file from here, and save the zip file named arcgis-web-appbuilder-2.6.zipinto thedeveloper/folder, right at the same level as theGruntfile.js.
- In the terminal, browse to the developerfolder
- npm install
- grunt init
Run grunt and as you modify your files, the web app should be updated automatically.
A few notes about the general ideas and principles that are used in both the builder and developer versions of this code
- We are currently supporting TypeScript version 2.6.
- The Declare Decorator is used to tell TypeScript how to translate our Widget class into a dojo/declare syntax that Web AppBuilder is looking for. Decorators are currently experimental (although widely used) so beware of that small risk. If TypeScript did take out decorators at some point, we would have to change how we're doing this.