A Form is a collection of Controls for AngularJS. Controls are ways for a user to enter data. This library is created by DUBOIS Romain and maintained by the Scille team.
In order to get started, you'll want to install some tools globally.
$ sudo apt-get install nodejs
$ sudo ln /usr/bin/nodejs /usr/bin/node
$ sudo apt-get install npm
$ sudo npm install -g bower gulp coffee-script karma-cli protractor
$ git clone https://github.com/Scille/sc-form
$ cd sc-form
$ npm install
$ bower install
$ bower install sc-form --save-dev
To be able to use the directive, you need to register the sc-form module as a dependency:
angular.module('yourModule', ['sc-form'
// other dependencies
]);
Directives can work on both attribute and element levels.
<div sc-text-input-directive
ng-model="textModel"
icon="{{icon}}"
label="{{label}}"
placeholder="{{placeholder}}"
popover-msg="{{popoverMsg}}"
error-msg="errorMsg"
upper-first-letter="upperFirstLetter"
is-disabled="isDisabled">
</div>
<div sc-list-text-input-directive
ng-model="listModel"
icon="{{icon}}"
label="{{label}}"
placeholder="{{placeholder}}"
popover-msg="{{popoverMsg}}"
error-msg="errorMsg"
is-disabled="isDisabled"
upper-first-letter="upperFirstLetter">
</div>
<div sc-pwd-input-directive
ng-model="pwdModel"
icon="{{icon}}"
label="{{label}}"
placeholder="{{placeholder}}"
popover-msg="{{popoverMsg}}"
error-msg="errorMsg"
strength="strength">
</div>
<div sc-number-input-directive
ng-model="numberModel"
icon="{{icon}}"
label="{{label}}"
placeholder="{{placeholder}}"
popover-msg="{{popoverMsg}}"
error-msg="errorMsg"
is-disabled="isDisabled"
step="step">
</div>
<div sc-date-input-directive
ng-model="dateModel"
icon="{{icon}}"
label="{{label}}"
popover-msg="{{popoverMsg}}"
type="{{type}}}"
approximative-model="approximativeModel"
error-msg="errorMsg"
is-disabled="isDisabled">
</div>
<div sc-select-input-directive
ng-model="selectModel"
icon="{{icon}}"
label="{{label}}"
options-json="{{json}}"
error-msg="errorMsg"
is-disabled="isDisabled"
options-model="optionsModel">
</div>
<div sc-list-select-input-directive
ng-model="listSelectModel"
icon="{{icon}}"
label="{{label}}"
options-json="{{json}}"
error-msg="errorMsg"
is-disabled="isDisabled"
options-model="optionsModel">
</div>
<div sc-array-input-directive
ng-model="arrayModel"
add-button="{{addButton}}"
json="{{json}}"
label="{{label}}"
is-disabled="isDisabled">
</div>
<div sc-img-input-directive
ng-model="imgModel"
label="{{label}}"
placeholder="{{placeholder}}"
error-msg="errorMsg"
is-disabled="isDisabled">
</div>
Note:
- ng-model: Will try to bind to the property given by evaluating the expression on the current scope. If the property doesn't already exist on this scope, it will be created implicitly and added to the scope.
- add-button: Sets the button value.
- icon: Sets the icon.
- json: Sets the JSON file.
- label: Sets the label text.
- options-json: Sets the select options values as JSON file.
- placeholder: Sets the input placeholder.
- popover-msg: Sets the popover message.
- type: Sets the input type (date or datetime-local).
- approximative-model: Determines if the input is an approximate date.
- error-msg: Sets the error message.
- is-disabled: Determines if the input is disabled or not.
- options-model: Sets the select options values.
- strength: Sets the regex password and unmatch password error value.
- step: Specifies the legal number intervals.
- upper-first-letter: Capitalizes the first letter of string.
sc-form/
|
|- demo/ -> Contains JavaScript file and HTML file. (Used by Gulp to run the demonstration)
|
|- release/ -> Contains the production minified release of the app.
| |- sc-form.min.css -> Minified CSS file.
| '- sc-form.min.js -> Minified JavaScript file.
|
|- src/ -> Contains CoffeeScript sources, LESS styles and other assets.
| |- script/ -> CoffeeScript sources and HTML that contains Angular-specific elements and attributes.
| '- style/ -> LESS sources.
|
'- test/ -> Contains tests for the application.
|- e2e/ -> End-To-End tests for AngularJS applications. (Protractor)
'- unit/ -> Unit tests for AngularJS components. (Karma)
Executing the demo with:
$ gulp serve
Executing demo on GitHub Pages: scille.github.io/sc-form
Executing Unit Tests with Gulp:
$ gulp unit-test
Executing Unit Tests by Karma:
$ karma start ./test/karma_conf.coffee --single-run
It will also generate HTML test coverage report inside ./.tmp/report-html directory.
Executing End-To-End Tests with Gulp:
$ gulp e2e-test
Executing End-To-End Tests by Protractor:
$ protractor ./test/protractor_conf.coffee
- see Bootstrap
DUBOIS Romain, Engineer R&D at SCILLE romain.dubois@scille.fr
LANDIETH Jérôme, Engineer R&D at SCILLE jerome.landieth@scille.fr
MEZINO Vincent, Engineer R&D at SCILLE vincent.mezino@scille.fr
STEMPERT Nicolas, Engineer R&D at SCILLE nicolas.stempert@scille.fr
Licensed under the MIT License