Items Mapping

31 Mar 20179 minutes to read

External data source can be mapped with HeatMap using itemsMapping property. It supports 2 kind of data source.

  • In TableMapping rows represents an objects in collection, columns represents numerical properties of that object.
  • In CellMapping each cell represent an object in collection, this collection is grouped based on specific property to form as rows and columns.

Let us see the difference between two types of mapping. Following table represents two different data structure to represent the same HeatMap.

CellMapping TableMapping
  • RAZOR
  • public ActionResult CellMapping()
            {
                CellMapping CellMapping = new CellMapping();
                CellMapping.Column = new PropertyMapping() { PropertyName = "ProductName", DisplayName = "Product Name" };
                CellMapping.Row = new PropertyMapping() { PropertyName = "Year", DisplayName = "Year" };
                CellMapping.Value = new PropertyMapping() { PropertyName = "Value" };
                Collection columnMapping = new Collection();
                columnMapping.Add(new HeaderMapping() { PropertyName = "Vegie-spread", DisplayName = "Vegie-spread" });
                columnMapping.Add(new HeaderMapping() { PropertyName = "Tofuaa", DisplayName = "Tofuaa" });
                columnMapping.Add(new HeaderMapping() { PropertyName = "Alice Mutton", DisplayName = "Alice Mutton" });
                columnMapping.Add(new HeaderMapping() { PropertyName = "Konbu", DisplayName = "Konbu" });
                columnMapping.Add(new HeaderMapping() { PropertyName = "Fløtemysost", DisplayName = "Fløtemysost" });
                columnMapping.Add(new HeaderMapping() { PropertyName = "Perth Pasties", DisplayName = "Perth Pasties" });
                CellMapping.ColumnMapping = columnMapping;
                HeaderMapping headerMapping = new HeaderMapping() { PropertyName = "Year", DisplayName = "Year", ColumnStyle = new ColumnStyle() { Width = 105, TextAlign = HeatMapTextAlign.Right } };
                CellMapping.HeaderMapping = headerMapping;
                ViewBag.itemsource = GetCellSource();
                ViewBag.itemsmapping = CellMapping;
                List<string> collection = new List<string>();
                collection.Add("heatmapLegend");
                ViewBag.legendcollection = collection;
                return View();
            }
            public Collection GetCellSource()
            {
                Collection collection = new Collection();
                string[] name = { "Vegie-spread", "Tofuaa", "Alice Mutton", "Konbu", "Fløtemysost", "Perth Pasties" };
                Random random = new Random();
    
                foreach (string item in name)
                {
                    for (int i = 0; i < 6; i++)
                    {
                        double value = random.Next(0, random.Next(0, 100));
                        collection.Add(new SampleCellData() { ProductName = item, Year = "Y" + (2011 + i), Value = value });
                    }
                }
                return collection;
            }
  • RAZOR
  • public ActionResult TableMapping()
                 {
                    TableMapping TableMapping = new TableMapping();
                    TableMapping.HeaderMapping = new HeaderMapping() { PropertyName = "ProductName", DisplayName = "Product Name", ColumnStyle = new ColumnStyle() { Width = 140, TextAlign = HeatMapTextAlign.Right } };
                    TableMapping.ColumnMapping.Add(new HeaderMapping() { PropertyName = "Y2010", DisplayName = "Y2010" });
                    TableMapping.ColumnMapping.Add(new HeaderMapping() { PropertyName = "Y2011", DisplayName = "Y2011" });
                    TableMapping.ColumnMapping.Add(new HeaderMapping() { PropertyName = "Y2012", DisplayName = "Y2012" });
                    TableMapping.ColumnMapping.Add(new HeaderMapping() { PropertyName = "Y2013", DisplayName = "Y2013" });
                    TableMapping.ColumnMapping.Add(new HeaderMapping() { PropertyName = "Y2014", DisplayName = "Y2014" });
                    TableMapping.ColumnMapping.Add(new HeaderMapping() { PropertyName = "Y2015", DisplayName = "Y2015" });
                    ViewBag.itemsource = GetTableSource();
                    ViewBag.itemsmapping = TableMapping;
                    List<string> collection = new List<string>();
                    collection.Add("heatmapLegend");
                    ViewBag.legendcollection = collection;
                    return View();
                }
                public Collection GetTableSource()
                {
                    Collection collection = new Collection();
                    Random random = new Random();
                    string[] rows = { "Vegie-spread", "Tofuaa", "Alice Mutton", "Konbu", "Fløtemysost", "Perth Pasties", "Boston Crab Meat", "Raclette Courdavault" };
                    for (int i = 0; i < 8; i++)
                    {
                        collection.Add(new SampleTableData()
                        {
                            ProductName = rows[i],
                            Y2010 = random.Next(0, 100),
                            Y2011 = random.Next(0, 100),
                            Y2012 = random.Next(0, 100),
                            Y2013 = random.Next(0, 100),
                            Y2014 = random.Next(0, 100),
                            Y2015 = random.Next(0, 100)
                        });
                    }
                    return collection;
                }
    Here, a single `ProductInfo` object represent a value for a particular product in a particular year Here, a single `ProductInfo` object represents value for a particular product from year 2010 to 2015.
  • RAZOR
  • <ej-heatmap is-responsive="true" id="heatmap" width="830" items-source="ViewBag.itemsource" items-mapping="ViewBag.itemsmapping" legend-collection="ViewBag.legendcollection">             
                   </ej-heatmap>
  • RAZOR
  • <ej-heatmap is-responsive="true" id="heatmap" width="950" items-source="ViewBag.itemsource" items-mapping="ViewBag.itemsmapping" legend-collection="ViewBag.legendcollection">            
                 </ej-heatmap>