jonny
jonny

Reputation: 797

highcharts not working properly

I want to make a highchart like this http://jsfiddle.net/gh/get/jquery/1.7.2/highslide-software/highcharts.com/tree/master/samples/highcharts/demo/line-labels/ I have a stored procedure which count all room type reserved for every month (january :double 2,triple 4..) I need to transmit I parameter to my stored procedure in Roomtypereservations.RoomTypeByDate(i); When i is 1 I get data for january, i is 2 data for february......

  public ActionResult Gresit()
    {
   DBContext.Current.Open();

  List<Series> allSeries = new List<Series>();
  List<Roomtypereservations> rezervari = new List<Roomtypereservations>();
  for (int i =1; i < 13; i++)
  {
      rezervari = Roomtypereservations.RoomTypeByDate(i);
      var results = new object[4];

      foreach (var a in rezervari)
      {
          results = (new object[] { a.NumRezervari });

          allSeries.Add(new Series
      {
          Name = a.Room_Type,

    //Data = new Data(myData)
          Data = new Data(results.ToArray())

      });
      }
  };


      Highcharts charts = new Highcharts("chart")
          .InitChart(new Chart { DefaultSeriesType = ChartTypes.Spline, })
          .SetTitle(new Title { Text = "Gradul De Ocupare pe luni" })
          .SetXAxis(new XAxis { Categories = Reservation.Categories })
          .SetYAxis(new YAxis
          {
              Title = new YAxisTitle { Text = "Numarul de Camere" },
              Labels = new YAxisLabels { Step = 5, Formatter = "function() { return this.value}" }

          })
          .SetTooltip(new Tooltip
          {
              Crosshairs = new Crosshairs(true),
              Shared = true
          })
          .SetPlotOptions(new PlotOptions
          {
              Spline = new PlotOptionsSpline
              {
                  Marker = new PlotOptionsSeriesMarker
                  {
                      Radius = 4,
                      LineColor = ColorTranslator.FromHtml("#666666"),
                      LineWidth = 1
                  }
              }
          })
          .SetSeries(allSeries.Select(s => new Series { Name = s.Name, Data = s.Data }).ToArray());

      return View(charts);

    }

But I am doing something wrong because I get this: All my data is showed for january. What am I doing wrong? enter image description here

Upvotes: 1

Views: 965

Answers (1)

Linger
Linger

Reputation: 15048

That is because you are looping through and creating a series for each data point. You need to take the allSeries.Add statement out of the foreach structure. Try using the below modified for structure:

for (int i =1; i < 13; i++)
{
  rezervari = Roomtypereservations.RoomTypeByDate(i);
  var results = new List<object>();

  foreach (var a in rezervari)
  {
    results.Add(a.NumRezervari);
  }

  allSeries.Add(new Series
  {
    Name = a.Room_Type,
    Data = new Data(results.ToArray())
  });
}

By the looks of it you are creating up to 12 different Series.

Upvotes: 4

Related Questions