-
Notifications
You must be signed in to change notification settings - Fork 6
Home
Ingvord edited this page Oct 1, 2017
·
31 revisions
- Go to index.html and download webix library:
- create new file in
resources/tango_webapp
e.g.resources/tango_webapp/device_tree.js
- add newly created file to
resources/tango_webapp/setup.js
:
MVC.Object.extend(TangoWebapp.ui, {
_webix_files: [
"dashboard",
"devices_tree" //<--------
]
});
//...
- start prototyping your component:
/** @module DevicesTree*/
(function(){
var devices_tree = webix.protoUI({...})
})();
- Create application's ui after platform_context.create i.e. in application's main controller do:
//controllers/tango_webapp/main_controller.js
"platform_context.create subscribe": function (event) {
// event.data contains fully properly initialized PlatformContext model
var platform_context = event.data;
webix.ui({
view: 'devices_tree', // custom webix component created above
context: platform_context
} ,0, 'content')
}
- In your component define _ui and $init functions:
//resources/tango_webapp/devices_tree.js
/**
* This function returns ui definition for this component. It can be of any complexity
*
* @private
*/
_ui:function(){
return {
template: 'ui'
};
},
/**
* @param {Object} config a configuration object passed to webix.ui function call
*/
$init: function(config){
webix.extend(config, this._ui());//attach our custom UI to this component
//config.context is a platform_context passed from main_controller, see above
}
JavaScriptMVC provides testing facility. Tests can be unit or functional.
- Create functional test using command line tool:
$/tango_webapp> ./jmvcc jmvc/generate/test functional devices_tree
This creates file in test/functional
. Move it into tango_webapp
if required.
- Add newly created test:
//apps/tango_webapp/test.js
include.functional_test(
"tango_webapp/devices_tree"
);
- Now add some tests:
//test/functional/tango_webapp/devices_tree_test.js
new Test.Functional('devices_tree_test', {
test_open: function () {
webix.ui({
view: 'window',
id: 'devices-tree-test-window',
body: {
view: 'devices_tree',
id: 'devices-tree-test',
//PlatformContext is created automatically during tests setup
//see test/setup.js
context: PlatformContext
}
}).show();
this.assert($$('devices-tree-test').isVisible());
},
//Do some tests
test_close: function () {
$$('devices-tree-test-window').destructor();
this.assert_not($$('device-panel-test'));
}
- Reload application. Make sure your are running it in test mode:
//index.html
<script type="text/javascript" src="jmvc/include.js?tango_webapp,test"></script>
^------------//