##// END OF EJS Templates
templates: Add an extension point to the authn plugin settings template....
johbo -
r88:8177bcae default
parent child Browse files
Show More
@@ -1,107 +1,116 b''
1 1 ## -*- coding: utf-8 -*-
2 2 <%inherit file="/base/base.html"/>
3 3
4 4 <%def name="title()">
5 5 ${_('Authentication Settings')}
6 6 %if c.rhodecode_name:
7 7 &middot; ${h.branding(c.rhodecode_name)}}
8 8 %endif
9 9 </%def>
10 10
11 11 <%def name="breadcrumbs_links()">
12 12 ${h.link_to(_('Admin'),h.url('admin_home'))}
13 13 &raquo;
14 14 ${h.link_to(_('Authentication Plugins'),request.resource_path(resource.__parent__, route_name='auth_home'))}
15 15 &raquo;
16 16 ${resource.display_name}
17 17 </%def>
18 18
19 19 <%def name="menu_bar_nav()">
20 20 ${self.menu_items(active='admin')}
21 21 </%def>
22 22
23 23 <%def name="main()">
24 24 <div class="box">
25 25 <div class="title">
26 26 ${self.breadcrumbs()}
27 27 </div>
28 28 <div class='sidebar-col-wrapper'>
29 29
30 30 ## TODO: This is repeated in the auth root template and should be merged
31 31 ## into a single solution.
32 32 <div class="sidebar">
33 33 <ul class="nav nav-pills nav-stacked">
34 34 % for item in resource.get_root().get_nav_list():
35 35 <li ${'class=active' if item == resource else ''}>
36 36 <a href="${request.resource_path(item, route_name='auth_home')}">${item.display_name}</a>
37 37 </li>
38 38 % endfor
39 39 </ul>
40 40 </div>
41 41
42 42 <div class="main-content-full-width">
43 43 <div class="panel panel-default">
44 44 <div class="panel-heading">
45 45 <h3 class="panel-title">${_('Plugin')}: ${resource.display_name}</h3>
46 46 </div>
47 47 <div class="panel-body">
48 48 <div class="plugin_form">
49 49 <div class="fields">
50 50 ${h.secure_form(request.resource_path(resource, route_name='auth_home'))}
51 51 <div class="form">
52
52 53 %for node in plugin.get_settings_schema():
53 54 <% label_css_class = ("label-checkbox" if (node.widget == "bool") else "") %>
54 55 <div class="field">
55 56 <div class="label ${label_css_class}"><label for="${node.name}">${node.title}</label></div>
56 57 <div class="input">
57 58 %if node.widget in ["string", "int", "unicode"]:
58 59 ${h.text(node.name, node.default, class_="medium")}
59 60 %elif node.widget == "password":
60 61 ${h.password(node.name, node.default, class_="medium")}
61 62 %elif node.widget == "bool":
62 63 <div class="checkbox">${h.checkbox(node.name, node.default)}</div>
63 64 %elif node.widget == "select":
64 65 ${h.select(node.name, node.default, node.validator.choices)}
65 66 %elif node.widget == "readonly":
66 67 ${node.default}
67 68 %else:
68 69 This field is of type ${node.typ}, which cannot be displayed. Must be one of [string|int|bool|select].
69 70 %endif
70 71 %if node.name in errors:
71 72 <span class="error-message">${errors.get(node.name)}</span>
72 73 <br />
73 74 %endif
74 75 <p class="help-block">${node.description}</p>
75 76 </div>
76 77 </div>
77 78 %endfor
79
80 ## Allow derived templates to add something below the form
81 ## input fields
82 %if hasattr(next, 'below_form_fields'):
83 ${next.below_form_fields()}
84 %endif
85
78 86 <div class="buttons">
79 87 ${h.submit('save',_('Save'),class_="btn")}
80 88 </div>
89
81 90 </div>
82 91 ${h.end_form()}
83 92 </div>
84 93 </div>
85 94 </div>
86 95 </div>
87 96 </div>
88 97
89 98 </div>
90 99 </div>
91 100 </%def>
92 101
93 102 ## TODO: Ugly hack to get ldap select elements to work.
94 103 ## Find a solution to integrate this nicely.
95 104 <script>
96 105 $(document).ready(function() {
97 106 var select2Options = {
98 107 containerCssClass: 'drop-menu',
99 108 dropdownCssClass: 'drop-menu-dropdown',
100 109 dropdownAutoWidth: true,
101 110 minimumResultsForSearch: -1
102 111 };
103 112 $("#tls_kind").select2(select2Options);
104 113 $("#tls_reqcert").select2(select2Options);
105 114 $("#search_scope").select2(select2Options);
106 115 });
107 116 </script>
General Comments 0
You need to be logged in to leave comments. Login now