This repo contains the source code for the interactive data visualization tool SimWrapper, available at https://simwrapper.app
- DOCS available at: https://docs.simwrapper.app/docs
- VSP TU Berlin also has a departmental SimWrapper site at https://vsp.berlin/simwrapper
This README details build instructions for the website itself.
The site uses npm and yarn, and was developed using VS Code.
- You should install VS Code, npm, and yarn first.
- All code is TypeScript and shall remain so.
The following VS Code plugins are used:
- Prettier to force code style consistencey
- Vetur, for Vuejs support. This site is a Vue SPA.
- Shader languages support
You will need to know this tech in order to hack on this website:
- TypeScript - typesafe JavaScript
- Vue - the glue that connects UI elements to code. Similar to React but lightweight and awesome
- ThreeJS - WebGL library for the fancy animations.
- Pug - the template language used in Vue files. Pug uses Python-style indentation instead of open/close XML tags, which makes it far easier to read than bare HTML.
One line fetches everything from the npm database:
npm ci
This command runs a local server with hot reload for testing, usually listens on http://localhost:8080
npm run dev
npm run build
Well... I have not written tests but the infrastructure is there to use jest.
npm run test:unit
Travis-CI is configured to automatically build the site with every push to master, so don't push to master until you are ready for your code to go live.
- Travis config is in
.travis.yml
/src: all TypeScript and Vue files go here/src/svnConfig.ts: this file defines the file storage locations available on the front page. Thesvnparameter must be a valid URL pointing to an http fileserver, running either Apache, subversion, or SimpleFileServer. Other file storage could be written and placed in/src/util./src/assets: images, .csvs, etc that get packaged by webpack/src/components: shared Vue components go here/src/layers: shared deck.gl layer files go here/src/plugins: Each plugin gets its own folder here. To create your own plugin, copy one of these, rename its folder and main .vue file, and register it inpluginRegistry.ts. Read the plugin developer guide for details./src/util: some typscript utility classes, notably including the HTTPFileServer/src/views: The Vue pages that render various site pages such as the home page. Vue pages are registered in/src/router.tsHomeIndex.vue: the front page. Add new thumbnails for pages or other content here.FolderBrowser.vue: Project pages are rendered by this page
/public: large .zip files, project notes, etc go in public. These files are pushed as-is by webpack; i.e. they are not packaged in any way/scripts: Python scripts go here. Most of these are used for postprocessing model results
Good luck and thanks for the help! -- Billy