Skip to content

Latest commit

 

History

History
92 lines (65 loc) · 4.32 KB

README.md

File metadata and controls

92 lines (65 loc) · 4.32 KB

angular-forms

AngularForms makes it easy to build forms for your AngularJS app. Create forms as JSON objects, and let AngularForms generate, compile and inject the HTML into your app, complete with Angular directives, validation and Twitter Bootstrap styling.

For full documentation and help getting started visit http://angularforms.org

Latest stable release: v2.0.2

Requirements

Note that Angular-forms.js is being developed with the latest stable versions of any required packages. It is quite possible that earlier version will work just fine.

Installation

The recommended way to add the required items and angular-forms.js to your project is to use bower.

bower install angular-forms.js

Add the follwing stylesheets and scripts to your app:

<link rel="stylesheet" href="/bower_components/bootstrap/dist/css/bootstrap.min.css">
<link rel="stylesheet" href="/bower_components/components-font-awesome/css/font-awesome.min.css">

<script src="/bower_components/jquery/jquery.min.js"></script>
<script src="/bower_components/jqueryui/ui/minified/jquery-ui.min.js"></script>
<script src="/bower_components/angular/angular.min.js"></script>
<script src="/bower_components/angular-forms.js/angular-forms.min.js"></script>

###Notes

  • the above assume bower installation and with packages installed in bower_components
  • jQueryUI is only required when using the spinner control

Sample Application

A sample application is included to provide a getting started example as well as aid in development. To use the sampe app, clone the angular-forms.js repo, install dependencies, and run the included web server. The following assumes the repo will be clones into ~/projects:

cd ~/projects
git clone [email protected]:chouseknecht/angular-forms.js.git
cd angular-forms.js
bower install

Start the web server:

cd ~/projects/angular-forms.js
./scripts/web-server.js

Point your browser to: http://localhost:8000/app/index.html

Contributing

At the moment there are no tests. They will be added shortly. In the meantime, install the sample app, as detailed above, and add new features or changes to the sample app and demonstrate that things are working as expected. Lint and minify the javascript using Grunt

Release Notes

####2.0.2

  • Added support for custom type fields. Use any HTML or an ng-template to create a completely custom element.
  • Added modelObject property to form definition. Value will be prepended to ng-model, providing a convenient way to define models within an object.

####2.0.1

  • ngOptions now works properly on select elements
  • Removed unnecessary control-label class from checkbox label
  • Fixed duplicate objectModel appearing on radio buttons

####2.0.0

  • Fixed hide/show fields and form validation. When fields are hidden using the ng-hide direcitve, they will now be removed from the angular form controller. When fields are shown using ng-show, they will be added to the angular form controller. Previously fields were not automatically added and removed from the controller, and this often caused the form to be in an invalid state due to errors on a hidden field. The user could not fix the problem, and the save button would be disabled.
  • Added a clearError() method to clear errors on a single field.
  • Code cleanup: removed afEmpty factory
  • Changing the module name to angularforms from AngularFormsModule. The factory is still called AngularForms.
  • For the modal module, changed the name to angularforms.modal from AngularFormsModalModule.

Road Map

Development of version 3 is underway! Version 3 will be a complete refactoring:

  • Angular Forms will become a directive, no longer requiring the controller to call an inject method.
  • As a directive, Angular Forms will be much easier to use, from implementation to unit testing.
  • Version 3 will be fully unit tested.
  • The spinner directive and any jquery-ui dependency will be completely removed.
  • Will fully support new features found in Angular 1.3