Source

trac-ticketlinks / trac / ticket / templates / ticket.html

Full commit
athomas 6d98c26 



jruigrok a76fd71 
athomas 6d98c26 
rblank 619cfcb 

athomas 6d98c26 


rblank 7a81ef7 


athomas 6d98c26 
cboos 3a11514 
cboos 5c0da47 
cboos bdb82ce 
rblank 6aba6f8 
cmlenz 586003c 
rblank ae56373 







cboos d758c82 

rblank ae56373 






rblank 619cfcb 
cboos 7b08375 
cboos e407fb9 
ecarter b9ad911 
cboos 38c80a1 
ecarter a6c1494 
athomas 6d98c26 
ecarter a6c1494 
cboos b0b4b3e 

ecarter a6c1494 
athomas 6d98c26 
ecarter a6c1494 
athomas 6d98c26 
cboos 3a11514 

cboos 5c0da47 
cboos 3a11514 
rblank 619cfcb 

cboos 51093ae 
rblank 619cfcb 

athomas 6d98c26 




cboos 2c2560c 
cboos 7c31f67 
cboos 2c2560c 

cboos e407fb9 
rblank 637bb3e 







cboos f1c5dcc 
rblank 3968d2b 
rblank 619cfcb 



cboos 44ca684 

athomas 6d98c26 

cboos 305f87c 
athomas 6d98c26 
rblank a68d380 
athomas 6d98c26 

rblank a68d380 
athomas 6d98c26 

rblank 619cfcb 



athomas 6d98c26 

rblank 7a81ef7 
athomas 6d98c26 
cboos 3fd5b7c 

cmlenz 586003c 
rblank 6cc059e 

athomas 6d98c26 

rblank 619cfcb 

athomas 6d98c26 
rblank 2b4abdb 






rblank 7a81ef7 
cboos 7c31f67 

cboos ef20597 
cboos 7c31f67 
cboos ef20597 

athomas 6d98c26 


cboos fe457e1 
cboos e485219 


cboos fe457e1 
athomas 6d98c26 




cboos 5dca0d6 
athomas 6d98c26 
rblank 2b4abdb 
cboos 64c521d 


cboos d758c82 
cboos 64c521d 

cboos d758c82 

rblank 2b4abdb 
rblank 734dcec 
cboos d758c82 
rblank 734dcec 

cboos e407fb9 
rblank 7a81ef7 
rblank 01a01ea 










cboos d758c82 

rblank 01a01ea 

cboos d758c82 

rblank 01a01ea 

cboos d758c82 

rblank 01a01ea 
rblank b32eb29 
athomas 6d98c26 
rblank 734dcec 
athomas 6d98c26 
rblank 619cfcb 
athomas 6d98c26 
cboos 3fd5b7c 
athomas 6d98c26 
rblank 619cfcb 



rblank ae56373 
rblank 619cfcb 
cboos e407fb9 
rblank 619cfcb 









rblank 9bdbe05 
rblank 619cfcb 
athomas 6d98c26 
rblank fa85bd1 
rblank 8c3f8c1 

rblank fa85bd1 
rblank ae56373 





rblank cc6c721 
rblank ae56373 
rblank 7a81ef7 
rblank ae56373 
athomas 6d98c26 
rblank 637bb3e 
rblank 619cfcb 



rblank 637bb3e 


























cboos 2d68d06 



cboos d758c82 

cboos 2d68d06 

rblank 637bb3e 


rblank d6507da 
rblank 637bb3e 





cboos fe457e1 

rblank 637bb3e 







rblank 111920a 
rblank 637bb3e 




rblank 111920a 
rblank 637bb3e 



rblank 9bdbe05 
rblank 637bb3e 











































cboos d758c82 

rblank 637bb3e 










athomas 6d98c26 
rblank 637bb3e 

athomas 6d98c26 
rblank 619cfcb 

rblank 9e5352f 
cboos 8e2aad5 

rblank 619cfcb 











rblank cc6c721 
rblank 619cfcb 




cboos 88b90f9 
athomas 6d98c26 
cboos d54c6dc 
athomas 6d98c26 


rblank 619cfcb 
rblank 1d12d91 


athomas 6d98c26 
cmlenz 26600b4 




jruigrok 13a2850 
jruigrok f09f8e4 
athomas 6d98c26 



jruigrok c8af570 
athomas 6d98c26 





  1
  2
  3
  4
  5
  6
  7
  8
  9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31
 32
 33
 34
 35
 36
 37
 38
 39
 40
 41
 42
 43
 44
 45
 46
 47
 48
 49
 50
 51
 52
 53
 54
 55
 56
 57
 58
 59
 60
 61
 62
 63
 64
 65
 66
 67
 68
 69
 70
 71
 72
 73
 74
 75
 76
 77
 78
 79
 80
 81
 82
 83
 84
 85
 86
 87
 88
 89
 90
 91
 92
 93
 94
 95
 96
 97
 98
 99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
<!DOCTYPE html
    PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN"
    "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml"
      xmlns:xi="http://www.w3.org/2001/XInclude"
      xmlns:py="http://genshi.edgewall.org/"
      xmlns:i18n="http://genshi.edgewall.org/i18n"
      py:with="preview_mode = 'preview' in req.args">
  <xi:include href="layout.html" />

  <head>
    <title py:choose="">
      <py:when test="ticket.exists">#${ticket.id} (${ticket.summary})</py:when>
      <py:otherwise>New Ticket</py:otherwise>
    </title>
    <script type="text/javascript" py:choose="">
      jQuery(document).ready(function($) {
        $("div.description").find("h1,h2,h3,h4,h5,h6").addAnchor(_("Link to this section"));
        $(".foldable").enableFolding(false, true);
      <py:when test="ticket.exists">
        var args = {realm: "ticket", id: ${ticket.id}, escape_newlines: ${int(preserve_newlines)}}
        $("#comment").autoPreview("${href.wiki_render()}", args, function(textarea, text, rendered) {
            $("#ticketchange div.comment").html(rendered);
            if (rendered)
              $("#ticketchange").show();
            else if ($("#ticketchange ul.changes").length == 0)
              $("#ticketchange").hide();
        });
        $("#trac-comment-editor textarea").autoPreview("${href.wiki_render()}", args,
                                                       function(textarea, text, rendered) {
          var comment = $("#trac-comment-editor").next("div.comment");
          comment.html(rendered);
          if (rendered)
            comment.show();
          else
            comment.hide();
        });
        $("#modify").parent().toggleClass("collapsed");
        $(".trac-topnav a").click(function() { $("#modify").parent().removeClass("collapsed"); });

        /* only enable control elements for the currently selected action */
        var actions = $("#action input[name='action']");

        function updateActionFields() {
          actions.each(function () {
            $(this).siblings().find("*[id]").enable($(this).checked());
            $(this).siblings().filter("*[id]").enable($(this).checked());
          });
        }
        actions.click(updateActionFields);
        updateActionFields();
      </py:when>
      <py:otherwise>
        $("#field-summary").focus();
      </py:otherwise>
      <py:if test="preview_mode">
        $("#changelog").parent().toggleClass("collapsed");
        $("#attachments").toggleClass("collapsed");
        $("#trac-add-comment").scrollToTop();
      </py:if>
      });
    </script>
  </head>

  <body>
    <py:def function="commentref(prefix, cnum)">
      <a href="#comment:$cnum">$prefix$cnum</a>
    </py:def>

    <div id="content" class="ticket"
         py:with="can_append = 'TICKET_APPEND' in perm(ticket.resource);
                  can_create = 'TICKET_CREATE' in perm(ticket.resource) and not ticket.exists;
                  can_modify = 'TICKET_CHGPROP' in perm(ticket.resource);
                  can_edit = 'TICKET_EDIT_DESCRIPTION' in perm(ticket.resource);
                  only_for_admin = 'TICKET_ADMIN' in perm(ticket.resource);
                  has_edit_comment = 'TICKET_EDIT_COMMENT' in perm(ticket.resource);
                  has_property_editor = not version and version != 0 and not cnum_edit
                                        and (can_append or can_modify or can_edit or can_create)">
      <div class="trac-topnav" py:if="(ticket.exists or preview_mode) and has_property_editor">
        <a href="#propertyform" title="Go to the ticket editor">Modify</a> &darr;
      </div>
      <h1 id="trac-ticket-title" py:choose="">
        <py:when test="ticket.exists">
          <a href="${href.ticket(ticket.id)}">Ticket #${ticket.id}</a>
          <span class="status">(${ticket.status}<py:if
              test="ticket.type"> ${ticket.type}</py:if><py:if
              test="ticket.resolution">: ${ticket.resolution}</py:if>)</span>
          <py:choose test="">
            <py:when test="version is None" />
            <py:when test="version == 0">
              &mdash; <i18n:msg>at <a href="#comment:description">Initial Version</a></i18n:msg>
            </py:when>
            <py:otherwise>
              &mdash; <i18n:msg params="version">at <a href="#comment:$version">Version $version</a></i18n:msg>
            </py:otherwise>
          </py:choose>
        </py:when>
        <py:otherwise>
          Create New Ticket <span py:if="preview_mode and ticket.type" class="status">(${ticket.type})</span>
        </py:otherwise>
      </h1>

      <xi:include href="ticket_box.html" py:if="ticket.exists or preview_mode"/>

      <py:if test="ticket.exists">
        <!--! do not show attachments for old versions of this ticket or for new tickets -->
        <py:if test="not version and version != 0 and ticket.exists">
          <xi:include href="list_of_attachments.html"
                      py:with="alist = attachments; foldable = True"/>
        </py:if>

        <div py:if="ticket.exists and changes">
          <h2 class="foldable">Change History</h2>
          <div id="changelog">
            <py:for each="change in changes"
                    py:with="can_edit_comment = has_edit_comment or (authname and authname != 'anonymous'
                                                                     and authname == change.author);
                             show_editor = can_edit_comment and str(change.cnum) == cnum_edit;
                             show_history = str(change.cnum) == cnum_hist;
                             max_version = max(change.comment_history);
                             comment_version = (max_version, int(cversion or 0))[show_history]">
              <div class="change" id="${'cnum' in change and 'trac-change-%d' % change.cnum or None}">
                <h3 class="change">
                  <span class="threading" py:if="'cnum' in change"
                        py:with="change_replies = replies.get(str(change.cnum), [])">
                    <span id="comment:$change.cnum" class="cnum">${commentref('comment:', change.cnum)}</span>
                    <py:if test="change_replies or 'replyto' in change">
                      <py:if test="'replyto' in change">
                        in reply to: ${commentref('&uarr;&nbsp;', change.replyto)}
                        <py:if test="change_replies">; </py:if>
                      </py:if>
                      <py:if test="change_replies">
                        <i18n:choose numeral="len(change_replies)">
                          <span i18n:singular="">follow-up:</span>
                          <span i18n:plural="">follow-ups:</span>
                        </i18n:choose>
                        <py:for each="reply in change_replies">
                          ${commentref('&darr;&nbsp;', reply)}
                        </py:for></py:if>
                    </py:if>
                  </span>
                  <i18n:msg params="date, author">Changed ${dateinfo(change.date)} ago by ${authorinfo(change.author)}</i18n:msg>
                </h3>
                <py:if test="not show_editor and comment_version == max_version">
                  <form py:if="'cnum' in change and can_edit_comment" method="get" action="#comment:${change.cnum}">
                    <div class="inlinebuttons">
                      <input type="hidden" name="cnum_edit" value="${change.cnum}"/>
                      <input type="submit" value="${_('Edit')}" title="${_('Edit comment %(cnum)s', cnum=change.cnum)}"/>
                    </div>
                  </form>
                  <form py:if="'cnum' in change and can_append" id="reply-to-comment-${change.cnum}"
                        method="get" action="#comment">
                    <div class="inlinebuttons">
                      <input type="hidden" name="replyto" value="${change.cnum}"/>
                      <input type="submit" value="${_('Reply')}" title="${_('Reply to comment %(cnum)s', cnum=change.cnum)}"/>
                    </div>
                  </form>
                </py:if>
                <xi:include href="ticket_change.html"/>
                <div py:if="not show_editor and len(change.comment_history) > 1" py:choose=""
                     class="trac-lastedit ${comment_version != max_version and 'trac-shade' or None}">
                  <i18n:msg params="version, date, author" py:when="comment_version != max_version">
                      Version ${comment_version}, edited ${dateinfo(change.comment_history[comment_version].date)} ago
                      by ${authorinfo(change.comment_history[comment_version].author)}
                  </i18n:msg>
                  <i18n:msg params="date, author" py:otherwise="">
                      Last edited ${dateinfo(change.comment_history[comment_version].date)} ago
                      by ${authorinfo(change.comment_history[comment_version].author)}
                  </i18n:msg>
                  <py:if test="comment_version > 0">
                    (<a href="${href.ticket(ticket.id, cnum_hist=change.cnum, cversion=comment_version - 1)
                               }#comment:${change.cnum}">previous</a>)
                  </py:if>
                  <py:if test="comment_version &lt; max_version">
                    (<a href="${href.ticket(ticket.id, cnum_hist=change.cnum, cversion=comment_version + 1)
                               }#comment:${change.cnum}">next</a>)
                  </py:if>
                  <py:if test="comment_version > 0">
                    (<a href="${href.ticket(ticket.id, action='comment-diff', cnum=change.cnum, 
                                            version=comment_version)}">diff</a>)
                  </py:if>
                </div>
              </div>
            </py:for>
          </div>
        </div>
      </py:if>
      <!--! End of the section we don't show on initial new tickets -->

      <form py:if="has_property_editor" method="post" id="propertyform"
            action="${ticket.exists and href.ticket(ticket.id) + '#trac-add-comment' or href.newticket()}">
        <!--! Add comment -->
        <div py:if="ticket.exists and can_append" class="field"
             py:with="show_comment_preview = (change_preview.fields or change_preview.comment) and cnum_edit is None">
          <div class="trac-nav">
            <a href="#content" title="View ticket fields and description">View</a> &uarr;
          </div>
          <h2 id="trac-add-comment">
            <a id="edit" onfocus="$('#comment').get(0).focus()">Add a comment</a>
          </h2>
          <!--! Comment field -->
          <fieldset class="iefix">
            <label for="comment" i18n:msg="">You may use
              <a tabindex="42" href="${href.wiki('WikiFormatting')}">WikiFormatting</a>
              here.
            </label>
            <textarea id="comment" name="comment" class="wikitext trac-resizable" rows="10" cols="78">
${comment}</textarea>
          </fieldset>
          <div py:if="preview_mode and chrome.warnings" i18n:msg="" class="warning system-message">
            Warnings are shown at the <a href="#warning">top of the page</a>. The ticket validation
            may have failed.
          </div>
          <!--! Preview of ticket changes -->
          <div id="ticketchange" class="ticketdraft" style="${not show_comment_preview and 'display: none' or None}">
            <h3 class="change" id="${'cnum' in change_preview and 'comment:%d' % change_preview.cnum or None}">
              <span class="threading" py:if="'replyto' in change_preview">
                in reply to: ${commentref('&uarr;&nbsp;', change_preview.replyto)}
              </span>
              <i18n:msg params="author">Changed by ${authorinfo(change_preview.author)}</i18n:msg>
            </h3>
            <xi:include href="ticket_change.html" py:with="change = change_preview"/>
          </div>
        </div>

        <div>
          <h2 py:if="ticket.exists" class="foldable">Modify Ticket</h2>
          <div id="modify">
            <!--! Properties -->
            <fieldset id="properties" py:if="can_modify or can_edit or can_create"
                      py:with="fields = [f for f in fields if not f.skip]">
              <legend py:choose="">
                  <py:when test="ticket.exists">Change Properties</py:when>
                  <py:otherwise>Properties</py:otherwise>
              </legend>
              <table>
                <tr py:if="can_modify or can_create">
                  <th><label for="field-summary">Summary:</label></th>
                  <td class="fullrow" colspan="3">
                    <input type="text" id="field-summary" name="field_summary"
                           value="$ticket.summary" size="70" />
                  </td>
                </tr>
                <py:if test="only_for_admin">
                  <tr>
                    <th><label for="field-reporter">Reporter:</label></th>
                    <td class="fullrow" colspan="3">
                      <input type="text" id="field-reporter" name="field_reporter"
                             value="${ticket.reporter}" size="70" />
                    </td>
                  </tr>
                </py:if>
                <py:if test="can_edit or can_create">
                  <tr>
                    <th><label for="field-description">Description:</label></th>
                    <td class="fullrow" colspan="3">
                      <fieldset class="iefix">
                        <label for="field-description" id="field-description-help" i18n:msg="">You may use
                          <a tabindex="42" href="${href.wiki('WikiFormatting')}">WikiFormatting</a> here.
                        </label>
                        <textarea id="field-description" name="field_description"
                                  class="wikitext trac-resizable" rows="10" cols="68">
${ticket.description}</textarea>
                      </fieldset>
                    </td>
                  </tr>
                </py:if>
                <tr py:for="row in group(fields, 2, lambda f: f.type != 'textarea')"
                    py:if="can_modify or can_create"
                    py:with="fullrow = len(row) == 1">
                  <py:for each="idx, field in enumerate(row)"
                          py:with="value = ticket.get_value_or_default(field.name)">
                    <th class="col${idx + 1}" py:if="idx == 0 or not fullrow">
                      <label for="field-${field.name}" py:if="field"
                             py:strip="field.type == 'radio'" i18n:msg="field">${
                        field.edit_label or field.label or field.name}:</label>
                    </th>
                    <td class="col${idx + 1}" py:if="idx == 0 or not fullrow"
                        colspan="${fullrow and 3 or None}">
                      <py:choose test="field.type" py:if="field">
                        <select py:when="'select'" id="field-${field.name}" name="field_${field.name}">
                          <option py:if="field.optional"></option>
                          <option py:for="option in field.options"
                                  selected="${value == option or None}"
                                  value="$option" py:content="option"></option>
                          <optgroup py:for="optgroup in field.optgroups"
                                    py:if="optgroup.options"
                                    label="${optgroup.label}">
                            <option py:for="option in optgroup.options"
                                    selected="${value == option or None}"
                                    value="$option" py:content="option"></option>
                          </optgroup>
                        </select>
                        <textarea py:when="'textarea'" id="field-${field.name}" name="field_${field.name}"
                                  cols="${field.width}" rows="${field.height}"
                                  class="${field.format == 'wiki' and 'wikitext ' or None}trac-resizable">
${value}</textarea>
                        <span py:when="'checkbox'">
                          <input type="checkbox" id="field-${field.name}" name="field_${field.name}"
                                 checked="${value == '1' and 'checked' or None}" value="1" />
                          <input type="hidden" name="field_checkbox_${field.name}" value="1" />
                        </span>
                        <label py:when="'radio'"
                               py:for="idx, option in enumerate(field.options)">
                          <input type="radio" name="field_${field.name}" value="${option}"
                                 checked="${value == option or None}" />
                          ${option}
                        </label>
                        <py:otherwise><!--! Text input fields -->
                          <py:choose>
                            <span py:when="field.cc_entry"><!--! Special case for Cc: field -->
                              <em>${field.cc_entry}</em>
                              <input type="checkbox" id="field-cc" name="cc_update"
                                title="This checkbox allows you to add or remove yourself from the CC list."
                                checked="${field.cc_update}" />
                            </span>
                            <!--! Cc: when TICKET_EDIT_CC is allowed -->
                            <span py:when="field.name == 'cc'">
                              <input  type="text" id="field-${field.name}"
                                title="Space or comma delimited email addresses and usernames are accepted."
                                name="field_${field.name}" value="${value}" />
                            </span>
                            <!--! All the other text input fields -->
                            <input py:otherwise="" type="text" id="field-${field.name}"
                              name="field_${field.name}" value="${value}" />
                          </py:choose>
                        </py:otherwise>
                      </py:choose>
                    </td>
                  </py:for>
                </tr>
              </table>
            </fieldset>

            <!--! Workflow support -->
            <py:if test="ticket.exists"> <!--! do not display the actions for New tickets -->
              <py:choose>
                <fieldset py:when="can_append or can_modify" id="action">
                  <legend>Action</legend>
                  <div py:for="key, label, controls, hints in action_controls">
                      <input type="radio" id="action_$key" name="action" value="$key"
                             checked="${key == action or None}" />
                      <label for="action_$key">$label</label>
                      $controls
                      <span class="hint" py:for="hint in hints">$hint</span>
                  </div>
                </fieldset>
                <py:otherwise>
                  <py:for each="key, label, controls, hints in action_controls">
                    <input py:if="key == action" type="hidden" name="action" value="$action" />
                  </py:for>
                </py:otherwise>
              </py:choose>
            </py:if>
          </div>
        </div>

        <!--! Author or Reporter -->
        <div py:if="authname == 'anonymous'" class="field">
          <fieldset py:choose="">
            <legend py:when="ticket.exists">Author</legend>
            <legend py:otherwise="">Reporter</legend>
            <table>
              <tr>
                <th>
                  <label for="author">Your email or username:</label><br />
                </th>
                <td>
                  <input type="text" id="author" name="author" size="40" value="$author_id" />
                  <br />
                </td>
              </tr>
            </table>
            <p py:if="author_id == 'anonymous'" class="hint">
              <i18n:msg>E-mail address and user name can be saved in the <a href="${href.prefs()}">Preferences</a>.</i18n:msg>
            </p>
          </fieldset>
        </div>

        <!--! Attachment on creation checkbox -->
        <p py:if="not ticket.exists and 'ATTACHMENT_CREATE' in perm(ticket.resource.child('attachment'))">
          <label>
            <input type="checkbox" name="attachment" checked="${'attachment' in req.args or None}" />
            I have files to attach to this ticket
          </label>
        </p>

        <div py:if="ticket.exists" class="trac-nav">
          <a href="#attachments" title="Go to the list of attachments">Attachments</a> &uarr;
        </div>
        <div class="buttons">
          <py:if test="ticket.exists">
            <input type="hidden" name="ts" value="${timestamp}" />
            <input type="hidden" name="replyto" value="${replyto}" />
            <input type="hidden" name="cnum" value="${cnum}" />
          </py:if>
          <input type="submit" name="preview" value="${_('Preview')}" accesskey="r" />&nbsp;
          <input type="submit" name="submit" value="${ticket.exists and _('Submit changes') or _('Create ticket')}" />
        </div>

      </form>

      <div id="help" i18n:msg="">
        <strong>Note:</strong> See
        <a href="${href.wiki('TracTickets')}">TracTickets</a> for help on using
        tickets.
      </div>
    </div>
  </body>
</html>