Skip to end of metadata
Go to start of metadata

You are viewing an old version of this page. View the current version.

Compare with Current View Page History

« Previous Version 2 Next »

The Form is a UI library that generates a form look and feel to add/update the data and submit the changes. The library is available in Dashboard UI and can be invoked by any module. The Form offers the following Features:

FeatureDescription
RenderingThe form is provided with a fields array, each field is represented by a configuration object that states how it should be rendered. Based on these configuration objects, the form is populated.
Operation AttachingThe form is passed on a list provided with the list buttons that will be displayed below the fields populate and the operations that should be triggered when these buttons are pressed.

The form can be populated in two methods:

  • Page Form: The form will be populated and the hooks are attached, a display directive is generated ngform. You can then use this directive anywhere on your page to print the form.
  • Modal Form: The form will be populated and the hooks are attached, however the form uses the Modal feature of AngularJS's Bootstrap and injects its ngform directive in it.


Usage


The Form requires a configuration object that includes the fields and actions it needs to populate. Since the form can be displayed in two methods as explained above, there are two constructors provided to build it. The below table explains the parameters passed on to the form constructors.

Build Form:

FeatureDescription
ScopeThe scope of the module's controller, refer to Create UI Module for more information.
ConfigurationA configuration object that contains the fields and operations.

Build Form in Modal:

FeatureDescription
ScopeThe scope of the module's controller, refer to Create UI Module for more information.
ModalAn instance of the Modal feature from AngularJS's Bootstrap.
ConfigurationA configuration object that contains the fields and operations.
Code Sample:
//create a form configuration object
var config = {
    "form": {
        //specify the list of inputs and how they should be rendered
        "entries": [
            {
                'name': 'username',
                'label': 'Username',
                'type': 'text',
                'placeholder': 'Enter Username...',
                'value': '',
                'tooltip': 'Usernames are alphanumeric and support _ & - characters only',
                'required': true
            },
            {
                'name': 'email',
                'label': 'Email',
                'type': 'email',
                'placeholder': 'Enter Email...',
                'value': '',
                'tooltip': 'myemail@example.domain',
                'required': true
            }
        ]
    },

    //give your form a machine name
    "name": 'addMember',

    //add a label for your form, it will show in the form's header
    "label": 'Add New Member',

    //attach some action buttons to the form
    "actions":[
        {
            'type': 'submit',               //button type
            'label': 'Add Member',          //button label
            'btn': 'primary',               //button class name (AngularJs's Bootstrap)
            'action': function(formData) {  //operation function, returns the data entered in the form
                //add your business logic here
            }
        },
        {
            'type': 'reset',
            'label': 'Cancel',
            'btn': 'danger',
            'action': function(formData) {
                //add your business logic here
            }
        }
    ]
};

//call buildForm
buildForm($scope, config);

//call buildForm
buildFormWithModal($scope, $modal, config);

The above code snippets demonstrates how the form configuration should be.


Supported Inputs


The Form supports several types of field rendering displays; field rendering configuration differ to support the different types of how fields could be rendered.

Property NameProperty TypeDescription
typeStringThe type of the field, should be one of the values of the forth column
Available: text | password | email | number | phone | url | readonly | textarea | radio | checkbox | select | multi-select | date-picker | html | document | image | audio | video
nameStringName of the Field
Available: text | password | email | number | phone | url | readonly | textarea | radio | checkbox | select | multi-select | date-picker | html | document | image | audio | video
labelStringLabel of the Field
Available: text | password | email | number | phone | url | readonly | textarea | radio | checkbox | select | multi-select | date-picker | html | document | image | audio | video
requiredBooleanSpecify if input is required or not
Available: text | password | email | number | phone | url | readonly | textarea | radio | checkbox | select | multi-select | date-picker | html
fieldMsgStringOptional text to display below input
Available: text | password | email | number | phone | url | readonly | textarea | radio | checkbox | select | multi-select | date-picker | html | document | image | audio | video
placeholderStringOptional text to by default as input placeholder
Available: text | email | number | phone | url | readonly | textarea
tooltipStringOptional text to display in a tooltip above input when mouse is over input
Available: text | password | email | number | phone | url | textarea | radio | checkbox | select | multi-select | date-picker
rowsintegerOptional number of rows in a textarea
Available: textarea
mindateMinimum starting date value
Available: date-picker
limitintegerMaximum number of uploaded files for the given type or 0 for unlimited
Available: document | image | audio | video
valueStringThe value of the input
Available: text | password | email | number | phone | url | readonly | textarea | html
valuearrayArray of available value and which are selected by default. Ex: [ {"v": "value1", "l": "Value 1", "selected": true}, {"v": "value2", "l": "Value 2"} ]
Available: select | radio | checkbox | multi-select
valuedateThe value of the date picker
Available: date-picker


File Handling


The Form Library provides support for 4 media types: Documents - Images - Audio Tracks - Videos.
Media inputs have special treatment in the form library. When provided, every input can have multiple medias, grouped under it.

Declaring a media input:

{
    'name': 'my_files',
    'label': 'My Files',
    'type': 'document',
    'limit': 1,
    'value': []
}

The above snippet shows how a media input named my_files of type document with a maximum limit of 1 media is provided to the form library. The above code will result in an input of type file, for the user to browse and select a file to be uploaded.


Modifying an existing media input:

Files should be stored in GridFS and not on the file system, this guarantees that if a service goes down, the data will not be lost.
The form adds 2 event listeners to every value in an existing media input: download - removeFile.
These listeners are used to either call a service API and download the original version of the media or to trigger a remove operation. Therefore when attempting to replace/remove an existing media input, additional information should be supplied.

{
    'name': 'my_files',
    'label': 'My Files',
    'type': 'document',
    'limit': 1,
    'value': [
        {
            '_id': '5551aca9e179c39b760f7a1a',
            'routeName': '/my_service/files/download',
            'headers': {
                'soajsauth': 'soajs_authentication_token'
            },
            'params': {
                'env': 'dev'
            },
            'metadata': {
                'mime': 'text/plain'
            },
            'contentType': 'text/plain',
            'filename': 'my_file.txt'
        }
    ]
}

The above snippet demonstrates how a media input should be provided to the form for editing. The following table explains the entries of every object inside the array:

PropertyDescriptionComputed
_idThe id of the file in GridFS.YES
routeNameThe Service API that should be called to download the original copy of this file.NO
headersAny optional headers that need to be provided when calling the service APIs to either download or remove the file.NO
paramsAny optional params that need to be provided when calling the service APIs to either download or remove the file.NO
metadataComputed Object by GridFS that contains the mime type information of the file.YES
contentTypeA computed value by GridFS representing the mimetype of the fileYES
fileNameA computed value by GridFS representing the mimetype of the fileYES
  • No labels

0 Comments

You are not logged in. Any changes you make will be marked as anonymous. You may want to Log In if you already have an account.