1
0
mirror of https://github.com/kakwa/ldapcherry synced 2024-12-18 10:50:04 +01:00

139 lines
5.6 KiB
Cheetah
Raw Normal View History

2015-06-27 22:35:34 +02:00
## -*- coding: utf-8 -*-
2015-06-10 22:45:04 +02:00
<%
from markupsafe import Markup
2015-06-10 23:30:16 +02:00
len_attr = len(attributes)
switch = len_attr / 2
if not switch * 2 == len_attr:
switch = switch + 1
counter = 1
lc1 = []
lc2 = []
for a in sorted(attributes.keys(), key=lambda attr: attributes[attr]['weight']):
if counter <= switch:
lc1.append(a)
else:
lc2.append(a)
counter = counter + 1
2015-06-10 22:45:04 +02:00
%>
2015-06-10 23:30:16 +02:00
<%def name="form_col(l)">
% for a in l:
2015-05-31 22:38:13 +02:00
<% attr = attributes[a] %>
<div class="form-group">
<div class="input-group">
<%
2015-06-18 23:43:58 +02:00
if modify:
required = ''
else:
required = ' required '
if not values is None and a in values:
2015-06-18 23:43:58 +02:00
if type(values[a]) is list:
2017-03-02 18:47:49 -08:00
raw_value = values[a][0]
2015-06-18 23:43:58 +02:00
else:
2017-03-02 18:47:49 -08:00
raw_value = values[a]
if raw_value is None:
raw_value = ''
value = Markup(' value="{}"').format(raw_value)
value2 = Markup('<option>{}</option>').format(raw_value)
else:
2017-03-02 18:47:49 -08:00
raw_value = ''
value = ''
value2 = ''
2016-06-16 22:11:48 +02:00
if 'default' in attr and value == '':
value = Markup(' value="{}"').format(attr['default'])
%>
2015-06-18 23:43:58 +02:00
<span class="input-group-addon" id="basic-addon-${a}">${attr['display_name']}</span>
% if modify and a == keyattr:
<input type="hidden" id="attr.${a}" name="attr.${a}" class="form-control" autocomplete='off' aria-describedby="basic-addon-${a}" ${required} ${value | n} readonly onfocus="this.removeAttribute('readonly');">
2017-03-02 18:47:49 -08:00
<span class="form-control" aria-describedby="basic-addon-${a}">${raw_value}</span>
% elif attr['type'] == 'string':
<input type="text" id="attr.${a}" name="attr.${a}" class="form-control" autocomplete='off' placeholder="${attr['description']}" aria-describedby="basic-addon-${a}" ${required} ${value | n} readonly onfocus="this.removeAttribute('readonly');">
2015-05-31 22:38:13 +02:00
% elif attr['type'] == 'email':
<input type="email" id="attr.${a}" name="attr.${a}" class="form-control" autocomplete='off' placeholder="${attr['description']}" aria-describedby="basic-addon-${a}" ${required} ${value | n} data-error="email address is invalid" readonly onfocus="this.removeAttribute('readonly');">
2015-05-31 22:38:13 +02:00
% elif attr['type'] == 'int':
<input type="number" id="attr.${a}" name="attr.${a}" class="form-control" autocomplete='off' placeholder="${attr['description']}" aria-describedby="basic-addon-${a}" ${required} ${value | n} readonly onfocus="this.removeAttribute('readonly');">
2015-05-31 22:38:13 +02:00
% elif attr['type'] == 'fix':
<input type="hidden" id="attr.${a}" name="attr.${a}" class="form-control" autocomplete='off' aria-describedby="basic-addon-${a}" ${required} value="${attr['value']}" readonly onfocus="this.removeAttribute('readonly');">
<span class="form-control" placeholder="${attr['description']}" aria-describedby="basic-addon-${a}">${attr['value']}</span>
2015-05-31 22:38:13 +02:00
% elif attr['type'] == 'stringlist':
<select class="form-control" id="attr.${a}" name="attr.${a}">
${value2 | n}
2015-06-02 08:33:46 +02:00
%for val in attr['values']:
%if '<option>' + val + '</option>' != value2:
2015-06-02 08:33:46 +02:00
<option>${val}</option>
%endif
2015-06-02 08:33:46 +02:00
%endfor
</select>
2015-05-31 22:38:13 +02:00
% elif attr['type'] == 'password':
<input type="password" class="form-control" data-ppolicy="ppolicy" name="attr.${a}1" id="${a}1" autocomplete='off' placeholder="${attr['description']}" ${required} readonly onfocus="this.removeAttribute('readonly');">
<span class="input-group-addon" id="basic-addon-${a}2">Retype ${attr['display_name']}</span>
<input type="password" class="form-control" data-match="#${a}1" data-match-error="Passwords don't match" name="attr.${a}2" id="#${a}2" autocomplete='off' placeholder="Confirm" ${required} readonly onfocus="this.removeAttribute('readonly');">
2017-03-02 18:47:49 -08:00
% elif attr['type'] == 'textfield':
<textarea id="attr.${a}" name="attr.${a}" class="form-control" placeholder="${attr['description']}">${raw_value}</textarea>
2015-05-31 22:38:13 +02:00
% endif
</div>
<div class="help-block with-errors"></div>
2015-05-31 22:38:13 +02:00
</div>
2015-06-10 23:30:16 +02:00
% endfor
</%def>
<div class="row">
2017-04-06 00:32:24 +02:00
<div class="col-md-6 column lcform-col-1" style="display:none;">
2015-06-10 23:30:16 +02:00
${form_col(lc1)}
2015-06-10 22:45:04 +02:00
</div>
2017-04-06 00:32:24 +02:00
<div class="col-md-6 column lcform-col-2" style="display:none;">
2015-06-10 23:30:16 +02:00
${form_col(lc2)}
2015-06-10 22:45:04 +02:00
</div>
</div>
2015-07-10 20:11:07 +02:00
% if autofill:
<%
attr_set = []
attr_events = {}
functions = {}
for attrid in attributes:
attr = attributes[attrid]
field = 'attr.' + attrid
if field not in attr_set:
attr_set.append(field)
if 'autofill' in attr:
function = attr['autofill']['function']
tuple = (field, function)
if not tuple in functions:
functions[tuple] = []
for arg in attr['autofill']['args']:
if arg[0] == '$':
field_arg = 'attr.' + arg[1:]
if field_arg not in attr_set:
attr_set.append(field_arg)
functions[tuple].append("fields['" + field_arg + "'].value")
if not field_arg in attr_events:
attr_events[field_arg] = []
attr_events[field_arg].append(tuple)
else:
value = arg
functions[tuple].append("'" + value + "'")
%>
<script>
var fields = new Object();
% for attr in attr_set:
fields['${attr}'] = document.getElementById('${attr}');
% endfor
% for attrid in attr_events:
if (fields['${attrid}'] != null) {
2015-07-08 00:57:03 +02:00
fields['${attrid}'].onchange = function () {
% for tuple in attr_events[attrid]:
if (typeof(${tuple[1]}) == "function") {
fields['${tuple[0]}'].value = ${tuple[1] | n}(${', '.join(functions[tuple]) | n});
}
% endfor
};
};
% endfor
</script>
% endif
<script>
$(document).ready(function() {
$('form:eq(1) *:input[type!=hidden]:first').focus();
});
</script>