diff options
author | Javier Sánchez Parra <jsanchez@soleta.eu> | 2022-08-23 16:15:23 +0200 |
---|---|---|
committer | Javier Sánchez Parra <jsanchez@soleta.eu> | 2022-09-27 09:48:35 +0200 |
commit | 0cc65a057d79e009ea07cd5deb86f84aaf49b537 (patch) | |
tree | dd60712eb744dad501199e917fd476c6c0759da7 /ogcp/views.py | |
parent | 0db56d5eee7d7d73073e904bb41cc1960ec1e29e (diff) |
Add a room to a center using the scopes tree
With this commit users can select a center from the scopes tree, and then
add a room to that center.
Diffstat (limited to 'ogcp/views.py')
-rw-r--r-- | ogcp/views.py | 14 |
1 files changed, 11 insertions, 3 deletions
diff --git a/ogcp/views.py b/ogcp/views.py index af1df47..72a86bb 100644 --- a/ogcp/views.py +++ b/ogcp/views.py @@ -96,7 +96,8 @@ def validate_elements(elements, min_len=1, max_len=float('inf')): return valid def parse_elements(checkboxes_dict): - unwanted_elements = ['csrf_token', 'scope-server', 'scope-room'] + unwanted_elements = ['csrf_token', 'scope-server', 'scope-center', + 'scope-room'] elements = set() for key, elements_list in checkboxes_dict.items(): if key not in unwanted_elements: @@ -1303,10 +1304,17 @@ def action_room_add(): flash(_('Room added successfully'), category='info') return redirect(url_for("scopes")) else: + params = request.args.to_dict() + if not params.get('scope-center'): + flash(_('Please, select one center'), category='error') + return redirect(url_for('scopes')) r = g.server.get('/scopes') + selected_center_id = params['scope-center'] centers = parse_scopes_from_tree(r.json(), 'center') - centers = [(center['id'], center['name']) for center in centers] - form.center.choices = list(centers) + selected_center = [(center['id'], center['name']) for center in centers + if center['id'] == int(selected_center_id)] + form.center.choices = selected_center + form.center.render_kw = {'readonly': True} scopes, clients = get_scopes() return render_template('actions/add_room.html', form=form, scopes=scopes) |