webui: add segments on topology graph page

https://fedorahosted.org/freeipa/ticket/4286

Reviewed-By: Martin Babinsky <mbabinsk@redhat.com>
This commit is contained in:
Petr Vobornik 2015-11-06 18:06:48 +01:00
parent 68f6c2c7dc
commit eb242ac9a9
2 changed files with 151 additions and 4 deletions

View File

@ -3004,8 +3004,14 @@ exp.state_evaluator = IPA.state_evaluator = function(spec) {
*/ */
that.init = function(facet) { that.init = function(facet) {
if (that.event_name && facet[that.event_name]) { if (!that.event_name) return;
if (facet[that.event_name] && facet[that.event_name].attach) {
// facets based on facet.facet
facet[that.event_name].attach(that.on_event); facet[that.event_name].attach(that.on_event);
} else if (facet.emit) {
// facets based on facet/Facet
on(facet, that.event_name, that.on_event);
} }
}; };

View File

@ -27,13 +27,14 @@ define([
'./facets/HeaderMixin', './facets/HeaderMixin',
'./facets/Facet', './facets/Facet',
'./topology_graph', './topology_graph',
'./navigation',
// plain imports // plain imports
'./search', './search',
'./entity'], './entity'],
function(lang, declare, Evented, Stateful, Deferred, on, all, when, function(lang, declare, Evented, Stateful, Deferred, on, all, when,
builder, IPA, $, menu, metadata_provider, phases, reg, rpc, builder, IPA, $, menu, metadata_provider, phases, reg, rpc,
text, mod_details, mod_facet, mod_field, ActionMixin, text, mod_details, mod_facet, mod_field, ActionMixin,
HeaderMixin, Facet, topology_graph) { HeaderMixin, Facet, topology_graph, navigation) {
/** /**
* Topology module * Topology module
* @class * @class
@ -344,6 +345,35 @@ topology.domainlevel_set_action = function(spec) {
return that; return that;
}; };
/**
* Sets 'managed-topology' state if topology is managed
* @class
* @extends facet.state_evaluator
*/
topology.managed_topology_evaluator = function(spec) {
spec = spec || {};
spec.event = spec.event || 'show';
var that = IPA.state_evaluator(spec);
that.name = spec.name || 'state_evaluator';
that.on_event = function() {
var old_state = that.state;
that.state = [];
if (IPA.domain_level >= topology.required_domain_level) {
that.state.push('managed-topology');
}
that.notify_on_change(old_state);
};
return that;
};
topology.topology_graph_facet_spec = { topology.topology_graph_facet_spec = {
name: 'topology-graph', name: 'topology-graph',
@ -352,12 +382,17 @@ topology.topology_graph_facet_spec = {
tab_label: 'Topology Graph', tab_label: 'Topology Graph',
facet_groups: [topology.search_facet_group], facet_groups: [topology.search_facet_group],
facet_group: 'search', facet_group: 'search',
actions: ['refresh'], actions: ['refresh', 'segment_add'],
control_buttons: [ control_buttons: [
{ {
name: 'refresh', name: 'refresh',
label: '@i18n:buttons.refresh', label: '@i18n:buttons.refresh',
icon: 'fa-refresh' icon: 'fa-refresh'
},
{
name: 'segment_add',
label: '@i18n:buttons.add',
icon: 'fa-plus'
} }
], ],
widgets: [ widgets: [
@ -371,7 +406,12 @@ topology.topology_graph_facet_spec = {
$type: 'topology-graph', $type: 'topology-graph',
name: 'topology-graph' name: 'topology-graph'
} }
] ],
state: {
evaluators: [
topology.managed_topology_evaluator
]
}
}; };
/** /**
@ -396,6 +436,106 @@ topology.TopologyGraphFacet = declare([Facet, ActionMixin, HeaderMixin], {
} }
}); });
/**
* Shows topology segment adder dialog with suffix select
*
* @class topology.add_segment_action
* @extends IPA.action
*/
topology.add_segment_action = function(spec) {
spec = spec || {};
spec.name = spec.name || 'segment_add';
spec.method = spec.method || 'add';
spec.enable_cond = spec.enable_cond || ['managed-topology'];
var that = IPA.action(spec);
that.execute_action = function(facet, on_success, on_error) {
that.facet = facet;
var entity = reg.entity.get('topologysegment');
var title = text.get('@i18n:dialogs.add_title');
var label = entity.metadata.label_singular;
title = title.replace('${entity}', label);
var dialog = IPA.entity_adder_dialog({
entity: 'topologysegment',
title: title,
fields: [
{
name: 'cn',
required: false
},
{
$type: 'entity_select',
name: 'suffix',
label: '@mo:topologysuffix.label_singular',
other_entity: 'topologysuffix',
other_field: 'cn',
z_index: 3,
required: true
},
{
$type: 'entity_select',
name: 'iparepltoposegmentleftnode',
other_entity: 'server',
other_field: 'cn',
z_index: 2
},
{
$type: 'entity_select',
name: 'iparepltoposegmentrightnode',
other_entity: 'server',
other_field: 'cn',
z_index: 1
}
]
});
dialog.added.attach(that.on_success);
dialog.show_edit_page = function(entity, result) {
var suffix = this.fields.get_field('suffix').save()[0];
var cn = result.cn[0];
navigation.show_entity(entity.name, 'default', [suffix, cn]);
};
dialog.create_add_command = function(record) {
var args = [this.fields.get_field('suffix').save()[0]];
var cn = this.fields.get_field('cn').save()[0];
if (cn) args.push(cn);
var options = {
'iparepltoposegmentleftnode':
this.fields.get_field('iparepltoposegmentleftnode').save()[0],
'iparepltoposegmentrightnode':
this.fields.get_field('iparepltoposegmentrightnode').save()[0]
};
var command = rpc.command({
entity: this.entity.name,
method: this.method,
retry: this.retry,
args: args,
options: options
});
return command;
};
dialog.open();
};
that.on_success = function(data) {
IPA.notify_success(data.result.summary);
that.facet.refresh();
};
return that;
};
/** /**
* Graph widget encapsulates and supply data to graph component * Graph widget encapsulates and supply data to graph component
@ -704,6 +844,7 @@ topology.register = function() {
e.register({type: 'domainlevel', spec: topology.domainlevel_spec}); e.register({type: 'domainlevel', spec: topology.domainlevel_spec});
a.register('domainlevel_set', topology.domainlevel_set_action); a.register('domainlevel_set', topology.domainlevel_set_action);
a.register('segment_add', topology.add_segment_action);
w.register('topology-graph', topology.TopologyGraphWidget); w.register('topology-graph', topology.TopologyGraphWidget);
fa.register({ fa.register({