14.3.157. crate_anon/crateweb/research/templates/pe_build.html

{# crate_anon/crateweb/research/templates/pe_build.html #}

{% extends "base.html" %}

{% block collapsejs %}{% endblock %}
{% block extrahead %}
    {% include "querybuilder_extrahead.html" %}
{% endblock %}

{% block onload %}onload="populate()"{% endblock %}

{% block content %}

    {% comment %}
        {% include "query_nav.html" %}
    {% endcomment %}

    <h1>Build a Patient Explorer</h1>

    <h2>Current Patient Explorer</h2>

    <h3>A. Output columns</h3>
    <div>{{ pmq_output_columns|safe }}</div>

    <h3>B. Patient selection criteria</h3>
    <div>{{ pmq_patient_conditions|safe }}</div>

    <h3>C. Manual patient selection query</h3>
    <div>{{ pmq_manual_patient_query|safe }}</div>

    <h3>Final patient selection query</h3>
    <div>{{ pmq_final_patient_query|safe }}</div>

    {{ warnings|safe }}

    <form action="{% url 'pe_build' %}" method="post">
        {% csrf_token %}
        <input type="submit" name="global_clear_select" value="Clear SELECT" />
        <input type="submit" name="global_clear_where" value="Clear WHERE" />
        <input type="submit" name="global_clear_everything" value="Clear everything" />
        <input type="submit" name="global_save" value="Save" />
        <input type="submit" name="global_run" value="Run" />
    </form>

    <h2>Build your Patient Explorer!</h2>

    {% include "querybuilder_form.html" with form_submit_url='pe_build' %}

    <h2>Set a manual patient query</h2>

    <div>This should select the master research ID (MRID); it should use the
        DISTINCT keyword so each MRID is selected only once; it should pick
        them WHERE mrid IS NOT NULL, and it should
        (ideally) ORDER BY that MRID for consistency when you run it more than
        once.</div>

    <form action="{% url 'pe_build' %}" method="post">
        {% csrf_token %}
        <table class="formtable">
            {{ manual_form }}
        </table>
        <input type="submit" name="global_manual_set" value="Set" />
        <input type="submit" name="global_manual_clear" value="Clear manual query" />
    </form>

    <h2>Explanation</h2>
    <ul>
        <li>Patient Explorers (PEs) do two things: (1) find patients based on
            criteria you specify, and (2) show information about those
            patients.</li>

        <li>The PE will automatically join tables in the same way as the
            Query Builder (q.v.).</li>

        <li>Each PE can generate several SQL statements: one to find patient
            IDs, and then one or more other ones to fetch information on those
            patients. You can take the SQL and edit it yourself, if you
            wish.</li>

        <li>The PE’s patient selection query can also be used for two other
            purposes, to help you find data. There is a <b>data finder</b>,
            which shows you a count of all records in every patient table,
            for the patient(s) you have selected, where data is present for
            that patient.
            There is also a <b>Monster Data</b> view, which shows you
            <i>all data</i> for each of those patients.</li>
    </ul>

{% endblock %}

{% block helpurl %}{{ HelpUrl.patient_explorer }}{% endblock %}