public void AddPlotBand(TheographPlotBandData plotBand)
        {
            if (this.PlotBands == null)
            {
                this.PlotBands = new List <TheographPlotBandData>();
            }

            this.PlotBands.Add(plotBand);
        }
Example #2
0
        internal static TheographChartViewModel GetPatientEpsiodesChart(PatientEpisodes patientEpisodes)
        {
            TheographChartViewModel output = new TheographChartViewModel();

            var episodeGroups = patientEpisodes.Episodes.GroupBy(x => x.EpisodeType.DisplayName);
            var xAxis         = new TheographAxisData
            {
                Type     = "datetime",
                Min      = DateTime.Today.AddYears(-1).ToHighchartsTime(),
                Max      = DateTime.Today.AddDays(1).ToHighchartsTime(),
                MinRange = 1000 * 60 * 60 * 24, // max zoom of 1 day,
            };

            xAxis.DateTimeLabelFormats = new TheographDataTimeLabelFormatData
            {
                Month = "%b %y",
                Week  = "%e %b",
                Day   = "%e %b"
            };

            var yAxis = new TheographAxisData();

            const int height = 100;

            yAxis.TickInterval = height;
            yAxis.Max          = episodeGroups.Count() * height;
            yAxis.MinRange     = episodeGroups.Count() * height;
            yAxis.Labels       = new TheographAxisLabelData();
            yAxis.Title        = new TheographTitleData();

            for (int i = 0; i < episodeGroups.Count(); i++)
            {
                var episodeGroup = episodeGroups.ElementAt(i);

                var series = new TheographChartSeries
                {
                    Name = episodeGroup.Key
                };

                var plotBand = new TheographPlotBandData
                {
                    From  = i * height,
                    To    = (i + 1) * height,
                    Color = (i % 2 == 0) ? "rgba(68, 170, 213, 0.1)" : null
                };

                plotBand.Label.Text = episodeGroup.Key;

                var orderedEpsiodes = episodeGroup.OrderBy(x => x.StartTime);

                foreach (var orderedEpsiode in orderedEpsiodes)
                {
                    int    yPoint       = ((i + 1) * height) - (height / 2);
                    string tooltipTitle = string.Format("{0}{1}",
                                                        episodeGroup.Key,
                                                        orderedEpsiode.TreatmentSite != null ? " at " + orderedEpsiode.TreatmentSite.Name : string.Empty);
                    StringBuilder sbToolTipText = new StringBuilder();
                    sbToolTipText.AppendFormat(
                        "Start: {0:ddd MMMM} <sup>{1}</sup> {0:yyyy HH:mm}",
                        orderedEpsiode.StartTime,
                        orderedEpsiode.StartTime.GetDayOrdinal());

                    if (orderedEpsiode.EndTime.HasValue)
                    {
                        sbToolTipText.AppendFormat(
                            "<br/>End: {0:ddd MMMM} <sup>{1}</sup> {0:yyyy HH:mm}",
                            orderedEpsiode.EndTime.Value,
                            orderedEpsiode.EndTime.Value.GetDayOrdinal());
                    }

                    // start point
                    var dataPoint = new TheographChartSeriesData
                    {
                        // * 1000 to conform with the Highcharts way of handling dates
                        EpisodeStartTimestamp = orderedEpsiode.StartTime.ToHighchartsTime(),
                        Y = yPoint
                    };

                    dataPoint.AddData("tooltipTitle", tooltipTitle);
                    dataPoint.AddData("tooltipText", sbToolTipText.ToString());
                    dataPoint.AddData("episodeId", orderedEpsiode.EpisodeId.Value);

                    series.Data.Add(dataPoint);

                    // end point
                    if (orderedEpsiode.EndTime.HasValue)
                    {
                        dataPoint = new TheographChartSeriesData
                        {
                            // * 1000 to conform with the Highcharts way of handling dates
                            EpisodeStartTimestamp = orderedEpsiode.EndTime.Value.ToHighchartsTime(),
                            Y = yPoint
                        };

                        dataPoint.AddData("tooltipTitle", tooltipTitle);
                        dataPoint.AddData("tooltipText", sbToolTipText.ToString());
                        dataPoint.AddData("episodeId", orderedEpsiode.EpisodeId.Value);

                        series.Data.Add(dataPoint);
                    }

                    // add null-value point to disconnect separate epsiodes
                    var dataNullPoint = new TheographChartSeriesData
                    {
                        EpisodeStartTimestamp = dataPoint.EpisodeStartTimestamp + 1,
                        Y = null
                    };

                    series.Data.Add(dataNullPoint);
                }

                output.Series.Add(series);
                yAxis.AddPlotBand(plotBand);
            }

            output.Axes.Add("x", xAxis);
            output.Axes.Add("y", yAxis);

            return(output);
        }
Example #3
0
        internal static TheographChartViewModel GetPatientEpsiodeEventsChart(PatientEpisode patientEpisode)
        {
            TheographChartViewModel output = new TheographChartViewModel();

            if (patientEpisode.Episode.Events.Count == 0)
            {
                return(output);
            }

            var eventGroups = patientEpisode.Episode.Events.GroupBy(x => x.EventType.DisplayName);

            var maxEventEndTime = patientEpisode.Episode.Events.Select(x => x.StartTime)
                                  .Union(patientEpisode.Episode.Events.Where(x => x.EndTime.HasValue).Select(x => x.EndTime.Value))
                                  .Max();

            DateTime start = patientEpisode.Episode.StartTime;
            DateTime end   = start;

            // set a sensible end time
            if (patientEpisode.Episode.EndTime.HasValue)
            {
                end = patientEpisode.Episode.EndTime.Value;
            }
            else
            {
                end = maxEventEndTime;
            }

            var xAxis = new TheographAxisData
            {
                Type         = "datetime",
                Min          = start.AddHours(-1).ToHighchartsTime(),
                Max          = end.AddHours(1).ToHighchartsTime(),
                TickInterval = 1000 * 60 * 30,
                MinRange     = 1000 * 60 * 60, // max zoom of 1 hour
            };

            var yAxis      = new TheographAxisData();
            var yPlotBands = new List <TheographPlotBandData>();

            const int height = 100;

            yAxis.TickInterval = height;
            yAxis.Max          = eventGroups.Count() * height;
            yAxis.MinRange     = eventGroups.Count() * height;
            yAxis.Labels       = new TheographAxisLabelData();
            yAxis.Title        = new TheographTitleData();

            for (int i = 0; i < eventGroups.Count(); i++)
            {
                var eventGroup = eventGroups.ElementAt(i);

                var series = new TheographChartSeries
                {
                    Name = eventGroup.Key
                };

                var plotBand = new TheographPlotBandData
                {
                    From  = i * height,
                    To    = (i + 1) * height,
                    Color = (i % 2 == 0) ? "rgba(68, 170, 213, 0.1)" : null
                };

                plotBand.Label.Text = eventGroup.Key;

                var orderedEvents = eventGroup.OrderBy(x => x.StartTime);

                foreach (var orderedEvent in orderedEvents)
                {
                    int yPoint = ((i + 1) * height) - (height / 2);

                    StringBuilder sbToolTipText = new StringBuilder();

                    string tooltipTitle = eventGroup.Key;

                    IResultsEvent resultsEvent = orderedEvent as IResultsEvent;

                    if (resultsEvent != null)
                    {
                        if (resultsEvent.Results.Count > 1)
                        {
                            tooltipTitle = string.Format("{0} : {1}",
                                                         eventGroup.Key,
                                                         orderedEvent.Code.DisplayName);

                            foreach (var result in resultsEvent.Results)
                            {
                                sbToolTipText.AppendFormat(
                                    "{0}{1}",
                                    sbToolTipText.Length == 0 ? string.Empty : "<br/>",
                                    result.GetDisplayValue());
                            }
                        }
                        else if (resultsEvent.Results.Count == 1)
                        {
                            sbToolTipText.AppendFormat(
                                "{0} : {1}",
                                orderedEvent.Code.DisplayName,
                                resultsEvent.Results[0].GetDisplayValue());
                        }
                    }

                    sbToolTipText.AppendFormat(
                        "{0}{1:ddd MMMM} <sup>{2}</sup> {1:yyyy HH:mm}",
                        sbToolTipText.Length == 0 ? string.Empty : "<br/>",
                        orderedEvent.StartTime,
                        orderedEvent.StartTime.GetDayOrdinal());

                    if (orderedEvent.EndTime.HasValue)
                    {
                        sbToolTipText.AppendFormat(
                            " to {0:ddd MMMM} <sup>{1}</sup> {0:yyyy HH:mm}",
                            orderedEvent.EndTime.Value,
                            orderedEvent.EndTime.Value.GetDayOrdinal());
                    }

                    // start point
                    var dataPoint = new TheographChartSeriesData
                    {
                        // * 1000 to conform with the Highcharts way of handling dates
                        EpisodeStartTimestamp = orderedEvent.StartTime.ToHighchartsTime(),
                        Y = yPoint
                    };

                    dataPoint.AddData("tooltipTitle", tooltipTitle);
                    dataPoint.AddData("tooltipText", sbToolTipText.ToString());
                    dataPoint.AddData("episodeId", orderedEvent.EpisodeId.Value);

                    series.Data.Add(dataPoint);

                    // end point
                    if (orderedEvent.EndTime.HasValue)
                    {
                        dataPoint = new TheographChartSeriesData
                        {
                            // * 1000 to conform with the Highcharts way of handling dates
                            EpisodeStartTimestamp = orderedEvent.EndTime.Value.ToUnixTime() * 1000,
                            Y = yPoint
                        };

                        dataPoint.AddData("tooltipTitle", tooltipTitle);
                        dataPoint.AddData("tooltipText", sbToolTipText.ToString());
                        dataPoint.AddData("episodeId", orderedEvent.EpisodeId.Value);

                        series.Data.Add(dataPoint);
                    }

                    // add null-value point to disconnect separate epsiodes
                    var dataNullPoint = new TheographChartSeriesData
                    {
                        EpisodeStartTimestamp = dataPoint.EpisodeStartTimestamp + 1,
                        Y = null
                    };

                    series.Data.Add(dataNullPoint);
                }

                output.Series.Add(series);
                yAxis.AddPlotBand(plotBand);
            }

            var xPlotBands = new List <TheographPlotBandData>();

            xAxis.AddPlotBand(new TheographPlotBandData
            {
                From  = start.ToHighchartsTime(),
                To    = end.ToHighchartsTime(),
                Color = "rgba(190, 220, 240, 0.35)"
            });

            output.Axes.Add("x", xAxis);
            output.Axes.Add("y", yAxis);

            return(output);
        }