{#-
       Licensed to the Apache Software Foundation (ASF) under one
       or more contributor license agreements.  See the NOTICE file
       distributed with this work for additional information
       regarding copyright ownership.  The ASF licenses this file
       to you under the Apache License, Version 2.0 (the
       "License"); you may not use this file except in compliance
       with the License.  You may obtain a copy of the License at
         http://www.apache.org/licenses/LICENSE-2.0
       Unless required by applicable law or agreed to in writing,
       software distributed under the License is distributed on an
       "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
       KIND, either express or implied.  See the License for the
       specific language governing permissions and limitations
       under the License.
-#}
{% extends g.theme.master %}
{% do g.register_forge_css('css/forge/hilite.css') %}
{% do g.register_app_css('css/tracker.css') %}
{% block head %}
  <meta name="robots" content="noindex">
{% endblock %}
{% block title %}{{c.project.name}} / {{c.app.config.options.mount_label}} / Search help{% endblock %}
{% block header %}Search help{% endblock %}
{% block content%}
    <div><h1>Searching for tickets</h1>
    <p>Searches use <a href="http://www.solrtutorial.com/solr-query-syntax.html" target="_blank">solr lucene query syntax</a>. Use the following fields in tracker ticket searches:</p>
    <ul>
    <li>User who owns the ticket - assigned_to</li>
    <li>Labels assigned to the ticket - labels</li>
    <li>Milestone the ticket is assigned to - _milestone</li>
    <li>Last modified date - mod_date</li>
    <li>Created date - created_date</li>
    <li>Body of the ticket - text</li>
    <li>Number of ticket - ticket_num</li>
    <li>User who created the ticket - reported_by</li>
    <li>Status of the ticket - status</li>
    <li>Title of the ticket - summary</li>
    <li>Private ticket - private</li>
    <li>Discussion Disabled ticket - discussion_disabled</li>
    <li>Votes up/down of the ticket - votes_up/votes_down (if enabled in tool options)</li>
    <li>Votes total of the ticket - votes_total</li>
    <li>Imported legacy id - import_id</li>
    {% if custom_fields %}
    <li>Custom fields:
        <ul>
        {% for field in custom_fields %}
            <li>{{field.name}}</li>
        {% endfor %}
        </ul>
    </li>
    {% endif %}
    </ul>
    <h2>Example searches</h2>
    <p>Any ticket that is not closed in the 1.0 milestone with "foo" in the title</p>
    <div class="codehilite"><pre>!status:closed AND summary:foo* AND _milestone:1.0</pre></div>
    <p>Tickets with the label "foo" but not the label "bar":</p>
    <div class="codehilite"><pre>labels:foo AND -labels:bar</pre></div>
    <p>Tickets assigned to or added by a user with the username "admin1" and the custom field "size" set to 2</p>
    <div class="codehilite"><pre>(assigned_to_s:admin1 or reported_by_s:admin1) AND _size:2</pre></div>
    <p>The ticket has "foo" as the title or the body with a number lower than 50</p>
    <div class="codehilite"><pre>(summary:foo or text:foo) AND ticket_num:[* TO 50]</pre></div>
    <p>Tickets last modified in April 2012</p>
    <div class="codehilite"><pre>mod_date_dt:[2012-04-01T00:00:00Z TO 2012-04-30T23:59:59Z]</pre></div>
    <p>Private tickets</p>
    <div class="codehilite"><pre>private:true</pre></div>
    <h2>Saving searches</h2>
    <p>Ticket searches may be saved for later use by project administrators. To save a search, click "Edit Searches" in the tracker sidebar. Click "Add Search" then enter a summary and search terms for the saved search. Your search will now show up in the sidebar under "Searches" with a count of how many tickets match the query.</p>
    <h2>Sorting search results</h2>
    <p>Ticket search results can be sorted by clicking the header of the column you want to sort by. The first click will sort the results in ascending order. Clicking the header again will sort the column in descending order. In addition to sorting by the column headers, you can manually sort on these properties:</p>
    <ul>
    <li>Labels assigned to the ticket - labels_t</li>
    <li>Milestone the ticket is assigned to - _milestone_s</li>
    <li>Last modified date - mod_date_dt</li>
    <li>Created date - created_date_dt</li>
    <li>Body of the ticket - text_s</li>
    <li>Number of ticket - ticket_num_i</li>
    <li>User who created the ticket - reported_by_s</li>
    <li>Status of the ticket - status_s</li>
    <li>Title of the ticket - snippet_s</li>
    <li>Private ticket - private_b</li>
    <li>Discussion disabled ticket - discussion_disabled_b</li>
    {% if custom_fields %}
    <li>Custom fields:
        <ul>
        {% for field in custom_fields %}
            <li>{{field.name}}</li>
        {% endfor %}
        </ul>
    </li>
    {% endif %}
    </ul>
    <p>You can use these properties by appending them to the url (only one sort allowed at a time) like this:</p>
    <div class="codehilite"><pre>{{ h.absurl(c.app.url) }}search/?q=_milestone:1.0&sort=snippet_s+asc</pre></div></div>
{% endblock %}