Added demo components for dev

Change-Id: Ibfe137d4e65154dc8dae2078c3eac794303b5484
diff --git a/dev/index.html b/dev/index.html
index 44fa838..dea5eef 100644
--- a/dev/index.html
+++ b/dev/index.html
@@ -13,9 +13,9 @@
 </head>
 <body style="padding-top: 50px">
   <div ng-app="ngXosLib" class="container">
-    <div ng-controller="testCtrl as vm">
-      <xos-form ng-model="vm.model" config="vm.config"></xos-form>
-    </div>
+    <nav-demo></nav-demo>
+
+    <div ui-view></div>
   </div>
   <!-- bower:js -->
   <script src="../bower_components/angular/angular.js"></script>
@@ -36,8 +36,8 @@
   <script src="/ui_components/dumbComponents/validation/validation.component.js"></script>
   <script src="/ui_components/dumbComponents/table/table.component.js"></script>
   <script src="/ui_components/dumbComponents/pagination/pagination.component.js"></script>
-  <script src="/ui_components/dumbComponents/form/form.component.js"></script>
   <script src="/ui_components/dumbComponents/field/field.component.js"></script>
+  <script src="/ui_components/dumbComponents/form/form.component.js"></script>
   <script src="/ui_components/dumbComponents/alert/alert.component.js"></script>
   <script src="/services/helpers/ui/label_formatter.service.js"></script>
   <script src="/services/helpers/ui/form.helpers.js"></script>
@@ -74,6 +74,11 @@
   <script src="/services/csrfToken.interceptor.js"></script>
   <script src="/index.ngdoc.js"></script>
   <!-- endinject -->
-  <script src="main.js"></script>
+  <script src="js/main.js"></script>
+  <script src="js/form.dev.js"></script>
+  <script src="js/field.dev.js"></script>
+  <script src="js/alert.dev.js"></script>
+  <script src="js/table.dev.js"></script>
+
 </body>
 </html>
\ No newline at end of file
diff --git a/dev/js/alert.dev.js b/dev/js/alert.dev.js
new file mode 100644
index 0000000..6d5cefc
--- /dev/null
+++ b/dev/js/alert.dev.js
@@ -0,0 +1,32 @@
+'use strict';

+

+angular.module('ngXosLib')

+  .component('alertTest', {

+    restrict: 'E',

+    bindings: {},

+    bindToController: true,

+    controllerAs: 'vm',

+    templateUrl: 'templates/alert.dev.html',

+    controller: function () {

+      this.config1 = {

+        type: 'danger'

+      };

+

+      this.config2 = {

+        type: 'danger',

+        closeBtn: true

+      };

+

+      this.config3 = {

+        type: 'info'

+      };

+

+      this.config4 = {

+        type: 'success'

+      };

+

+      this.config5 = {

+        type: 'warning'

+      };

+    }

+  })
\ No newline at end of file
diff --git a/dev/js/field.dev.js b/dev/js/field.dev.js
new file mode 100644
index 0000000..656aec9
--- /dev/null
+++ b/dev/js/field.dev.js
@@ -0,0 +1,52 @@
+'use strict';

+

+angular.module('ngXosLib')

+  .component('fieldTest', {

+    restrict: 'E',

+    bindings: {},

+    bindToController: true,

+    controllerAs: 'vm',

+    templateUrl: 'templates/field.dev.html',

+    controller: function () {

+      this.field1 = {

+        name: 'number-field',

+        field: {label: 'My Number Value:', type: 'number'},

+        model: 2

+      };

+

+      this.field2 = {

+        name: 'date-field',

+        field: {label: 'My Date Value:', type: 'date'},

+        model: new Date()

+      };

+

+      this.field3 = {

+        name: 'boolean-field',

+        field: {label: 'My Boolean Value:', type: 'boolean'},

+        model: true

+      };

+

+      this.field4 = {

+        name: 'email-field',

+        field: {label: 'My Email Value:', type: 'email'},

+        model: 'sample@domain.us'

+      };

+      this.field5 = {

+        name: 'Empty Object Field',

+        label: 'Empty Object Field',

+        type: 'object',

+        properties: {

+          foo: {

+            label: 'FooLabel:',

+            type: 'string',

+            validators: {

+              required: true

+            }

+          },

+          bar: {

+            type: 'number'

+          }

+        }

+      }

+    }

+  });
\ No newline at end of file
diff --git a/dev/js/form.dev.js b/dev/js/form.dev.js
new file mode 100644
index 0000000..99afda0
--- /dev/null
+++ b/dev/js/form.dev.js
@@ -0,0 +1,62 @@
+'use strict';

+

+angular.module('ngXosLib')

+  .component('formTest', {

+    restrict: 'E',

+    bindings: {},

+    bindToController: true,

+    controllerAs: 'vm',

+    templateUrl: 'templates/form.dev.html',

+    controller: function () {

+      this.model = {

+        first_name: 'Jhon',

+        last_name: 'Doe',

+      },

+      this.config = {

+        exclude: ['password', 'last_login'],

+        formName: 'sampleForm',

+        actions: [

+          {

+            label: 'Save',

+            icon: 'ok', // refers to bootstraps glyphicon

+            cb: (user) => { // receive the model

+              console.log(user);

+            },

+            class: 'success'

+          }

+        ],

+        fields: {

+          first_name: {

+            type: 'string',

+            validators: {

+              required: true

+            }

+          },

+          last_name: {

+            label: 'Surname',

+            type: 'string',

+            validators: {

+              required: true,

+              minlength: 10

+            }

+          },

+          details_field: {

+            label: 'Empty Object Field',

+            type: 'object',

+            properties: {

+              foo: {

+                label: 'FooLabel:',

+                type: 'string',

+                validators: {

+                  required: true

+                }

+              },

+              bar: {

+                type: 'number'

+              }

+            }

+          }

+        }

+      }

+    }

+  })
\ No newline at end of file
diff --git a/dev/js/main.js b/dev/js/main.js
new file mode 100644
index 0000000..6026569
--- /dev/null
+++ b/dev/js/main.js
@@ -0,0 +1,74 @@
+/* eslint-disable angular/ng_module_name */
+(function(){
+  'use strict';
+  console.log('hello!');
+  angular.module('ngXosLib', ['xos.helpers', 'ui.router'])
+  .run(function () {
+    console.info('Dev Environment ready!')
+  })
+  .config(($stateProvider) => {
+    $stateProvider
+    .state('form-test', {
+      url: '/form/',
+      template: '<form-test></form-test>'
+    })
+    .state('table-test', {
+      url: '/table/',
+      template: '<table-test></table-test>'
+    })
+    .state('alert-test', {
+      url: '/alert/',
+      template: '<alert-test></alert-test>'
+    })
+    .state('field-test', {
+      url: '/field/',
+      template: '<field-test></field-test>'
+    })
+  })
+  .component('navDemo', {
+    restrict: 'E',
+    bindings: {},
+    bindToController: true,
+    controllerAs: 'vm',
+    templateUrl: 'templates/nav.dev.html',
+    controller: function ($rootScope) {
+
+      this.active = 'form';
+
+      $rootScope.$on('$stateChangeSuccess', (event, toState, toParams, fromState, fromParams)=> {
+
+        let strSelected = toState.url.split('/').join('');
+        this.active = strSelected.charAt(0).toUpperCase() + strSelected.slice(1);
+      });
+
+      this.config = {
+        actions: [
+          {
+            label: 'Form',
+            class: '',
+            link: '/#/form/'
+          },
+          {
+            label: 'Field',
+            class: '',
+            link: '/#/field/'
+
+          },
+          {
+            label: 'Alert',
+            class: '',
+            link: '/#/alert/'
+
+          },
+          {
+            label: 'Table',
+            class: '',
+            link: '/#/table/'
+
+          }
+        ]
+      }
+    }
+  });
+
+})();
\ No newline at end of file
diff --git a/dev/js/table.dev.js b/dev/js/table.dev.js
new file mode 100644
index 0000000..4ac974d
--- /dev/null
+++ b/dev/js/table.dev.js
@@ -0,0 +1,25 @@
+'use strict';

+

+angular.module('ngXosLib')

+  .component('tableTest', {

+    restrict: 'E',

+    bindings: {},

+    bindToController: true,

+    controllerAs: 'vm',

+    templateUrl: 'templates/table.dev.html',

+    controller: function () {

+      this.config = {

+        columns: [

+          {

+            label: '#',

+            prop: 'id'

+          },

+          {

+            label: 'Name:',

+            prop: 'name'

+          }

+        ]

+      };

+      this.data = [{id: 1, name: 'Jhon'}]

+    }

+  })
\ No newline at end of file
diff --git a/dev/main.js b/dev/main.js
deleted file mode 100644
index f7ab8eb..0000000
--- a/dev/main.js
+++ /dev/null
@@ -1,61 +0,0 @@
-/* eslint-disable angular/ng_module_name */
-(function () {
-  'use strict';
-  console.log('hello1!');
-  angular.module('ngXosLib', ['xos.helpers'])
-  .run(function(){
-    console.info('Dev Environment ready!')
-  })
-  .controller('testCtrl', function(){
-    this.model = {
-      first_name: 'Jhon',
-      last_name: 'Doe',
-    }
-    this.config = {
-      exclude: ['password', 'last_login'],
-      formName: 'sampleForm',
-      actions: [
-        {
-          label: 'Save',
-          icon: 'ok', // refers to bootstraps glyphicon
-          cb: (user) => { // receive the model
-            console.log(user);
-          },
-          class: 'success'
-        }
-      ],
-      fields: {
-        first_name: {
-          type: 'string',
-          validators: {
-            required: true
-          }
-        },
-        last_name: {
-          label: 'Surname',
-          type: 'string',
-          validators: {
-            required: true,
-            minlength: 10
-          }
-        },
-        details_field: {
-          label: 'Empty Object Field',
-          type: 'object',
-          properties: {
-            foo: {
-              label: 'FooLabel:',
-              type: 'string',
-              validators: {
-                required: true
-              }
-            },
-            bar: {
-              type: 'number'
-            }
-          }
-        }
-      }
-    };
-  });
-})();
\ No newline at end of file
diff --git a/dev/templates/alert.dev.html b/dev/templates/alert.dev.html
new file mode 100644
index 0000000..a528e7e
--- /dev/null
+++ b/dev/templates/alert.dev.html
@@ -0,0 +1,16 @@
+

+<xos-alert config="vm.config1">

+  A sample alert message

+</xos-alert>

+<xos-alert config="vm.config2">

+  A sample alert message (with close button)

+</xos-alert>

+<xos-alert config="vm.config3">

+  A sample info message

+</xos-alert>

+<xos-alert config="vm.config4">

+  A sample success message

+</xos-alert>

+<xos-alert config="vm.config5">

+  A sample warning message

+</xos-alert>
\ No newline at end of file
diff --git a/dev/templates/field.dev.html b/dev/templates/field.dev.html
new file mode 100644
index 0000000..2a24150
--- /dev/null
+++ b/dev/templates/field.dev.html
@@ -0,0 +1,5 @@
+<xos-field ng-model="vm.field1.model" name="vm.field1.name" field="vm.field1.field"></xos-field>

+<xos-field ng-model="vm.field2.model" name="vm.field2.name" field="vm.field2.field"></xos-field>

+<xos-field ng-model="vm.field3.model" name="vm.field3.name" field="vm.field3.field"></xos-field>

+<xos-field ng-model="vm.field4.model" name="vm.field4.name" field="vm.field4.field"></xos-field>

+<xos-field ng-model="vm.field5.model" name="vm.field5.name" field="vm.field5"></xos-field>

diff --git a/dev/templates/form.dev.html b/dev/templates/form.dev.html
new file mode 100644
index 0000000..d2f12ff
--- /dev/null
+++ b/dev/templates/form.dev.html
@@ -0,0 +1 @@
+<xos-form ng-model="vm.model" config="vm.config"></xos-form>

diff --git a/dev/templates/nav.dev.html b/dev/templates/nav.dev.html
new file mode 100644
index 0000000..6dfbcae
--- /dev/null
+++ b/dev/templates/nav.dev.html
@@ -0,0 +1,7 @@
+<nav class="navbar navbar-default">

+  <div class="">

+    <ul class="nav navbar-nav">

+      <li ng-repeat="action in vm.config.actions" ng-class="{active:vm.active==action.label}"><a href="{{action.link}}">{{action.label}} </a></li>

+    </ul>

+  </div>

+</nav>
\ No newline at end of file
diff --git a/dev/templates/table.dev.html b/dev/templates/table.dev.html
new file mode 100644
index 0000000..41c10bf
--- /dev/null
+++ b/dev/templates/table.dev.html
@@ -0,0 +1 @@
+<xos-table config="vm.config" data="vm.data"></xos-table>
\ No newline at end of file
diff --git a/dist/xosNgLib.css b/dist/xosNgLib.css
index e8cb002..44648e1 100644
--- a/dist/xosNgLib.css
+++ b/dist/xosNgLib.css
@@ -248,4 +248,4 @@
   /* TODO move in xos.scss*/
   margin-top: 15px; }
 
-/*# sourceMappingURL=data:application/json;base64,{"version":3,"file":"xosNgLib.css","sources":["main.scss","animations.scss","../../bower_components/bootstrap-sass/assets/stylesheets/bootstrap/_variables.scss","loader.scss","../ui_components/dumbComponents/table/table.scss","../ui_components/dumbComponents/alert/alert.scss","../ui_components/dumbComponents/validation/validation.scss","../ui_components/dumbComponents/field/field.scss","../ui_components/dumbComponents/form/form.scss","../ui_components/smartComponents/smartTable/smartTable.scss"],"sourcesContent":["@import './animations.scss';\n@import '../../bower_components/bootstrap-sass/assets/stylesheets/bootstrap/_variables.scss';\n@import './loader.scss';\n\n@import '../ui_components/dumbComponents/table/table.scss';\n@import '../ui_components/dumbComponents/alert/alert.scss';\n@import '../ui_components/dumbComponents/validation/validation.scss';\n@import '../ui_components/dumbComponents/field/field.scss';\n@import '../ui_components/dumbComponents/form/form.scss';\n\n@import '../ui_components/smartComponents/smartTable/smartTable.scss';\n\n[ng\\:cloak], [ng-cloak], [data-ng-cloak], [x-ng-cloak], .ng-cloak, .x-ng-cloak {\n  display: none !important;\n}\n\n.row + .row {\n  /* TODO move in xos.scss*/ \n  margin-top: $form-group-margin-bottom;\n}","@keyframes slideInRight {\n  from {\n    transform: translate3d(100%, 0, 0);\n    visibility: visible;\n  }\n\n  to {\n    transform: translate3d(0, 0, 0);\n  }\n}\n\n@keyframes slideOutRight {\n  from {\n    transform: translate3d(0, 0, 0);\n  }\n\n  to {\n    visibility: hidden;\n    transform: translate3d(100%, 0, 0);\n  }\n}\n\n@keyframes fadeInUp {\n  from {\n    opacity: 0;\n    transform: translate3d(0, 100%, 0);\n  }\n\n  to {\n    opacity: 1;\n    transform: none;\n  }\n}\n\n@keyframes fadeOutDown {\n  from {\n    opacity: 1;\n  }\n\n  to {\n    opacity: 0;\n    transform: translate3d(0, 100%, 0);\n  }\n}","$bootstrap-sass-asset-helper: false !default;\n//\n// Variables\n// --------------------------------------------------\n\n\n//== Colors\n//\n//## Gray and brand colors for use across Bootstrap.\n\n$gray-base:              #000 !default;\n$gray-darker:            lighten($gray-base, 13.5%) !default; // #222\n$gray-dark:              lighten($gray-base, 20%) !default;   // #333\n$gray:                   lighten($gray-base, 33.5%) !default; // #555\n$gray-light:             lighten($gray-base, 46.7%) !default; // #777\n$gray-lighter:           lighten($gray-base, 93.5%) !default; // #eee\n\n$brand-primary:         darken(#428bca, 6.5%) !default; // #337ab7\n$brand-success:         #5cb85c !default;\n$brand-info:            #5bc0de !default;\n$brand-warning:         #f0ad4e !default;\n$brand-danger:          #d9534f !default;\n\n\n//== Scaffolding\n//\n//## Settings for some of the most global styles.\n\n//** Background color for `<body>`.\n$body-bg:               #fff !default;\n//** Global text color on `<body>`.\n$text-color:            $gray-dark !default;\n\n//** Global textual link color.\n$link-color:            $brand-primary !default;\n//** Link hover color set via `darken()` function.\n$link-hover-color:      darken($link-color, 15%) !default;\n//** Link hover decoration.\n$link-hover-decoration: underline !default;\n\n\n//== Typography\n//\n//## Font, line-height, and color for body text, headings, and more.\n\n$font-family-sans-serif:  \"Helvetica Neue\", Helvetica, Arial, sans-serif !default;\n$font-family-serif:       Georgia, \"Times New Roman\", Times, serif !default;\n//** Default monospace fonts for `<code>`, `<kbd>`, and `<pre>`.\n$font-family-monospace:   Menlo, Monaco, Consolas, \"Courier New\", monospace !default;\n$font-family-base:        $font-family-sans-serif !default;\n\n$font-size-base:          14px !default;\n$font-size-large:         ceil(($font-size-base * 1.25)) !default; // ~18px\n$font-size-small:         ceil(($font-size-base * 0.85)) !default; // ~12px\n\n$font-size-h1:            floor(($font-size-base * 2.6)) !default; // ~36px\n$font-size-h2:            floor(($font-size-base * 2.15)) !default; // ~30px\n$font-size-h3:            ceil(($font-size-base * 1.7)) !default; // ~24px\n$font-size-h4:            ceil(($font-size-base * 1.25)) !default; // ~18px\n$font-size-h5:            $font-size-base !default;\n$font-size-h6:            ceil(($font-size-base * 0.85)) !default; // ~12px\n\n//** Unit-less `line-height` for use in components like buttons.\n$line-height-base:        1.428571429 !default; // 20/14\n//** Computed \"line-height\" (`font-size` * `line-height`) for use with `margin`, `padding`, etc.\n$line-height-computed:    floor(($font-size-base * $line-height-base)) !default; // ~20px\n\n//** By default, this inherits from the `<body>`.\n$headings-font-family:    inherit !default;\n$headings-font-weight:    500 !default;\n$headings-line-height:    1.1 !default;\n$headings-color:          inherit !default;\n\n\n//== Iconography\n//\n//## Specify custom location and filename of the included Glyphicons icon font. Useful for those including Bootstrap via Bower.\n\n//** Load fonts from this directory.\n\n// [converter] If $bootstrap-sass-asset-helper if used, provide path relative to the assets load path.\n// [converter] This is because some asset helpers, such as Sprockets, do not work with file-relative paths.\n$icon-font-path: if($bootstrap-sass-asset-helper, \"bootstrap/\", \"../fonts/bootstrap/\") !default;\n\n//** File name for all font files.\n$icon-font-name:          \"glyphicons-halflings-regular\" !default;\n//** Element ID within SVG icon file.\n$icon-font-svg-id:        \"glyphicons_halflingsregular\" !default;\n\n\n//== Components\n//\n//## Define common padding and border radius sizes and more. Values based on 14px text and 1.428 line-height (~20px to start).\n\n$padding-base-vertical:     6px !default;\n$padding-base-horizontal:   12px !default;\n\n$padding-large-vertical:    10px !default;\n$padding-large-horizontal:  16px !default;\n\n$padding-small-vertical:    5px !default;\n$padding-small-horizontal:  10px !default;\n\n$padding-xs-vertical:       1px !default;\n$padding-xs-horizontal:     5px !default;\n\n$line-height-large:         1.3333333 !default; // extra decimals for Win 8.1 Chrome\n$line-height-small:         1.5 !default;\n\n$border-radius-base:        4px !default;\n$border-radius-large:       6px !default;\n$border-radius-small:       3px !default;\n\n//** Global color for active items (e.g., navs or dropdowns).\n$component-active-color:    #fff !default;\n//** Global background color for active items (e.g., navs or dropdowns).\n$component-active-bg:       $brand-primary !default;\n\n//** Width of the `border` for generating carets that indicator dropdowns.\n$caret-width-base:          4px !default;\n//** Carets increase slightly in size for larger components.\n$caret-width-large:         5px !default;\n\n\n//== Tables\n//\n//## Customizes the `.table` component with basic values, each used across all table variations.\n\n//** Padding for `<th>`s and `<td>`s.\n$table-cell-padding:            8px !default;\n//** Padding for cells in `.table-condensed`.\n$table-condensed-cell-padding:  5px !default;\n\n//** Default background color used for all tables.\n$table-bg:                      transparent !default;\n//** Background color used for `.table-striped`.\n$table-bg-accent:               #f9f9f9 !default;\n//** Background color used for `.table-hover`.\n$table-bg-hover:                #f5f5f5 !default;\n$table-bg-active:               $table-bg-hover !default;\n\n//** Border color for table and cell borders.\n$table-border-color:            #ddd !default;\n\n\n//== Buttons\n//\n//## For each of Bootstrap's buttons, define text, background and border color.\n\n$btn-font-weight:                normal !default;\n\n$btn-default-color:              #333 !default;\n$btn-default-bg:                 #fff !default;\n$btn-default-border:             #ccc !default;\n\n$btn-primary-color:              #fff !default;\n$btn-primary-bg:                 $brand-primary !default;\n$btn-primary-border:             darken($btn-primary-bg, 5%) !default;\n\n$btn-success-color:              #fff !default;\n$btn-success-bg:                 $brand-success !default;\n$btn-success-border:             darken($btn-success-bg, 5%) !default;\n\n$btn-info-color:                 #fff !default;\n$btn-info-bg:                    $brand-info !default;\n$btn-info-border:                darken($btn-info-bg, 5%) !default;\n\n$btn-warning-color:              #fff !default;\n$btn-warning-bg:                 $brand-warning !default;\n$btn-warning-border:             darken($btn-warning-bg, 5%) !default;\n\n$btn-danger-color:               #fff !default;\n$btn-danger-bg:                  $brand-danger !default;\n$btn-danger-border:              darken($btn-danger-bg, 5%) !default;\n\n$btn-link-disabled-color:        $gray-light !default;\n\n// Allows for customizing button radius independently from global border radius\n$btn-border-radius-base:         $border-radius-base !default;\n$btn-border-radius-large:        $border-radius-large !default;\n$btn-border-radius-small:        $border-radius-small !default;\n\n\n//== Forms\n//\n//##\n\n//** `<input>` background color\n$input-bg:                       #fff !default;\n//** `<input disabled>` background color\n$input-bg-disabled:              $gray-lighter !default;\n\n//** Text color for `<input>`s\n$input-color:                    $gray !default;\n//** `<input>` border color\n$input-border:                   #ccc !default;\n\n// TODO: Rename `$input-border-radius` to `$input-border-radius-base` in v4\n//** Default `.form-control` border radius\n// This has no effect on `<select>`s in some browsers, due to the limited stylability of `<select>`s in CSS.\n$input-border-radius:            $border-radius-base !default;\n//** Large `.form-control` border radius\n$input-border-radius-large:      $border-radius-large !default;\n//** Small `.form-control` border radius\n$input-border-radius-small:      $border-radius-small !default;\n\n//** Border color for inputs on focus\n$input-border-focus:             #66afe9 !default;\n\n//** Placeholder text color\n$input-color-placeholder:        #999 !default;\n\n//** Default `.form-control` height\n$input-height-base:              ($line-height-computed + ($padding-base-vertical * 2) + 2) !default;\n//** Large `.form-control` height\n$input-height-large:             (ceil($font-size-large * $line-height-large) + ($padding-large-vertical * 2) + 2) !default;\n//** Small `.form-control` height\n$input-height-small:             (floor($font-size-small * $line-height-small) + ($padding-small-vertical * 2) + 2) !default;\n\n//** `.form-group` margin\n$form-group-margin-bottom:       15px !default;\n\n$legend-color:                   $gray-dark !default;\n$legend-border-color:            #e5e5e5 !default;\n\n//** Background color for textual input addons\n$input-group-addon-bg:           $gray-lighter !default;\n//** Border color for textual input addons\n$input-group-addon-border-color: $input-border !default;\n\n//** Disabled cursor for form controls and buttons.\n$cursor-disabled:                not-allowed !default;\n\n\n//== Dropdowns\n//\n//## Dropdown menu container and contents.\n\n//** Background for the dropdown menu.\n$dropdown-bg:                    #fff !default;\n//** Dropdown menu `border-color`.\n$dropdown-border:                rgba(0,0,0,.15) !default;\n//** Dropdown menu `border-color` **for IE8**.\n$dropdown-fallback-border:       #ccc !default;\n//** Divider color for between dropdown items.\n$dropdown-divider-bg:            #e5e5e5 !default;\n\n//** Dropdown link text color.\n$dropdown-link-color:            $gray-dark !default;\n//** Hover color for dropdown links.\n$dropdown-link-hover-color:      darken($gray-dark, 5%) !default;\n//** Hover background for dropdown links.\n$dropdown-link-hover-bg:         #f5f5f5 !default;\n\n//** Active dropdown menu item text color.\n$dropdown-link-active-color:     $component-active-color !default;\n//** Active dropdown menu item background color.\n$dropdown-link-active-bg:        $component-active-bg !default;\n\n//** Disabled dropdown menu item background color.\n$dropdown-link-disabled-color:   $gray-light !default;\n\n//** Text color for headers within dropdown menus.\n$dropdown-header-color:          $gray-light !default;\n\n//** Deprecated `$dropdown-caret-color` as of v3.1.0\n$dropdown-caret-color:           #000 !default;\n\n\n//-- Z-index master list\n//\n// Warning: Avoid customizing these values. They're used for a bird's eye view\n// of components dependent on the z-axis and are designed to all work together.\n//\n// Note: These variables are not generated into the Customizer.\n\n$zindex-navbar:            1000 !default;\n$zindex-dropdown:          1000 !default;\n$zindex-popover:           1060 !default;\n$zindex-tooltip:           1070 !default;\n$zindex-navbar-fixed:      1030 !default;\n$zindex-modal-background:  1040 !default;\n$zindex-modal:             1050 !default;\n\n\n//== Media queries breakpoints\n//\n//## Define the breakpoints at which your layout will change, adapting to different screen sizes.\n\n// Extra small screen / phone\n//** Deprecated `$screen-xs` as of v3.0.1\n$screen-xs:                  480px !default;\n//** Deprecated `$screen-xs-min` as of v3.2.0\n$screen-xs-min:              $screen-xs !default;\n//** Deprecated `$screen-phone` as of v3.0.1\n$screen-phone:               $screen-xs-min !default;\n\n// Small screen / tablet\n//** Deprecated `$screen-sm` as of v3.0.1\n$screen-sm:                  768px !default;\n$screen-sm-min:              $screen-sm !default;\n//** Deprecated `$screen-tablet` as of v3.0.1\n$screen-tablet:              $screen-sm-min !default;\n\n// Medium screen / desktop\n//** Deprecated `$screen-md` as of v3.0.1\n$screen-md:                  992px !default;\n$screen-md-min:              $screen-md !default;\n//** Deprecated `$screen-desktop` as of v3.0.1\n$screen-desktop:             $screen-md-min !default;\n\n// Large screen / wide desktop\n//** Deprecated `$screen-lg` as of v3.0.1\n$screen-lg:                  1200px !default;\n$screen-lg-min:              $screen-lg !default;\n//** Deprecated `$screen-lg-desktop` as of v3.0.1\n$screen-lg-desktop:          $screen-lg-min !default;\n\n// So media queries don't overlap when required, provide a maximum\n$screen-xs-max:              ($screen-sm-min - 1) !default;\n$screen-sm-max:              ($screen-md-min - 1) !default;\n$screen-md-max:              ($screen-lg-min - 1) !default;\n\n\n//== Grid system\n//\n//## Define your custom responsive grid.\n\n//** Number of columns in the grid.\n$grid-columns:              12 !default;\n//** Padding between columns. Gets divided in half for the left and right.\n$grid-gutter-width:         30px !default;\n// Navbar collapse\n//** Point at which the navbar becomes uncollapsed.\n$grid-float-breakpoint:     $screen-sm-min !default;\n//** Point at which the navbar begins collapsing.\n$grid-float-breakpoint-max: ($grid-float-breakpoint - 1) !default;\n\n\n//== Container sizes\n//\n//## Define the maximum width of `.container` for different screen sizes.\n\n// Small screen / tablet\n$container-tablet:             (720px + $grid-gutter-width) !default;\n//** For `$screen-sm-min` and up.\n$container-sm:                 $container-tablet !default;\n\n// Medium screen / desktop\n$container-desktop:            (940px + $grid-gutter-width) !default;\n//** For `$screen-md-min` and up.\n$container-md:                 $container-desktop !default;\n\n// Large screen / wide desktop\n$container-large-desktop:      (1140px + $grid-gutter-width) !default;\n//** For `$screen-lg-min` and up.\n$container-lg:                 $container-large-desktop !default;\n\n\n//== Navbar\n//\n//##\n\n// Basics of a navbar\n$navbar-height:                    50px !default;\n$navbar-margin-bottom:             $line-height-computed !default;\n$navbar-border-radius:             $border-radius-base !default;\n$navbar-padding-horizontal:        floor(($grid-gutter-width / 2)) !default;\n$navbar-padding-vertical:          (($navbar-height - $line-height-computed) / 2) !default;\n$navbar-collapse-max-height:       340px !default;\n\n$navbar-default-color:             #777 !default;\n$navbar-default-bg:                #f8f8f8 !default;\n$navbar-default-border:            darken($navbar-default-bg, 6.5%) !default;\n\n// Navbar links\n$navbar-default-link-color:                #777 !default;\n$navbar-default-link-hover-color:          #333 !default;\n$navbar-default-link-hover-bg:             transparent !default;\n$navbar-default-link-active-color:         #555 !default;\n$navbar-default-link-active-bg:            darken($navbar-default-bg, 6.5%) !default;\n$navbar-default-link-disabled-color:       #ccc !default;\n$navbar-default-link-disabled-bg:          transparent !default;\n\n// Navbar brand label\n$navbar-default-brand-color:               $navbar-default-link-color !default;\n$navbar-default-brand-hover-color:         darken($navbar-default-brand-color, 10%) !default;\n$navbar-default-brand-hover-bg:            transparent !default;\n\n// Navbar toggle\n$navbar-default-toggle-hover-bg:           #ddd !default;\n$navbar-default-toggle-icon-bar-bg:        #888 !default;\n$navbar-default-toggle-border-color:       #ddd !default;\n\n\n//=== Inverted navbar\n// Reset inverted navbar basics\n$navbar-inverse-color:                      lighten($gray-light, 15%) !default;\n$navbar-inverse-bg:                         #222 !default;\n$navbar-inverse-border:                     darken($navbar-inverse-bg, 10%) !default;\n\n// Inverted navbar links\n$navbar-inverse-link-color:                 lighten($gray-light, 15%) !default;\n$navbar-inverse-link-hover-color:           #fff !default;\n$navbar-inverse-link-hover-bg:              transparent !default;\n$navbar-inverse-link-active-color:          $navbar-inverse-link-hover-color !default;\n$navbar-inverse-link-active-bg:             darken($navbar-inverse-bg, 10%) !default;\n$navbar-inverse-link-disabled-color:        #444 !default;\n$navbar-inverse-link-disabled-bg:           transparent !default;\n\n// Inverted navbar brand label\n$navbar-inverse-brand-color:                $navbar-inverse-link-color !default;\n$navbar-inverse-brand-hover-color:          #fff !default;\n$navbar-inverse-brand-hover-bg:             transparent !default;\n\n// Inverted navbar toggle\n$navbar-inverse-toggle-hover-bg:            #333 !default;\n$navbar-inverse-toggle-icon-bar-bg:         #fff !default;\n$navbar-inverse-toggle-border-color:        #333 !default;\n\n\n//== Navs\n//\n//##\n\n//=== Shared nav styles\n$nav-link-padding:                          10px 15px !default;\n$nav-link-hover-bg:                         $gray-lighter !default;\n\n$nav-disabled-link-color:                   $gray-light !default;\n$nav-disabled-link-hover-color:             $gray-light !default;\n\n//== Tabs\n$nav-tabs-border-color:                     #ddd !default;\n\n$nav-tabs-link-hover-border-color:          $gray-lighter !default;\n\n$nav-tabs-active-link-hover-bg:             $body-bg !default;\n$nav-tabs-active-link-hover-color:          $gray !default;\n$nav-tabs-active-link-hover-border-color:   #ddd !default;\n\n$nav-tabs-justified-link-border-color:            #ddd !default;\n$nav-tabs-justified-active-link-border-color:     $body-bg !default;\n\n//== Pills\n$nav-pills-border-radius:                   $border-radius-base !default;\n$nav-pills-active-link-hover-bg:            $component-active-bg !default;\n$nav-pills-active-link-hover-color:         $component-active-color !default;\n\n\n//== Pagination\n//\n//##\n\n$pagination-color:                     $link-color !default;\n$pagination-bg:                        #fff !default;\n$pagination-border:                    #ddd !default;\n\n$pagination-hover-color:               $link-hover-color !default;\n$pagination-hover-bg:                  $gray-lighter !default;\n$pagination-hover-border:              #ddd !default;\n\n$pagination-active-color:              #fff !default;\n$pagination-active-bg:                 $brand-primary !default;\n$pagination-active-border:             $brand-primary !default;\n\n$pagination-disabled-color:            $gray-light !default;\n$pagination-disabled-bg:               #fff !default;\n$pagination-disabled-border:           #ddd !default;\n\n\n//== Pager\n//\n//##\n\n$pager-bg:                             $pagination-bg !default;\n$pager-border:                         $pagination-border !default;\n$pager-border-radius:                  15px !default;\n\n$pager-hover-bg:                       $pagination-hover-bg !default;\n\n$pager-active-bg:                      $pagination-active-bg !default;\n$pager-active-color:                   $pagination-active-color !default;\n\n$pager-disabled-color:                 $pagination-disabled-color !default;\n\n\n//== Jumbotron\n//\n//##\n\n$jumbotron-padding:              30px !default;\n$jumbotron-color:                inherit !default;\n$jumbotron-bg:                   $gray-lighter !default;\n$jumbotron-heading-color:        inherit !default;\n$jumbotron-font-size:            ceil(($font-size-base * 1.5)) !default;\n$jumbotron-heading-font-size:    ceil(($font-size-base * 4.5)) !default;\n\n\n//== Form states and alerts\n//\n//## Define colors for form feedback states and, by default, alerts.\n\n$state-success-text:             #3c763d !default;\n$state-success-bg:               #dff0d8 !default;\n$state-success-border:           darken(adjust-hue($state-success-bg, -10), 5%) !default;\n\n$state-info-text:                #31708f !default;\n$state-info-bg:                  #d9edf7 !default;\n$state-info-border:              darken(adjust-hue($state-info-bg, -10), 7%) !default;\n\n$state-warning-text:             #8a6d3b !default;\n$state-warning-bg:               #fcf8e3 !default;\n$state-warning-border:           darken(adjust-hue($state-warning-bg, -10), 5%) !default;\n\n$state-danger-text:              #a94442 !default;\n$state-danger-bg:                #f2dede !default;\n$state-danger-border:            darken(adjust-hue($state-danger-bg, -10), 5%) !default;\n\n\n//== Tooltips\n//\n//##\n\n//** Tooltip max width\n$tooltip-max-width:           200px !default;\n//** Tooltip text color\n$tooltip-color:               #fff !default;\n//** Tooltip background color\n$tooltip-bg:                  #000 !default;\n$tooltip-opacity:             .9 !default;\n\n//** Tooltip arrow width\n$tooltip-arrow-width:         5px !default;\n//** Tooltip arrow color\n$tooltip-arrow-color:         $tooltip-bg !default;\n\n\n//== Popovers\n//\n//##\n\n//** Popover body background color\n$popover-bg:                          #fff !default;\n//** Popover maximum width\n$popover-max-width:                   276px !default;\n//** Popover border color\n$popover-border-color:                rgba(0,0,0,.2) !default;\n//** Popover fallback border color\n$popover-fallback-border-color:       #ccc !default;\n\n//** Popover title background color\n$popover-title-bg:                    darken($popover-bg, 3%) !default;\n\n//** Popover arrow width\n$popover-arrow-width:                 10px !default;\n//** Popover arrow color\n$popover-arrow-color:                 $popover-bg !default;\n\n//** Popover outer arrow width\n$popover-arrow-outer-width:           ($popover-arrow-width + 1) !default;\n//** Popover outer arrow color\n$popover-arrow-outer-color:           fade_in($popover-border-color, 0.05) !default;\n//** Popover outer arrow fallback color\n$popover-arrow-outer-fallback-color:  darken($popover-fallback-border-color, 20%) !default;\n\n\n//== Labels\n//\n//##\n\n//** Default label background color\n$label-default-bg:            $gray-light !default;\n//** Primary label background color\n$label-primary-bg:            $brand-primary !default;\n//** Success label background color\n$label-success-bg:            $brand-success !default;\n//** Info label background color\n$label-info-bg:               $brand-info !default;\n//** Warning label background color\n$label-warning-bg:            $brand-warning !default;\n//** Danger label background color\n$label-danger-bg:             $brand-danger !default;\n\n//** Default label text color\n$label-color:                 #fff !default;\n//** Default text color of a linked label\n$label-link-hover-color:      #fff !default;\n\n\n//== Modals\n//\n//##\n\n//** Padding applied to the modal body\n$modal-inner-padding:         15px !default;\n\n//** Padding applied to the modal title\n$modal-title-padding:         15px !default;\n//** Modal title line-height\n$modal-title-line-height:     $line-height-base !default;\n\n//** Background color of modal content area\n$modal-content-bg:                             #fff !default;\n//** Modal content border color\n$modal-content-border-color:                   rgba(0,0,0,.2) !default;\n//** Modal content border color **for IE8**\n$modal-content-fallback-border-color:          #999 !default;\n\n//** Modal backdrop background color\n$modal-backdrop-bg:           #000 !default;\n//** Modal backdrop opacity\n$modal-backdrop-opacity:      .5 !default;\n//** Modal header border color\n$modal-header-border-color:   #e5e5e5 !default;\n//** Modal footer border color\n$modal-footer-border-color:   $modal-header-border-color !default;\n\n$modal-lg:                    900px !default;\n$modal-md:                    600px !default;\n$modal-sm:                    300px !default;\n\n\n//== Alerts\n//\n//## Define alert colors, border radius, and padding.\n\n$alert-padding:               15px !default;\n$alert-border-radius:         $border-radius-base !default;\n$alert-link-font-weight:      bold !default;\n\n$alert-success-bg:            $state-success-bg !default;\n$alert-success-text:          $state-success-text !default;\n$alert-success-border:        $state-success-border !default;\n\n$alert-info-bg:               $state-info-bg !default;\n$alert-info-text:             $state-info-text !default;\n$alert-info-border:           $state-info-border !default;\n\n$alert-warning-bg:            $state-warning-bg !default;\n$alert-warning-text:          $state-warning-text !default;\n$alert-warning-border:        $state-warning-border !default;\n\n$alert-danger-bg:             $state-danger-bg !default;\n$alert-danger-text:           $state-danger-text !default;\n$alert-danger-border:         $state-danger-border !default;\n\n\n//== Progress bars\n//\n//##\n\n//** Background color of the whole progress component\n$progress-bg:                 #f5f5f5 !default;\n//** Progress bar text color\n$progress-bar-color:          #fff !default;\n//** Variable for setting rounded corners on progress bar.\n$progress-border-radius:      $border-radius-base !default;\n\n//** Default progress bar color\n$progress-bar-bg:             $brand-primary !default;\n//** Success progress bar color\n$progress-bar-success-bg:     $brand-success !default;\n//** Warning progress bar color\n$progress-bar-warning-bg:     $brand-warning !default;\n//** Danger progress bar color\n$progress-bar-danger-bg:      $brand-danger !default;\n//** Info progress bar color\n$progress-bar-info-bg:        $brand-info !default;\n\n\n//== List group\n//\n//##\n\n//** Background color on `.list-group-item`\n$list-group-bg:                 #fff !default;\n//** `.list-group-item` border color\n$list-group-border:             #ddd !default;\n//** List group border radius\n$list-group-border-radius:      $border-radius-base !default;\n\n//** Background color of single list items on hover\n$list-group-hover-bg:           #f5f5f5 !default;\n//** Text color of active list items\n$list-group-active-color:       $component-active-color !default;\n//** Background color of active list items\n$list-group-active-bg:          $component-active-bg !default;\n//** Border color of active list elements\n$list-group-active-border:      $list-group-active-bg !default;\n//** Text color for content within active list items\n$list-group-active-text-color:  lighten($list-group-active-bg, 40%) !default;\n\n//** Text color of disabled list items\n$list-group-disabled-color:      $gray-light !default;\n//** Background color of disabled list items\n$list-group-disabled-bg:         $gray-lighter !default;\n//** Text color for content within disabled list items\n$list-group-disabled-text-color: $list-group-disabled-color !default;\n\n$list-group-link-color:         #555 !default;\n$list-group-link-hover-color:   $list-group-link-color !default;\n$list-group-link-heading-color: #333 !default;\n\n\n//== Panels\n//\n//##\n\n$panel-bg:                    #fff !default;\n$panel-body-padding:          15px !default;\n$panel-heading-padding:       10px 15px !default;\n$panel-footer-padding:        $panel-heading-padding !default;\n$panel-border-radius:         $border-radius-base !default;\n\n//** Border color for elements within panels\n$panel-inner-border:          #ddd !default;\n$panel-footer-bg:             #f5f5f5 !default;\n\n$panel-default-text:          $gray-dark !default;\n$panel-default-border:        #ddd !default;\n$panel-default-heading-bg:    #f5f5f5 !default;\n\n$panel-primary-text:          #fff !default;\n$panel-primary-border:        $brand-primary !default;\n$panel-primary-heading-bg:    $brand-primary !default;\n\n$panel-success-text:          $state-success-text !default;\n$panel-success-border:        $state-success-border !default;\n$panel-success-heading-bg:    $state-success-bg !default;\n\n$panel-info-text:             $state-info-text !default;\n$panel-info-border:           $state-info-border !default;\n$panel-info-heading-bg:       $state-info-bg !default;\n\n$panel-warning-text:          $state-warning-text !default;\n$panel-warning-border:        $state-warning-border !default;\n$panel-warning-heading-bg:    $state-warning-bg !default;\n\n$panel-danger-text:           $state-danger-text !default;\n$panel-danger-border:         $state-danger-border !default;\n$panel-danger-heading-bg:     $state-danger-bg !default;\n\n\n//== Thumbnails\n//\n//##\n\n//** Padding around the thumbnail image\n$thumbnail-padding:           4px !default;\n//** Thumbnail background color\n$thumbnail-bg:                $body-bg !default;\n//** Thumbnail border color\n$thumbnail-border:            #ddd !default;\n//** Thumbnail border radius\n$thumbnail-border-radius:     $border-radius-base !default;\n\n//** Custom text color for thumbnail captions\n$thumbnail-caption-color:     $text-color !default;\n//** Padding around the thumbnail caption\n$thumbnail-caption-padding:   9px !default;\n\n\n//== Wells\n//\n//##\n\n$well-bg:                     #f5f5f5 !default;\n$well-border:                 darken($well-bg, 7%) !default;\n\n\n//== Badges\n//\n//##\n\n$badge-color:                 #fff !default;\n//** Linked badge text color on hover\n$badge-link-hover-color:      #fff !default;\n$badge-bg:                    $gray-light !default;\n\n//** Badge text color in active nav link\n$badge-active-color:          $link-color !default;\n//** Badge background color in active nav link\n$badge-active-bg:             #fff !default;\n\n$badge-font-weight:           bold !default;\n$badge-line-height:           1 !default;\n$badge-border-radius:         10px !default;\n\n\n//== Breadcrumbs\n//\n//##\n\n$breadcrumb-padding-vertical:   8px !default;\n$breadcrumb-padding-horizontal: 15px !default;\n//** Breadcrumb background color\n$breadcrumb-bg:                 #f5f5f5 !default;\n//** Breadcrumb text color\n$breadcrumb-color:              #ccc !default;\n//** Text color of current page in the breadcrumb\n$breadcrumb-active-color:       $gray-light !default;\n//** Textual separator for between breadcrumb elements\n$breadcrumb-separator:          \"/\" !default;\n\n\n//== Carousel\n//\n//##\n\n$carousel-text-shadow:                        0 1px 2px rgba(0,0,0,.6) !default;\n\n$carousel-control-color:                      #fff !default;\n$carousel-control-width:                      15% !default;\n$carousel-control-opacity:                    .5 !default;\n$carousel-control-font-size:                  20px !default;\n\n$carousel-indicator-active-bg:                #fff !default;\n$carousel-indicator-border-color:             #fff !default;\n\n$carousel-caption-color:                      #fff !default;\n\n\n//== Close\n//\n//##\n\n$close-font-weight:           bold !default;\n$close-color:                 #000 !default;\n$close-text-shadow:           0 1px 0 #fff !default;\n\n\n//== Code\n//\n//##\n\n$code-color:                  #c7254e !default;\n$code-bg:                     #f9f2f4 !default;\n\n$kbd-color:                   #fff !default;\n$kbd-bg:                      #333 !default;\n\n$pre-bg:                      #f5f5f5 !default;\n$pre-color:                   $gray-dark !default;\n$pre-border-color:            #ccc !default;\n$pre-scrollable-max-height:   340px !default;\n\n\n//== Type\n//\n//##\n\n//** Horizontal offset for forms and lists.\n$component-offset-horizontal: 180px !default;\n//** Text muted color\n$text-muted:                  $gray-light !default;\n//** Abbreviations and acronyms border color\n$abbr-border-color:           $gray-light !default;\n//** Headings small color\n$headings-small-color:        $gray-light !default;\n//** Blockquote small color\n$blockquote-small-color:      $gray-light !default;\n//** Blockquote font size\n$blockquote-font-size:        ($font-size-base * 1.25) !default;\n//** Blockquote border color\n$blockquote-border-color:     $gray-lighter !default;\n//** Page header border color\n$page-header-border-color:    $gray-lighter !default;\n//** Width of horizontal description list titles\n$dl-horizontal-offset:        $component-offset-horizontal !default;\n//** Point at which .dl-horizontal becomes horizontal\n$dl-horizontal-breakpoint:    $grid-float-breakpoint !default;\n//** Horizontal line color.\n$hr-border:                   $gray-lighter !default;\n",".loader {\n  font-size: 10px;\n  margin: 0 auto;\n  text-indent: -9999em;\n  width: 11em;\n  height: 11em;\n  border-radius: 50%;\n  background: #ffffff;\n  background: -moz-linear-gradient(left, #ffffff 10%, rgba(255, 255, 255, 0) 42%);\n  background: -webkit-linear-gradient(left, #ffffff 10%, rgba(255, 255, 255, 0) 42%);\n  background: -o-linear-gradient(left, #ffffff 10%, rgba(255, 255, 255, 0) 42%);\n  background: -ms-linear-gradient(left, #ffffff 10%, rgba(255, 255, 255, 0) 42%);\n  background: linear-gradient(to right, #ffffff 10%, rgba(255, 255, 255, 0) 42%);\n  position: relative;\n  animation: loaderSpinner 1.4s infinite linear;\n  transform: translateZ(0);\n}\n.loader:before {\n  width: 50%;\n  height: 50%;\n  background: $brand-primary;\n  border-radius: 100% 0 0 0;\n  position: absolute;\n  top: 0;\n  left: 0;\n  content: '';\n}\n.loader:after {\n  background: #fff;\n  width: 75%;\n  height: 75%;\n  border-radius: 50%;\n  content: '';\n  margin: auto;\n  position: absolute;\n  top: 0;\n  left: 0;\n  bottom: 0;\n  right: 0;\n}\n\n@keyframes loaderSpinner {\n  0% {\n    -webkit-transform: rotate(0deg);\n    transform: rotate(0deg);\n  }\n  100% {\n    -webkit-transform: rotate(360deg);\n    transform: rotate(360deg);\n  }\n}","@import '../../../styles/animations.scss';\n\nxos-table {\n\n  display: block;\n\n  tr.ng-move,\n  tr.ng-enter,\n  tr.ng-leave {\n    transition:all linear 0.5s;\n  }\n\n  tr.ng-leave.ng-leave-active,\n  tr.ng-move,\n  tr.ng-enter {\n    opacity:0;\n    animation: 0.5s slideOutRight ease-in-out;\n  }\n\n  tr.ng-leave,\n  tr.ng-move.ng-move-active,\n  tr.ng-enter.ng-enter-active {\n    opacity:1;\n    animation: 0.5s slideInRight ease-in-out;\n  }\n\n  td dl {\n    margin-bottom: 0;\n\n    dt {\n      width: auto !important;\n      margin-right: 10px;\n    }\n    \n    dt:after {\n      /*display: block;*/\n      content: ':';\n    }\n\n    dd {\n      margin-left: 0 !important;\n    }\n  }\n}","@import '../../../styles/animations.scss';\n\nxos-alert {\n  margin-top: $form-group-margin-bottom;\n  display: block;\n\n  /* when hiding */\n  .ng-hide-add         { animation:0.5s fadeOutDown ease-in-out; }\n\n  /* when showing */\n  .ng-hide-remove      { animation:0.5s fadeInUp ease-in-out; }\n}","@import '../../../styles/animations.scss';\n@import '../../../../bower_components/bootstrap-sass/assets/stylesheets/bootstrap/_variables.scss';\n\ninput + xos-validation {\n  margin-top: $form-group-margin-bottom;\n  display: block;\n}","xos-field {\n  display: block;\n}","@import '../../../styles/animations.scss';\n@import '../../../../bower_components/bootstrap-sass/assets/stylesheets/bootstrap/_variables.scss';\n\nxos-form {\n  button {\n    margin-bottom: $form-group-margin-bottom;\n  }\n\n  button + button {\n   margin-left: $form-group-margin-bottom; \n  }\n}","xos-smart-table{\n  \n}"],"mappings":"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","names":[],"sourceRoot":"/source/"} */
+/*# sourceMappingURL=data:application/json;base64,{"version":3,"file":"xosNgLib.css","sources":["main.scss","animations.scss","../../bower_components/bootstrap-sass/assets/stylesheets/bootstrap/_variables.scss","loader.scss","../ui_components/dumbComponents/table/table.scss","../ui_components/dumbComponents/alert/alert.scss","../ui_components/dumbComponents/validation/validation.scss","../ui_components/dumbComponents/field/field.scss","../ui_components/dumbComponents/form/form.scss","../ui_components/smartComponents/smartTable/smartTable.scss"],"sourcesContent":["@import './animations.scss';\n@import '../../bower_components/bootstrap-sass/assets/stylesheets/bootstrap/_variables.scss';\n@import './loader.scss';\n\n@import '../ui_components/dumbComponents/table/table.scss';\n@import '../ui_components/dumbComponents/alert/alert.scss';\n@import '../ui_components/dumbComponents/validation/validation.scss';\n@import '../ui_components/dumbComponents/field/field.scss';\n@import '../ui_components/dumbComponents/form/form.scss';\n\n@import '../ui_components/smartComponents/smartTable/smartTable.scss';\n\n[ng\\:cloak], [ng-cloak], [data-ng-cloak], [x-ng-cloak], .ng-cloak, .x-ng-cloak {\n  display: none !important;\n}\n\n.row + .row {\n  /* TODO move in xos.scss*/ \n  margin-top: $form-group-margin-bottom;\n}","@keyframes slideInRight {\n  from {\n    transform: translate3d(100%, 0, 0);\n    visibility: visible;\n  }\n\n  to {\n    transform: translate3d(0, 0, 0);\n  }\n}\n\n@keyframes slideOutRight {\n  from {\n    transform: translate3d(0, 0, 0);\n  }\n\n  to {\n    visibility: hidden;\n    transform: translate3d(100%, 0, 0);\n  }\n}\n\n@keyframes fadeInUp {\n  from {\n    opacity: 0;\n    transform: translate3d(0, 100%, 0);\n  }\n\n  to {\n    opacity: 1;\n    transform: none;\n  }\n}\n\n@keyframes fadeOutDown {\n  from {\n    opacity: 1;\n  }\n\n  to {\n    opacity: 0;\n    transform: translate3d(0, 100%, 0);\n  }\n}","$bootstrap-sass-asset-helper: false !default;\r\n//\r\n// Variables\r\n// --------------------------------------------------\r\n\r\n\r\n//== Colors\r\n//\r\n//## Gray and brand colors for use across Bootstrap.\r\n\r\n$gray-base:              #000 !default;\r\n$gray-darker:            lighten($gray-base, 13.5%) !default; // #222\r\n$gray-dark:              lighten($gray-base, 20%) !default;   // #333\r\n$gray:                   lighten($gray-base, 33.5%) !default; // #555\r\n$gray-light:             lighten($gray-base, 46.7%) !default; // #777\r\n$gray-lighter:           lighten($gray-base, 93.5%) !default; // #eee\r\n\r\n$brand-primary:         darken(#428bca, 6.5%) !default; // #337ab7\r\n$brand-success:         #5cb85c !default;\r\n$brand-info:            #5bc0de !default;\r\n$brand-warning:         #f0ad4e !default;\r\n$brand-danger:          #d9534f !default;\r\n\r\n\r\n//== Scaffolding\r\n//\r\n//## Settings for some of the most global styles.\r\n\r\n//** Background color for `<body>`.\r\n$body-bg:               #fff !default;\r\n//** Global text color on `<body>`.\r\n$text-color:            $gray-dark !default;\r\n\r\n//** Global textual link color.\r\n$link-color:            $brand-primary !default;\r\n//** Link hover color set via `darken()` function.\r\n$link-hover-color:      darken($link-color, 15%) !default;\r\n//** Link hover decoration.\r\n$link-hover-decoration: underline !default;\r\n\r\n\r\n//== Typography\r\n//\r\n//## Font, line-height, and color for body text, headings, and more.\r\n\r\n$font-family-sans-serif:  \"Helvetica Neue\", Helvetica, Arial, sans-serif !default;\r\n$font-family-serif:       Georgia, \"Times New Roman\", Times, serif !default;\r\n//** Default monospace fonts for `<code>`, `<kbd>`, and `<pre>`.\r\n$font-family-monospace:   Menlo, Monaco, Consolas, \"Courier New\", monospace !default;\r\n$font-family-base:        $font-family-sans-serif !default;\r\n\r\n$font-size-base:          14px !default;\r\n$font-size-large:         ceil(($font-size-base * 1.25)) !default; // ~18px\r\n$font-size-small:         ceil(($font-size-base * 0.85)) !default; // ~12px\r\n\r\n$font-size-h1:            floor(($font-size-base * 2.6)) !default; // ~36px\r\n$font-size-h2:            floor(($font-size-base * 2.15)) !default; // ~30px\r\n$font-size-h3:            ceil(($font-size-base * 1.7)) !default; // ~24px\r\n$font-size-h4:            ceil(($font-size-base * 1.25)) !default; // ~18px\r\n$font-size-h5:            $font-size-base !default;\r\n$font-size-h6:            ceil(($font-size-base * 0.85)) !default; // ~12px\r\n\r\n//** Unit-less `line-height` for use in components like buttons.\r\n$line-height-base:        1.428571429 !default; // 20/14\r\n//** Computed \"line-height\" (`font-size` * `line-height`) for use with `margin`, `padding`, etc.\r\n$line-height-computed:    floor(($font-size-base * $line-height-base)) !default; // ~20px\r\n\r\n//** By default, this inherits from the `<body>`.\r\n$headings-font-family:    inherit !default;\r\n$headings-font-weight:    500 !default;\r\n$headings-line-height:    1.1 !default;\r\n$headings-color:          inherit !default;\r\n\r\n\r\n//== Iconography\r\n//\r\n//## Specify custom location and filename of the included Glyphicons icon font. Useful for those including Bootstrap via Bower.\r\n\r\n//** Load fonts from this directory.\r\n\r\n// [converter] If $bootstrap-sass-asset-helper if used, provide path relative to the assets load path.\r\n// [converter] This is because some asset helpers, such as Sprockets, do not work with file-relative paths.\r\n$icon-font-path: if($bootstrap-sass-asset-helper, \"bootstrap/\", \"../fonts/bootstrap/\") !default;\r\n\r\n//** File name for all font files.\r\n$icon-font-name:          \"glyphicons-halflings-regular\" !default;\r\n//** Element ID within SVG icon file.\r\n$icon-font-svg-id:        \"glyphicons_halflingsregular\" !default;\r\n\r\n\r\n//== Components\r\n//\r\n//## Define common padding and border radius sizes and more. Values based on 14px text and 1.428 line-height (~20px to start).\r\n\r\n$padding-base-vertical:     6px !default;\r\n$padding-base-horizontal:   12px !default;\r\n\r\n$padding-large-vertical:    10px !default;\r\n$padding-large-horizontal:  16px !default;\r\n\r\n$padding-small-vertical:    5px !default;\r\n$padding-small-horizontal:  10px !default;\r\n\r\n$padding-xs-vertical:       1px !default;\r\n$padding-xs-horizontal:     5px !default;\r\n\r\n$line-height-large:         1.3333333 !default; // extra decimals for Win 8.1 Chrome\r\n$line-height-small:         1.5 !default;\r\n\r\n$border-radius-base:        4px !default;\r\n$border-radius-large:       6px !default;\r\n$border-radius-small:       3px !default;\r\n\r\n//** Global color for active items (e.g., navs or dropdowns).\r\n$component-active-color:    #fff !default;\r\n//** Global background color for active items (e.g., navs or dropdowns).\r\n$component-active-bg:       $brand-primary !default;\r\n\r\n//** Width of the `border` for generating carets that indicate dropdowns.\r\n$caret-width-base:          4px !default;\r\n//** Carets increase slightly in size for larger components.\r\n$caret-width-large:         5px !default;\r\n\r\n\r\n//== Tables\r\n//\r\n//## Customizes the `.table` component with basic values, each used across all table variations.\r\n\r\n//** Padding for `<th>`s and `<td>`s.\r\n$table-cell-padding:            8px !default;\r\n//** Padding for cells in `.table-condensed`.\r\n$table-condensed-cell-padding:  5px !default;\r\n\r\n//** Default background color used for all tables.\r\n$table-bg:                      transparent !default;\r\n//** Background color used for `.table-striped`.\r\n$table-bg-accent:               #f9f9f9 !default;\r\n//** Background color used for `.table-hover`.\r\n$table-bg-hover:                #f5f5f5 !default;\r\n$table-bg-active:               $table-bg-hover !default;\r\n\r\n//** Border color for table and cell borders.\r\n$table-border-color:            #ddd !default;\r\n\r\n\r\n//== Buttons\r\n//\r\n//## For each of Bootstrap's buttons, define text, background and border color.\r\n\r\n$btn-font-weight:                normal !default;\r\n\r\n$btn-default-color:              #333 !default;\r\n$btn-default-bg:                 #fff !default;\r\n$btn-default-border:             #ccc !default;\r\n\r\n$btn-primary-color:              #fff !default;\r\n$btn-primary-bg:                 $brand-primary !default;\r\n$btn-primary-border:             darken($btn-primary-bg, 5%) !default;\r\n\r\n$btn-success-color:              #fff !default;\r\n$btn-success-bg:                 $brand-success !default;\r\n$btn-success-border:             darken($btn-success-bg, 5%) !default;\r\n\r\n$btn-info-color:                 #fff !default;\r\n$btn-info-bg:                    $brand-info !default;\r\n$btn-info-border:                darken($btn-info-bg, 5%) !default;\r\n\r\n$btn-warning-color:              #fff !default;\r\n$btn-warning-bg:                 $brand-warning !default;\r\n$btn-warning-border:             darken($btn-warning-bg, 5%) !default;\r\n\r\n$btn-danger-color:               #fff !default;\r\n$btn-danger-bg:                  $brand-danger !default;\r\n$btn-danger-border:              darken($btn-danger-bg, 5%) !default;\r\n\r\n$btn-link-disabled-color:        $gray-light !default;\r\n\r\n// Allows for customizing button radius independently from global border radius\r\n$btn-border-radius-base:         $border-radius-base !default;\r\n$btn-border-radius-large:        $border-radius-large !default;\r\n$btn-border-radius-small:        $border-radius-small !default;\r\n\r\n\r\n//== Forms\r\n//\r\n//##\r\n\r\n//** `<input>` background color\r\n$input-bg:                       #fff !default;\r\n//** `<input disabled>` background color\r\n$input-bg-disabled:              $gray-lighter !default;\r\n\r\n//** Text color for `<input>`s\r\n$input-color:                    $gray !default;\r\n//** `<input>` border color\r\n$input-border:                   #ccc !default;\r\n\r\n// TODO: Rename `$input-border-radius` to `$input-border-radius-base` in v4\r\n//** Default `.form-control` border radius\r\n// This has no effect on `<select>`s in some browsers, due to the limited stylability of `<select>`s in CSS.\r\n$input-border-radius:            $border-radius-base !default;\r\n//** Large `.form-control` border radius\r\n$input-border-radius-large:      $border-radius-large !default;\r\n//** Small `.form-control` border radius\r\n$input-border-radius-small:      $border-radius-small !default;\r\n\r\n//** Border color for inputs on focus\r\n$input-border-focus:             #66afe9 !default;\r\n\r\n//** Placeholder text color\r\n$input-color-placeholder:        #999 !default;\r\n\r\n//** Default `.form-control` height\r\n$input-height-base:              ($line-height-computed + ($padding-base-vertical * 2) + 2) !default;\r\n//** Large `.form-control` height\r\n$input-height-large:             (ceil($font-size-large * $line-height-large) + ($padding-large-vertical * 2) + 2) !default;\r\n//** Small `.form-control` height\r\n$input-height-small:             (floor($font-size-small * $line-height-small) + ($padding-small-vertical * 2) + 2) !default;\r\n\r\n//** `.form-group` margin\r\n$form-group-margin-bottom:       15px !default;\r\n\r\n$legend-color:                   $gray-dark !default;\r\n$legend-border-color:            #e5e5e5 !default;\r\n\r\n//** Background color for textual input addons\r\n$input-group-addon-bg:           $gray-lighter !default;\r\n//** Border color for textual input addons\r\n$input-group-addon-border-color: $input-border !default;\r\n\r\n//** Disabled cursor for form controls and buttons.\r\n$cursor-disabled:                not-allowed !default;\r\n\r\n\r\n//== Dropdowns\r\n//\r\n//## Dropdown menu container and contents.\r\n\r\n//** Background for the dropdown menu.\r\n$dropdown-bg:                    #fff !default;\r\n//** Dropdown menu `border-color`.\r\n$dropdown-border:                rgba(0,0,0,.15) !default;\r\n//** Dropdown menu `border-color` **for IE8**.\r\n$dropdown-fallback-border:       #ccc !default;\r\n//** Divider color for between dropdown items.\r\n$dropdown-divider-bg:            #e5e5e5 !default;\r\n\r\n//** Dropdown link text color.\r\n$dropdown-link-color:            $gray-dark !default;\r\n//** Hover color for dropdown links.\r\n$dropdown-link-hover-color:      darken($gray-dark, 5%) !default;\r\n//** Hover background for dropdown links.\r\n$dropdown-link-hover-bg:         #f5f5f5 !default;\r\n\r\n//** Active dropdown menu item text color.\r\n$dropdown-link-active-color:     $component-active-color !default;\r\n//** Active dropdown menu item background color.\r\n$dropdown-link-active-bg:        $component-active-bg !default;\r\n\r\n//** Disabled dropdown menu item background color.\r\n$dropdown-link-disabled-color:   $gray-light !default;\r\n\r\n//** Text color for headers within dropdown menus.\r\n$dropdown-header-color:          $gray-light !default;\r\n\r\n//** Deprecated `$dropdown-caret-color` as of v3.1.0\r\n$dropdown-caret-color:           #000 !default;\r\n\r\n\r\n//-- Z-index master list\r\n//\r\n// Warning: Avoid customizing these values. They're used for a bird's eye view\r\n// of components dependent on the z-axis and are designed to all work together.\r\n//\r\n// Note: These variables are not generated into the Customizer.\r\n\r\n$zindex-navbar:            1000 !default;\r\n$zindex-dropdown:          1000 !default;\r\n$zindex-popover:           1060 !default;\r\n$zindex-tooltip:           1070 !default;\r\n$zindex-navbar-fixed:      1030 !default;\r\n$zindex-modal-background:  1040 !default;\r\n$zindex-modal:             1050 !default;\r\n\r\n\r\n//== Media queries breakpoints\r\n//\r\n//## Define the breakpoints at which your layout will change, adapting to different screen sizes.\r\n\r\n// Extra small screen / phone\r\n//** Deprecated `$screen-xs` as of v3.0.1\r\n$screen-xs:                  480px !default;\r\n//** Deprecated `$screen-xs-min` as of v3.2.0\r\n$screen-xs-min:              $screen-xs !default;\r\n//** Deprecated `$screen-phone` as of v3.0.1\r\n$screen-phone:               $screen-xs-min !default;\r\n\r\n// Small screen / tablet\r\n//** Deprecated `$screen-sm` as of v3.0.1\r\n$screen-sm:                  768px !default;\r\n$screen-sm-min:              $screen-sm !default;\r\n//** Deprecated `$screen-tablet` as of v3.0.1\r\n$screen-tablet:              $screen-sm-min !default;\r\n\r\n// Medium screen / desktop\r\n//** Deprecated `$screen-md` as of v3.0.1\r\n$screen-md:                  992px !default;\r\n$screen-md-min:              $screen-md !default;\r\n//** Deprecated `$screen-desktop` as of v3.0.1\r\n$screen-desktop:             $screen-md-min !default;\r\n\r\n// Large screen / wide desktop\r\n//** Deprecated `$screen-lg` as of v3.0.1\r\n$screen-lg:                  1200px !default;\r\n$screen-lg-min:              $screen-lg !default;\r\n//** Deprecated `$screen-lg-desktop` as of v3.0.1\r\n$screen-lg-desktop:          $screen-lg-min !default;\r\n\r\n// So media queries don't overlap when required, provide a maximum\r\n$screen-xs-max:              ($screen-sm-min - 1) !default;\r\n$screen-sm-max:              ($screen-md-min - 1) !default;\r\n$screen-md-max:              ($screen-lg-min - 1) !default;\r\n\r\n\r\n//== Grid system\r\n//\r\n//## Define your custom responsive grid.\r\n\r\n//** Number of columns in the grid.\r\n$grid-columns:              12 !default;\r\n//** Padding between columns. Gets divided in half for the left and right.\r\n$grid-gutter-width:         30px !default;\r\n// Navbar collapse\r\n//** Point at which the navbar becomes uncollapsed.\r\n$grid-float-breakpoint:     $screen-sm-min !default;\r\n//** Point at which the navbar begins collapsing.\r\n$grid-float-breakpoint-max: ($grid-float-breakpoint - 1) !default;\r\n\r\n\r\n//== Container sizes\r\n//\r\n//## Define the maximum width of `.container` for different screen sizes.\r\n\r\n// Small screen / tablet\r\n$container-tablet:             (720px + $grid-gutter-width) !default;\r\n//** For `$screen-sm-min` and up.\r\n$container-sm:                 $container-tablet !default;\r\n\r\n// Medium screen / desktop\r\n$container-desktop:            (940px + $grid-gutter-width) !default;\r\n//** For `$screen-md-min` and up.\r\n$container-md:                 $container-desktop !default;\r\n\r\n// Large screen / wide desktop\r\n$container-large-desktop:      (1140px + $grid-gutter-width) !default;\r\n//** For `$screen-lg-min` and up.\r\n$container-lg:                 $container-large-desktop !default;\r\n\r\n\r\n//== Navbar\r\n//\r\n//##\r\n\r\n// Basics of a navbar\r\n$navbar-height:                    50px !default;\r\n$navbar-margin-bottom:             $line-height-computed !default;\r\n$navbar-border-radius:             $border-radius-base !default;\r\n$navbar-padding-horizontal:        floor(($grid-gutter-width / 2)) !default;\r\n$navbar-padding-vertical:          (($navbar-height - $line-height-computed) / 2) !default;\r\n$navbar-collapse-max-height:       340px !default;\r\n\r\n$navbar-default-color:             #777 !default;\r\n$navbar-default-bg:                #f8f8f8 !default;\r\n$navbar-default-border:            darken($navbar-default-bg, 6.5%) !default;\r\n\r\n// Navbar links\r\n$navbar-default-link-color:                #777 !default;\r\n$navbar-default-link-hover-color:          #333 !default;\r\n$navbar-default-link-hover-bg:             transparent !default;\r\n$navbar-default-link-active-color:         #555 !default;\r\n$navbar-default-link-active-bg:            darken($navbar-default-bg, 6.5%) !default;\r\n$navbar-default-link-disabled-color:       #ccc !default;\r\n$navbar-default-link-disabled-bg:          transparent !default;\r\n\r\n// Navbar brand label\r\n$navbar-default-brand-color:               $navbar-default-link-color !default;\r\n$navbar-default-brand-hover-color:         darken($navbar-default-brand-color, 10%) !default;\r\n$navbar-default-brand-hover-bg:            transparent !default;\r\n\r\n// Navbar toggle\r\n$navbar-default-toggle-hover-bg:           #ddd !default;\r\n$navbar-default-toggle-icon-bar-bg:        #888 !default;\r\n$navbar-default-toggle-border-color:       #ddd !default;\r\n\r\n\r\n//=== Inverted navbar\r\n// Reset inverted navbar basics\r\n$navbar-inverse-color:                      lighten($gray-light, 15%) !default;\r\n$navbar-inverse-bg:                         #222 !default;\r\n$navbar-inverse-border:                     darken($navbar-inverse-bg, 10%) !default;\r\n\r\n// Inverted navbar links\r\n$navbar-inverse-link-color:                 lighten($gray-light, 15%) !default;\r\n$navbar-inverse-link-hover-color:           #fff !default;\r\n$navbar-inverse-link-hover-bg:              transparent !default;\r\n$navbar-inverse-link-active-color:          $navbar-inverse-link-hover-color !default;\r\n$navbar-inverse-link-active-bg:             darken($navbar-inverse-bg, 10%) !default;\r\n$navbar-inverse-link-disabled-color:        #444 !default;\r\n$navbar-inverse-link-disabled-bg:           transparent !default;\r\n\r\n// Inverted navbar brand label\r\n$navbar-inverse-brand-color:                $navbar-inverse-link-color !default;\r\n$navbar-inverse-brand-hover-color:          #fff !default;\r\n$navbar-inverse-brand-hover-bg:             transparent !default;\r\n\r\n// Inverted navbar toggle\r\n$navbar-inverse-toggle-hover-bg:            #333 !default;\r\n$navbar-inverse-toggle-icon-bar-bg:         #fff !default;\r\n$navbar-inverse-toggle-border-color:        #333 !default;\r\n\r\n\r\n//== Navs\r\n//\r\n//##\r\n\r\n//=== Shared nav styles\r\n$nav-link-padding:                          10px 15px !default;\r\n$nav-link-hover-bg:                         $gray-lighter !default;\r\n\r\n$nav-disabled-link-color:                   $gray-light !default;\r\n$nav-disabled-link-hover-color:             $gray-light !default;\r\n\r\n//== Tabs\r\n$nav-tabs-border-color:                     #ddd !default;\r\n\r\n$nav-tabs-link-hover-border-color:          $gray-lighter !default;\r\n\r\n$nav-tabs-active-link-hover-bg:             $body-bg !default;\r\n$nav-tabs-active-link-hover-color:          $gray !default;\r\n$nav-tabs-active-link-hover-border-color:   #ddd !default;\r\n\r\n$nav-tabs-justified-link-border-color:            #ddd !default;\r\n$nav-tabs-justified-active-link-border-color:     $body-bg !default;\r\n\r\n//== Pills\r\n$nav-pills-border-radius:                   $border-radius-base !default;\r\n$nav-pills-active-link-hover-bg:            $component-active-bg !default;\r\n$nav-pills-active-link-hover-color:         $component-active-color !default;\r\n\r\n\r\n//== Pagination\r\n//\r\n//##\r\n\r\n$pagination-color:                     $link-color !default;\r\n$pagination-bg:                        #fff !default;\r\n$pagination-border:                    #ddd !default;\r\n\r\n$pagination-hover-color:               $link-hover-color !default;\r\n$pagination-hover-bg:                  $gray-lighter !default;\r\n$pagination-hover-border:              #ddd !default;\r\n\r\n$pagination-active-color:              #fff !default;\r\n$pagination-active-bg:                 $brand-primary !default;\r\n$pagination-active-border:             $brand-primary !default;\r\n\r\n$pagination-disabled-color:            $gray-light !default;\r\n$pagination-disabled-bg:               #fff !default;\r\n$pagination-disabled-border:           #ddd !default;\r\n\r\n\r\n//== Pager\r\n//\r\n//##\r\n\r\n$pager-bg:                             $pagination-bg !default;\r\n$pager-border:                         $pagination-border !default;\r\n$pager-border-radius:                  15px !default;\r\n\r\n$pager-hover-bg:                       $pagination-hover-bg !default;\r\n\r\n$pager-active-bg:                      $pagination-active-bg !default;\r\n$pager-active-color:                   $pagination-active-color !default;\r\n\r\n$pager-disabled-color:                 $pagination-disabled-color !default;\r\n\r\n\r\n//== Jumbotron\r\n//\r\n//##\r\n\r\n$jumbotron-padding:              30px !default;\r\n$jumbotron-color:                inherit !default;\r\n$jumbotron-bg:                   $gray-lighter !default;\r\n$jumbotron-heading-color:        inherit !default;\r\n$jumbotron-font-size:            ceil(($font-size-base * 1.5)) !default;\r\n$jumbotron-heading-font-size:    ceil(($font-size-base * 4.5)) !default;\r\n\r\n\r\n//== Form states and alerts\r\n//\r\n//## Define colors for form feedback states and, by default, alerts.\r\n\r\n$state-success-text:             #3c763d !default;\r\n$state-success-bg:               #dff0d8 !default;\r\n$state-success-border:           darken(adjust-hue($state-success-bg, -10), 5%) !default;\r\n\r\n$state-info-text:                #31708f !default;\r\n$state-info-bg:                  #d9edf7 !default;\r\n$state-info-border:              darken(adjust-hue($state-info-bg, -10), 7%) !default;\r\n\r\n$state-warning-text:             #8a6d3b !default;\r\n$state-warning-bg:               #fcf8e3 !default;\r\n$state-warning-border:           darken(adjust-hue($state-warning-bg, -10), 5%) !default;\r\n\r\n$state-danger-text:              #a94442 !default;\r\n$state-danger-bg:                #f2dede !default;\r\n$state-danger-border:            darken(adjust-hue($state-danger-bg, -10), 5%) !default;\r\n\r\n\r\n//== Tooltips\r\n//\r\n//##\r\n\r\n//** Tooltip max width\r\n$tooltip-max-width:           200px !default;\r\n//** Tooltip text color\r\n$tooltip-color:               #fff !default;\r\n//** Tooltip background color\r\n$tooltip-bg:                  #000 !default;\r\n$tooltip-opacity:             .9 !default;\r\n\r\n//** Tooltip arrow width\r\n$tooltip-arrow-width:         5px !default;\r\n//** Tooltip arrow color\r\n$tooltip-arrow-color:         $tooltip-bg !default;\r\n\r\n\r\n//== Popovers\r\n//\r\n//##\r\n\r\n//** Popover body background color\r\n$popover-bg:                          #fff !default;\r\n//** Popover maximum width\r\n$popover-max-width:                   276px !default;\r\n//** Popover border color\r\n$popover-border-color:                rgba(0,0,0,.2) !default;\r\n//** Popover fallback border color\r\n$popover-fallback-border-color:       #ccc !default;\r\n\r\n//** Popover title background color\r\n$popover-title-bg:                    darken($popover-bg, 3%) !default;\r\n\r\n//** Popover arrow width\r\n$popover-arrow-width:                 10px !default;\r\n//** Popover arrow color\r\n$popover-arrow-color:                 $popover-bg !default;\r\n\r\n//** Popover outer arrow width\r\n$popover-arrow-outer-width:           ($popover-arrow-width + 1) !default;\r\n//** Popover outer arrow color\r\n$popover-arrow-outer-color:           fade_in($popover-border-color, 0.05) !default;\r\n//** Popover outer arrow fallback color\r\n$popover-arrow-outer-fallback-color:  darken($popover-fallback-border-color, 20%) !default;\r\n\r\n\r\n//== Labels\r\n//\r\n//##\r\n\r\n//** Default label background color\r\n$label-default-bg:            $gray-light !default;\r\n//** Primary label background color\r\n$label-primary-bg:            $brand-primary !default;\r\n//** Success label background color\r\n$label-success-bg:            $brand-success !default;\r\n//** Info label background color\r\n$label-info-bg:               $brand-info !default;\r\n//** Warning label background color\r\n$label-warning-bg:            $brand-warning !default;\r\n//** Danger label background color\r\n$label-danger-bg:             $brand-danger !default;\r\n\r\n//** Default label text color\r\n$label-color:                 #fff !default;\r\n//** Default text color of a linked label\r\n$label-link-hover-color:      #fff !default;\r\n\r\n\r\n//== Modals\r\n//\r\n//##\r\n\r\n//** Padding applied to the modal body\r\n$modal-inner-padding:         15px !default;\r\n\r\n//** Padding applied to the modal title\r\n$modal-title-padding:         15px !default;\r\n//** Modal title line-height\r\n$modal-title-line-height:     $line-height-base !default;\r\n\r\n//** Background color of modal content area\r\n$modal-content-bg:                             #fff !default;\r\n//** Modal content border color\r\n$modal-content-border-color:                   rgba(0,0,0,.2) !default;\r\n//** Modal content border color **for IE8**\r\n$modal-content-fallback-border-color:          #999 !default;\r\n\r\n//** Modal backdrop background color\r\n$modal-backdrop-bg:           #000 !default;\r\n//** Modal backdrop opacity\r\n$modal-backdrop-opacity:      .5 !default;\r\n//** Modal header border color\r\n$modal-header-border-color:   #e5e5e5 !default;\r\n//** Modal footer border color\r\n$modal-footer-border-color:   $modal-header-border-color !default;\r\n\r\n$modal-lg:                    900px !default;\r\n$modal-md:                    600px !default;\r\n$modal-sm:                    300px !default;\r\n\r\n\r\n//== Alerts\r\n//\r\n//## Define alert colors, border radius, and padding.\r\n\r\n$alert-padding:               15px !default;\r\n$alert-border-radius:         $border-radius-base !default;\r\n$alert-link-font-weight:      bold !default;\r\n\r\n$alert-success-bg:            $state-success-bg !default;\r\n$alert-success-text:          $state-success-text !default;\r\n$alert-success-border:        $state-success-border !default;\r\n\r\n$alert-info-bg:               $state-info-bg !default;\r\n$alert-info-text:             $state-info-text !default;\r\n$alert-info-border:           $state-info-border !default;\r\n\r\n$alert-warning-bg:            $state-warning-bg !default;\r\n$alert-warning-text:          $state-warning-text !default;\r\n$alert-warning-border:        $state-warning-border !default;\r\n\r\n$alert-danger-bg:             $state-danger-bg !default;\r\n$alert-danger-text:           $state-danger-text !default;\r\n$alert-danger-border:         $state-danger-border !default;\r\n\r\n\r\n//== Progress bars\r\n//\r\n//##\r\n\r\n//** Background color of the whole progress component\r\n$progress-bg:                 #f5f5f5 !default;\r\n//** Progress bar text color\r\n$progress-bar-color:          #fff !default;\r\n//** Variable for setting rounded corners on progress bar.\r\n$progress-border-radius:      $border-radius-base !default;\r\n\r\n//** Default progress bar color\r\n$progress-bar-bg:             $brand-primary !default;\r\n//** Success progress bar color\r\n$progress-bar-success-bg:     $brand-success !default;\r\n//** Warning progress bar color\r\n$progress-bar-warning-bg:     $brand-warning !default;\r\n//** Danger progress bar color\r\n$progress-bar-danger-bg:      $brand-danger !default;\r\n//** Info progress bar color\r\n$progress-bar-info-bg:        $brand-info !default;\r\n\r\n\r\n//== List group\r\n//\r\n//##\r\n\r\n//** Background color on `.list-group-item`\r\n$list-group-bg:                 #fff !default;\r\n//** `.list-group-item` border color\r\n$list-group-border:             #ddd !default;\r\n//** List group border radius\r\n$list-group-border-radius:      $border-radius-base !default;\r\n\r\n//** Background color of single list items on hover\r\n$list-group-hover-bg:           #f5f5f5 !default;\r\n//** Text color of active list items\r\n$list-group-active-color:       $component-active-color !default;\r\n//** Background color of active list items\r\n$list-group-active-bg:          $component-active-bg !default;\r\n//** Border color of active list elements\r\n$list-group-active-border:      $list-group-active-bg !default;\r\n//** Text color for content within active list items\r\n$list-group-active-text-color:  lighten($list-group-active-bg, 40%) !default;\r\n\r\n//** Text color of disabled list items\r\n$list-group-disabled-color:      $gray-light !default;\r\n//** Background color of disabled list items\r\n$list-group-disabled-bg:         $gray-lighter !default;\r\n//** Text color for content within disabled list items\r\n$list-group-disabled-text-color: $list-group-disabled-color !default;\r\n\r\n$list-group-link-color:         #555 !default;\r\n$list-group-link-hover-color:   $list-group-link-color !default;\r\n$list-group-link-heading-color: #333 !default;\r\n\r\n\r\n//== Panels\r\n//\r\n//##\r\n\r\n$panel-bg:                    #fff !default;\r\n$panel-body-padding:          15px !default;\r\n$panel-heading-padding:       10px 15px !default;\r\n$panel-footer-padding:        $panel-heading-padding !default;\r\n$panel-border-radius:         $border-radius-base !default;\r\n\r\n//** Border color for elements within panels\r\n$panel-inner-border:          #ddd !default;\r\n$panel-footer-bg:             #f5f5f5 !default;\r\n\r\n$panel-default-text:          $gray-dark !default;\r\n$panel-default-border:        #ddd !default;\r\n$panel-default-heading-bg:    #f5f5f5 !default;\r\n\r\n$panel-primary-text:          #fff !default;\r\n$panel-primary-border:        $brand-primary !default;\r\n$panel-primary-heading-bg:    $brand-primary !default;\r\n\r\n$panel-success-text:          $state-success-text !default;\r\n$panel-success-border:        $state-success-border !default;\r\n$panel-success-heading-bg:    $state-success-bg !default;\r\n\r\n$panel-info-text:             $state-info-text !default;\r\n$panel-info-border:           $state-info-border !default;\r\n$panel-info-heading-bg:       $state-info-bg !default;\r\n\r\n$panel-warning-text:          $state-warning-text !default;\r\n$panel-warning-border:        $state-warning-border !default;\r\n$panel-warning-heading-bg:    $state-warning-bg !default;\r\n\r\n$panel-danger-text:           $state-danger-text !default;\r\n$panel-danger-border:         $state-danger-border !default;\r\n$panel-danger-heading-bg:     $state-danger-bg !default;\r\n\r\n\r\n//== Thumbnails\r\n//\r\n//##\r\n\r\n//** Padding around the thumbnail image\r\n$thumbnail-padding:           4px !default;\r\n//** Thumbnail background color\r\n$thumbnail-bg:                $body-bg !default;\r\n//** Thumbnail border color\r\n$thumbnail-border:            #ddd !default;\r\n//** Thumbnail border radius\r\n$thumbnail-border-radius:     $border-radius-base !default;\r\n\r\n//** Custom text color for thumbnail captions\r\n$thumbnail-caption-color:     $text-color !default;\r\n//** Padding around the thumbnail caption\r\n$thumbnail-caption-padding:   9px !default;\r\n\r\n\r\n//== Wells\r\n//\r\n//##\r\n\r\n$well-bg:                     #f5f5f5 !default;\r\n$well-border:                 darken($well-bg, 7%) !default;\r\n\r\n\r\n//== Badges\r\n//\r\n//##\r\n\r\n$badge-color:                 #fff !default;\r\n//** Linked badge text color on hover\r\n$badge-link-hover-color:      #fff !default;\r\n$badge-bg:                    $gray-light !default;\r\n\r\n//** Badge text color in active nav link\r\n$badge-active-color:          $link-color !default;\r\n//** Badge background color in active nav link\r\n$badge-active-bg:             #fff !default;\r\n\r\n$badge-font-weight:           bold !default;\r\n$badge-line-height:           1 !default;\r\n$badge-border-radius:         10px !default;\r\n\r\n\r\n//== Breadcrumbs\r\n//\r\n//##\r\n\r\n$breadcrumb-padding-vertical:   8px !default;\r\n$breadcrumb-padding-horizontal: 15px !default;\r\n//** Breadcrumb background color\r\n$breadcrumb-bg:                 #f5f5f5 !default;\r\n//** Breadcrumb text color\r\n$breadcrumb-color:              #ccc !default;\r\n//** Text color of current page in the breadcrumb\r\n$breadcrumb-active-color:       $gray-light !default;\r\n//** Textual separator for between breadcrumb elements\r\n$breadcrumb-separator:          \"/\" !default;\r\n\r\n\r\n//== Carousel\r\n//\r\n//##\r\n\r\n$carousel-text-shadow:                        0 1px 2px rgba(0,0,0,.6) !default;\r\n\r\n$carousel-control-color:                      #fff !default;\r\n$carousel-control-width:                      15% !default;\r\n$carousel-control-opacity:                    .5 !default;\r\n$carousel-control-font-size:                  20px !default;\r\n\r\n$carousel-indicator-active-bg:                #fff !default;\r\n$carousel-indicator-border-color:             #fff !default;\r\n\r\n$carousel-caption-color:                      #fff !default;\r\n\r\n\r\n//== Close\r\n//\r\n//##\r\n\r\n$close-font-weight:           bold !default;\r\n$close-color:                 #000 !default;\r\n$close-text-shadow:           0 1px 0 #fff !default;\r\n\r\n\r\n//== Code\r\n//\r\n//##\r\n\r\n$code-color:                  #c7254e !default;\r\n$code-bg:                     #f9f2f4 !default;\r\n\r\n$kbd-color:                   #fff !default;\r\n$kbd-bg:                      #333 !default;\r\n\r\n$pre-bg:                      #f5f5f5 !default;\r\n$pre-color:                   $gray-dark !default;\r\n$pre-border-color:            #ccc !default;\r\n$pre-scrollable-max-height:   340px !default;\r\n\r\n\r\n//== Type\r\n//\r\n//##\r\n\r\n//** Horizontal offset for forms and lists.\r\n$component-offset-horizontal: 180px !default;\r\n//** Text muted color\r\n$text-muted:                  $gray-light !default;\r\n//** Abbreviations and acronyms border color\r\n$abbr-border-color:           $gray-light !default;\r\n//** Headings small color\r\n$headings-small-color:        $gray-light !default;\r\n//** Blockquote small color\r\n$blockquote-small-color:      $gray-light !default;\r\n//** Blockquote font size\r\n$blockquote-font-size:        ($font-size-base * 1.25) !default;\r\n//** Blockquote border color\r\n$blockquote-border-color:     $gray-lighter !default;\r\n//** Page header border color\r\n$page-header-border-color:    $gray-lighter !default;\r\n//** Width of horizontal description list titles\r\n$dl-horizontal-offset:        $component-offset-horizontal !default;\r\n//** Point at which .dl-horizontal becomes horizontal\r\n$dl-horizontal-breakpoint:    $grid-float-breakpoint !default;\r\n//** Horizontal line color.\r\n$hr-border:                   $gray-lighter !default;\r\n",".loader {\n  font-size: 10px;\n  margin: 0 auto;\n  text-indent: -9999em;\n  width: 11em;\n  height: 11em;\n  border-radius: 50%;\n  background: #ffffff;\n  background: -moz-linear-gradient(left, #ffffff 10%, rgba(255, 255, 255, 0) 42%);\n  background: -webkit-linear-gradient(left, #ffffff 10%, rgba(255, 255, 255, 0) 42%);\n  background: -o-linear-gradient(left, #ffffff 10%, rgba(255, 255, 255, 0) 42%);\n  background: -ms-linear-gradient(left, #ffffff 10%, rgba(255, 255, 255, 0) 42%);\n  background: linear-gradient(to right, #ffffff 10%, rgba(255, 255, 255, 0) 42%);\n  position: relative;\n  animation: loaderSpinner 1.4s infinite linear;\n  transform: translateZ(0);\n}\n.loader:before {\n  width: 50%;\n  height: 50%;\n  background: $brand-primary;\n  border-radius: 100% 0 0 0;\n  position: absolute;\n  top: 0;\n  left: 0;\n  content: '';\n}\n.loader:after {\n  background: #fff;\n  width: 75%;\n  height: 75%;\n  border-radius: 50%;\n  content: '';\n  margin: auto;\n  position: absolute;\n  top: 0;\n  left: 0;\n  bottom: 0;\n  right: 0;\n}\n\n@keyframes loaderSpinner {\n  0% {\n    -webkit-transform: rotate(0deg);\n    transform: rotate(0deg);\n  }\n  100% {\n    -webkit-transform: rotate(360deg);\n    transform: rotate(360deg);\n  }\n}","@import '../../../styles/animations.scss';\n\nxos-table {\n\n  display: block;\n\n  tr.ng-move,\n  tr.ng-enter,\n  tr.ng-leave {\n    transition:all linear 0.5s;\n  }\n\n  tr.ng-leave.ng-leave-active,\n  tr.ng-move,\n  tr.ng-enter {\n    opacity:0;\n    animation: 0.5s slideOutRight ease-in-out;\n  }\n\n  tr.ng-leave,\n  tr.ng-move.ng-move-active,\n  tr.ng-enter.ng-enter-active {\n    opacity:1;\n    animation: 0.5s slideInRight ease-in-out;\n  }\n\n  td dl {\n    margin-bottom: 0;\n\n    dt {\n      width: auto !important;\n      margin-right: 10px;\n    }\n    \n    dt:after {\n      /*display: block;*/\n      content: ':';\n    }\n\n    dd {\n      margin-left: 0 !important;\n    }\n  }\n}","@import '../../../styles/animations.scss';\n\nxos-alert {\n  margin-top: $form-group-margin-bottom;\n  display: block;\n\n  /* when hiding */\n  .ng-hide-add         { animation:0.5s fadeOutDown ease-in-out; }\n\n  /* when showing */\n  .ng-hide-remove      { animation:0.5s fadeInUp ease-in-out; }\n}","@import '../../../styles/animations.scss';\n@import '../../../../bower_components/bootstrap-sass/assets/stylesheets/bootstrap/_variables.scss';\n\ninput + xos-validation {\n  margin-top: $form-group-margin-bottom;\n  display: block;\n}","xos-field {\n  display: block;\n}","@import '../../../styles/animations.scss';\n@import '../../../../bower_components/bootstrap-sass/assets/stylesheets/bootstrap/_variables.scss';\n\nxos-form {\n  button {\n    margin-bottom: $form-group-margin-bottom;\n  }\n\n  button + button {\n   margin-left: $form-group-margin-bottom; \n  }\n}","xos-smart-table{\n  \n}"],"mappings":"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","names":[],"sourceRoot":"/source/"} */
diff --git a/dist/xosUiComponents.js b/dist/xosUiComponents.js
index eb1e43a..985ee85 100644
--- a/dist/xosUiComponents.js
+++ b/dist/xosUiComponents.js
@@ -30,14 +30,228 @@
 })();
 'use strict';
 
-var _typeof = typeof Symbol === "function" && typeof Symbol.iterator === "symbol" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol ? "symbol" : typeof obj; };
+function _toConsumableArray(arr) { if (Array.isArray(arr)) { for (var i = 0, arr2 = Array(arr.length); i < arr.length; i++) { arr2[i] = arr[i]; } return arr2; } else { return Array.from(arr); } }
 
 /**
  * © OpenCORD
  *
  * Visit http://guide.xosproject.org/devguide/addview/ for more information
  *
- * Created by teone on 3/24/16.
+ * Created by teone on 5/25/16.
+ */
+
+(function () {
+  'use strict';
+
+  angular.module('xos.uiComponents')
+  /**
+    * @ngdoc directive
+    * @name xos.uiComponents.directive:xosField
+    * @restrict E
+    * @description The xos-field directive.
+    * This component decide, give a field wich kind of input it need to print.
+    * @param {string} name The field name
+    * @param {object} field The field configuration:
+    * ```
+    * {
+    *   label: 'Label',
+    *   type: 'number', //typeof field
+    *   validators: {} // see xosForm for more details
+    * }
+    * ```
+    * @param {mixed} ngModel The field value
+    *
+    * @example
+    
+    # Basic Example
+    
+      <example module="sampleField1">
+        <file name="script.js">
+          angular.module('sampleField1', ['xos.uiComponents'])
+          .factory('_', function($window){
+            return $window._;
+          })
+          .controller('SampleCtrl', function(){
+            this.name = 'input-name';
+            this.field = {label: 'My String Value:', type: 'string'};
+            this.model = 'my string';
+          });
+        </file>
+        <file name="index.html">
+          <div ng-controller="SampleCtrl as vm">
+            <xos-field ng-model="vm.model" name="vm.name" field="vm.field"></xos-field>
+          </div>
+        </file>
+      </example>
+      
+      # Possible Values
+       <example module="sampleField2">
+        <file name="script.js">
+          angular.module('sampleField2', ['xos.uiComponents'])
+          .factory('_', function($window){
+            return $window._;
+          })
+          .controller('SampleCtrl', function(){
+            this.field1 = {
+              name: 'number-field',
+              field: {label: 'My Number Value:', type: 'number'},
+              model: 2
+            };
+             this.field2 = {
+              name: 'date-field',
+              field: {label: 'My Date Value:', type: 'date'},
+              model: new Date()
+            };
+             this.field3 = {
+              name: 'boolean-field',
+              field: {label: 'My Boolean Value:', type: 'boolean'},
+              model: true
+            };
+             this.field4 = {
+              name: 'email-field',
+              field: {label: 'My Email Value:', type: 'email'},
+              model: 'sample@domain.us'
+            };
+          });
+        </file>
+        <file name="index.html">
+          <div ng-controller="SampleCtrl as vm">
+            <xos-field ng-model="vm.field1.model" name="vm.field1.name" field="vm.field1.field"></xos-field>
+            <xos-field ng-model="vm.field2.model" name="vm.field2.name" field="vm.field2.field"></xos-field>
+            <xos-field ng-model="vm.field3.model" name="vm.field3.name" field="vm.field3.field"></xos-field>
+            <xos-field ng-model="vm.field4.model" name="vm.field4.name" field="vm.field4.field"></xos-field>
+          </div>
+        </file>
+      </example>
+       # This element is recursive
+       <example module="sampleField3">
+        <file name="script.js">
+          angular.module('sampleField3', ['xos.uiComponents'])
+          .factory('_', function($window){
+            return $window._;
+          })
+          .controller('SampleCtrl', function(){
+            this.name1 = 'input-name';
+            this.field1 = {label: 'My Object Field:', type: 'object'};
+            this.model1 = {
+              name: 'Jhon',
+              age: '25',
+              email: 'jhon@thewall.ru',
+              active: true
+            };
+             this.name2 = 'another-name';
+            this.field2 = {
+              label: 'Empty Object Field',
+              type: 'object',
+              properties: {
+                foo: {
+                  label: 'FooLabel:',
+                  type: 'string',
+                  validators: {
+                    required: true
+                  }
+                },
+                bar: {
+                  type: 'number'
+                }
+              }
+            }
+          });
+        </file>
+        <file name="index.html">
+          <div ng-controller="SampleCtrl as vm">
+            <h4>Autogenerated object field</h4>
+            <xos-field ng-model="vm.model1" name="vm.name1" field="vm.field1"></xos-field>
+             <h4>Configured object field</h4>
+            <xos-field ng-model="vm.model2" name="vm.name2" field="vm.field2"></xos-field>
+          </div>
+        </file>
+      </example>
+    */
+  .component('xosField', {
+    restrict: 'E',
+    bindings: {
+      name: '=',
+      field: '=',
+      ngModel: '='
+    },
+    template: '\n      <label ng-if="vm.field.type !== \'object\'">{{vm.field.label}}</label>\n          <input\n            xos-custom-validator custom-validator="vm.field.validators.custom || null"\n            ng-if="vm.field.type !== \'boolean\' && vm.field.type !== \'object\' && vm.field.type !== \'select\'"\n            type="{{vm.field.type}}"\n            name="{{vm.name}}"\n            class="form-control"\n            ng-model="vm.ngModel"\n            ng-minlength="vm.field.validators.minlength || 0"\n            ng-maxlength="vm.field.validators.maxlength || 2000"\n            ng-required="vm.field.validators.required || false" />\n            <select class="form-control" ng-if ="vm.field.type === \'select\'"\n              name = "{{vm.name}}"\n              ng-options="item.id as item.label for item in vm.field.options"\n              ng-model="vm.ngModel"\n              ng-required="vm.field.validators.required || false">\n              </select>\n          <span class="boolean-field" ng-if="vm.field.type === \'boolean\'">\n            <a href="#"\n              class="btn btn-success"\n              ng-show="vm.ngModel"\n              ng-click="vm.ngModel = false">\n              <i class="glyphicon glyphicon-ok"></i>\n            </a>\n            <a href="#"\n              class="btn btn-danger"\n              ng-show="!vm.ngModel"\n              ng-click="vm.ngModel = true">\n              <i class="glyphicon glyphicon-remove"></i>\n            </a>\n          </span>\n          <div\n            class="panel panel-default object-field"\n            ng-if="vm.field.type == \'object\' && (!vm.isEmptyObject(vm.ngModel) || !vm.isEmptyObject(vm.field.properties))"\n            >\n            <div class="panel-heading">{{vm.field.label}}</div>\n            <div class="panel-body">\n              <div ng-if="!vm.field.properties" ng-repeat="(k, v) in vm.ngModel">\n                <xos-field\n                  name="k"\n                  field="{label: vm.formatLabel(k), type: vm.getType(v)}"\n                  ng-model="v">\n                </xos-field>\n              </div>\n              <div ng-if="vm.field.properties" ng-repeat="(k, v) in vm.field.properties">\n                <xos-field\n                  name="k"\n                  field="{\n                    label: v.label || vm.formatLabel(k),\n                    type: v.type,\n                    validators: v.validators\n                  }"\n                  ng-model="vm.ngModel[k]">\n                </xos-field>\n              </div>\n            </div>\n          </div>\n    ',
+    bindToController: true,
+    controllerAs: 'vm',
+    // the compile cicle is needed to support recursion
+    //compile: function (element) {
+    //  return RecursionHelper.compile(element);
+    //},
+    controller: ["$attrs", "XosFormHelpers", "LabelFormatter", function controller($attrs, XosFormHelpers, LabelFormatter) {
+
+      if (!this.name) {
+        throw new Error('[xosField] Please provide a field name');
+      }
+      if (!this.field) {
+        throw new Error('[xosField] Please provide a field definition');
+      }
+      if (!this.field.type) {
+        throw new Error('[xosField] Please provide a type in the field definition');
+      }
+      if (!$attrs.ngModel) {
+        throw new Error('[xosField] Please provide an ng-model');
+      }
+      this.getType = XosFormHelpers._getFieldFormat;
+      this.formatLabel = LabelFormatter.format;
+
+      this.isEmptyObject = function (o) {
+        return o ? Object.keys(o).length === 0 : true;
+      };
+    }]
+  })
+
+  /**
+   * @ngdoc directive
+   * @name xos.uiComponents.directive:xosCustomValidator
+   * @restrict A
+   * @description The xosCustomValidator directive.
+   * This component apply a custom validation function
+   * @param {function} customValidator The function that execute the validation.
+   *
+   * You should do your validation here and return true | false,
+   * or alternatively you can return an array [errorName, true|false]
+   */
+  .directive('xosCustomValidator', function () {
+    return {
+      restrict: 'A',
+      scope: {
+        fn: '=customValidator'
+      },
+      require: 'ngModel',
+      link: function link(scope, element, attr, ctrl) {
+        if (!angular.isFunction(scope.fn)) {
+          return;
+        }
+
+        function customValidatorWrapper(ngModelValue) {
+          var valid = scope.fn(ngModelValue);
+          if (angular.isArray(valid)) {
+            // ES6 spread rocks over fn.apply()
+            ctrl.$setValidity.apply(ctrl, _toConsumableArray(valid));
+          } else {
+            ctrl.$setValidity('custom', valid);
+          }
+          return ngModelValue;
+        }
+
+        ctrl.$parsers.push(customValidatorWrapper);
+      }
+    };
+  });
+})();
+'use strict';
+
+/**
+ * © OpenCORD
+ *
+ * Visit http://guide.xosproject.org/devguide/addview/ for more information
+ *
+ * Created by teone on 4/15/16.
  */
 
 (function () {
@@ -46,214 +260,182 @@
   angular.module('xos.uiComponents')
 
   /**
-  * @ngdoc directive
-  * @name xos.uiComponents.directive:xosSmartTable
-  * @link xos.uiComponents.directive:xosTable xosTable
-  * @link xos.uiComponents.directive:xosForm xosForm
-  * @restrict E
-  * @description The xos-table directive
-  * @param {Object} config The configuration for the component,
-  * it is composed by the name of an angular [$resource](https://docs.angularjs.org/api/ngResource/service/$resource)
-  * and an array of fields that shouldn't be printed.
-  * ```
-  * {
-      resource: 'Users',
-      hiddenFields: []
-    }
-  * ```
-  * @scope
+    * @ngdoc directive
+    * @name xos.uiComponents.directive:xosValidation
+    * @restrict E
+    * @description The xos-validation directive
+    * @param {Object} errors The error object
+    * @element ANY
+    * @scope
   * @example
-   <example module="sampleSmartTable">
+  <example module="sampleValidation">
     <file name="index.html">
       <div ng-controller="SampleCtrl as vm">
-        <xos-smart-table config="vm.config"></xos-smart-table>
+        <div class="row">
+          <div class="col-xs-12">
+            <label>Set an error type:</label>
+          </div>
+          <div class="col-xs-2">
+            <a class="btn"
+              ng-click="vm.field.$error.required = !vm.field.$error.required"
+              ng-class="{'btn-default': !vm.field.$error.required, 'btn-success': vm.field.$error.required}">
+              Required
+            </a>
+          </div>
+          <div class="col-xs-2">
+            <a class="btn"
+              ng-click="vm.field.$error.email = !vm.field.$error.email"
+              ng-class="{'btn-default': !vm.field.$error.email, 'btn-success': vm.field.$error.email}">
+              Email
+            </a>
+          </div>
+          <div class="col-xs-2">
+            <a class="btn"
+              ng-click="vm.field.$error.minlength = !vm.field.$error.minlength"
+              ng-class="{'btn-default': !vm.field.$error.minlength, 'btn-success': vm.field.$error.minlength}">
+              Min Length
+            </a>
+          </div>
+          <div class="col-xs-2">
+            <a class="btn"
+              ng-click="vm.field.$error.maxlength = !vm.field.$error.maxlength"
+              ng-class="{'btn-default': !vm.field.$error.maxlength, 'btn-success': vm.field.$error.maxlength}">
+              Max Length
+            </a>
+          </div>
+        </div>
+        <xos-validation field ="vm.field" form = "vm.form"></xos-validation>
       </div>
     </file>
     <file name="script.js">
-      angular.module('sampleSmartTable', ['xos.uiComponents', 'ngResource', 'ngMockE2E'])
-      // This is only for documentation purpose
-      .run(function($httpBackend, _){
-        let datas = [{id: 1, name: 'Jhon', surname: 'Doe'}];
-        let count = 1;
-         let paramsUrl = new RegExp(/\/test\/(.+)/);
-         $httpBackend.whenDELETE(paramsUrl, undefined, ['id']).respond((method, url, data, headers, params) => {
-          data = angular.fromJson(data);
-          let id = url.match(paramsUrl)[1];
-          _.remove(datas, (d) => {
-            return d.id === parseInt(id);
-          })
-          return [204];
-        });
-         $httpBackend.whenGET('/test').respond(200, datas)
-        $httpBackend.whenPOST('/test').respond((method, url, data) => {
-          data = angular.fromJson(data);
-          data.id = ++count;
-          datas.push(data);
-          return [201, data, {}];
-        });
-      })
-      .factory('_', function($window){
-        return $window._;
-      })
-      .service('SampleResource', function($resource){
-        return $resource('/test/:id', {id: '@id'});
-      })
-      // End of documentation purpose, example start
+      angular.module('sampleValidation', ['xos.uiComponents'])
       .controller('SampleCtrl', function(){
-        this.config = {
-          resource: 'SampleResource'
+        this.field = {
+          $error: {}
         };
+        this.form= {
+        $submitted:true
+        }
       });
     </file>
   </example>
-  */
+    */
 
-  .component('xosSmartTable', {
+  .component('xosValidation', {
     restrict: 'E',
     bindings: {
-      config: '='
+      field: '=',
+      form: '='
     },
-    template: '\n        <div class="row" ng-show="vm.data.length > 0">\n          <div class="col-xs-12 text-right">\n            <a href="" class="btn btn-success" ng-click="vm.createItem()">\n              Add\n            </a>\n          </div>\n        </div>\n        <div class="row">\n          <div class="col-xs-12 table-responsive">\n            <xos-table config="vm.tableConfig" data="vm.data"></xos-table>\n          </div>\n        </div>\n        <div class="panel panel-default" ng-show="vm.detailedItem">\n          <div class="panel-heading">\n            <div class="row">\n              <div class="col-xs-11">\n                <h3 class="panel-title" ng-show="vm.detailedItem.id">Update {{vm.config.resource}} {{vm.detailedItem.id}}</h3>\n                <h3 class="panel-title" ng-show="!vm.detailedItem.id">Create {{vm.config.resource}} item</h3>\n              </div>\n              <div class="col-xs-1">\n                <a href="" ng-click="vm.cleanForm()">\n                  <i class="glyphicon glyphicon-remove pull-right"></i>\n                </a>\n              </div>\n            </div>\n          </div>\n          <div class="panel-body">\n            <xos-form config="vm.formConfig" ng-model="vm.detailedItem"></xos-form>\n          </div>\n        </div>\n        <xos-alert config="{type: \'success\', closeBtn: true}" show="vm.responseMsg">{{vm.responseMsg}}</xos-alert>\n        <xos-alert config="{type: \'danger\', closeBtn: true}" show="vm.responseErr">{{vm.responseErr}}</xos-alert>\n      ',
+    template: '\n      <div ng-cloak>\n        <xos-alert config="vm.config" show="vm.field.$error.required !== undefined && vm.field.$error.required !== false  && (vm.field.$touched || vm.form.$submitted)">\n          Field required\n        </xos-alert>\n        <xos-alert config="vm.config" show="vm.field.$error.email !== undefined && vm.field.$error.email !== false && (vm.field.$touched || vm.form.$submitted)">\n          This is not a valid email\n        </xos-alert>\n        <xos-alert config="vm.config" show="vm.field.$error.minlength !== undefined && vm.field.$error.minlength !== false && (vm.field.$touched || vm.form.$submitted)">\n          Too short\n        </xos-alert>\n        <xos-alert config="vm.config" show="vm.field.$error.maxlength !== undefined && vm.field.$error.maxlength !== false && (vm.field.$touched || vm.form.$submitted)">\n          Too long\n        </xos-alert>\n        <xos-alert config="vm.config" show="vm.field.$error.custom !== undefined && vm.field.$error.custom !== false && (vm.field.$touched || vm.form.$submitted)">\n          Field invalid\n        </xos-alert>\n      </div>\n    ',
+    transclude: true,
     bindToController: true,
     controllerAs: 'vm',
-    controller: ["$injector", "LabelFormatter", "_", "XosFormHelpers", function controller($injector, LabelFormatter, _, XosFormHelpers) {
+    controller: function controller() {
+      this.config = {
+        type: 'danger'
+      };
+    }
+  });
+})();
+'use strict';
+
+/**
+ * © OpenCORD
+ *
+ * Visit http://guide.xosproject.org/devguide/addview/ for more information
+ *
+ * Created by teone on 4/15/16.
+ */
+
+(function () {
+  'use strict';
+
+  angular.module('xos.uiComponents')
+
+  /**
+    * @ngdoc directive
+    * @name xos.uiComponents.directive:xosPagination
+    * @restrict E
+    * @description The xos-table directive
+    * @param {Number} pageSize Number of elements per page
+    * @param {Number} totalElements Number of total elements in the collection
+    * @param {Function} change The callback to be triggered on page change.
+    * * @element ANY
+    * @scope
+    * @example
+  <example module="samplePagination">
+    <file name="index.html">
+      <div ng-controller="SampleCtrl1 as vm">
+        <xos-pagination
+          page-size="vm.pageSize"
+          total-elements="vm.totalElements"
+          change="vm.change">
+        </xos-pagination>
+      </div>
+    </file>
+    <file name="script.js">
+      angular.module('samplePagination', ['xos.uiComponents'])
+      .controller('SampleCtrl1', function(){
+        this.pageSize = 10;
+        this.totalElements = 35;
+        this.change = (pageNumber) => {
+          console.log(pageNumber);
+        }
+      });
+    </file>
+  </example>
+  **/
+
+  .component('xosPagination', {
+    restrict: 'E',
+    bindings: {
+      pageSize: '=',
+      totalElements: '=',
+      change: '='
+    },
+    template: '\n      <div class="row" ng-if="vm.pageList.length > 1">\n        <div class="col-xs-12 text-center">\n          <ul class="pagination">\n            <li\n              ng-click="vm.goToPage(vm.currentPage - 1)"\n              ng-class="{disabled: vm.currentPage == 0}">\n              <a href="" aria-label="Previous">\n                  <span aria-hidden="true">&laquo;</span>\n              </a>\n            </li>\n            <li ng-repeat="i in vm.pageList" ng-class="{active: i === vm.currentPage}">\n              <a href="" ng-click="vm.goToPage(i)">{{i + 1}}</a>\n            </li>\n            <li\n              ng-click="vm.goToPage(vm.currentPage + 1)"\n              ng-class="{disabled: vm.currentPage == vm.pages - 1}">\n              <a href="" aria-label="Next">\n                  <span aria-hidden="true">&raquo;</span>\n              </a>\n            </li>\n          </ul>\n        </div>\n      </div>\n    ',
+    bindToController: true,
+    controllerAs: 'vm',
+    controller: ["$scope", function controller($scope) {
       var _this = this;
 
-      // TODO
-      // - Validate the config (what if resource does not exist?)
+      this.currentPage = 0;
 
-      // NOTE
-      // Corner case
-      // - if response is empty, how can we generate a form ?
-
-      this.responseMsg = false;
-      this.responseErr = false;
-
-      this.tableConfig = {
-        columns: [],
-        actions: [{
-          label: 'delete',
-          icon: 'remove',
-          cb: function cb(item) {
-            _this.Resource.delete({ id: item.id }).$promise.then(function () {
-              _.remove(_this.data, function (d) {
-                return d.id === item.id;
-              });
-              _this.responseMsg = _this.config.resource + ' with id ' + item.id + ' successfully deleted';
-            }).catch(function (err) {
-              _this.responseErr = err.data.detail || 'Error while deleting ' + _this.config.resource + ' with id ' + item.id;
-            });
-          },
-          color: 'red'
-        }, {
-          label: 'details',
-          icon: 'search',
-          cb: function cb(item) {
-            _this.detailedItem = item;
-          }
-        }],
-        classes: 'table table-striped table-bordered table-responsive',
-        filter: 'field',
-        order: true,
-        pagination: {
-          pageSize: 10
+      this.goToPage = function (n) {
+        if (n < 0 || n === _this.pages) {
+          return;
         }
+        _this.currentPage = n;
+        _this.change(n);
       };
 
-      this.formConfig = {
-        exclude: this.config.hiddenFields,
-        fields: {},
-        formName: this.config.resource + 'Form',
-        actions: [{
-          label: 'Save',
-          icon: 'ok',
-          cb: function cb(item) {
-            var p = void 0;
-            var isNew = true;
-
-            if (item.id) {
-              p = item.$update();
-              isNew = false;
-            } else {
-              p = item.$save();
-            }
-
-            p.then(function (res) {
-              if (isNew) {
-                _this.data.push(angular.copy(res));
-              }
-              delete _this.detailedItem;
-              _this.responseMsg = _this.config.resource + ' with id ' + item.id + ' successfully saved';
-            }).catch(function (err) {
-              _this.responseErr = err.data.detail || 'Error while saving ' + _this.config.resource + ' with id ' + item.id;
-            });
-          },
-          class: 'success'
-        }]
+      this.createPages = function (pages) {
+        var arr = [];
+        for (var i = 0; i < pages; i++) {
+          arr.push(i);
+        }
+        return arr;
       };
 
-      this.cleanForm = function () {
-        delete _this.detailedItem;
-      };
-
-      this.createItem = function () {
-        _this.detailedItem = new _this.Resource();
-      };
-
-      this.Resource = $injector.get(this.config.resource);
-
-      var getData = function getData() {
-        _this.Resource.query().$promise.then(function (res) {
-
-          if (!res[0]) {
-            _this.data = res;
-            return;
-          }
-
-          var item = res[0];
-          var props = Object.keys(item);
-
-          _.remove(props, function (p) {
-            return p === 'id' || p === 'validators';
-          });
-
-          // TODO move out cb,  non sense triggering a lot of times
-          if (angular.isArray(_this.config.hiddenFields)) {
-            props = _.difference(props, _this.config.hiddenFields);
-          }
-
-          var labels = props.map(function (p) {
-            return LabelFormatter.format(p);
-          });
-
-          props.forEach(function (p, i) {
-            var fieldConfig = {
-              label: labels[i],
-              prop: p
-            };
-
-            if (angular.isString(item[p]) && typeof item[p] !== 'undefined') {
-              fieldConfig.type = _typeof(item[p]);
-            }
-
-            _this.tableConfig.columns.push(fieldConfig);
-          });
-
-          // build form structure
-          // TODO move in a pure function for testing purposes
-          props.forEach(function (p, i) {
-            _this.formConfig.fields[p] = {
-              label: LabelFormatter.format(labels[i]).replace(':', ''),
-              type: XosFormHelpers._getFieldFormat(item[p])
-            };
-          });
-
-          _this.data = res;
-        });
-      };
-
-      getData();
+      // watch for data changes
+      $scope.$watch(function () {
+        return _this.totalElements;
+      }, function () {
+        if (_this.totalElements) {
+          _this.pages = Math.ceil(_this.totalElements / _this.pageSize);
+          _this.pageList = _this.createPages(_this.pages);
+        }
+      });
     }]
+  }).filter('pagination', function () {
+    return function (input, start) {
+      if (!input || !angular.isArray(input)) {
+        return input;
+      }
+      start = parseInt(start, 10);
+      return input.slice(start);
+    };
   });
 })();
 'use strict';
@@ -508,100 +690,6 @@
  *
  * Visit http://guide.xosproject.org/devguide/addview/ for more information
  *
- * Created by teone on 4/15/16.
- */
-
-(function () {
-  'use strict';
-
-  angular.module('xos.uiComponents')
-
-  /**
-    * @ngdoc directive
-    * @name xos.uiComponents.directive:xosValidation
-    * @restrict E
-    * @description The xos-validation directive
-    * @param {Object} errors The error object
-    * @element ANY
-    * @scope
-  * @example
-  <example module="sampleValidation">
-    <file name="index.html">
-      <div ng-controller="SampleCtrl as vm">
-        <div class="row">
-          <div class="col-xs-12">
-            <label>Set an error type:</label>
-          </div>
-          <div class="col-xs-2">
-            <a class="btn"
-              ng-click="vm.field.$error.required = !vm.field.$error.required"
-              ng-class="{'btn-default': !vm.field.$error.required, 'btn-success': vm.field.$error.required}">
-              Required
-            </a>
-          </div>
-          <div class="col-xs-2">
-            <a class="btn"
-              ng-click="vm.field.$error.email = !vm.field.$error.email"
-              ng-class="{'btn-default': !vm.field.$error.email, 'btn-success': vm.field.$error.email}">
-              Email
-            </a>
-          </div>
-          <div class="col-xs-2">
-            <a class="btn"
-              ng-click="vm.field.$error.minlength = !vm.field.$error.minlength"
-              ng-class="{'btn-default': !vm.field.$error.minlength, 'btn-success': vm.field.$error.minlength}">
-              Min Length
-            </a>
-          </div>
-          <div class="col-xs-2">
-            <a class="btn"
-              ng-click="vm.field.$error.maxlength = !vm.field.$error.maxlength"
-              ng-class="{'btn-default': !vm.field.$error.maxlength, 'btn-success': vm.field.$error.maxlength}">
-              Max Length
-            </a>
-          </div>
-        </div>
-        <xos-validation field ="vm.field" form = "vm.form"></xos-validation>
-      </div>
-    </file>
-    <file name="script.js">
-      angular.module('sampleValidation', ['xos.uiComponents'])
-      .controller('SampleCtrl', function(){
-        this.field = {
-          $error: {}
-        };
-        this.form= {
-        $submitted:true
-        }
-      });
-    </file>
-  </example>
-    */
-
-  .component('xosValidation', {
-    restrict: 'E',
-    bindings: {
-      field: '=',
-      form: '='
-    },
-    template: '\n      <div ng-cloak>\n        <xos-alert config="vm.config" show="vm.field.$error.required !== undefined && vm.field.$error.required !== false  && (vm.field.$touched || vm.form.$submitted)">\n          Field required\n        </xos-alert>\n        <xos-alert config="vm.config" show="vm.field.$error.email !== undefined && vm.field.$error.email !== false && (vm.field.$touched || vm.form.$submitted)">\n          This is not a valid email\n        </xos-alert>\n        <xos-alert config="vm.config" show="vm.field.$error.minlength !== undefined && vm.field.$error.minlength !== false && (vm.field.$touched || vm.form.$submitted)">\n          Too short\n        </xos-alert>\n        <xos-alert config="vm.config" show="vm.field.$error.maxlength !== undefined && vm.field.$error.maxlength !== false && (vm.field.$touched || vm.form.$submitted)">\n          Too long\n        </xos-alert>\n        <xos-alert config="vm.config" show="vm.field.$error.custom !== undefined && vm.field.$error.custom !== false && (vm.field.$touched || vm.form.$submitted)">\n          Field invalid\n        </xos-alert>\n      </div>\n    ',
-    transclude: true,
-    bindToController: true,
-    controllerAs: 'vm',
-    controller: function controller() {
-      this.config = {
-        type: 'danger'
-      };
-    }
-  });
-})();
-'use strict';
-
-/**
- * © OpenCORD
- *
- * Visit http://guide.xosproject.org/devguide/addview/ for more information
- *
  * Created by teone on 3/24/16.
  */
 
@@ -1032,106 +1120,6 @@
  *
  * Visit http://guide.xosproject.org/devguide/addview/ for more information
  *
- * Created by teone on 4/15/16.
- */
-
-(function () {
-  'use strict';
-
-  angular.module('xos.uiComponents')
-
-  /**
-    * @ngdoc directive
-    * @name xos.uiComponents.directive:xosPagination
-    * @restrict E
-    * @description The xos-table directive
-    * @param {Number} pageSize Number of elements per page
-    * @param {Number} totalElements Number of total elements in the collection
-    * @param {Function} change The callback to be triggered on page change.
-    * * @element ANY
-    * @scope
-    * @example
-  <example module="samplePagination">
-    <file name="index.html">
-      <div ng-controller="SampleCtrl1 as vm">
-        <xos-pagination
-          page-size="vm.pageSize"
-          total-elements="vm.totalElements"
-          change="vm.change">
-        </xos-pagination>
-      </div>
-    </file>
-    <file name="script.js">
-      angular.module('samplePagination', ['xos.uiComponents'])
-      .controller('SampleCtrl1', function(){
-        this.pageSize = 10;
-        this.totalElements = 35;
-        this.change = (pageNumber) => {
-          console.log(pageNumber);
-        }
-      });
-    </file>
-  </example>
-  **/
-
-  .component('xosPagination', {
-    restrict: 'E',
-    bindings: {
-      pageSize: '=',
-      totalElements: '=',
-      change: '='
-    },
-    template: '\n      <div class="row" ng-if="vm.pageList.length > 1">\n        <div class="col-xs-12 text-center">\n          <ul class="pagination">\n            <li\n              ng-click="vm.goToPage(vm.currentPage - 1)"\n              ng-class="{disabled: vm.currentPage == 0}">\n              <a href="" aria-label="Previous">\n                  <span aria-hidden="true">&laquo;</span>\n              </a>\n            </li>\n            <li ng-repeat="i in vm.pageList" ng-class="{active: i === vm.currentPage}">\n              <a href="" ng-click="vm.goToPage(i)">{{i + 1}}</a>\n            </li>\n            <li\n              ng-click="vm.goToPage(vm.currentPage + 1)"\n              ng-class="{disabled: vm.currentPage == vm.pages - 1}">\n              <a href="" aria-label="Next">\n                  <span aria-hidden="true">&raquo;</span>\n              </a>\n            </li>\n          </ul>\n        </div>\n      </div>\n    ',
-    bindToController: true,
-    controllerAs: 'vm',
-    controller: ["$scope", function controller($scope) {
-      var _this = this;
-
-      this.currentPage = 0;
-
-      this.goToPage = function (n) {
-        if (n < 0 || n === _this.pages) {
-          return;
-        }
-        _this.currentPage = n;
-        _this.change(n);
-      };
-
-      this.createPages = function (pages) {
-        var arr = [];
-        for (var i = 0; i < pages; i++) {
-          arr.push(i);
-        }
-        return arr;
-      };
-
-      // watch for data changes
-      $scope.$watch(function () {
-        return _this.totalElements;
-      }, function () {
-        if (_this.totalElements) {
-          _this.pages = Math.ceil(_this.totalElements / _this.pageSize);
-          _this.pageList = _this.createPages(_this.pages);
-        }
-      });
-    }]
-  }).filter('pagination', function () {
-    return function (input, start) {
-      if (!input || !angular.isArray(input)) {
-        return input;
-      }
-      start = parseInt(start, 10);
-      return input.slice(start);
-    };
-  });
-})();
-'use strict';
-
-/**
- * © OpenCORD
- *
- * Visit http://guide.xosproject.org/devguide/addview/ for more information
- *
  * Created by teone on 4/18/16.
  */
 
@@ -1384,222 +1372,6 @@
 })();
 'use strict';
 
-function _toConsumableArray(arr) { if (Array.isArray(arr)) { for (var i = 0, arr2 = Array(arr.length); i < arr.length; i++) { arr2[i] = arr[i]; } return arr2; } else { return Array.from(arr); } }
-
-/**
- * © OpenCORD
- *
- * Visit http://guide.xosproject.org/devguide/addview/ for more information
- *
- * Created by teone on 5/25/16.
- */
-
-(function () {
-  'use strict';
-
-  angular.module('xos.uiComponents')
-  /**
-    * @ngdoc directive
-    * @name xos.uiComponents.directive:xosField
-    * @restrict E
-    * @description The xos-field directive.
-    * This component decide, give a field wich kind of input it need to print.
-    * @param {string} name The field name
-    * @param {object} field The field configuration:
-    * ```
-    * {
-    *   label: 'Label',
-    *   type: 'number', //typeof field
-    *   validators: {} // see xosForm for more details
-    * }
-    * ```
-    * @param {mixed} ngModel The field value
-    *
-    * @example
-    
-    # Basic Example
-    
-      <example module="sampleField1">
-        <file name="script.js">
-          angular.module('sampleField1', ['xos.uiComponents'])
-          .factory('_', function($window){
-            return $window._;
-          })
-          .controller('SampleCtrl', function(){
-            this.name = 'input-name';
-            this.field = {label: 'My String Value:', type: 'string'};
-            this.model = 'my string';
-          });
-        </file>
-        <file name="index.html">
-          <div ng-controller="SampleCtrl as vm">
-            <xos-field ng-model="vm.model" name="vm.name" field="vm.field"></xos-field>
-          </div>
-        </file>
-      </example>
-      
-      # Possible Values
-       <example module="sampleField2">
-        <file name="script.js">
-          angular.module('sampleField2', ['xos.uiComponents'])
-          .factory('_', function($window){
-            return $window._;
-          })
-          .controller('SampleCtrl', function(){
-            this.field1 = {
-              name: 'number-field',
-              field: {label: 'My Number Value:', type: 'number'},
-              model: 2
-            };
-             this.field2 = {
-              name: 'date-field',
-              field: {label: 'My Date Value:', type: 'date'},
-              model: new Date()
-            };
-             this.field3 = {
-              name: 'boolean-field',
-              field: {label: 'My Boolean Value:', type: 'boolean'},
-              model: true
-            };
-             this.field4 = {
-              name: 'email-field',
-              field: {label: 'My Email Value:', type: 'email'},
-              model: 'sample@domain.us'
-            };
-          });
-        </file>
-        <file name="index.html">
-          <div ng-controller="SampleCtrl as vm">
-            <xos-field ng-model="vm.field1.model" name="vm.field1.name" field="vm.field1.field"></xos-field>
-            <xos-field ng-model="vm.field2.model" name="vm.field2.name" field="vm.field2.field"></xos-field>
-            <xos-field ng-model="vm.field3.model" name="vm.field3.name" field="vm.field3.field"></xos-field>
-            <xos-field ng-model="vm.field4.model" name="vm.field4.name" field="vm.field4.field"></xos-field>
-          </div>
-        </file>
-      </example>
-       # This element is recursive
-       <example module="sampleField3">
-        <file name="script.js">
-          angular.module('sampleField3', ['xos.uiComponents'])
-          .factory('_', function($window){
-            return $window._;
-          })
-          .controller('SampleCtrl', function(){
-            this.name1 = 'input-name';
-            this.field1 = {label: 'My Object Field:', type: 'object'};
-            this.model1 = {
-              name: 'Jhon',
-              age: '25',
-              email: 'jhon@thewall.ru',
-              active: true
-            };
-             this.name2 = 'another-name';
-            this.field2 = {
-              label: 'Empty Object Field',
-              type: 'object',
-              properties: {
-                foo: {
-                  label: 'FooLabel:',
-                  type: 'string',
-                  validators: {
-                    required: true
-                  }
-                },
-                bar: {
-                  type: 'number'
-                }
-              }
-            }
-          });
-        </file>
-        <file name="index.html">
-          <div ng-controller="SampleCtrl as vm">
-            <h4>Autogenerated object field</h4>
-            <xos-field ng-model="vm.model1" name="vm.name1" field="vm.field1"></xos-field>
-             <h4>Configured object field</h4>
-            <xos-field ng-model="vm.model2" name="vm.name2" field="vm.field2"></xos-field>
-          </div>
-        </file>
-      </example>
-    */
-  .component('xosField', {
-    restrict: 'E',
-    bindings: {
-      name: '=',
-      field: '=',
-      ngModel: '='
-    },
-    template: '\n      <label ng-if="vm.field.type !== \'object\'">{{vm.field.label}}</label>\n          <input\n            xos-custom-validator custom-validator="vm.field.validators.custom || null"\n            ng-if="vm.field.type !== \'boolean\' && vm.field.type !== \'object\' && vm.field.type !== \'select\'"\n            type="{{vm.field.type}}"\n            name="{{vm.name}}"\n            class="form-control"\n            ng-model="vm.ngModel"\n            ng-minlength="vm.field.validators.minlength || 0"\n            ng-maxlength="vm.field.validators.maxlength || 2000"\n            ng-required="vm.field.validators.required || false" />\n            <select class="form-control" ng-if ="vm.field.type === \'select\'"\n              name = "{{vm.name}}"\n              ng-options="item.id as item.label for item in vm.field.options"\n              ng-model="vm.ngModel"\n              ng-required="vm.field.validators.required || false">\n              </select>\n          <span class="boolean-field" ng-if="vm.field.type === \'boolean\'">\n            <a href="#"\n              class="btn btn-success"\n              ng-show="vm.ngModel"\n              ng-click="vm.ngModel = false">\n              <i class="glyphicon glyphicon-ok"></i>\n            </a>\n            <a href="#"\n              class="btn btn-danger"\n              ng-show="!vm.ngModel"\n              ng-click="vm.ngModel = true">\n              <i class="glyphicon glyphicon-remove"></i>\n            </a>\n          </span>\n          <div\n            class="panel panel-default object-field"\n            ng-if="vm.field.type == \'object\' && (!vm.isEmptyObject(vm.ngModel) || !vm.isEmptyObject(vm.field.properties))"\n            >\n            <div class="panel-heading">{{vm.field.label}}</div>\n            <div class="panel-body">\n              <div ng-if="!vm.field.properties" ng-repeat="(k, v) in vm.ngModel">\n                <xos-field\n                  name="k"\n                  field="{label: vm.formatLabel(k), type: vm.getType(v)}"\n                  ng-model="v">\n                </xos-field>\n              </div>\n              <div ng-if="vm.field.properties" ng-repeat="(k, v) in vm.field.properties">\n                <xos-field\n                  name="k"\n                  field="{\n                    label: v.label || vm.formatLabel(k),\n                    type: v.type,\n                    validators: v.validators\n                  }"\n                  ng-model="vm.ngModel[k]">\n                </xos-field>\n              </div>\n            </div>\n          </div>\n    ',
-    bindToController: true,
-    controllerAs: 'vm',
-    // the compile cicle is needed to support recursion
-    //compile: function (element) {
-    //  return RecursionHelper.compile(element);
-    //},
-    controller: ["$attrs", "XosFormHelpers", "LabelFormatter", function controller($attrs, XosFormHelpers, LabelFormatter) {
-
-      if (!this.name) {
-        throw new Error('[xosField] Please provide a field name');
-      }
-      if (!this.field) {
-        throw new Error('[xosField] Please provide a field definition');
-      }
-      if (!this.field.type) {
-        throw new Error('[xosField] Please provide a type in the field definition');
-      }
-      if (!$attrs.ngModel) {
-        throw new Error('[xosField] Please provide an ng-model');
-      }
-      this.getType = XosFormHelpers._getFieldFormat;
-      this.formatLabel = LabelFormatter.format;
-
-      this.isEmptyObject = function (o) {
-        return o ? Object.keys(o).length === 0 : true;
-      };
-    }]
-  })
-
-  /**
-   * @ngdoc directive
-   * @name xos.uiComponents.directive:xosCustomValidator
-   * @restrict A
-   * @description The xosCustomValidator directive.
-   * This component apply a custom validation function
-   * @param {function} customValidator The function that execute the validation.
-   *
-   * You should do your validation here and return true | false,
-   * or alternatively you can return an array [errorName, true|false]
-   */
-  .directive('xosCustomValidator', function () {
-    return {
-      restrict: 'A',
-      scope: {
-        fn: '=customValidator'
-      },
-      require: 'ngModel',
-      link: function link(scope, element, attr, ctrl) {
-        if (!angular.isFunction(scope.fn)) {
-          return;
-        }
-
-        function customValidatorWrapper(ngModelValue) {
-          var valid = scope.fn(ngModelValue);
-          if (angular.isArray(valid)) {
-            // ES6 spread rocks over fn.apply()
-            ctrl.$setValidity.apply(ctrl, _toConsumableArray(valid));
-          } else {
-            ctrl.$setValidity('custom', valid);
-          }
-          return ngModelValue;
-        }
-
-        ctrl.$parsers.push(customValidatorWrapper);
-      }
-    };
-  });
-})();
-'use strict';
-
 /**
  * © OpenCORD
  *
@@ -1735,6 +1507,234 @@
 })();
 'use strict';
 
+var _typeof = typeof Symbol === "function" && typeof Symbol.iterator === "symbol" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol ? "symbol" : typeof obj; };
+
+/**
+ * © OpenCORD
+ *
+ * Visit http://guide.xosproject.org/devguide/addview/ for more information
+ *
+ * Created by teone on 3/24/16.
+ */
+
+(function () {
+  'use strict';
+
+  angular.module('xos.uiComponents')
+
+  /**
+  * @ngdoc directive
+  * @name xos.uiComponents.directive:xosSmartTable
+  * @link xos.uiComponents.directive:xosTable xosTable
+  * @link xos.uiComponents.directive:xosForm xosForm
+  * @restrict E
+  * @description The xos-table directive
+  * @param {Object} config The configuration for the component,
+  * it is composed by the name of an angular [$resource](https://docs.angularjs.org/api/ngResource/service/$resource)
+  * and an array of fields that shouldn't be printed.
+  * ```
+  * {
+      resource: 'Users',
+      hiddenFields: []
+    }
+  * ```
+  * @scope
+  * @example
+   <example module="sampleSmartTable">
+    <file name="index.html">
+      <div ng-controller="SampleCtrl as vm">
+        <xos-smart-table config="vm.config"></xos-smart-table>
+      </div>
+    </file>
+    <file name="script.js">
+      angular.module('sampleSmartTable', ['xos.uiComponents', 'ngResource', 'ngMockE2E'])
+      // This is only for documentation purpose
+      .run(function($httpBackend, _){
+        let datas = [{id: 1, name: 'Jhon', surname: 'Doe'}];
+        let count = 1;
+         let paramsUrl = new RegExp(/\/test\/(.+)/);
+         $httpBackend.whenDELETE(paramsUrl, undefined, ['id']).respond((method, url, data, headers, params) => {
+          data = angular.fromJson(data);
+          let id = url.match(paramsUrl)[1];
+          _.remove(datas, (d) => {
+            return d.id === parseInt(id);
+          })
+          return [204];
+        });
+         $httpBackend.whenGET('/test').respond(200, datas)
+        $httpBackend.whenPOST('/test').respond((method, url, data) => {
+          data = angular.fromJson(data);
+          data.id = ++count;
+          datas.push(data);
+          return [201, data, {}];
+        });
+      })
+      .factory('_', function($window){
+        return $window._;
+      })
+      .service('SampleResource', function($resource){
+        return $resource('/test/:id', {id: '@id'});
+      })
+      // End of documentation purpose, example start
+      .controller('SampleCtrl', function(){
+        this.config = {
+          resource: 'SampleResource'
+        };
+      });
+    </file>
+  </example>
+  */
+
+  .component('xosSmartTable', {
+    restrict: 'E',
+    bindings: {
+      config: '='
+    },
+    template: '\n        <div class="row" ng-show="vm.data.length > 0">\n          <div class="col-xs-12 text-right">\n            <a href="" class="btn btn-success" ng-click="vm.createItem()">\n              Add\n            </a>\n          </div>\n        </div>\n        <div class="row">\n          <div class="col-xs-12 table-responsive">\n            <xos-table config="vm.tableConfig" data="vm.data"></xos-table>\n          </div>\n        </div>\n        <div class="panel panel-default" ng-show="vm.detailedItem">\n          <div class="panel-heading">\n            <div class="row">\n              <div class="col-xs-11">\n                <h3 class="panel-title" ng-show="vm.detailedItem.id">Update {{vm.config.resource}} {{vm.detailedItem.id}}</h3>\n                <h3 class="panel-title" ng-show="!vm.detailedItem.id">Create {{vm.config.resource}} item</h3>\n              </div>\n              <div class="col-xs-1">\n                <a href="" ng-click="vm.cleanForm()">\n                  <i class="glyphicon glyphicon-remove pull-right"></i>\n                </a>\n              </div>\n            </div>\n          </div>\n          <div class="panel-body">\n            <xos-form config="vm.formConfig" ng-model="vm.detailedItem"></xos-form>\n          </div>\n        </div>\n        <xos-alert config="{type: \'success\', closeBtn: true}" show="vm.responseMsg">{{vm.responseMsg}}</xos-alert>\n        <xos-alert config="{type: \'danger\', closeBtn: true}" show="vm.responseErr">{{vm.responseErr}}</xos-alert>\n      ',
+    bindToController: true,
+    controllerAs: 'vm',
+    controller: ["$injector", "LabelFormatter", "_", "XosFormHelpers", function controller($injector, LabelFormatter, _, XosFormHelpers) {
+      var _this = this;
+
+      // TODO
+      // - Validate the config (what if resource does not exist?)
+
+      // NOTE
+      // Corner case
+      // - if response is empty, how can we generate a form ?
+
+      this.responseMsg = false;
+      this.responseErr = false;
+
+      this.tableConfig = {
+        columns: [],
+        actions: [{
+          label: 'delete',
+          icon: 'remove',
+          cb: function cb(item) {
+            _this.Resource.delete({ id: item.id }).$promise.then(function () {
+              _.remove(_this.data, function (d) {
+                return d.id === item.id;
+              });
+              _this.responseMsg = _this.config.resource + ' with id ' + item.id + ' successfully deleted';
+            }).catch(function (err) {
+              _this.responseErr = err.data.detail || 'Error while deleting ' + _this.config.resource + ' with id ' + item.id;
+            });
+          },
+          color: 'red'
+        }, {
+          label: 'details',
+          icon: 'search',
+          cb: function cb(item) {
+            _this.detailedItem = item;
+          }
+        }],
+        classes: 'table table-striped table-bordered table-responsive',
+        filter: 'field',
+        order: true,
+        pagination: {
+          pageSize: 10
+        }
+      };
+
+      this.formConfig = {
+        exclude: this.config.hiddenFields,
+        fields: {},
+        formName: this.config.resource + 'Form',
+        actions: [{
+          label: 'Save',
+          icon: 'ok',
+          cb: function cb(item) {
+            var p = void 0;
+            var isNew = true;
+
+            if (item.id) {
+              p = item.$update();
+              isNew = false;
+            } else {
+              p = item.$save();
+            }
+
+            p.then(function (res) {
+              if (isNew) {
+                _this.data.push(angular.copy(res));
+              }
+              delete _this.detailedItem;
+              _this.responseMsg = _this.config.resource + ' with id ' + item.id + ' successfully saved';
+            }).catch(function (err) {
+              _this.responseErr = err.data.detail || 'Error while saving ' + _this.config.resource + ' with id ' + item.id;
+            });
+          },
+          class: 'success'
+        }]
+      };
+
+      this.cleanForm = function () {
+        delete _this.detailedItem;
+      };
+
+      this.createItem = function () {
+        _this.detailedItem = new _this.Resource();
+      };
+
+      this.Resource = $injector.get(this.config.resource);
+
+      var getData = function getData() {
+        _this.Resource.query().$promise.then(function (res) {
+
+          if (!res[0]) {
+            _this.data = res;
+            return;
+          }
+
+          var item = res[0];
+          var props = Object.keys(item);
+
+          _.remove(props, function (p) {
+            return p === 'id' || p === 'validators';
+          });
+
+          // TODO move out cb,  non sense triggering a lot of times
+          if (angular.isArray(_this.config.hiddenFields)) {
+            props = _.difference(props, _this.config.hiddenFields);
+          }
+
+          var labels = props.map(function (p) {
+            return LabelFormatter.format(p);
+          });
+
+          props.forEach(function (p, i) {
+            var fieldConfig = {
+              label: labels[i],
+              prop: p
+            };
+
+            if (angular.isString(item[p]) && typeof item[p] !== 'undefined') {
+              fieldConfig.type = _typeof(item[p]);
+            }
+
+            _this.tableConfig.columns.push(fieldConfig);
+          });
+
+          // build form structure
+          // TODO move in a pure function for testing purposes
+          props.forEach(function (p, i) {
+            _this.formConfig.fields[p] = {
+              label: LabelFormatter.format(labels[i]).replace(':', ''),
+              type: XosFormHelpers._getFieldFormat(item[p])
+            };
+          });
+
+          _this.data = res;
+        });
+      };
+
+      getData();
+    }]
+  });
+})();
+'use strict';
+
 (function () {
   'use strict';