Giter Site home page Giter Site logo

starwalker / angular-schema-form-uiselect Goto Github PK

View Code? Open in Web Editor NEW

This project forked from chengz/schema-form-uiselect

0.0 2.0 0.0 1.25 MB

ui-select implementation for schema-form

License: MIT License

JavaScript 71.00% HTML 15.37% CSS 13.62%

angular-schema-form-uiselect's Introduction

ui-select add-on

This ui-select add-on uses as the name implies the ui-select plugin to provide a select dropdown interface. ui-select is used.

Installation

The editor is an add-on to the Bootstrap decorator. To use it, just include bootstrape-uiselect.min.js.

Easiest way is to install is with bower, this will also include dependencies:

$ bower install angular-schema-form-uiselect

You'll need to load a few additional files to use the editor:

Be sure to load this projects files after you load angular schema form

Example

<script type="text/javascript" src="/bower_components/angular/angular.min.js"></script>
<script src="bower_components/angular-sanitize/angular-sanitize.min.js"></script>
<script src="bower_components/angular-translate/angular-translate.min.js"></script>
<script src='bower_components/angular-ui-select/dist/select.js'></script>
<script src="bower_components/tv4/tv4.js"></script>
<script src="bower_components/objectpath/lib/ObjectPath.js"></script>
<script src="bower_components/angular-schema-form/dist/schema-form.min.js"></script>
<script src="bower_components/angular-schema-form/dist/bootstrap-decorator.min.js"></script>
<script src="schema-form-strapselect.js"></script>

When you create your module, be sure to depend on this project's module as well.

angular.module('yourModule', ['schemaForm']);

Usage

The add-on adds a new form type, uiselect, and a new default mapping.

Schema Default Form type
"type": "string" and "format": "uiselect" uiselect
"type": "array" and "format": "uiselect" uimultiselect

Schema Definintion

person_list: {
  title: 'Person List',
  type: 'string',
  format: 'uiselect',
  items: [
    { value: '1', label: 'Person 1' },
    { value: '2', label: 'Person 2' }
  ]
},
persons_list: {
  title: 'Persons List',
  type: 'array',
  format: 'uiselect',
  items: [
    { value: '1', label: 'Person 1' },
    { value: '2', label: 'Person 2' },
    { value: '3', label: 'Person 3' }
  ]
}

The demo form is loaded from Light Framework Server as it is persisted in graph database. The source code can be found here.

Options

The add-on provides some of the options available in ui-select:

  • To specify a class for select
{
  key: 'person_list',
  placeholder: 'Some Place Holder', //default will translate placeholder.select
  options: {
    uiClass: 'short_select'
  }
}
  • To use the tagging feature of ui select (allowing new values to be added) - see full description here
{
  key: 'person_list',
  placeholder: 'Some Place Holder', //default will translate placeholder.select
  options : {
          tagging: tagFunction ,
          taggingLabel: '(new)',
          taggingTokens: 'SPACE|ENTER|,'
  }
}
  • To use the grouping feature of ui-select the grouping attribute or function can be declared like this.
  • Note that at the present time grouping is not supported at the same time as tagging as there is a bug in the ui select library.
     {
       key: 'another',
       options:{
          groupBy : 'label', //Add the name of the attribute here
       }
     }
  • If a description field is declared in the schema then this will be shown in the drop-down list.

  • searchDescriptions can be turned on and off - for example:

    • If description is provided for context, search may not be desirable due to short / common words / repetition between items.
    • If the description is used for synonyms of the label, search is necessary.
     {
       key: 'another',
       options:{
          searchDescriptions : true
       }
     }

angular-schema-form-uiselect's People

Contributors

chengz avatar stevehu avatar strets123 avatar

Watchers

 avatar  avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.