3 class DiagramView(openerp.addons.web.controllers.main.View):
4 _cp_path = "/web_diagram/diagram"
6 @openerp.addons.web.http.jsonrequest
7 def get_diagram_info(self, req, id, model, node, connector,
8 src_node, des_node, label, **kw):
10 visible_node_fields = kw.get('visible_node_fields',[])
11 invisible_node_fields = kw.get('invisible_node_fields',[])
12 node_fields_string = kw.get('node_fields_string',[])
13 connector_fields = kw.get('connector_fields',[])
14 connector_fields_string = kw.get('connector_fields_string',[])
18 bgcolor = kw.get('bgcolor','')
19 shape = kw.get('shape','')
22 for color_spec in bgcolor.split(';'):
24 colour, color_state = color_spec.split(':')
25 bgcolors[colour] = color_state
28 for shape_spec in shape.split(';'):
30 shape_colour, shape_color_state = shape_spec.split(':')
31 shapes[shape_colour] = shape_color_state
33 ir_view = req.session.model('ir.ui.view')
34 graphs = ir_view.graph_get(
35 int(id), model, node, connector, src_node, des_node, label,
36 (140, 180), req.session.context)
37 nodes = graphs['nodes']
38 transitions = graphs['transitions']
40 for blnk_node in graphs['blank_nodes']:
41 isolate_nodes[blnk_node['id']] = blnk_node
43 y = map(lambda t: t['y'],filter(lambda x: x['y'] if x['x']==20 else None, nodes.values()))
44 y_max = (y and max(y)) or 120
49 for tr in transitions:
51 connectors.setdefault(tr, {
53 's_id': transitions[tr][0],
54 'd_id': transitions[tr][1]
56 connector_tr = req.session.model(connector)
57 connector_ids = connector_tr.search([('id', 'in', list_tr)], 0, 0, 0, req.session.context)
59 data_connectors =connector_tr.read(connector_ids, connector_fields, req.session.context)
61 for tr in data_connectors:
62 transition_id = str(tr['id'])
63 _sourceid, label = graphs['label'][transition_id]
64 t = connectors[transition_id]
66 source=tr[src_node][1],
67 destination=tr[des_node][1],
72 for i, fld in enumerate(connector_fields):
73 t['options'][connector_fields_string[i]] = tr[fld]
75 fields = req.session.model('ir.model.fields')
76 field_ids = fields.search([('model', '=', model), ('relation', '=', node)], 0, 0, 0, req.session.context)
77 field_data = fields.read(field_ids, ['relation_field'], req.session.context)
78 node_act = req.session.model(node)
79 search_acts = node_act.search([(field_data[0]['relation_field'], '=', id)], 0, 0, 0, req.session.context)
80 data_acts = node_act.read(search_acts, invisible_node_fields + visible_node_fields, req.session.context)
83 n = nodes.get(str(act['id']))
85 n = isolate_nodes.get(act['id'], {})
87 n.update(x=20, y=y_max)
95 for color, expr in bgcolors.items():
99 for shape, expr in shapes.items():
103 for i, fld in enumerate(visible_node_fields):
104 n['options'][node_fields_string[i]] = act[fld]
106 _id, name = req.session.model(model).name_get([id], req.session.context)[0]
107 return dict(nodes=nodes,
110 parent_field=graphs['node_parent_field'])