renalware-core 2.0.149 → 2.0.151
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/README.md +23 -2
- data/app/assets/config/renalware/core/manifest.js +1 -0
- data/app/assets/images/renalware/icons/align-justify.svg +3 -0
- data/app/assets/images/renalware/icons/bar-chart.svg +1 -0
- data/app/assets/images/renalware/icons/chart-bar.svg +1 -0
- data/app/assets/images/renalware/icons/chart.svg +3 -0
- data/app/assets/images/renalware/icons/list-bullet.svg +1 -0
- data/app/assets/images/renalware/icons/list.svg +8 -0
- data/app/assets/javascripts/renalware/README.md +25 -1
- data/app/assets/javascripts/renalware/components/dialogs.js.erb +3 -1
- data/app/assets/javascripts/renalware/components/hd.js +2 -2
- data/app/assets/javascripts/renalware/components/letters.js +1 -1
- data/app/assets/javascripts/renalware/components/masonry.run.js +2 -2
- data/app/assets/javascripts/renalware/components/patient_menu.js +1 -1
- data/app/assets/javascripts/renalware/components/toggler.js +1 -1
- data/app/assets/javascripts/renalware/rollup_compiled.css +87457 -0
- data/app/assets/javascripts/renalware/rollup_compiled.js +3148 -3
- data/app/assets/stylesheets/renalware/core.scss +1 -0
- data/app/assets/stylesheets/renalware/modules/_hd.scss +8 -4
- data/app/assets/stylesheets/renalware/modules/_pathology.scss +8 -1
- data/app/assets/stylesheets/renalware/modules/_pd.scss +35 -0
- data/app/assets/stylesheets/renalware/partials/_charting.scss +17 -0
- data/app/assets/stylesheets/renalware/partials/_forms.scss +5 -1
- data/app/assets/stylesheets/renalware/partials/_simple_form.scss +8 -0
- data/app/assets/stylesheets/renalware/partials/_utilities.scss +12 -0
- data/app/assets/stylesheets/tailwind/tailwind.css +3 -0
- data/app/components/renalware/application_component.rb +2 -1
- data/app/components/renalware/events/{biopsies_component.html.slim → event_list_component.html.slim} +5 -4
- data/app/components/renalware/events/event_list_component.rb +77 -0
- data/app/components/renalware/hd/administer_prescription_dropdown_component.rb +1 -5
- data/app/components/renalware/hd/prescription_last_administration_component.html.slim +0 -1
- data/app/components/renalware/hd/prescription_last_administration_component.rb +8 -7
- data/app/components/renalware/letters/unread_electronic_ccs_component.rb +1 -0
- data/app/components/renalware/pathology/chart_component.html.slim +5 -0
- data/app/components/renalware/pathology/chart_component.rb +40 -0
- data/app/components/renalware/pathology/sparkline_component.html.slim +15 -0
- data/app/components/renalware/pathology/sparkline_component.rb +135 -0
- data/app/components/renalware/patients/side_menu_component.rb +2 -11
- data/app/components/renalware/pd/adequacy_results_component.html.slim +9 -0
- data/app/components/renalware/pd/adequacy_results_component.rb +39 -0
- data/app/components/renalware/pd/pet_results_component.html.slim +37 -0
- data/app/components/renalware/pd/pet_results_component.rb +84 -0
- data/app/{views/renalware/surveys/_eq5d_summary_part.html.slim → components/renalware/surveys/eq5d_component.html.slim} +5 -5
- data/app/{models/renalware/surveys/eq5d_summary_part.rb → components/renalware/surveys/eq5d_component.rb} +7 -5
- data/app/{views/renalware/surveys/_pos_s_summary_part.html.slim → components/renalware/surveys/pos_s_component.html.slim} +6 -9
- data/app/{models/renalware/surveys/pos_s_summary_part.rb → components/renalware/surveys/pos_s_component.rb} +9 -5
- data/app/components/renalware/system/admin_menu_component.rb +2 -2
- data/app/components/renalware/system/article_component.html.slim +3 -0
- data/app/components/renalware/system/article_component.rb +9 -0
- data/app/controllers/renalware/admissions/consults_controller.rb +1 -1
- data/app/controllers/renalware/concerns/pdf_renderable.rb +1 -1
- data/app/controllers/renalware/hd/scheduling/diaries_controller.rb +1 -1
- data/app/controllers/renalware/medications/prescriptions_controller.rb +1 -1
- data/app/controllers/renalware/pathology/charts_controller.rb +21 -0
- data/app/controllers/renalware/pathology/current_observation_results_controller.rb +1 -1
- data/app/controllers/renalware/pathology/historical_observation_results_controller.rb +1 -1
- data/app/controllers/renalware/pathology/nearest_observation_results_controller.rb +52 -0
- data/app/controllers/renalware/pathology/observation_requests_controller.rb +1 -1
- data/app/controllers/renalware/pathology/observations_controller.rb +26 -2
- data/app/controllers/renalware/pathology/requests/requests_controller.rb +7 -5
- data/app/controllers/renalware/pd/adequacy_completions_controller.rb +18 -0
- data/app/controllers/renalware/pd/adequacy_results_controller.rb +98 -0
- data/app/controllers/renalware/pd/pet_completions_controller.rb +18 -0
- data/app/controllers/renalware/pd/pet_results_controller.rb +122 -0
- data/app/controllers/renalware/pd/unified_pet_adequacies_controller.rb +102 -0
- data/app/controllers/renalware/renal/aki_alerts_controller.rb +1 -1
- data/app/controllers/renalware/renal/registry_preflight_checks_controller.rb +55 -19
- data/app/documents/renalware/age.rb +3 -1
- data/app/helpers/renalware/application_helper.rb +7 -7
- data/app/helpers/renalware/article_helper.rb +3 -3
- data/app/helpers/renalware/boolean_helper.rb +15 -0
- data/app/helpers/renalware/clipboard_helper.rb +2 -3
- data/app/helpers/renalware/dashboards_helper.rb +2 -2
- data/app/helpers/renalware/definition_list_helper.rb +3 -3
- data/app/helpers/renalware/devise_helper.rb +1 -1
- data/app/helpers/renalware/form_helper.rb +2 -2
- data/app/helpers/renalware/letters_helper.rb +1 -1
- data/app/helpers/renalware/link_helper.rb +1 -1
- data/app/helpers/renalware/mdm_helper.rb +1 -0
- data/app/helpers/renalware/navigation_helper.rb +1 -1
- data/app/helpers/renalware/patient_helper.rb +2 -2
- data/app/helpers/renalware/snippets_helper.rb +9 -10
- data/app/helpers/renalware/toggle_helper.rb +6 -6
- data/app/helpers/renalware/tooltip_helper.rb +14 -16
- data/app/inputs/clock_picker_input.rb +3 -3
- data/app/inputs/date_picker_input.rb +3 -3
- data/app/inputs/simple_time_input.rb +3 -3
- data/app/inputs/trix_editor_input.rb +2 -0
- data/app/javascript/renalware/controllers/blas_controller.js +37 -0
- data/app/javascript/renalware/controllers/modal_controller.js +137 -0
- data/app/javascript/renalware/controllers/pathology/sparklines_controller.js +206 -0
- data/app/javascript/renalware/controllers/pd/pet_charts_controller.js +169 -0
- data/app/javascript/renalware/controllers/session_controller.js +1 -1
- data/app/javascript/renalware/controllers/simple_toggle_controller.js +17 -0
- data/app/javascript/renalware/controllers/tabs_controller.js +43 -0
- data/app/javascript/renalware/controllers/toggle_controller.js +2 -2
- data/app/javascript/renalware/index.js +10 -0
- data/app/models/concerns/renalware/patients_ransack_helper.rb +2 -0
- data/app/models/renalware/clinics/body_surface_area.rb +40 -0
- data/app/models/renalware/clinics/clinic_visit.rb +21 -1
- data/app/models/renalware/clinics/total_body_water.rb +63 -0
- data/app/models/renalware/events/advanced_care_plan.rb +24 -0
- data/app/models/renalware/events/clinical_frailty_score.rb +24 -0
- data/app/models/renalware/feeds/hl7_message.rb +1 -0
- data/app/models/renalware/hd/prescription_last_administration_query.rb +4 -0
- data/app/models/renalware/hd/session_forms/pdf_renderer.rb +1 -1
- data/app/models/renalware/hd/sessions/auditable_session_collection.rb +4 -1
- data/app/models/renalware/letters/html_renderer.rb +1 -1
- data/app/models/renalware/letters/printing/duplex_interleaved_pdf_renderer.rb +1 -1
- data/app/models/renalware/letters/recipient_address_pdf_renderer.rb +1 -1
- data/app/models/renalware/pathology/nearest_observations_query.rb +44 -0
- data/app/models/renalware/pathology/observations_jsonb_serializer.rb +1 -1
- data/app/models/renalware/patient.rb +16 -1
- data/app/models/renalware/patients/alert.rb +1 -0
- data/app/models/renalware/patients/ingestion/update_master_patient_index.rb +1 -0
- data/app/models/renalware/patients/patient_hospital_identifiers.rb +1 -0
- data/app/models/renalware/pd.rb +2 -0
- data/app/models/renalware/pd/adequacy_calculated_attributes.rb +159 -0
- data/app/models/renalware/pd/adequacy_result.rb +76 -0
- data/app/models/renalware/pd/apd/glucose_calculator.rb +1 -0
- data/app/models/renalware/pd/patient.rb +4 -0
- data/app/models/renalware/pd/pet_dextrose_concentration.rb +17 -0
- data/app/models/renalware/pd/pet_result.rb +92 -0
- data/app/models/renalware/pd/unified_pet_adequacy_form.rb +46 -0
- data/app/models/renalware/renal/registry/preflight_checks/missing_esrf_query.rb +50 -0
- data/app/models/renalware/snippets/duplicate_snippet_title_generator.rb +1 -0
- data/app/models/renalware/transplants/recipient_workup_builder.rb +1 -0
- data/app/models/renalware/transplants/registration_status.rb +1 -1
- data/app/models/renalware/ukrdc/outgoing/rendering/patient_number.rb +1 -1
- data/app/models/renalware/user.rb +10 -0
- data/app/pdfs/renalware/events/event_pdf.rb +1 -0
- data/app/policies/renalware/events/advanced_care_plan_policy.rb +10 -0
- data/app/policies/renalware/events/clinical_frailty_score_policy.rb +10 -0
- data/app/policies/renalware/pd/adequacy_result_policy.rb +15 -0
- data/app/policies/renalware/pd/pet_result_policy.rb +15 -0
- data/app/policies/renalware/renal/registry_preflight_check_policy.rb +4 -0
- data/app/presenters/renalware/clinical/profile_presenter.rb +1 -0
- data/app/presenters/renalware/hd/dashboard_presenter.rb +1 -0
- data/app/presenters/renalware/hd/profile_presenter.rb +1 -0
- data/app/presenters/renalware/hd/scheduling/diary_presenter.rb +1 -0
- data/app/presenters/renalware/hd/session_presenter.rb +1 -0
- data/app/presenters/renalware/hd/unmet_preferences_presenter.rb +1 -1
- data/app/presenters/renalware/mdm_patients_presenter.rb +1 -0
- data/app/presenters/renalware/pd/dashboard_presenter.rb +10 -2
- data/app/presenters/renalware/ukrdc/patient_presenter.rb +1 -0
- data/app/presenters/renalware/user_session_presenter.rb +1 -1
- data/app/validators/renalware/patients/nhs_number_validator.rb +88 -0
- data/app/values/renalware/address.rb +1 -0
- data/app/views/renalware/accesses/assessments/show.html.slim +1 -1
- data/app/views/renalware/accesses/procedures/show.html.slim +1 -1
- data/app/views/renalware/accesses/profiles/show.html.slim +1 -1
- data/app/views/renalware/admin/cache/show.html.slim +36 -0
- data/app/views/renalware/admin/playgrounds/show.html.slim +3 -0
- data/app/views/renalware/clinical/profiles/show.html.slim +11 -1
- data/app/views/renalware/clinics/clinic_visits/_table.html.slim +2 -0
- data/app/views/renalware/clinics/clinic_visits/_table_row.html.slim +2 -0
- data/app/views/renalware/dashboard/letters/_letter.html.slim +1 -1
- data/app/views/renalware/directory/people/show.html.slim +1 -1
- data/app/views/renalware/events/advanced_care_plans/_cell.html.slim +2 -0
- data/app/views/renalware/events/advanced_care_plans/_inputs.html.slim +4 -0
- data/app/views/renalware/events/advanced_care_plans/_toggled_cell.html.slim +8 -0
- data/app/views/renalware/events/clinical_frailty_score/_cell.html.slim +2 -0
- data/app/views/renalware/events/clinical_frailty_score/_inputs.html.slim +4 -0
- data/app/views/renalware/events/clinical_frailty_score/_toggled_cell.html.slim +8 -0
- data/app/views/renalware/events/events/_table.html.slim +1 -1
- data/app/views/renalware/hd/current_profile/_show.html.slim +1 -1
- data/app/views/renalware/hd/current_profile/show.html.slim +1 -1
- data/app/views/renalware/hd/prescription_administrations/_form.html.slim +2 -0
- data/app/views/renalware/hd/sessions/_show.html.slim +1 -1
- data/app/views/renalware/hd/witnesses/_form.html.slim +2 -0
- data/app/views/renalware/letters/electronic_receipts/_table.html.slim +1 -1
- data/app/views/renalware/low_clearance/dashboards/show.html.slim +10 -0
- data/app/views/renalware/mdm/_pathology.html.slim +0 -1
- data/app/views/renalware/mdm/show.html.slim +1 -1
- data/app/views/renalware/navigation/_menu.html.slim +1 -0
- data/app/views/renalware/navigation/_pd.html.slim +5 -0
- data/app/views/renalware/pathology/charts/show.html.slim +11 -0
- data/app/views/renalware/pathology/current_observation_results/index.html.slim +6 -0
- data/app/views/renalware/pathology/historical_observation_results/_table.html.slim +4 -3
- data/app/views/renalware/pathology/historical_observation_results/index.html.slim +1 -1
- data/app/views/renalware/pathology/observations/_diff.html.slim +1 -1
- data/app/views/renalware/patients/patients/show.html.slim +1 -1
- data/app/views/renalware/pd/_exit_site_infections.html.slim +4 -0
- data/app/views/renalware/pd/_peritonitis_episodes.html.slim +3 -0
- data/app/views/renalware/pd/adequacy_completions/_filters.html.slim +19 -0
- data/app/views/renalware/pd/adequacy_completions/index.html.slim +4 -0
- data/app/views/renalware/pd/adequacy_results/_form_fields.html.slim +9 -0
- data/app/views/renalware/pd/adequacy_results/_table.html.slim +72 -0
- data/app/views/renalware/pd/adequacy_results/edit.html.slim +89 -0
- data/app/views/renalware/pd/adequacy_results/index.js.erb +1 -0
- data/app/views/renalware/pd/adequacy_results/new.html.slim +8 -0
- data/app/views/renalware/pd/dashboards/show.html.slim +3 -0
- data/app/views/renalware/pd/dashboards/show/_page_actions.html.slim +14 -0
- data/app/views/renalware/pd/pet_completions/_filters.html.slim +24 -0
- data/app/views/renalware/pd/pet_completions/index.html.slim +4 -0
- data/app/views/renalware/pd/pet_results/_form_fields.html.slim +12 -0
- data/app/views/renalware/pd/pet_results/_pathology_results.html.slim +36 -0
- data/app/views/renalware/pd/pet_results/_table.html.slim +62 -0
- data/app/views/renalware/pd/pet_results/edit.html.slim +35 -0
- data/app/views/renalware/pd/pet_results/index.js.erb +1 -0
- data/app/views/renalware/pd/pet_results/new.html.slim +8 -0
- data/app/views/renalware/pd/unified_pet_adequacies/_form.html.slim +22 -0
- data/app/views/renalware/pd/unified_pet_adequacies/new.html.slim +2 -0
- data/app/views/renalware/renal/profiles/show.html.slim +1 -1
- data/app/views/renalware/renal/registry_preflight_checks/_filters.html.slim +5 -3
- data/app/views/renalware/renal/registry_preflight_checks/_navigation.html.slim +1 -0
- data/app/views/renalware/renal/registry_preflight_checks/deaths.html.slim +2 -1
- data/app/views/renalware/renal/registry_preflight_checks/missing_esrf.html.slim +12 -0
- data/app/views/renalware/renal/registry_preflight_checks/patients.html.slim +1 -2
- data/app/views/renalware/surveys/dashboards/show.html.slim +2 -2
- data/app/views/renalware/transplants/donor_workups/show.html.slim +1 -1
- data/app/views/renalware/transplants/mdm/_bottom.html.slim +3 -1
- data/app/views/renalware/transplants/recipient_followups/show.html.slim +1 -1
- data/app/views/renalware/transplants/recipient_operations/show.html.slim +1 -1
- data/app/views/renalware/transplants/recipient_workups/show.html.slim +1 -1
- data/app/views/renalware/transplants/registrations/show.html.slim +1 -1
- data/config/initializers/inflections.rb +8 -0
- data/config/initializers/wicked_pdf.rb +12 -0
- data/config/locales/en-GB.yml +1 -1
- data/config/locales/renalware/events/advanced_care_plan.en.yml +12 -0
- data/config/locales/renalware/events/biopsy.en.yml +2 -0
- data/config/locales/renalware/events/clinical_frailty_score.en.yml +16 -0
- data/config/locales/renalware/events/clinical_frailty_score_component.en.yml +8 -0
- data/config/locales/renalware/nhs_number.en.yml +6 -0
- data/config/locales/renalware/pd/adequacy_result.en.yml +9 -0
- data/config/locales/renalware/pd/dashboard.en.yml +3 -0
- data/config/locales/renalware/pd/pet_result.en.yml +23 -0
- data/config/locales/renalware/renal/registry.en.yml +1 -0
- data/config/routes/pathology.rb +6 -0
- data/config/routes/pd.rb +5 -0
- data/config/routes/renal.rb +1 -0
- data/db/functions/generate_secure_id_v01.sql +1 -1
- data/db/migrate/20200226145010_add_unique_indexes.rb +46 -0
- data/db/migrate/20200421082715_add_body_surface_area_to_clinic_visits.rb +8 -0
- data/db/migrate/20200421132911_create_pd_pet_dextrose_concentrations.rb +13 -0
- data/db/migrate/20200421143546_create_pet_results.rb +66 -0
- data/db/migrate/20200427123229_create_adequacy_results.rb +54 -0
- data/db/migrate/20200616115709_add_height_weight_to_pd_adequacy_results.rb +8 -0
- data/db/migrate/20200618144228_add_feature_flags_to_users.rb +14 -0
- data/db/seeds/default/events/event_types.csv +2 -0
- data/lib/renalware/engine.rb +4 -2
- data/lib/renalware/version_number.rb +11 -0
- data/lib/tasks/renalware.rake +7 -1
- data/spec/factories/accesses/profiles.rb +1 -0
- data/spec/factories/events/events_types.rb +12 -0
- data/spec/factories/patients/patients.rb +22 -1
- data/spec/factories/pd/adequacy_results.rb +16 -0
- data/spec/factories/pd/pet_results.rb +9 -0
- metadata +115 -25
- data/app/components/renalware/events/biopsies_component.rb +0 -20
- data/lib/renalware/version.rb +0 -5
@@ -4,14 +4,14 @@ class DatePickerInput < SimpleForm::Inputs::StringInput
|
|
4
4
|
# Note that where we use `wrapper: :clockpicker` or `wrapper: horizontal_clockpicker`,
|
5
5
|
# #input is not called and we call #prefix_column and #input_column directly.
|
6
6
|
def input(_wrapper_options)
|
7
|
-
template.
|
7
|
+
template.tag.div(class: "row collapse #{class_name}-wrapper") do
|
8
8
|
template.concat prefix_column
|
9
9
|
template.concat input_column
|
10
10
|
end
|
11
11
|
end
|
12
12
|
|
13
13
|
def prefix_column(_wrapper_options = {})
|
14
|
-
template.
|
14
|
+
template.tag.div(class: "small-2 columns") do
|
15
15
|
template.concat icon_calendar
|
16
16
|
end
|
17
17
|
end
|
@@ -20,7 +20,7 @@ class DatePickerInput < SimpleForm::Inputs::StringInput
|
|
20
20
|
html_options = input_html_options
|
21
21
|
html_options[:class] ||= []
|
22
22
|
html_options[:class] << class_name
|
23
|
-
template.
|
23
|
+
template.tag.div(class: "small-10 columns") do
|
24
24
|
datestamp = @builder.object.public_send(attribute_name)
|
25
25
|
value = format_date(datestamp)
|
26
26
|
template.concat @builder.text_field(attribute_name, html_options.merge(value: value))
|
@@ -2,14 +2,14 @@
|
|
2
2
|
|
3
3
|
class SimpleTimeInput < SimpleForm::Inputs::StringInput
|
4
4
|
def input(_wrapper_options)
|
5
|
-
template.
|
5
|
+
template.tag.div(class: "row collapse datepicker-wrapper") do
|
6
6
|
template.concat prefix_column
|
7
7
|
template.concat input_column
|
8
8
|
end
|
9
9
|
end
|
10
10
|
|
11
11
|
def prefix_column
|
12
|
-
template.
|
12
|
+
template.tag.div(class: "large-2 columns") do
|
13
13
|
template.concat icon_clock
|
14
14
|
end
|
15
15
|
end
|
@@ -17,7 +17,7 @@ class SimpleTimeInput < SimpleForm::Inputs::StringInput
|
|
17
17
|
def input_column
|
18
18
|
html_options = input_html_options
|
19
19
|
html_options[:class] ||= []
|
20
|
-
template.
|
20
|
+
template.tag.div(class: "large-10 columns") do
|
21
21
|
time = @builder.object.public_send(attribute_name)
|
22
22
|
value = time.present? ? I18n.l(time, format: :time) : ""
|
23
23
|
template.concat @builder.text_field(attribute_name, html_options.merge(value: value))
|
@@ -1,5 +1,6 @@
|
|
1
1
|
# frozen_string_literal: true
|
2
2
|
|
3
|
+
# rubocop:disable Rails/ContentTag
|
3
4
|
# See https://github.com/kylefox/trix/blob/master/lib/trix/simple_form/trix_editor_input.rb
|
4
5
|
class TrixEditorInput < SimpleForm::Inputs::Base
|
5
6
|
def input(_wrapper_options)
|
@@ -12,3 +13,4 @@ class TrixEditorInput < SimpleForm::Inputs::Base
|
|
12
13
|
template.content_tag("div", hidden_field + editor_tag, class: "trix-editor-wrapper")
|
13
14
|
end
|
14
15
|
end
|
16
|
+
# rubocop:enable Rails/ContentTag
|
@@ -0,0 +1,37 @@
|
|
1
|
+
// NB Chartkick and Highcharts are defined as global in rollup
|
2
|
+
const Highcharts = window.Highcharts
|
3
|
+
|
4
|
+
import { Controller } from "stimulus"
|
5
|
+
|
6
|
+
export default class extends Controller {
|
7
|
+
static targets = [ "chart", "title" ]
|
8
|
+
|
9
|
+
// E.g. clicked on/hovered over a link so we fetch the json for this anchor's url
|
10
|
+
// and repopulate the graph
|
11
|
+
show(e) {
|
12
|
+
e.preventDefault()
|
13
|
+
fetch(e.currentTarget.href)
|
14
|
+
.then(response => response.json())
|
15
|
+
.then(data => this.refreshChart(data))
|
16
|
+
}
|
17
|
+
|
18
|
+
refreshChart(seriesData) {
|
19
|
+
// Could use chart title instead
|
20
|
+
this.titleTarget.innerHTML = `${seriesData.code} (${seriesData.name})`
|
21
|
+
let options = this.chartOptions
|
22
|
+
options["series"] = [{ name: seriesData.code, data: seriesData.results }]
|
23
|
+
Highcharts.chart(this.chartTarget.id, options)
|
24
|
+
}
|
25
|
+
|
26
|
+
get chartOptions() {
|
27
|
+
return {
|
28
|
+
chart: {
|
29
|
+
type: "line"
|
30
|
+
},
|
31
|
+
xAxis: {
|
32
|
+
type: "date"
|
33
|
+
},
|
34
|
+
series: []
|
35
|
+
}
|
36
|
+
}
|
37
|
+
}
|
@@ -0,0 +1,137 @@
|
|
1
|
+
// Adapted from https://github.com/excid3/tailwindcss-stimulus-components/blob/master/src/modal.js
|
2
|
+
// Designed to work with tailwindcss
|
3
|
+
//
|
4
|
+
// Visit The Stimulus Handbook for more details
|
5
|
+
// https://stimulusjs.org/handbook/introduction
|
6
|
+
//
|
7
|
+
// This example controller works with specially annotated HTML like:
|
8
|
+
//
|
9
|
+
//<div data-controller="modal" data-modal-allow-background-close="false">
|
10
|
+
// <a href="#" data-action="click->modal#open" class="bg-blue-500 hover:bg-blue-700 text-white font-bold py-3 px-6 rounded">
|
11
|
+
// <span>Open Modal</span>
|
12
|
+
// </a>
|
13
|
+
// <!-- Modal Container -->
|
14
|
+
// <div data-target="modal.container" data-action="click->modal#closeBackground keyup@window->modal#closeWithKeyboard" class="hidden animated fadeIn fixed inset-0 overflow-y-auto flex items-center justify-center" style="z-index: 9999;">
|
15
|
+
// <!-- Modal Inner Container -->
|
16
|
+
// <div class="max-h-screen w-full max-w-lg relative">
|
17
|
+
// <!-- Modal Card -->
|
18
|
+
// <div class="m-1 bg-white rounded shadow">
|
19
|
+
// <div class="p-8">
|
20
|
+
// <h2 class="text-xl mb-4">Large Modal Content</h2>
|
21
|
+
// <p class="mb-4">This is an example modal dialog box.</p>
|
22
|
+
// <div class="flex justify-end items-center flex-wrap mt-6">
|
23
|
+
// <button class="bg-blue-500 hover:bg-blue-700 text-white font-bold py-2 px-4 rounded" data-action="click->modal#close">Close</button>
|
24
|
+
// </div>
|
25
|
+
// </div>
|
26
|
+
// </div>
|
27
|
+
// </div>
|
28
|
+
// </div>
|
29
|
+
//</div>
|
30
|
+
|
31
|
+
import { Controller } from "stimulus"
|
32
|
+
|
33
|
+
export default class extends Controller {
|
34
|
+
static targets = ["container"];
|
35
|
+
|
36
|
+
connect() {
|
37
|
+
// The class we should toggle on the container
|
38
|
+
this.toggleClass = this.data.get("class") || "hidden"
|
39
|
+
|
40
|
+
// The HTML for the background element
|
41
|
+
this.backgroundHtml = this.data.get("backgroundHtml") || this._backgroundHTML()
|
42
|
+
|
43
|
+
// The ID of the background to hide/remove
|
44
|
+
this.backgroundId = this.data.get("backgroundId") || "modal-background"
|
45
|
+
|
46
|
+
// Let the user close the modal by clicking on the background
|
47
|
+
this.allowBackgroundClose = (this.data.get("allowBackgroundClose") || "true") === "true"
|
48
|
+
}
|
49
|
+
|
50
|
+
disconnect() {
|
51
|
+
this.close()
|
52
|
+
}
|
53
|
+
|
54
|
+
open(e) {
|
55
|
+
e.preventDefault()
|
56
|
+
e.target.blur()
|
57
|
+
|
58
|
+
// Lock the scroll and save current scroll position
|
59
|
+
this.lockScroll()
|
60
|
+
|
61
|
+
// Unhide the modal
|
62
|
+
this.containerTarget.classList.remove(this.toggleClass)
|
63
|
+
|
64
|
+
// Insert the background
|
65
|
+
if (!this.data.get("disable-backdrop")) {
|
66
|
+
document.body.insertAdjacentHTML("beforeend", this.backgroundHtml)
|
67
|
+
this.background = document.querySelector(`#${this.backgroundId}`)
|
68
|
+
}
|
69
|
+
}
|
70
|
+
|
71
|
+
close(e) {
|
72
|
+
if (e) e.preventDefault()
|
73
|
+
|
74
|
+
// Unlock the scroll and restore previous scroll position
|
75
|
+
this.unlockScroll()
|
76
|
+
|
77
|
+
// Hide the modal
|
78
|
+
this.containerTarget.classList.add(this.toggleClass)
|
79
|
+
|
80
|
+
// Remove the background
|
81
|
+
if (this.background) { this.background.remove() }
|
82
|
+
}
|
83
|
+
|
84
|
+
closeBackground(e) {
|
85
|
+
if (this.allowBackgroundClose && e.target === this.containerTarget) {
|
86
|
+
this.close(e)
|
87
|
+
}
|
88
|
+
}
|
89
|
+
|
90
|
+
closeWithKeyboard(e) {
|
91
|
+
if (e.keyCode === 27 && !this.containerTarget.classList.contains(this.toggleClass)) {
|
92
|
+
this.close(e)
|
93
|
+
}
|
94
|
+
}
|
95
|
+
|
96
|
+
_backgroundHTML() {
|
97
|
+
return "<div id=\"modal-background\" class=\"fixed top-0 left-0 w-full h-full\" style=\"background-color: rgba(0, 0, 0, 0.8); z-index: 9998;\"></div>"
|
98
|
+
}
|
99
|
+
|
100
|
+
lockScroll() {
|
101
|
+
// Add right padding to the body so the page doesn't shift
|
102
|
+
// when we disable scrolling
|
103
|
+
const scrollbarWidth = window.innerWidth - document.documentElement.clientWidth
|
104
|
+
document.body.style.paddingRight = `${scrollbarWidth}px`
|
105
|
+
|
106
|
+
// Save the scroll position
|
107
|
+
this.saveScrollPosition()
|
108
|
+
|
109
|
+
// Add classes to body to fix its position
|
110
|
+
document.body.classList.add("fixed", "inset-x-0", "overflow-hidden")
|
111
|
+
|
112
|
+
// Add negative top position in order for body to stay in place
|
113
|
+
document.body.style.top = `-${this.scrollPosition}px`
|
114
|
+
}
|
115
|
+
|
116
|
+
unlockScroll() {
|
117
|
+
// Remove tweaks for scrollbar
|
118
|
+
document.body.style.paddingRight = null
|
119
|
+
|
120
|
+
// Remove classes from body to unfix position
|
121
|
+
document.body.classList.remove("fixed", "inset-x-0", "overflow-hidden")
|
122
|
+
|
123
|
+
// Restore the scroll position of the body before it got locked
|
124
|
+
this.restoreScrollPosition()
|
125
|
+
|
126
|
+
// Remove the negative top inline style from body
|
127
|
+
document.body.style.top = null
|
128
|
+
}
|
129
|
+
|
130
|
+
saveScrollPosition() {
|
131
|
+
this.scrollPosition = window.pageYOffset || document.body.scrollTop
|
132
|
+
}
|
133
|
+
|
134
|
+
restoreScrollPosition() {
|
135
|
+
document.documentElement.scrollTop = this.scrollPosition
|
136
|
+
}
|
137
|
+
}
|
@@ -0,0 +1,206 @@
|
|
1
|
+
// NB Chartkick and Highcharts are defined as global in rollup
|
2
|
+
// const Chartkick = window.Chartkick
|
3
|
+
|
4
|
+
|
5
|
+
import { Controller } from "stimulus"
|
6
|
+
|
7
|
+
export default class extends Controller {
|
8
|
+
static targets = ["chart"]
|
9
|
+
|
10
|
+
connect() {
|
11
|
+
// let data = this.data.get("chartData")
|
12
|
+
// let chartId = this.chartTarget.id
|
13
|
+
|
14
|
+
// console.log(chartId)
|
15
|
+
// let json = [
|
16
|
+
// {
|
17
|
+
// name: "",
|
18
|
+
// data: data
|
19
|
+
// }
|
20
|
+
// ]
|
21
|
+
console.log("Not implemented")
|
22
|
+
//Highcharts.SparkLine(this.chartTarget, {})
|
23
|
+
// series: [{
|
24
|
+
// name: '',
|
25
|
+
// data: data
|
26
|
+
// }]
|
27
|
+
// })
|
28
|
+
//new Chartkick.LineChart(chartId, json, this.chartOptions)
|
29
|
+
}
|
30
|
+
|
31
|
+
// get chartOptions() {
|
32
|
+
// return {
|
33
|
+
// library: {
|
34
|
+
// chart: {
|
35
|
+
// type: "area",
|
36
|
+
// margin: [0, 0, 0, 0],
|
37
|
+
// height: 20,
|
38
|
+
// width: 80,
|
39
|
+
// skipClone: true,
|
40
|
+
// style: {
|
41
|
+
// overflow: "visible"
|
42
|
+
// }
|
43
|
+
// },
|
44
|
+
// credits: {
|
45
|
+
// enabled: false
|
46
|
+
// },
|
47
|
+
// title: "",
|
48
|
+
// xAxis: {
|
49
|
+
// type: "datetime",
|
50
|
+
// tickPositions: [],
|
51
|
+
// labels: {
|
52
|
+
// enabled: false
|
53
|
+
// },
|
54
|
+
// startOnTick: false,
|
55
|
+
// endOnTick: false,
|
56
|
+
// title: {
|
57
|
+
// text: null
|
58
|
+
// }
|
59
|
+
// },
|
60
|
+
// legend: {
|
61
|
+
// enabled: false
|
62
|
+
// },
|
63
|
+
// yAxis: {
|
64
|
+
// tickPositions: [0],
|
65
|
+
// endOnTick: false,
|
66
|
+
// startOnTick: false,
|
67
|
+
// title: {
|
68
|
+
// text: null
|
69
|
+
// },
|
70
|
+
// min: 0,
|
71
|
+
// labels: {
|
72
|
+
// enabled: false
|
73
|
+
// }
|
74
|
+
// },
|
75
|
+
// tooltip: {
|
76
|
+
// hideDelay: 0,
|
77
|
+
// outside: true,
|
78
|
+
// shared: true,
|
79
|
+
// xDateFormat: '%d-%b-%Y'
|
80
|
+
// },
|
81
|
+
// plotOptions: {
|
82
|
+
// series: {
|
83
|
+
// animation: false,
|
84
|
+
// lineWidth: 1,
|
85
|
+
// shadow: false,
|
86
|
+
// states: {
|
87
|
+
// hover: {
|
88
|
+
// lineWidth: 1
|
89
|
+
// }
|
90
|
+
// },
|
91
|
+
// marker: {
|
92
|
+
// radius: 1,
|
93
|
+
// states: {
|
94
|
+
// hover: {
|
95
|
+
// radius: 2
|
96
|
+
// }
|
97
|
+
// }
|
98
|
+
// },
|
99
|
+
// fillOpacity: 0.25
|
100
|
+
// },
|
101
|
+
// column: {
|
102
|
+
// negativeColor: "#910000",
|
103
|
+
// borderColor: "silver"
|
104
|
+
// }
|
105
|
+
// }
|
106
|
+
// }
|
107
|
+
// }
|
108
|
+
// }
|
109
|
+
}
|
110
|
+
/**
|
111
|
+
* Create a constructor for sparklines that takes some sensible defaults and merges in the individual
|
112
|
+
* chart options.
|
113
|
+
*/
|
114
|
+
|
115
|
+
/*
|
116
|
+
window.Highcharts.SparkLine = function (a, b, c) {
|
117
|
+
console.log("defining1");
|
118
|
+
var hasRenderToArg = typeof a === 'string' || a.nodeName,
|
119
|
+
options = arguments[hasRenderToArg ? 1 : 0],
|
120
|
+
defaultOptions = {
|
121
|
+
chart: {
|
122
|
+
renderTo: (options.chart && options.chart.renderTo) || this,
|
123
|
+
backgroundColor: null,
|
124
|
+
borderWidth: 0,
|
125
|
+
type: 'area',
|
126
|
+
margin: [2, 0, 2, 0],
|
127
|
+
width: 120,
|
128
|
+
height: 20,
|
129
|
+
style: {
|
130
|
+
overflow: 'visible'
|
131
|
+
},
|
132
|
+
|
133
|
+
// small optimalization, saves 1-2 ms each sparkline
|
134
|
+
skipClone: true
|
135
|
+
},
|
136
|
+
title: {
|
137
|
+
text: ''
|
138
|
+
},
|
139
|
+
credits: {
|
140
|
+
enabled: false
|
141
|
+
},
|
142
|
+
xAxis: {
|
143
|
+
labels: {
|
144
|
+
enabled: false
|
145
|
+
},
|
146
|
+
title: {
|
147
|
+
text: null
|
148
|
+
},
|
149
|
+
startOnTick: false,
|
150
|
+
endOnTick: false,
|
151
|
+
tickPositions: []
|
152
|
+
},
|
153
|
+
yAxis: {
|
154
|
+
endOnTick: false,
|
155
|
+
startOnTick: false,
|
156
|
+
labels: {
|
157
|
+
enabled: false
|
158
|
+
},
|
159
|
+
title: {
|
160
|
+
text: null
|
161
|
+
},
|
162
|
+
tickPositions: [0]
|
163
|
+
},
|
164
|
+
legend: {
|
165
|
+
enabled: false
|
166
|
+
},
|
167
|
+
tooltip: {
|
168
|
+
hideDelay: 0,
|
169
|
+
outside: true,
|
170
|
+
shared: true
|
171
|
+
},
|
172
|
+
plotOptions: {
|
173
|
+
series: {
|
174
|
+
animation: false,
|
175
|
+
lineWidth: 1,
|
176
|
+
shadow: false,
|
177
|
+
states: {
|
178
|
+
hover: {
|
179
|
+
lineWidth: 1
|
180
|
+
}
|
181
|
+
},
|
182
|
+
marker: {
|
183
|
+
radius: 1,
|
184
|
+
states: {
|
185
|
+
hover: {
|
186
|
+
radius: 2
|
187
|
+
}
|
188
|
+
}
|
189
|
+
},
|
190
|
+
fillOpacity: 0.25
|
191
|
+
},
|
192
|
+
column: {
|
193
|
+
negativeColor: '#910000',
|
194
|
+
borderColor: 'silver'
|
195
|
+
}
|
196
|
+
}
|
197
|
+
};
|
198
|
+
|
199
|
+
options = Highcharts.merge(defaultOptions, options);
|
200
|
+
|
201
|
+
return hasRenderToArg ?
|
202
|
+
new Highcharts.Chart(a, options, c) :
|
203
|
+
new Highcharts.Chart(options, b)
|
204
|
+
}
|
205
|
+
|
206
|
+
*/
|
@@ -0,0 +1,169 @@
|
|
1
|
+
// NB Chartkick and Highcharts are defined as global in rollup
|
2
|
+
const Highcharts = window.Highcharts // Highcharts is defined as global in rollup
|
3
|
+
const $ = window.$
|
4
|
+
import { Controller } from "stimulus"
|
5
|
+
import more from "highcharts/highcharts-more"
|
6
|
+
more(Highcharts)
|
7
|
+
|
8
|
+
export default class extends Controller {
|
9
|
+
connect() {
|
10
|
+
$.getJSON(
|
11
|
+
this.data.get("url"),
|
12
|
+
(data) => {
|
13
|
+
Highcharts.chart(this.element, {
|
14
|
+
chart: {
|
15
|
+
scrollablePlotArea: {
|
16
|
+
minWidth: 600,
|
17
|
+
scrollPositionX: 1
|
18
|
+
}
|
19
|
+
},
|
20
|
+
title: {
|
21
|
+
//text: "Peritoneal Equilibration Test",
|
22
|
+
text: "",
|
23
|
+
align: "left"
|
24
|
+
},
|
25
|
+
subtitle: {
|
26
|
+
text: "",
|
27
|
+
align: "left"
|
28
|
+
},
|
29
|
+
xAxis: {
|
30
|
+
title: {
|
31
|
+
text: "D/P creatinine (4hrs)"
|
32
|
+
},
|
33
|
+
type: "linear",
|
34
|
+
labels: {
|
35
|
+
overflow: "justify"
|
36
|
+
},
|
37
|
+
plotBands: [{
|
38
|
+
from: 0.3,
|
39
|
+
to: 0.5,
|
40
|
+
color: "rgba(68, 170, 213, 0.1)",
|
41
|
+
label: {
|
42
|
+
text: "Low",
|
43
|
+
style: {
|
44
|
+
color: "#606060"
|
45
|
+
}
|
46
|
+
}
|
47
|
+
}, {
|
48
|
+
from: 0.5,
|
49
|
+
to: 0.65,
|
50
|
+
color: "rgba(0, 0, 0, 0)",
|
51
|
+
label: {
|
52
|
+
text: "Low average",
|
53
|
+
style: {
|
54
|
+
color: "#606060"
|
55
|
+
}
|
56
|
+
}
|
57
|
+
}, {
|
58
|
+
from: 0.65,
|
59
|
+
to: 0.82,
|
60
|
+
color: "rgba(68, 170, 213, 0.1)",
|
61
|
+
label: {
|
62
|
+
text: "High average",
|
63
|
+
style: {
|
64
|
+
color: "#606060"
|
65
|
+
}
|
66
|
+
}
|
67
|
+
}, {
|
68
|
+
from: 0.82,
|
69
|
+
to: 1.0,
|
70
|
+
color: "rgba(0, 0, 0, 0)",
|
71
|
+
label: {
|
72
|
+
text: "High",
|
73
|
+
style: {
|
74
|
+
color: "#606060"
|
75
|
+
}
|
76
|
+
}
|
77
|
+
}]
|
78
|
+
},
|
79
|
+
yAxis: {
|
80
|
+
title: {
|
81
|
+
text: "Net Ultrafiltration (mls)"
|
82
|
+
},
|
83
|
+
tickInterval: 200,
|
84
|
+
minorGridLineWidth: 0,
|
85
|
+
gridLineWidth: 0,
|
86
|
+
alternateGridColor: null,
|
87
|
+
floor: -600,
|
88
|
+
plotLines: [{
|
89
|
+
color: "#BBB",
|
90
|
+
width: 1,
|
91
|
+
value: 0
|
92
|
+
}]
|
93
|
+
},
|
94
|
+
|
95
|
+
tooltip: {
|
96
|
+
formatter: function () {
|
97
|
+
return "<br>D_Pcr <b>" + this.x + "</b><br>" +
|
98
|
+
"netUF <b>" + this.y + "</b>"
|
99
|
+
}
|
100
|
+
},
|
101
|
+
plotOptions: {
|
102
|
+
pointStart: 0.3,
|
103
|
+
line: {
|
104
|
+
dataLabels: {
|
105
|
+
enabled: true,
|
106
|
+
format: "{point.index}",
|
107
|
+
style: {
|
108
|
+
fontSize: "15px"
|
109
|
+
}
|
110
|
+
}
|
111
|
+
},
|
112
|
+
series: {
|
113
|
+
enableMouseTracking: false
|
114
|
+
},
|
115
|
+
dataLabels: {
|
116
|
+
enabled: true,
|
117
|
+
style: {
|
118
|
+
fontWeight: "bold"
|
119
|
+
}
|
120
|
+
}
|
121
|
+
},
|
122
|
+
series: [
|
123
|
+
{
|
124
|
+
name: "Expected",
|
125
|
+
color: "#00a499", //"#D970D9",
|
126
|
+
showInLegend: true,
|
127
|
+
type: "polygon",
|
128
|
+
data: [
|
129
|
+
[0.36,400],
|
130
|
+
[0.36,1000],
|
131
|
+
[0.5,1000],
|
132
|
+
[0.9,600],
|
133
|
+
[0.9,300],
|
134
|
+
[0.6,100],
|
135
|
+
[0.36,400]
|
136
|
+
]
|
137
|
+
},
|
138
|
+
{
|
139
|
+
name: "Warning",
|
140
|
+
color: "#fff495",
|
141
|
+
showInLegend: true,
|
142
|
+
type: "polygon",
|
143
|
+
data: [
|
144
|
+
[0.6,100],
|
145
|
+
[0.9,300],
|
146
|
+
[1.0,200],
|
147
|
+
[1.0,-600],
|
148
|
+
[0.75,-600],
|
149
|
+
[0.6,100]
|
150
|
+
]
|
151
|
+
},
|
152
|
+
{
|
153
|
+
// patient data
|
154
|
+
color: "#040481",
|
155
|
+
showInLegend: false,
|
156
|
+
enableMouseTracking: true,
|
157
|
+
data: data
|
158
|
+
}],
|
159
|
+
navigation: {
|
160
|
+
menuItemStyle: {
|
161
|
+
fontSize: "10px"
|
162
|
+
}
|
163
|
+
}
|
164
|
+
})
|
165
|
+
this.element.style.overflow = "unset"
|
166
|
+
}
|
167
|
+
)
|
168
|
+
}
|
169
|
+
}
|