2 <script type="text/javascript" language="JavaScript">
3 var filterform_displayed = false;
4 function filter_click()
6 var form = document.getElementById('filterform');
11 if (filterform_displayed) {
12 form.style['display'] = 'none';
13 filterform_displayed = false;
15 form.style['display'] = 'block';
16 filterform_displayed = true;
21 function enable_selected_submitter(select, input)
23 select.name = 'submitter';
26 function filter_form_submit(form)
30 var submitter_select = document.getElementById("submitter_select");
31 var submitter_input = document.getElementById("submitter_input");
32 if (!submitter_select || !submitter_input) {
37 /* submitter handling. if possible, use the select box, otherwise leave
38 * as-is (and so the text box is used). */
40 if (submitter_select.options.length == 0) {
41 /* if there's no match, just use the input */
43 } else if (submitter_select.options.length == 1) {
44 /* if there's only one match, request by id */
45 submitter_select.selectedIndex = 0;
46 enable_selected_submitter(submitter_select, submitter_input);
48 } else if (submitter_select.selectedIndex != -1) {
49 /* if the user has explicitly selected, request by id */
50 enable_selected_submitter(submitter_select, submitter_input);
54 for (i = 0; i < form.elements.length; i++) {
55 var e = form.elements[i];
56 if (e.type == 'submit') {
60 /* handle submitter data */
61 if (e.type == 'select-one') {
65 if (e.selectedIndex != -1
66 && e.options[e.selectedIndex].value == '') {
81 function submitter_complete_response()
83 if (req.readyState != 4) {
88 eval("completions = " + req.responseText);
90 if (completions.length == 0) {
95 var submitter_select = document.getElementById("submitter_select");
96 var submitter_input = document.getElementById("submitter_input");
97 if (!submitter_select || !submitter_input) {
102 for (i = 0; i < completions.length; i++) {
103 name = completions[i]['fields']['name'];
105 name = completions[i]['fields']['name'] +
106 ' <' + completions[i]['fields']['email'] + '>';
108 name = completions[i]['fields']['email'];
110 o = new Option(name, completions[i]['pk']);
111 submitter_select.options[i] = o;
114 /* remove remaining options */
115 for (; i < submitter_select.length; i++) {
116 submitter_select.options[i] = null;
119 submitter_select.disabled = false;
123 function submitter_field_change(field)
126 var value = field.value;
127 if (value.length < 4) {
135 var url = '{% url 'patchwork.views.submitter_complete' %}?q=' + value +
137 req = new XMLHttpRequest();
138 req.onreadystatechange = submitter_complete_response;
139 req.open("GET", url, true);
144 <div class="filters">
145 <div id="filtersummary">
146 <strong><a href="javascript:filter_click()">Filters</a>:</strong>
147 {% if filters.applied_filters %}
148 {% for filter in filters.applied_filters %}
149 {{ filter.name }} = {{ filter.condition }}
150 {% if not filter.forced %}
151 <a href="{{ filter.url_without_me }}"><img
152 width="16" height="16" alt="remove filter" title="remove filter"
153 src="/images/16-circle-blue-remove.png"></a>
155 {% if not forloop.last %} | {% endif %}
159 <a href="javascript:filter_click()"><img
160 width="16" height="16" alt="add filter" title="add filter"
161 src="/images/16-circle-blue-add.png"></a>
164 <div id="filterform" style="padding-top: 1em; display: none">
165 <form action="" method="get" onSubmit="return filter_form_submit(this)">
167 {% for filter in filters.available_filters %}
169 <td>{{ filter.name }}</td>
170 <td>{{ filter.form }}</td>
175 <td><input type="submit" value="Apply"/></td>