| Index: appengine/monorail/templates/tracker/field-create-page.ezt
|
| diff --git a/appengine/monorail/templates/tracker/field-create-page.ezt b/appengine/monorail/templates/tracker/field-create-page.ezt
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..1234e02ac252f6019d27754f28029beaf3ed8155
|
| --- /dev/null
|
| +++ b/appengine/monorail/templates/tracker/field-create-page.ezt
|
| @@ -0,0 +1,237 @@
|
| +[define title]Add a Field[end]
|
| +[define category_css]css/ph_detail.css[end]
|
| +[include "../framework/master-header.ezt" "showtabs"]
|
| +
|
| +<a href="/p/[projectname]/adminLabels">‹ Back to field list</a><br><br>
|
| +
|
| +
|
| +<h4>Add a custom field</h4>
|
| +
|
| +<form action="create.do" method="POST">
|
| +<input type="hidden" name="token" value="[form_token]">
|
| +
|
| +<table cellspacing="8" class="rowmajor vt">
|
| + <tr>
|
| + <th width="1%">Name:</th>
|
| + <td>
|
| + <input id="fieldname" name="name" size="30" value="[initial_field_name]" class="acob">
|
| + <span id="fieldnamefeedback" class="fielderror" style="margin-left:1em">
|
| + [if-any errors.field_name][errors.field_name][end]
|
| + </span>
|
| + </td>
|
| + </tr>
|
| +
|
| + <tr>
|
| + <th>Description:</th>
|
| + <td>
|
| + <textarea name="docstring" rows="4" cols="75">[initial_field_docstring]</textarea>
|
| + </td>
|
| + </tr>
|
| +
|
| + <tr>
|
| + <th>Type:</th>
|
| + <td>
|
| + <select id="field_type" name="field_type">
|
| + <option value="enum_type" [is initial_type "enum_type"]selected="selected"[end]>Enum</option>
|
| + <option value="int_type" [is initial_type "int_type"]selected="selected"[end]>Integer</option>
|
| + <option value="str_type" [is initial_type "str_type"]selected="selected"[end]>String</option>
|
| + <option value="user_type" [is initial_type "user_type"]selected="selected"[end]>User</option>
|
| + </select>
|
| + </td>
|
| + </tr>
|
| +
|
| + <tr>
|
| + <th>Applicable:</th>
|
| + <td>When issue type is:
|
| + <select id="applicable_type" name="applicable_type">
|
| + <option value="" [is initial_applicable_type ""]selected="selected"[end]>Anything</option>
|
| + <option disabled="disabled">----</option>
|
| + [for well_known_issue_types]
|
| + <option value="[well_known_issue_types]" [is initial_applicable_type well_known_issue_types]selected="selected"[end]>[well_known_issue_types]</option>
|
| + [end]
|
| + </select>
|
| + [# TODO(jrobbins): AND with free-form applicability predicate.]
|
| + </td>
|
| + </tr>
|
| +
|
| + <tr>
|
| + <th>Required:</th>
|
| + <td>
|
| + <input type="checkbox" id="is_required" name="is_required" class="acob"
|
| + [if-any initial_is_required]checked="checked"[end]>
|
| + <label for="is_required">Required when applicable</label>
|
| + </td>
|
| + </tr>
|
| +
|
| + <tr>
|
| + <th>Multivalued:</th>
|
| + <td>
|
| + <input type="checkbox" name="is_multivalued" class="acob"
|
| + [if-any initial_is_multivalued]checked="checked"[end]>
|
| + </td>
|
| + </tr>
|
| +
|
| + <tr id="choices_row" style="display:none">
|
| + <th>Choices:</th>
|
| + <td>
|
| + <textarea id="choices" name="choices" rows="10" cols="75" style="tab-size:12"
|
| + >[initial_choices]</textarea>
|
| + </td>
|
| + </tr>
|
| +
|
| + <tr id="int_row" style="display:none">
|
| + <th>Validation:</th>
|
| + <td>
|
| + Min value: <input type="number" name="min_value" style="text-align:right; width: 4em">
|
| + Max value: <input type="number" name="max_value" style="text-align:right; width: 4em"><br>
|
| + </td>
|
| + </tr>
|
| +
|
| + <tr id="str_row" style="display:none">
|
| + <th>Validation:</th>
|
| + <td>
|
| + Regex: <input type="text" name="regex" size="30"><br>
|
| + </td>
|
| + </tr>
|
| +
|
| + <tr id="user_row" style="display:none">
|
| + <th>Validation:</th>
|
| + <td>
|
| + <input type="checkbox" name="needs_member" id="needs_member" class="acob"
|
| + [if-any initial_needs_member]checked[end]>
|
| + <label for="needs_member">User must be a project member</label><br>
|
| + <span id="needs_perm_span" style="margin-left:1em">
|
| + Required permission:
|
| + <input type="text" name="needs_perm" id="needs_perm" size="20"
|
| + value="[initial_needs_perm]" class="acob">
|
| + </span><br>
|
| + </td>
|
| + </tr>
|
| + <tr id="user_row2" style="display:none">
|
| + <th>Permissions:</th>
|
| + <td>
|
| + The users named in this field is granted this permission on this issue:<br>
|
| + [# TODO(jrobbins): one-click way to specify View vs. EditIssue vs. any custom perm.]
|
| + <input type="text" name="grants_perm" id="grants_perm" class="acob"
|
| + size="20" value="[initial_grants_perm]" autocomplete="off">
|
| + </td>
|
| + </tr>
|
| + <tr id="user_row3" style="display:none">
|
| + <th>Notification:</th>
|
| + <td>
|
| + The users named in this field will be notified via email whenever:<br>
|
| + <select name="notify_on">
|
| + <option value="never" [is initial_notify_on "0"]selected="selected"[end]
|
| + >No notifications</option>
|
| + <option value="any_comment" [is initial_notify_on "1"]selected="selected"[end]
|
| + >Any change or comment is added</option>
|
| + </select>
|
| + </td>
|
| + </tr>
|
| +
|
| + <th>Admins:</th>
|
| + <td>
|
| + <input id="member_admins" name="admin_names" size="75" value="[initial_admins]"
|
| + autocomplete="off" class="acob">
|
| + <span class="fielderror" style="margin-left:1em">
|
| + [if-any errors.field_admins][errors.field_admins][end]
|
| + </span>
|
| + </td>
|
| + </tr>
|
| +
|
| + <tr>
|
| + <td></td>
|
| + <td>
|
| + <input id="submit_btn" type="submit" name="submit" value="Create field">
|
| + </td>
|
| + </tr>
|
| +
|
| +</table>
|
| +</form>
|
| +
|
| +[include "../framework/footer-script.ezt"]
|
| +
|
| +<script type="text/javascript" nonce="[nonce]">
|
| +runOnLoad(function() {
|
| + _fetchOptions('[projectname]', 'issueOptions',
|
| + CS_env.token, [project.cached_content_timestamp]);
|
| +
|
| + _onload();
|
| + var submit = document.getElementById('submit_btn');
|
| + submit.disabled = 'disabled';
|
| + var fieldname = document.getElementById('fieldname');
|
| + var oldName = '';
|
| + fieldname.focus();
|
| +
|
| + var fieldNameRE = /^[[]a-zA-Z]([[]-_]?[[]a-zA-Z0-9])*$/;
|
| +
|
| + function checkFieldName() {
|
| + name = fieldname.value;
|
| + if (name != oldName) {
|
| + oldName = name;
|
| + feedback = document.getElementById('fieldnamefeedback');
|
| + submit.disabled = 'disabled';
|
| + if (name == '') {
|
| + feedback.innerText = 'Please choose a field name';
|
| + } else if (!fieldNameRE.test(name)) {
|
| + feedback.innerText = 'Invalid field name';
|
| + } else if (name.length > 30) {
|
| + feedback.innerText = 'Field name is too long';
|
| + } else {
|
| + _checkFieldNameOnServer('[projectname]', name, CS_env.token);
|
| + }
|
| + }
|
| + }
|
| +
|
| + setInterval(checkFieldName, 700);
|
| +
|
| + function updateForm(new_type) {
|
| + var choices_row = document.getElementById('choices_row');
|
| + choices_row.style.display = (new_type == 'enum_type') ? '' : 'none';
|
| +
|
| + var int_row = document.getElementById('int_row');
|
| + int_row.style.display = (new_type == 'int_type') ? '' : 'none';
|
| +
|
| + var str_row = document.getElementById('str_row');
|
| + str_row.style.display = (new_type == 'str_type') ? '' : 'none';
|
| +
|
| + var user_row_display = (new_type == 'user_type') ? '' : 'none';
|
| + document.getElementById('user_row').style.display = user_row_display;
|
| + document.getElementById('user_row2').style.display = user_row_display;
|
| + document.getElementById('user_row3').style.display = user_row_display;
|
| + }
|
| +
|
| + var type_select = document.getElementById('field_type');
|
| + updateForm(type_select.value);
|
| + type_select.addEventListener("change", function() {
|
| + updateForm(type_select.value);
|
| + });
|
| +
|
| + var needs_perm_span = document.getElementById('needs_perm_span');
|
| + var needs_perm = document.getElementById('needs_perm');
|
| + function enableNeedsPerm(enable) {
|
| + needs_perm_span.style.color = enable ? 'inherit' : '#999';
|
| + needs_perm.disabled = enable ? '' : 'disabled';
|
| + if (!enable) needs_perm.value = '';
|
| + }
|
| + enableNeedsPerm(false);
|
| +
|
| + var needs_member = document.getElementById("needs_member");
|
| + if (needs_member)
|
| + needs_member.addEventListener("change", function() {
|
| + enableNeedsPerm(needs_member.checked);
|
| + });
|
| +
|
| + var acobElements = document.getElementsByClassName("acob");
|
| + for (var i = 0; i < acobElements.length; ++i) {
|
| + var el = acobElements[[]i];
|
| + el.addEventListener("focus", function(event) {
|
| + _acrob(null);
|
| + _acof(event);
|
| + });
|
| + }
|
| +});
|
| +</script>
|
| +
|
| +
|
| +[include "../framework/master-footer.ezt"]
|
|
|