App for creating a flexible grid system that can be used for Augmentative and Alternative Communication (AAC), for Smart Home control and as a webradio or YouTube player.
These are the most important features of AsTeRICS Grid:
- Cross platform: runs on PC, Smartphone, Tablet, Windows, Linux, Android, iOS
- No installation needed, just open https://grid.asterics.eu/ in the browser
- Once loaded, AsTeRICS Grid runs offline without internet connection
- Optionally synchronize configuration using the cloud (data is end-to-end encrypted)
- Very flexible grid system, layouts are completely customizable
- Text-to-speech in various languages
- Internationalization: create grid sets in multiple languages
- Various input possibilities like Clicking, Tapping (on touchscreen), Hovering, Scanning, Keyboard, Buttons, and even more complex ones like Eye-Tracking, Head-Tracking or use of EMG muscle sensors (using the AsTeRICS Framework)
- Integrated search for open AAC symbols from https://www.opensymbols.org/
- Smart Home control (using the AsTeRICS Framework)
- Flexible keyboard layouts with word prediction and self-learning dictionaries
- Play webradios (over 25000) using radio-browser.info
- Search and play YouTube videos
There are two versions of AsTeRICS Grid online:
- https://grid.asterics.eu/ current stable release
- https://grid.asterics.eu/latest/ current testing (beta) release, possibly unstable
See User documentation or AsTeRICS Grid Playlist on YouTube.
Also see Developer documentation (not finished, maybe outdated) and the Collaboration guide.
- clone the project
git clone git@github.com:asterics/AsTeRICS-Grid.git
- install node.js https://nodejs.org/
- install yarn, see https://yarnpkg.com/
- go to the directory of the cloned project and run
yarn install
- run
npm run start
and open http://localhost:9095
After yarn install
the following commands are available:
npm run start
--> starts a webserver serving the AsTeRICS grid onhttp://localhost:9095
, does hot reloading if js-sources change.npm run start-legacy
--> same asstart
but js sources are transformed to ES5 using babel.npm run start-no-live
--> same asstart
but hot reloading is disabled.npm run build
--> builds the js-files in foldersrc
toapp/build
folder.npm run start-superlogin-dev
--> runs superlogin locally and makes it possible to create "online users" within the locally running application. A local CouchDb instance is necessary in order to work.npm run release
-> releases the current version with a new tag and push it togh-pages
branch in order to be served at https://grid.asterics.eu/npm run release-latest
-> same asnpm run release
but with destination https://grid.asterics.eu/latest/npm run test
-> runs tests of the project using Jest.
The AsTeRICS Grid evolved out of AsTeRICS Ergo, see AsTeRICS Ergo Master Plan and AsTeRICS Ergo Architecture and will eventually replace AsTeRICS Ergo.
If you want to support the development of AsTeRICS Grid or contribute to the costs for running the server/database for syncronization you're very welcome to donate:
Most of the work for AsTeRICS Grid has been accomplished at the UAS Technikum Wien in course of the R&D-projects ToRaDes (MA23 project 18-04) and WBT (MA23 project 26-02), which have been supported by the City of Vienna, see: ToRaDes Project Information, Webpage WBT project.
Other people and organizations we want to thank:
- Thanks to ARASAAC for collaborating and providing their pictogram API
- Thanks to crowdin.com for providing a free open source license
- Thanks to browserstack.com for providing us free UI tests on their platform.
- Thanks to Alex Segler for the great Webradio API radio-browser.info which makes it possible to search and play webradios within AsTeRICS Grid
- Thanks to the makers of the API from opensymbols.org which makes it possible to search for open AAC symbols within AsTeRICS Grid
- Thanks to ResponsiveVoice for providing an free non-commercial version, ResponsiveVoice-NonCommercial licensed under
- Thanks to all the developers of these projects, which are all used by AsTeRICS Grid in production: