forked from shaba/openuds
Done multi tab forms
Advancing on Transport new/edit (this & network will server as base for other tabs)
This commit is contained in:
parent
fa2335efd4
commit
d46400c1f7
@ -56,11 +56,11 @@ class Transports(ModelHandlerMixin, Handler):
|
||||
'comments': item.comments,
|
||||
'priority': item.priority,
|
||||
'nets_positive': item.nets_positive,
|
||||
'networks': [ {'id': k.id} for k in item.networks.all() ],
|
||||
'deployed_count': item.deployedServices.count(),
|
||||
'type': type_.type(),
|
||||
}
|
||||
|
||||
|
||||
|
||||
class Types(ModelTypeHandlerMixin, Handler):
|
||||
path = 'transports'
|
||||
@ -78,7 +78,7 @@ class Types(ModelTypeHandlerMixin, Handler):
|
||||
'label': ugettext('Priority'),
|
||||
'tooltip': ugettext('Priority of this transport'),
|
||||
'type': 'numeric',
|
||||
'order': 100, # At end
|
||||
'order': -50, # At end
|
||||
})
|
||||
except:
|
||||
raise NotFound('type not found')
|
||||
|
@ -226,7 +226,7 @@ class ModelTypeHandlerMixin(object):
|
||||
'required': True,
|
||||
'label': _('Name'),
|
||||
'tooltip': _('Name of this element'),
|
||||
'order': -2,
|
||||
'order': -100,
|
||||
})
|
||||
# And maybe comments (only if model has this field)
|
||||
if 'comments' in flds:
|
||||
@ -235,7 +235,7 @@ class ModelTypeHandlerMixin(object):
|
||||
'label': _('Comments'),
|
||||
'tooltip': _('Comments for this element'),
|
||||
'length': 256,
|
||||
'order': -1,
|
||||
'order': -99,
|
||||
})
|
||||
return gui
|
||||
|
||||
|
@ -32,7 +32,7 @@
|
||||
'''
|
||||
from __future__ import unicode_literals
|
||||
|
||||
#from django.utils import simplejson
|
||||
#from django.utils import simplejson as json
|
||||
import ujson as json
|
||||
from django import http
|
||||
|
||||
|
@ -13,4 +13,4 @@ class XUACompatibleMiddleware(object):
|
||||
def process_response(self, request, response):
|
||||
if response.get('content-type', '').startswith('text/html'):
|
||||
response['X-UA-Compatible'] = 'IE=edge'
|
||||
return response
|
||||
return response
|
||||
|
@ -145,24 +145,48 @@ gui.connectivity.link = function(event) {
|
||||
onEdit: function(value, event, table, refreshFnc) {
|
||||
gui.connectivity.transports.rest.gui(value.type, function(itemGui){
|
||||
gui.connectivity.transports.rest.item(value.id, function(item) {
|
||||
var form = gui.form.fromFields(itemGui, item);
|
||||
gui.launchModalForm(gettext('Edit transport')+' '+value.name,form, function(form_selector, closeFnc) {
|
||||
var fields = gui.form.read(form_selector);
|
||||
fields.data_type = value.type;
|
||||
fields.nets_positive = false;
|
||||
gui.connectivity.transports.rest.save(fields, function(data) { // Success on put
|
||||
closeFnc();
|
||||
refreshFnc();
|
||||
}, gui.failRequestModalFnc(gettext('Error creating transport')) // Fail on put, show modal message
|
||||
);
|
||||
return false;
|
||||
});
|
||||
var tabs = {
|
||||
tabs: [
|
||||
{
|
||||
title: 'General',
|
||||
fields: itemGui,
|
||||
},
|
||||
{
|
||||
title: 'Networks',
|
||||
fields: [],
|
||||
},
|
||||
]
|
||||
};
|
||||
var form = gui.form.fromFields(tabs, item);
|
||||
gui.launchModalForm(gettext('Edit transport')+' '+value.name,form, function(form_selector, closeFnc) {
|
||||
var fields = gui.form.read(form_selector);
|
||||
fields.data_type = value.type;
|
||||
fields.nets_positive = false;
|
||||
gui.connectivity.transports.rest.save(fields, function(data) { // Success on put
|
||||
closeFnc();
|
||||
refreshFnc();
|
||||
}, gui.failRequestModalFnc(gettext('Error creating transport')) // Fail on put, show modal message
|
||||
);
|
||||
return false;
|
||||
});
|
||||
});
|
||||
});
|
||||
},
|
||||
onNew: function(type, table, refreshFnc) {
|
||||
gui.connectivity.transports.rest.gui(type, function(itemGui) {
|
||||
var form = gui.form.fromFields(itemGui);
|
||||
var tabs = {
|
||||
tabs: [
|
||||
{
|
||||
title: 'General',
|
||||
fields: itemGui,
|
||||
},
|
||||
{
|
||||
title: 'Networks',
|
||||
fields: [],
|
||||
},
|
||||
]
|
||||
};
|
||||
var form = gui.form.fromFields(tabs);
|
||||
gui.launchModalForm(gettext('New transport'), form, function(form_selector, closeFnc) {
|
||||
var fields = gui.form.read(form_selector);
|
||||
// Append "own" fields, in this case data_type
|
||||
|
@ -38,7 +38,16 @@
|
||||
var form = '<form class="form-horizontal" role="form">' +
|
||||
'<input type="hidden" name="id" class="modal_field_data" value="' + item.id + '">';
|
||||
if( fields.tabs ) {
|
||||
|
||||
var id = 'tab-' + Math.random().toString().split('.')[1]; // Get a random base ID for tab entries
|
||||
var tabs = [];
|
||||
var tabsContent = [];
|
||||
var active = ' active in' ;
|
||||
$.each(fields.tabs, function(index, tab){
|
||||
tabsContent.push('<div class="tab-pane fade' + active + '" id="' + id + index + '">' + gui.fieldsToHtml(tab.fields, item) + '</div>' );
|
||||
tabs.push('<li><a href="#' + id + index + '" data-toggle="tab">' + tab.title + '</a></li>' );
|
||||
active = '';
|
||||
});
|
||||
form += '<ul class="nav nav-tabs">' + tabs.join('\n') + '</ul><div class="tab-content">' + tabsContent.join('\n') + '</div>';
|
||||
} else {
|
||||
form += gui.fieldsToHtml(fields, item, editing);
|
||||
}
|
||||
|
@ -119,7 +119,7 @@
|
||||
};
|
||||
|
||||
gui.launchModalForm = function(title, form, onSuccess) {
|
||||
var id = Math.random().toString().split('.')[1]; // Get a random ID for this modal
|
||||
var id = 'modal-' + Math.random().toString().split('.')[1]; // Get a random ID for this modal
|
||||
gui.appendToWorkspace(gui.modal(id, title, form));
|
||||
id = '#' + id; // for jQuery
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user