Research
Security News
Quasar RAT Disguised as an npm Package for Detecting Vulnerabilities in Ethereum Smart Contracts
Socket researchers uncover a malicious npm package posing as a tool for detecting vulnerabilities in Etherium smart contracts.
angular-schema-form
Advanced tools
Create complex forms from a JSON schema with angular.
Generate forms from JSON schemas using AngularJS!
medium.com/@SchemaFormIO / schemaform.io / @SchemaFormIO / Movie
If you use ASF in your project/company please let us know! We'd love to feature you on the site.
There has been some recent developments in this project that you might want to read about.
Try out the example page. Try editing the schema or form definition and see what comes out!
Hint: By pressing the 'Save to gist' button (top left), you can save your example into a shareable link.
Schema Form is a set of AngularJS directives (and a couple of services). It can do two things to make life easier:
Schema Form uses convention over configuration, so it comes packaged with some sensible defaults. But you can always customize it by changing the order and types of form fields.
Schema Form is inspired by the nice JSON Form library and aims to be roughly compatible with it, especially its form definition. So what sets Schema Form apart from JSON Form?
You can find all documentation here, it covers all the different field types and their options.
It also covers how to extend angular schema form with your own field types.
First, expose your schema, form, and model to the $scope.
angular.module('myModule', ['schemaForm'])
.controller('FormController', function($scope) {
$scope.schema = {
type: "object",
properties: {
name: { type: "string", minLength: 2, title: "Name", description: "Name or alias" },
title: {
type: "string",
enum: ['dr','jr','sir','mrs','mr','NaN','dj']
}
}
};
$scope.form = [
"*",
{
type: "submit",
title: "Save"
}
];
$scope.model = {};
});
Then load them into Schema Form using the sfSchema
, sfForm
, and sfModel
directives.
<div ng-controller="FormController">
<form sf-schema="schema" sf-form="form" sf-model="model"></form>
</div>
npm i angular-schema-form@latest
For the latest pre-release (alpha)
npm i angular-schema-form@pre-release
It's simplest to install Schema Form using Bower. If you use the bootstrap decorator use the one from the angular-schema-form-bootstrap repo
bower install angular-schema-form angular-schema-form-bootstrap
bower install angular-schema-form angular-schema-form-bootstrap
This will install the latest release and basic dependencies. See dependencies section below.
You can also load the files via cdnjs.com.
You can also just download the contents of the dist/
folder and add dependencies manually.
Schema form has a lot of dependencies, most of which are optional. Schema Form depends on:
If you install via bower you get all of the above except bootstrap since we don't want to push a certain version or flavor on you. Also make sure you got the angular version you actually want.
tabarray
. Tab arrays default to tabs on the left side. For these to work, you'll need to include the CSS from bootstrap-vertical-tabs. However, you won't need Bootstrap Vertical Tabs for horizontal tabs (the tabType: "top"
option).The minified files include templates - no need to load additional HTML files.
Schema form is split into two main files, dist/schema-form.min.js
and
dist/bootstrap-decorator.min.js
and they need be loaded in that order. AngularJS,
tv4 and objectpath
also needs to be loaded before Schema Form.
<script type="text/javascript" src="bower_components/angular/angular.min.js"></script>
<script type="text/javascript" src="bower_components/angular-sanitize/angular-sanitize.min.js"></script>
<script type="text/javascript" src="bower_components/tv4/tv4.js"></script>
<script type="text/javascript" src="bower_components/objectpath/lib/ObjectPath.js"></script>
<script type="text/javascript" src="bower_components/angular-schema-form/dist/schema-form.min.js"></script>
<script type="text/javascript" src="bower_components/angular-schema-form/dist/bootstrap-decorator.min.js"></script>
Don't forget to load the schemaForm
module or nothing will happen.
angular.module('myModule', ['schemaForm']);
There are several add-ons available, for a full list see the web page. Your can also create your own add-ons!
Contributions are welcome! Please see Contributing.md for more info.
The new Webpack compilation has made it easier to manage files and code and run build scripts, but it is still not easy enough for users unfamiliar with it... yet.
NOTE in order to build simultaneously with json-schema-form-core
you must have it cloned
as a sibling directory to this one OR npm install the version you wish to build with.
Webpack now generates a header to indicate version and date of build. Do not create PR with the DIST folder.
This branch will be the next version of Angular Schema Form, currently please use the examples/example.html file as the best example to get the framework working.
The example uses angular-schema-form.js and angular-schema-form-bootstrap.js for the version of the code it executes, if you want your page to behave the same you obviously need the same version!
To see how to make an add-on work I have now included the calculate add-on file within the examples/add-on directory.
Unit tests are run with karma and written using mocha, chai and sinon
To run the tests:
npm test
.$ npm install
$ bower install
$ npm test
FAQs
Create complex forms from a JSON schema with angular.
The npm package angular-schema-form receives a total of 1,034 weekly downloads. As such, angular-schema-form popularity was classified as popular.
We found that angular-schema-form demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Research
Security News
Socket researchers uncover a malicious npm package posing as a tool for detecting vulnerabilities in Etherium smart contracts.
Security News
Research
A supply chain attack on Rspack's npm packages injected cryptomining malware, potentially impacting thousands of developers.
Research
Security News
Socket researchers discovered a malware campaign on npm delivering the Skuld infostealer via typosquatted packages, exposing sensitive data.