Demo: http://arcticlcc.github.io/dmplanner/
##About
The DMPlanner is a JavaScript application for creating data management plans. The DMPlanner is primarily built using the ExtJS framework. See the CREDITS for a list of other open source libraries used.
The DMPlanner is a client-side application. By default, no data is sent to a remote server, but is stored in the browser cache (local storage). Data will persist until the browser cache is cleared. When the DMPlanner loads, it checks local storage for cached data.
Data may also be saved to or loaded from a (JSON) file. This allows data to be stored indefinitely or transferred between systems.
The DMPlanner is configured using a JSON file. The config file serves as both template for generating new plans and the storage format. The "saved" output contains both the configuration as well as the data for each plan.
By default, any of the native ExtJS form field widgets (or sub-classes) may be used when defining a plan. To supplement the basic form widgets, custom plug-ins may also be created, such as maps or drag-n-drop lists.
##Data Model
The image below show the basic data model for the JSON config file.
##Development/Installation
###Option 1: Using the JSON config
Creating a new (or editing an existing) JSON config file is the easiest way to customize the DMPlanner. Use this option, if you're not interested in creating new plugins or modifying the application source.
Steps:
- Fork or clone the repository.
- The production code is in the gh-pages branch.
- Customize
- Edit the data.json file or one of the examples.
- Update the documentation files.
- If you push the changes to GitHub, you'll have a DMPlanner instance hosted at {username}.github.io/dmplanner/
Alternative: Download the gh-pages branch and use with any web server.
###Option 2: Modifying the source
TODO
##License
Unless otherwise noted, the contents of this repository are released into the public domain, see the LICENSE.
Note: ExtJS is licensed under the terms of the Open Source GPL 3.0 license. See additional licensing info included with other external libraries.
##Directory Layout
This folder contains files used in the build process.
This folder contains the javascript files for the application.
This folder contains files used in the build process.
This folder contains external JavaScript libraries and git sub-modules.
This folder contains override classes. All overrides in this folder will be automatically included in application builds if the target class of the override is loaded.
This folder contains static resources (typically an "images"
folder as well).
This folder contains misc. support code for sass builds (global functions, mixins, etc.)
This folder contains sass files defining css rules corresponding to classes included in the application's javascript code build. By default, files in this folder are mapped to the application's root namespace, 'dmplanner'. The namespace to which files in this directory are matched is controlled by the app.sass.namespace property in dmplanner/.sencha/app/sencha.cfg.
This folder contains sass files defining sass variables corresponding to classes included in the application's javascript code build. By default, files in this folder are mapped to the application's root namespace, 'dmplanner'. The namespace to which files in this directory are matched is controlled by the app.sass.namespace property in dmplanner/.sencha/app/sencha.cfg.
This folder contains ExtJS user extensions.