aboutsummaryrefslogtreecommitdiff
path: root/inst/app/templates/content/estimators
diff options
context:
space:
mode:
authorNaeem Model <me@nmode.ca>2024-05-09 20:22:45 +0000
committerNaeem Model <me@nmode.ca>2024-05-09 20:22:45 +0000
commitdce01ac19a0298388089ce4297a44ef2aa2c4c46 (patch)
tree1dbc74e9f7e9139f14a517b33a0e3c82c6e04dd0 /inst/app/templates/content/estimators
parente06a56581d43cb3c59d51b9b39e6d0fb36efe31c (diff)
Revamp Shiny app
Diffstat (limited to 'inst/app/templates/content/estimators')
-rw-r--r--inst/app/templates/content/estimators/add-estimators.html34
-rw-r--r--inst/app/templates/content/estimators/add-estimators/components/mu.html20
-rw-r--r--inst/app/templates/content/estimators/add-estimators/components/panel.html21
-rw-r--r--inst/app/templates/content/estimators/add-estimators/descriptions/id.html1
-rw-r--r--inst/app/templates/content/estimators/add-estimators/descriptions/idea.html1
-rw-r--r--inst/app/templates/content/estimators/add-estimators/descriptions/seq_bayes.html1
-rw-r--r--inst/app/templates/content/estimators/add-estimators/descriptions/wp.html1
-rw-r--r--inst/app/templates/content/estimators/add-estimators/parameters/id.html1
-rw-r--r--inst/app/templates/content/estimators/add-estimators/parameters/idea.html1
-rw-r--r--inst/app/templates/content/estimators/add-estimators/parameters/seq_bayes.html22
-rw-r--r--inst/app/templates/content/estimators/add-estimators/parameters/wp.html39
-rw-r--r--inst/app/templates/content/estimators/view-estimates.html21
12 files changed, 163 insertions, 0 deletions
diff --git a/inst/app/templates/content/estimators/add-estimators.html b/inst/app/templates/content/estimators/add-estimators.html
new file mode 100644
index 0000000..dce2dae
--- /dev/null
+++ b/inst/app/templates/content/estimators/add-estimators.html
@@ -0,0 +1,34 @@
+<div class="accordion accordion-flush" id="estimators-accordion">
+ {{
+ htmlTemplate("templates/content/estimators/add-estimators/components/panel.html",
+ id = "id",
+ header = "Incidence Decay (ID)",
+ reference_label = "Fisman et al. (PloS One, 2013)",
+ reference_url = "https://doi.org/10.1371/journal.pone.0083622"
+ )
+ }}
+ {{
+ htmlTemplate("templates/content/estimators/add-estimators/components/panel.html",
+ id = "idea",
+ header = "Incidence Decay and Exponential Adjustment (IDEA)",
+ reference_label = "Fisman et al. (PloS One, 2013)",
+ reference_url = "https://doi.org/10.1371/journal.pone.0083622"
+ )
+ }}
+ {{
+ htmlTemplate("templates/content/estimators/add-estimators/components/panel.html",
+ id = "seq_bayes",
+ header = "Sequential Bayes (seqB)",
+ reference_label = "Bettencourt and Riberio (PloS One, 2008)",
+ reference_url = "https://doi.org/10.1371/journal.pone.0002185"
+ )
+ }}
+ {{
+ htmlTemplate("templates/content/estimators/add-estimators/components/panel.html",
+ id = "wp",
+ header = "White and Pagano (WP)",
+ reference_label = "White and Pagano (Statistics in Medicine, 2008)",
+ reference_url = "https://doi.org/10.1002/sim.3136"
+ )
+ }}
+</div>
diff --git a/inst/app/templates/content/estimators/add-estimators/components/mu.html b/inst/app/templates/content/estimators/add-estimators/components/mu.html
new file mode 100644
index 0000000..f25a1c8
--- /dev/null
+++ b/inst/app/templates/content/estimators/add-estimators/components/mu.html
@@ -0,0 +1,20 @@
+<!-- Serial interval label and help tooltip. -->
+<label class="form-label" for="mu_{{ id }}">
+ Serial interval (&#956;)
+ <sup data-bs-toggle="tooltip" data-bs-placement="right"
+ data-bs-title="The serial interval is the time between when an infected individual (the infector) becomes
+ symptomatic, to when another individual (who is infected by the infector) becomes symptomatic.">
+ [?]
+ </sup>
+</label>
+<div class="input-group">
+ <!-- Serial interval input field. -->
+ <input name="mu_{{ id }}" class="form-control" type="text">
+ <!-- Days/weeks dropdown. -->
+ <select name="mu_{{ id }}_units" class="form-select">
+ <option value="Days" selected>Days</option>
+ <option value="Weeks">Weeks</option>
+ </select>
+</div>
+<!-- Warning text for incorrect values. -->
+<small id="mu_{{ id }}_warn" class="form-text text-primary shiny-text-output"></small>
diff --git a/inst/app/templates/content/estimators/add-estimators/components/panel.html b/inst/app/templates/content/estimators/add-estimators/components/panel.html
new file mode 100644
index 0000000..b1e0378
--- /dev/null
+++ b/inst/app/templates/content/estimators/add-estimators/components/panel.html
@@ -0,0 +1,21 @@
+<div class="accordion-item">
+ <h2 class="accordion-header">
+ <button class="accordion-button collapsed" type="button"
+ data-bs-toggle="collapse" data-bs-target="#{{ id }}">
+ <h4>{{ header }}</h4>
+ </button>
+ </h2>
+ <div id="{{ id }}" class="accordion-collapse collapse" data-bs-parent="#estimators-accordion">
+ <div class="accordion-body">
+ <p>Reference: <a href="{{ reference_url }}" target="_blank"><em>{{ reference_label }}</em></a></p>
+ <p>{{ htmlTemplate(paste0("templates/content/estimators/add-estimators/descriptions/", id, ".html")) }}</p>
+ <h5>Parameters</h5>
+ <form class="my-3">
+ {{ htmlTemplate(paste0("templates/content/estimators/add-estimators/parameters/", id, ".html")) }}
+ </form>
+ <button id="add_{{ id }}" type="button" class="btn btn-outline-primary btn-sm action-button">
+ <span class="glyphicon glyphicon-plus"></span> Add
+ </button>
+ </div>
+ </div>
+</div>
diff --git a/inst/app/templates/content/estimators/add-estimators/descriptions/id.html b/inst/app/templates/content/estimators/add-estimators/descriptions/id.html
new file mode 100644
index 0000000..b182ae5
--- /dev/null
+++ b/inst/app/templates/content/estimators/add-estimators/descriptions/id.html
@@ -0,0 +1 @@
+This is a short description of the ID method.
diff --git a/inst/app/templates/content/estimators/add-estimators/descriptions/idea.html b/inst/app/templates/content/estimators/add-estimators/descriptions/idea.html
new file mode 100644
index 0000000..edfbb79
--- /dev/null
+++ b/inst/app/templates/content/estimators/add-estimators/descriptions/idea.html
@@ -0,0 +1 @@
+This is a short description of the IDEA method.
diff --git a/inst/app/templates/content/estimators/add-estimators/descriptions/seq_bayes.html b/inst/app/templates/content/estimators/add-estimators/descriptions/seq_bayes.html
new file mode 100644
index 0000000..f6df3ee
--- /dev/null
+++ b/inst/app/templates/content/estimators/add-estimators/descriptions/seq_bayes.html
@@ -0,0 +1 @@
+This is a short description of the seqB method.
diff --git a/inst/app/templates/content/estimators/add-estimators/descriptions/wp.html b/inst/app/templates/content/estimators/add-estimators/descriptions/wp.html
new file mode 100644
index 0000000..640b44d
--- /dev/null
+++ b/inst/app/templates/content/estimators/add-estimators/descriptions/wp.html
@@ -0,0 +1 @@
+This is a short description of the WP method.
diff --git a/inst/app/templates/content/estimators/add-estimators/parameters/id.html b/inst/app/templates/content/estimators/add-estimators/parameters/id.html
new file mode 100644
index 0000000..a3159ca
--- /dev/null
+++ b/inst/app/templates/content/estimators/add-estimators/parameters/id.html
@@ -0,0 +1 @@
+{{ htmlTemplate("templates/content/estimators/add-estimators/components/mu.html", id = "id") }}
diff --git a/inst/app/templates/content/estimators/add-estimators/parameters/idea.html b/inst/app/templates/content/estimators/add-estimators/parameters/idea.html
new file mode 100644
index 0000000..379be84
--- /dev/null
+++ b/inst/app/templates/content/estimators/add-estimators/parameters/idea.html
@@ -0,0 +1 @@
+{{ htmlTemplate("templates/content/estimators/add-estimators/components/mu.html", id = "idea") }}
diff --git a/inst/app/templates/content/estimators/add-estimators/parameters/seq_bayes.html b/inst/app/templates/content/estimators/add-estimators/parameters/seq_bayes.html
new file mode 100644
index 0000000..bcc82b7
--- /dev/null
+++ b/inst/app/templates/content/estimators/add-estimators/parameters/seq_bayes.html
@@ -0,0 +1,22 @@
+<div class="row">
+ <!-- Serial interval (mu). -->
+ <div class="col-md">
+ {{ htmlTemplate("templates/content/estimators/add-estimators/components/mu.html", id = "seq_bayes") }}
+ </div>
+ <!-- Maximum value of the uniform prior (kappa). -->
+ <div class="col-md mt-2 mt-md-0">
+ <!-- Label and help tooltip. -->
+ <label class="form-label" for="kappa">
+ Maximum prior (&#954;)
+ <sup data-bs-toggle="tooltip" data-bs-placement="right" data-bs-html="true"
+ data-bs-title="The initial maximum belief of <em>R<sub>0</sub></em>. The higher this value, the higher
+ <em>R<sub>0</sub></em> is believed to be prior to the estimation.">
+ [?]
+ </sup>
+ </label>
+ <!-- Input field. -->
+ <input name="kappa" class="form-control" type="text" placeholder="Default: 20">
+ <!-- Warning text for incorrect values. -->
+ <small id="kappa_warn" class="form-text text-primary shiny-text-output"></small>
+ </div>
+</div>
diff --git a/inst/app/templates/content/estimators/add-estimators/parameters/wp.html b/inst/app/templates/content/estimators/add-estimators/parameters/wp.html
new file mode 100644
index 0000000..b789a23
--- /dev/null
+++ b/inst/app/templates/content/estimators/add-estimators/parameters/wp.html
@@ -0,0 +1,39 @@
+<!-- Radio buttons to specify whether the serial interval is known. -->
+<label class="form-label" for="wp_mu_known">Is the serial interval known?</label>
+<div class="shiny-input-radiogroup" id="wp_mu_known">
+ <div class="form-check form-check-inline">
+ <label class="form-check-label">
+ <input type="radio" class="form-check-input me-2" name="wp_mu_known" value="Yes" checked>Yes
+ </label>
+ </div>
+ <div class="form-check form-check-inline">
+ <label class="form-check-label">
+ <input type="radio" class="form-check-input me-2" name="wp_mu_known" value="No">No
+ </label>
+ </div>
+</div>
+<!-- Show the input field for the serial interval if it is known. -->
+<div data-display-if="input.wp_mu_known == 'Yes'" class="mt-2 mt-md-0">
+ {{ htmlTemplate("templates/content/estimators/add-estimators/components/mu.html", id = "wp") }}
+</div>
+<!-- Show the input fields for the grid search parameters if the serial interval is unknown. -->
+<div data-display-if="input.wp_mu_known == 'No'" class="row">
+ <!-- Grid length. -->
+ <div class="col-md mt-2 mt-md-0">
+ <label class="form-label" for="grid_length">Grid length</label>
+ <input name="grid_length" class="form-control" type="text" placeholder="Default: 100">
+ <small id="grid_length_warn" class="form-text text-primary shiny-text-output"></small>
+ </div>
+ <!-- Maximum shape. -->
+ <div class="col-md mt-2 mt-md-0">
+ <label class="form-label" for="max_shape">Maximum shape</label>
+ <input name="max_shape" class="form-control" type="text" placeholder="Default: 10">
+ <small id="max_shape_warn" class="form-text text-primary shiny-text-output"></small>
+ </div>
+ <!-- Grid length. -->
+ <div class="col-md mt-2 mt-md-0">
+ <label class="form-label" for="max_scale">Maximum scale</label>
+ <input name="max_scale" class="form-control" type="text" placeholder="Default: 10">
+ <small id="max_scale_warn" class="form-text text-primary shiny-text-output"></small>
+ </div>
+</div>
diff --git a/inst/app/templates/content/estimators/view-estimates.html b/inst/app/templates/content/estimators/view-estimates.html
new file mode 100644
index 0000000..e81fff6
--- /dev/null
+++ b/inst/app/templates/content/estimators/view-estimates.html
@@ -0,0 +1,21 @@
+<h4>Estimates table</h4>
+<!-- Estimates table. -->
+<div class="my-3">
+ {{ DT::dataTableOutput(outputId = "estimates_table") }}
+</div>
+<!-- Display inactive delete button when no columns are selected. -->
+<button type="button" class="btn btn-primary btn-sm text-white" disabled
+ data-display-if="'estimates_table_columns_selected' in input &&
+ input.estimates_table_columns_selected.length == 0">
+ <span class="glyphicon glyphicon-remove"></span> Delete column(s)
+</button>
+<!-- Display active delete button when at least one column is selected. -->
+<button id="estimators_delete" type="button" class="btn btn-primary btn-sm action-button text-white"
+ data-display-if="'estimates_table_columns_selected' in input &&
+ input.estimates_table_columns_selected.length != 0">
+ <span class="glyphicon glyphicon-remove"></span> Delete column(s)
+</button>
+<!-- Button to export estimates table as a CSV file. -->
+<a id="estimates_export" type="button" class="btn btn-outline-primary btn-sm shiny-download-link">
+ <span class="glyphicon glyphicon-download-alt"></span> Export table
+</a>