/mobile-ui-elements

Primary LanguageJavaScriptBSD 3-Clause "New" or "Revised" LicenseBSD-3-Clause

Mobile UI Elements (BETA)

Try it out!!

Watch this video!!

Material Design Contact Manager

Mobile UI Elements is a free, open-source Force.com (unsupported) library to simplify the development of mobile apps. The library, based on the Google’s Polymer framework, provides the fundamental building blocks for creating HTML5 apps that run well on smartphones and tablets. The elements can be mixed together to create fairly complex force.com applications and the apps can be deployed in the browser or embedded inside Container from the Salesforce Mobile SDK. Note: The library is still in heavy development and is missing certain features as well as complete documentation. This document is intended to introduce you to the app's architecture and design and make it as easy as possible for you to jump in, run it, and start contributing.

  • What is it?
  • Setup
  • Available UI Elements
  • Third-party Code
  • FAQ
  • Mobile UI Elements License

What is it?

Mobile UI Elements is a set of web components built using Google’s Polymer framework. The library utilizes the future of HTML5 standards, such as Custom Elements, ShadowDOM, Templates, HTML imports etc., to provide a set of new HTML tags that generate the Saleforce driven UI for your mobile application. It's built on top of Salesforce Mobile SDK 2.0 and extends the open source frameworks such as Backbone.js and Undescore.js and JQuery. It also comes with some stylesheets, providing the responsive design for tablets and phones, and Sample Apps to showcase how to use them in a real application. You can easily combine and extend this library to develop UI specific to your application.

Setup

Global Dependencies

Install

and then open Terminal:

$ sudo npm install -g grunt-cli

Project Setup

$ git clone https://github.com/ForceDotComLabs/mobile-ui-elements.git
$ cd mobile-ui-elements
$ npm install
$ bower install

To build the project, execute:

$ grunt

To build the project for distribution, execute (all assets will be generated in dist directory):

$ grunt dist

Run a local node server:

$ node proxy.js	

This repo contains two sample webapps, simple.html and index.html. To run the sample app in Safari:

1. Open index.html or simple.html in an editor
2. At the bottom of the page, replace `<session_id>` with salesforce session Id. To obtain the salesforce session Id, follow the instructions below.
3. Also replace the `<instance>` with the instance of the org. Eg. https://na1.salesforce.com
4. Open http://localhost:9000/index.html and you should be able to browse a simple list and detail of an account.

Obtaining salesforce session Id for running the sample app:

1. Login into salesforce using your web browser.
2. Open the salesforce API debugshell by going to https://<your org instance url>/soap/ajax/29.0/debugshell.html
3. In debugshell, run the following command to obtain the session ID: sforce.connection.sessionId

Available UI Elements

  1. force-ui-app: force-ui-app element is a top level UI element that provides the basic styling and structure for the application. This element uses polymer layout features to enable flexible sections on the page. This is useful in single page view with split view panels. All the children of the main section must have the class "content" specified on them to apply the right styles.

    Supported attributes include:

    • multipage: (Optional) Default: false. When true, force-ui-app shows only one direct child, with class="page", at a time and allows navigation to other child elements.
    • startpage: (Optional) Default: first direct child element with class="page". Instance of the DOM element, with class="page", that should be shown first when the app loads.
    • hideheader: (Optional) Default: false. Show/Hide default header on the page.

    Example (when using inside Visualforce):

    <force-ui-app multipage="true"></force-ui-app>
    
  2. force-ui-list: force-ui-list element enables the rendering of list of records for any sobject. The element can be configured using various attributes, such as query, sobject and querytype, to show specific set of records. This element should always be a child of force-ui-app element to inherit the appropriate styles.

    Supported attributes include:

    • sobject: (Required) Type of sobject on which you want to render a list.
    • query: (Optional) Default: null. SOQL/SOSL/SmartSQL statement to fetch the records. Required when querytype is soql, sosl or cache.
    • querytype: (Optional) Default: mru. Type of query (mru, soql, sosl, cache). Required if query attribute is specified.

    Example:

    <force-ui-list sobject="Account" querytype="mru"></force-ui-list>
    
  3. force-ui-detail: force-ui-detail element enables the rendering of full view of a salesforce record. This element uses the force-sobject-layout element to fetch the page layout for the record. This element also embeds a force-sobject element to allow all the CRUD operations on an SObject. This element should always be a child of force-ui-app element to inherit the default styles.

    Supported attributes include:

    • All attributes of force-sobject-layout element.
    • fieldlist: (Optional) Default: All fields on the layout. A list of fields that should be displayed for the record.
    • fieldlabels: (Optional) Default: Actual field labels. A list of labels for fields provided in fieldlist attribute. The order of labels should be same as the order of fields in the fieldlist attribute.

    Example:

    <force-ui-detail sobject="Account" recordid="001000000000AAA"></force-ui-detail>
    
  4. force-selector-list: force-selector-list is an extension of core-selector element and provides a wrapper around force-sobject-collection element. The element acts as a base for any list UI element that also needs the selector functionality. It automatically updates the selected attribute when a row has been clicked on.

    Supported attributes include:

    • All the attributes of the core-selector element.
    • sobject: (Required) Type of sobject on which you want to render a list
    • query: (Optional) SOQL/SOSL/SmartSQL statement to fetch the records. Required when querytype is soql, sosl or cache.
    • querytype: Type of query (mru, soql, sosl, cache). Required if query is specified.
    • selected: Id of the selected sobject.

    Properties:

    • collection: Returns an instance of Force.SObjectCollection with associated models.

    Methods:

    • fetch: Executes a fetch request on the underlying collection object based on the current config.

    Example:

    <force-selector-list sobject="Account" querytype="mru"></force-selector-list>
    
  5. force-sobject-collection: force-sobject-collection is a low level polymer wrapper for the SmartSync Force.SObjectCollection, which auto manages the offline data store for caching (when running inside a container), provides a simple DOM based interface for SmartSync interactions, and allows other polymer elements to easily consume SmartSync.

    Supported attributes include:

    • sobject: (Required) Type of sobject on which you want to render a list
    • query: (Optional) SOQL/SOSL/SmartSQL statement to fetch the records. Required when querytype is soql, sosl or cache.
    • querytype: (Optional) Default: mru. Type of query (mru, soql, sosl, cache). Required if query attribute is specified.
    • autosync: (Optional) Default: true. Auto synchronize (fetch/save) changes to the model with the remote server/local store. If false, use fetch/save methods to commit changes to server or local store.
    • maxsize: (Optional) Default: -1. If positive

    Methods:

    • fetch: Initiates the fetching of records from the relevant data store (server/offline store).
    • reset: Replaces all the existing contents of the collection and initiates autosync if enabled.

    Events:

    • reset: when the collection's entire contents have been replaced.
    • sync: when the collection has been successfully synced with the server
    • error: when a request to remote server has failed.

    Example:

    <force-sobject-collection sobject="Account" querytype="mru"></force-sobject-collection>
    
  6. force-sobject: force-sobject element wraps the SmartSync Force.SObject into a polymer element, providing auto management of the offline store for caching, a simpler DOM based interface to interact with Smartsync SObject Model, and allows other polymer elements to easily comsume smartsync.

    Supported attributes include:

    • sobject: (Required) Type of sobject on which you want to fetch the record
    • recordid: (Required) Id of the record that needs to be fetched.
    • fieldlist: (Optional) Default: All fields. A list of fields that need to be fetched for the record.
    • autosync: (Optional) Default: true. Auto synchronize (fetch/save) changes to the model with the remote server/local store. If false, use fetch/save methods to commit changes to server or local store.
    • mergemode: (Optional) Default: "Overwrite". The merge model to use when saving record changes to salesforce.

    Methods:

    • fetch: Initiate the fetching of record data from the relevant data store (server/offline store).
    • save: Initiate the saving of record data to the relevant data store (server/offline store).
    • destroy: Initiate the deleting of record data from the relevant data store (server/offline store).

    Properties:

    • fields: Returns an object with map of all the sobject fields and corresponding values. Use this object to get/set the sobject field values.

    Events:

    • sync: when the data has been successfully synced with the server.
    • destroy: when a record is deleted.
    • error: when a request to remote server has failed.
    • invalid: when the data validation fails on the client.

    Example:

    <force-sobject sobject="Account" recordid="001000000000AAA"></force-sobject>
    
  7. force-sobject-store: force-sobject-store element wraps the SmartSync Force.StoreCache into a polymer element. This element auto manages the lifecycle of the smartstore soup for each sobject type, auto creates index spec based on the lookup relationships on the sobject, provides a simpler DOM based interface to interact with Smartsync SObject Model and allows other polymer elements to easily comsume smartstore.

    Supported attributes include:

    • sobject: (Required) Type of sobject that you would like to store in this cache.
    • fieldstoindex: (Optional) Addition fields (given by their name) that you want to have indexes on.

    Properties:

    • cacheReady: Returns a promise to track store cache creation progress.
    • cache: Returns an instance of Force.StoreCache when it's ready to store/retrieve data.
    • cacheForOriginals: Returns an instance of Force.StoreCache to be used to keep data copy for conflict resolution.

    Methods:

    • destroy: Removes the soup from smartstore. Returns a promise to track the completion of process.

    Events:

    • store-ready: Fires this event when the store cache has been successfully created and ready to use.
    • store-destroy: Fires this event when the store cache has been successfully removed.

    Example:

    <force-sobject-store sobject="Account"></force-sobject-store>
    
  8. force-sobject-layout: force-sobject-layout element provides the layout information for a particular sobject record. It wraps the describeLayout API call. The layout information is cached in memory for existing session and stored in smartstore for offline consumption. This object also provides a base definition for elements that depend on page layouts, such as force-ui-detail and force-sobject-related.

    Supported attributes include:

    • sobject: (Required) Type of sobject on which you want to fetch the layout
    • hasrecordtypes: (Optional) Default: false. If false, the element returns the default layout. Set true if the sobject has recordtypes or if you are unsure. If set to true, "recordid" or "recordtypeid" must be provided.
    • recordtypeid: (Optional) Default: null. Id of the record type for which layout has to be fetched. Required if "hasrecordtypes" is true and "recordid" is not provided.
    • recordid: (Optional) Default: null. Id of the record for which layout has to be fetched. Required if "hasrecordtypes" is true and "recordtypeid" is not provided.

    Methods:

    • whenDetailSections: Initiate the fetching of layout's detail view sections data from the relevant data store (server/offline store). Returns a promise, when complete, returns an array of all detail sections.
    • whenEditSections: Initiate the fetching of layout's edit view sections data from the relevant data store (server/offline store). Returns a promise, when complete, returns an array of all edit sections.
    • whenRelatedLists: Initiate the fetching of layout's related lists data from the relevant data store (server/offline store). Returns a promise, when complete, returns an array of all related list infos.

    Example:

    <force-sobject-layout sobject="Account"></force-sobject-layout>
    
  9. force-sobject-relatedlists: force-sobject-relatedlists element enables the rendering of related lists of a sobject record. It embeds the force-sobject-layout element to fetch the related lists configuraton from the page layout settings. a) Parses the related lists configuration for a particular sobject type, and b) If "recordid" attribute is provided, also generates a soql/cache query to fetch the related record items.

    Supported attributes include:

    • All attributes of force-sobject-layout
    • relationships: (Optional) Default: null. A list of relationship names that should only be fetched. If null, it fetches all related lists that are queryable.

    Properties:

    • relatedLists: An array of all the related list information.

    Example:

    <force-sobject-relatedlists sobject="Account" recordid="001000000000AAA"></force-sobject-relatedlists>
    
  10. force-selector-relatedlist: force-selector-relatedlist element is an extension of core-selector element and fetches the records of related sobject using a force-sobject-collection element. This is a base element for UI element that needs to render the related list for a record and also needs the selector functionality.

    Supported attributes include:

    • related: (Required) Object instance of each related list item from the array obtained via force-sobject-relatedlists element. The object must contain the query and querytype properties to fetch the related items

    Properties:

    • models: Returns an array of all the related records. Each item is an object with properties "impl", "id" and "fieldValues". "impl" is the instance of the Force.SObject. "id" is the ID of the current record. "fieldValues" is an array containing field values in the column/field order on the related list.

    Methods:

    • updateModels: Updates the "models" property on the element based on the current set of models in the collection.

    Example:

    <force-selector-relatedlist related="{{related}}"></force-selector-relatedlist>
    
  11. force-ui-relatedlist: force-ui-relatedlist element is an extension of force-selector-relatedlist element and renders a list of related records to an sobject record. This element should always be a child of force-ui-app element to inherit the default styles.

    Supported attributes include:

    • All attributes of force-selector-relatedlist

    Properties:

    • selected: Returns the value of "idfield" of the selected records.

    Example:

    <force-ui-relatedlist related="{{related}}"></force-ui-relatedlist>
    

Using these elements on a web page

To initiate these elements to start fetching data from salesforce, you need setup a valid salesforce session information. To do so, you will need to call the SFDC.launch() method with accessToken and instanceUrl information of your salesforce org.

Example:

<script>
    document.addEventListener('WebComponentsReady', function() {
        SFDC.launch({
            accessToken: '<valid salesforce session id. Can be obtained via mobile sdk>',
            instanceUrl: '<valid salesforce instance url or your salesforce org>'
        });
    });
</script>

Third-party Code

This library makes use of a number of third-party components:

  • Polymer, a JavaScript library to add new extensions and features to modern HTML5 browsers. It's built on top of Web Components, and designed to leverage the evolving web platform on modern browsers.
  • jQuery, the JavaScript library to make it easy to write javascript.
  • Backbonejs, a JavaScript library providing the model–view–presenter (MVP) application design paradigm.
  • Underscorejs, a utility-belt library for JavaScript.
  • Ratchet, Prototype iPhone apps with simple HTML, CSS, and JS components.

FAQ

Polymer is still "alpha" project. How should I use it?

Polymer as an overall project is still a work in progress. We feel that the underlying platform code leveraged for UI Elements is stable enough to start creating new apps for learning and prototyping purposes. Polymer will continue to be tweaked as the Web Components standard reaches its final stage. Various building blocks of Web Components, including Shadow DOM, are now natively supported in Chrome. This enables better performance for your mobile applications.

Polymer doesn't work inside the WebView on Android below 4.4

This is limitation of the older version of WebKit used for the WebView on pre 4.4 devices. Polymer does work in the Android Mobile browsers along with all of the popular evergreen browsers. If Android WebView is a real limitation, please let us know.

Does it work with other devices?

We got our samples to work on IE10 running on Windows Mobile, Safari on iOS6/7, Chrome, Safari, and Firefox

What's the level of support for this project?

Mobile UI Elements is an unsupported project. It's a way for us to share our code with the community that might be beneficial for certain use cases. We'd love to build a vibrant community for this project. A lot depends on the level of interest.

I don't see any data show up in my components

Please check the JavaScript console to be sure of the error. You might not be getting the data because your session has expired. If that's the case get a new session id. Or you might have enabled cross-domain scripting in Chrome or your other browser.

Mobile UI Elements License

Copyright (c) 2014, salesforce.com, inc. All rights reserved.

Redistribution and use in source and binary forms, with or without modification, are permitted provided that the following conditions are met:

  • Redistributions of source code must retain the above copyright notice, this list of conditions and the following disclaimer.
  • Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the following disclaimer in the documentation and/or other materials provided with the distribution.
  • Neither the name of salesforce.com, inc. nor the names of its contributors may be used to endorse or promote products derived from this software without specific prior written permission.

THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.