Show More
plugin_settings.mako
132 lines
| 4.6 KiB
| application/x-mako
|
MakoHtmlLexer
r1282 | ## -*- coding: utf-8 -*- | |||
<%inherit file="/base/base.mako"/> | ||||
<%def name="title()"> | ||||
${_('Authentication Settings')} | ||||
%if c.rhodecode_name: | ||||
· ${h.branding(c.rhodecode_name)}} | ||||
%endif | ||||
</%def> | ||||
<%def name="breadcrumbs_links()"> | ||||
r1758 | ${h.link_to(_('Admin'),h.route_path('admin_home'))} | |||
r1282 | » | |||
${h.link_to(_('Authentication Plugins'),request.resource_path(resource.__parent__, route_name='auth_home'))} | ||||
» | ||||
${resource.display_name} | ||||
</%def> | ||||
<%def name="menu_bar_nav()"> | ||||
${self.menu_items(active='admin')} | ||||
</%def> | ||||
<%def name="main()"> | ||||
<div class="box"> | ||||
<div class="title"> | ||||
${self.breadcrumbs()} | ||||
</div> | ||||
<div class='sidebar-col-wrapper'> | ||||
## TODO: This is repeated in the auth root template and should be merged | ||||
## into a single solution. | ||||
<div class="sidebar"> | ||||
<ul class="nav nav-pills nav-stacked"> | ||||
% for item in resource.get_root().get_nav_list(): | ||||
<li ${'class=active' if item == resource else ''}> | ||||
<a href="${request.resource_path(item, route_name='auth_home')}">${item.display_name}</a> | ||||
</li> | ||||
% endfor | ||||
</ul> | ||||
</div> | ||||
<div class="main-content-full-width"> | ||||
<div class="panel panel-default"> | ||||
<div class="panel-heading"> | ||||
<h3 class="panel-title">${_('Plugin')}: ${resource.display_name}</h3> | ||||
</div> | ||||
<div class="panel-body"> | ||||
<div class="plugin_form"> | ||||
<div class="fields"> | ||||
r1918 | ${h.secure_form(request.resource_path(resource, route_name='auth_home'), request=request)} | |||
r1282 | <div class="form"> | |||
%for node in plugin.get_settings_schema(): | ||||
r3245 | <% | |||
label_to_type = {'label-checkbox': 'bool', 'label-textarea': 'textarea'} | ||||
%> | ||||
r1282 | <div class="field"> | |||
r3245 | <div class="label ${label_to_type.get(node.widget)}"><label for="${node.name}">${node.title}</label></div> | |||
r1282 | <div class="input"> | |||
%if node.widget in ["string", "int", "unicode"]: | ||||
r3245 | ${h.text(node.name, defaults.get(node.name), class_="large")} | |||
r1282 | %elif node.widget == "password": | |||
r3245 | ${h.password(node.name, defaults.get(node.name), class_="large")} | |||
r1282 | %elif node.widget == "bool": | |||
<div class="checkbox">${h.checkbox(node.name, True, checked=defaults.get(node.name))}</div> | ||||
%elif node.widget == "select": | ||||
r3252 | ${h.select(node.name, defaults.get(node.name), node.validator.choices, class_="select2AuthSetting")} | |||
r3245 | %elif node.widget == "textarea": | |||
<div class="textarea" style="margin-left: 0px">${h.textarea(node.name, defaults.get(node.name), rows=10)}</div> | ||||
r1282 | %elif node.widget == "readonly": | |||
${node.default} | ||||
%else: | ||||
This field is of type ${node.typ}, which cannot be displayed. Must be one of [string|int|bool|select]. | ||||
%endif | ||||
r3245 | ||||
r1282 | %if node.name in errors: | |||
<span class="error-message">${errors.get(node.name)}</span> | ||||
<br /> | ||||
%endif | ||||
r1470 | <p class="help-block pre-formatting">${node.description}</p> | |||
r1282 | </div> | |||
</div> | ||||
%endfor | ||||
## Allow derived templates to add something below the form | ||||
## input fields | ||||
%if hasattr(next, 'below_form_fields'): | ||||
${next.below_form_fields()} | ||||
%endif | ||||
<div class="buttons"> | ||||
${h.submit('save',_('Save'),class_="btn")} | ||||
</div> | ||||
</div> | ||||
${h.end_form()} | ||||
</div> | ||||
</div> | ||||
r3290 | ||||
% if request.GET.get('schema'): | ||||
## this is for development and creation of example configurations for documentation | ||||
<pre> | ||||
% for node in plugin.get_settings_schema(): | ||||
*option*: `${node.name}` => `${defaults.get(node.name)}`${'\n # '.join(['']+node.description.splitlines())} | ||||
% endfor | ||||
</pre> | ||||
% endif | ||||
r1282 | </div> | |||
</div> | ||||
</div> | ||||
</div> | ||||
</div> | ||||
r3290 | ||||
r1282 | <script> | |||
$(document).ready(function() { | ||||
var select2Options = { | ||||
containerCssClass: 'drop-menu', | ||||
dropdownCssClass: 'drop-menu-dropdown', | ||||
dropdownAutoWidth: true, | ||||
minimumResultsForSearch: -1 | ||||
r3252 | }; | |||
$('.select2AuthSetting').select2(select2Options); | ||||
r1282 | }); | |||
</script> | ||||
</%def> | ||||