This commit is contained in:
santiago.sferco 2024-07-04 14:26:31 -03:00
parent ad3c3f8e33
commit 3ec4ca0325

View File

@ -4,78 +4,97 @@ defmodule DerivantesWeb.DerivantesLive do
import Ecto.Query import Ecto.Query
def mount(_params, _session, socket) do def mount(_params, _session, socket) do
{:ok, filters = to_form(%{}, as: "filters")
socket {:ok,
|> assign(studies: get_studies(socket)) socket
} |> assign(studies: get_studies(socket, %{}))
|> assign(filters: filters)
}
end end
def render(assigns) do def render(assigns) do
~H""" ~H"""
<div> <div>
<%= if length(@studies) > 0 do %> <div class="pantalla_estudios_header">
<div class="estudio_patientname"> <img src={~p"/images/sana_americano_logo.png"} alt="IM LOGO"/>
<h1>Bienvenido, <%= @current_user.email %> </h1> </div>
<p>Para ver un estudio haga click en el icono de Informe o de Imágenes.</p> <div class="estudio_patientname">
</div> <h1>Bienvenido, <%= @current_user.email %> </h1>
<div class="estudio_container"> <p>Para ver un estudio haga click en el icono de Informe o de Imágenes.</p>
<div class="estudio_details"> </div>
<p>Estudios</p> <div>
</div> <.simple_form
<div class="estudio_icons"> for={@filters}
<p>Informe</p> id="filters"
<p>Imágenes</p> phx-update="ignore"
</div> phx-submit="filter_study"
</div> >
<%= for study <- @studies do %> <.input field={@filters[:dni]} type="text"/>
<div class="estudio_container"> <.input field={@filters[:accession]} type="text"/>
<div class="estudio_details"> <:actions>
<p><b>Fecha y hora:</b> <%= format_date(study.fecha) %> - <%= format_hour(study.hora) %></p> <.button phx-disable-with="Buscando..." class="w-full">Buscar</.button>
<p><b>DNI:</b> <%= study.dni %></p> </:actions>
<p><b>Accession N°</b> <%= study.accession %></p> </.simple_form>
<p><b>Matricula derivante</b> <%= @current_user.matricula %></p> </div>
<%= if length(@studies) > 0 do %>
<div class="estudio_container">
<div class="estudio_details">
<p>Estudios</p>
</div>
<div class="estudio_icons">
<p>Informe</p>
<p>Imágenes</p>
</div>
</div>
<%= for study <- @studies do %>
<div class="estudio_container">
<div class="estudio_details">
<p><b>Fecha y hora:</b> <%= format_date(study.fecha) %> - <%= format_hour(study.hora) %></p>
<p><b>DNI:</b> <%= study.dni %></p>
<p><b>Accession N°</b> <%= study.accession %></p>
<p><b>Matricula derivante</b> <%= @current_user.matricula %></p>
</div> </div>
<div class="estudio_icons"> <div class="estudio_icons">
<%= case {study.modality, study.esteco, study.estrx} do %> <%= case {study.modality, study.esteco, study.estrx} do %>
<% {"US", "F", _} -> %> <% {"US", "F", _} -> %>
<a href={"https://sga.sanatorio-americano.com.ar/diagnostico/impeco.asp?id=#{study.accession}"} target="_blank" style="color: #297177"> <a href={"https://sga.sanatorio-americano.com.ar/diagnostico/impeco.asp?id=#{study.accession}"} target="_blank" style="color: #297177">
<i class="fa-regular fa-file-lines fa-3x" style="color: #297177"></i> <i class="fa-regular fa-file-lines fa-3x" style="color: #297177"></i>
</a> </a>
<% {modality, _, "E"} when modality != "US" -> %> <% {modality, _, "E"} when modality != "US" -> %>
<a href={"https://ed.sanatorio-americano.com.ar/cgi-bin/minisite.bf/pdfonthefly/#{study.accession}"} target="_blank" style="color: #297177"> <a href={"https://ed.sanatorio-americano.com.ar/cgi-bin/minisite.bf/pdfonthefly/#{study.accession}"} target="_blank" style="color: #297177">
<i class="fa-regular fa-file-lines fa-3x" style="color: #297177"></i> <i class="fa-regular fa-file-lines fa-3x" style="color: #297177"></i>
</a> </a>
<% _ -> %> <% _ -> %>
<i class="fa-solid fa-file-circle-question fa-3x" style="color: #DCDCDC"></i> <i class="fa-solid fa-file-circle-question fa-3x" style="color: #DCDCDC"></i>
<% end %> <% end %>
<%= if study.modality != "US" do %> <%= if study.modality != "US" do %>
<a href={"https://imagenes.sanatorio-americano.com.ar/portal/Default.aspx?user_name=urlusr&password=1nt3gr4c10n$$$&accession_number=#{study.accession}"} target="_blank" style="color: #297177"> <a href={"https://imagenes.sanatorio-americano.com.ar/portal/Default.aspx?user_name=urlusr&password=1nt3gr4c10n$$$&accession_number=#{study.accession}"} target="_blank" style="color: #297177">
<i class="fa-solid fa-file-circle-check fa-3x" style="color: #297177"></i> <i class="fa-solid fa-file-circle-check fa-3x" style="color: #297177"></i>
</a> </a>
<% else %> <% else %>
<i class="fa-solid fa-file-circle-question fa-3x" style="color: #DCDCDC"></i> <i class="fa-solid fa-file-circle-question fa-3x" style="color: #DCDCDC"></i>
<% end %> <% end %>
</div> </div>
</div> </div>
<% end %> <% end %>
<% else %> <% else %>
<div> <div>
<h1> <h1>
No hay estudios para mostrar No hay estudios para mostrar
</h1> </h1>
</div> </div>
<% end %> <% end %>
</div> </div>
""" """
end end
def format_date(date_string) when is_binary(date_string) do def format_date(date_string) when is_binary(date_string) do
anio = String.slice(date_string, 0..3) anio = String.slice(date_string, 0..3)
mes = String.slice(date_string, 4..5) mes = String.slice(date_string, 4..5)
dia = String.slice(date_string, 6..7) dia = String.slice(date_string, 6..7)
"#{dia}/#{mes}/#{anio}" "#{dia}/#{mes}/#{anio}"
end end
def format_hour(hour_string) when is_binary(hour_string) do def format_hour(hour_string) when is_binary(hour_string) do
hora = String.slice(hour_string, 0..1) hora = String.slice(hour_string, 0..1)
@ -84,26 +103,61 @@ defmodule DerivantesWeb.DerivantesLive do
"#{hora}:#{minutos}:#{segundos}" "#{hora}:#{minutos}:#{segundos}"
end end
def get_studies(socket) do def get_studies(socket, filter) do
query = from vl in "V_LISTAINGRESOS",
select: %{ keys = Map.keys(filter)
idstudy: field(vl, :ID), IO.inspect(keys)
estrx: field(vl, :ESTRX), mat_filter = dynamic([vl], vl.matder == ^socket.assigns.current_user.matricula)
esteco: field(vl, :ESTECO), filter_conditions =
# desc: field(vl, :PROD_DESC), Enum.reduce(keys, mat_filter, fn v, filter_conditions ->
hora: field(vl, :START_TIME), case v do
fecha: field(vl, :START_DATE), "dni" ->
modality: field(vl, :MODALITY), if(filter["dni"] != "") do
dni: field(vl, :TIPO_DOCUMENTO), dynamic([vl], vl.tipo_documento == ^filter["dni"] and ^filter_conditions)
lastname: field(vl, :PATIENTLASTNAME), else
accession: field(vl, :ACCESSIONNUMBER), filter_conditions
patientname: field(vl, :PATIENTFIRSTNAME) end
}, "accession" ->
where: field(vl, :MATDER) == ^socket.assigns.current_user.matricula, if(filter["accession"] != "") do
order_by: [desc: field(vl, :START_DATE)], dynamic([vl], vl.accessionnumber == ^filter["accession"] and ^filter_conditions)
limit: 20 else
estudios = Derivantes.TdsRepo.all(query) filter_conditions
estudios end
_ ->
filter_conditions
end
end)
query = from vl in "V_LISTAINGRESOS",
select: %{
idstudy: field(vl, :ID),
estrx: field(vl, :ESTRX),
esteco: field(vl, :ESTECO),
# desc: field(vl, :PROD_DESC),
hora: field(vl, :START_TIME),
fecha: field(vl, :START_DATE),
modality: field(vl, :MODALITY),
dni: field(vl, :TIPO_DOCUMENTO),
lastname: field(vl, :PATIENTLASTNAME),
accession: field(vl, :ACCESSIONNUMBER),
patientname: field(vl, :PATIENTFIRSTNAME)
},
where: ^filter_conditions,
order_by: [desc: field(vl, :START_DATE)],
limit: 20
estudios = Derivantes.TdsRepo.all(query)
estudios
end end
def handle_event(event, params, socket) do
case event do
"filter_study" ->
studies = get_studies(socket, params["filters"])
{:noreply,
socket
|> assign(studies: studies)
}
end
end
end end