ASP.NET Core MVC コントロールヘルプ
カスタムタイル
コントロールの使用 > DashboardLayout > チュートリアル > カスタムタイル

This walkthrough depicts how you can customize the tile header and the tile content. The walkthrough lets you accomplish the following customizations.

  1. Hide the default toolbar and the default header.
  2. Modify the tile header to display a custom title.
  3. Update the tile content.

The topic comprises the following steps.

Create an MVC Application

Create a new MVC application using the ComponentOne or VisualStudio templates. For more information about creating an MVC application, see Configuring your MVC Application topic.

Add Data to the Application

  1. Add a new class to the Models folder (Name: DashboardData.cs). For more information on how to add a new model, see Adding Controls.
  2. Replace the following code in the DashboardData.cs model to define the classes that serve as a datasource for the different controls rendered in the DashboardLayout control.
    C#
    コードのコピー
    using System;
    using System.Collections.Generic;
    using System.Linq;
    using System.Web;
    
    namespace CustomTile.Models
    {
        public class DashboardData
        {
            private IEnumerable<CountryData> _countryDetails = null;
            public IEnumerable<CountryData> CountryDetails
            {
                get
                {
                    if (_countryDetails == null)
                    {
                        _countryDetails = GetCountryData();
                    }
                    return _countryDetails;
                }
            }
    
            public IEnumerable<CountryData> GetCountryData()
            {
                var rand = new Random(0);
                var countryID = new[] { "CR001", "CR002", "CR003", "CR004", "CR005", "CR006" };
                var countries = new[] { "US", "Germany", "UK", "Japan", "China", "India" };          
    
                var list = countries.Select((c, i) =>
                {
                    double sales = rand.Next(1, 6);
                    double budget = rand.Next(1, 9);
                    double expenses = rand.Next(1, 6);
                    return new CountryData { ID = countryID[i], Country = c, Sales = sales, Budget = budget, Expenses = expenses };
                });
                return list;
            }
        }
        public class CountryData
        {
            public string ID { get; set; }
            public string Country { get; set; }
            public double Sales { get; set; }
            public double Budget { get; set; }
            public double Expenses { get; set; }
        }
    }
    
Back to Top

Add Controller to the Application

  1. In the Solution Explorer, right click the folder Controllers.
  2. From the context menu, select Add | Controller. The Add Scaffold dialog appears.
  3. In the Add Scaffold dialog, follow these steps:
    1. Select the MVC 5 Controller - Empty template, and then click Add.
    2. Set name of the controller (for example: DashboardController).
    3. Click Add.
  4. Include the following references as shown below.
    C#
    コードのコピー
    using <ApplicationName>.Models;
    

  5. Replace the Index() method with the following method.
    DashboardController.cs
    コードのコピー
    public ActionResult Index()
            {
                DashboardData data = new DashboardData();    
                return View(data.CountryDetails);
            }
    
Back to Top

Add View to the Application

  1. From the Solution Explorer, expand the folder Controllers and double click the DashboardController.
  2. Place the cursor inside the method Index().
  3. Right click and select Add View. The Add View dialog appears.
  4. In the Add View dialog, verify that the View name is Index and View engine is Razor (CSHTML).
  5. Click Add to add a view for the controller, and then copy the following codes and paste it inside Index.cshtml.

    The code snippet provided below shows how to handle the OnClientFormatTile event provided by DashboardLayout class to create custom tiles for the DashboardLayout control.

    The event argument for this event is of type TileFormattedEventArgs and provides access to different elements of the tile. In the sample code below, the tile header text is accessed by using the “headerText” property, the header element is accessed using “headerElement” property and the “contentElement” property is used to access the content of the tile. These properties have been used to update the header content and the tile content.
    Index.cshtml
    コードのコピー
    <script type="text/javascript">
        function formatTile(sender, e) {
            var dashboard = sender, // DashboardLayoutコントロールを取得します
                tile = e.tile; // 書式設定されたタイルを取得します
    
            switch (tile.headerText) {
                case 'Sales Dashboard': UpdateHeader(e.headerElement);
                    break;
                case 'Country': UpdateTileContent(e.tile, e.contentElement);
                    break;
            }
        }
        // ヘッダータイトルを変更します
        function UpdateHeader(header) {
            var headerText = 'Sales Dashboard for 2018';
            header.querySelector('span.title').innerText = headerText;
        }
        // タイルの内容を更新します
        function UpdateTileContent(tile, contentElement) {
            var grid = wijmo.Control.getControl('#salesDashboardFGrid');
    
            if (grid && grid.selectedItems && grid.selectedItems.length) {
                var selectedRowData = grid.selectedItems[0];
                tile.hostElement.style.backgroundColor = '#009ccc';
                var htmlContent = '<div style="color:white;">Country</div>' +
                    '<div style="font-size:72px; text-align: center; color:white;overflow:hidden; text-overflow:ellipsis">' + selectedRowData.Country + '</div>';
                contentElement.innerHTML = htmlContent;
            }
        }
        function gridSelectionChanged(sender, e) {
            // グリッドでselectionChangedイベントが発生した後でDashboardLayoutコントロールを更新します
            var dashboard = wijmo.Control.getControl('#custom');
            dashboard.refresh();
        }
    </script>           
    

    The code snippet provided below initializes a DashboardLayout control and the controls that are to be rendered inside the DashboardLayout control.
    Index.cshtml
    コードのコピー
    @using <ApplicationName>.Models
    @using C1.Web.Mvc.Grid;
    @model IEnumerable<CountryData>
    
    <script type="text/javascript">
            c1.documentReady(function () {
                var dashboard = wijmo.Control.getControl("#custom");
                dashboard.refresh();
            });
            function formatTile(sender, e) {
                var dashboard = sender, // DashboardLayoutコントロールを取得します
                    tile = e.tile; // 書式設定されたタイルを取得します
    
                switch (tile.headerText) {
                    case 'Sales Dashboard': UpdateHeader(e.headerElement);
                        break;
                    case 'Country': UpdateTileContent(e.tile, e.contentElement);
                        break;
                }
            }
            // ヘッダータイトルを変更します
            function UpdateHeader(header) {
                var headerText = 'Sales Dashboard for 2018';
                header.querySelector('span.title').innerText = headerText;
            }
            // タイルの内容を更新します
            function UpdateTileContent(tile, contentElement) {
                var grid = wijmo.Control.getControl('#salesDashboardFGrid');
    
                if (grid && grid.selectedItems && grid.selectedItems.length) {
                    var selectedRowData = grid.selectedItems[0];
                    tile.hostElement.style.backgroundColor = '#009ccc';
                    var htmlContent = '<div style="color:white;">Country</div>' +
                        '<div style="font-size:72px; text-align: center; color:white;overflow:hidden; text-overflow:ellipsis">' + selectedRowData.Country + '</div>';
                    contentElement.innerHTML = htmlContent;
                }
            }
            function gridSelectionChanged(sender, e) {
                // グリッドでselectionChangedイベントが発生した後でDashboardLayoutコントロールを更新します
                var dashboard = wijmo.Control.getControl('#custom');
                dashboard.refresh();
            }
        </script>
        <c1-dashboard-layout format-tile="formatTile" id="custom">
            <c1-auto-grid-layout orientation="Vertical" max-rows-or-columns="6" cell-size="152">
                <c1-auto-grid-group>
                    <c1-auto-grid-tile header-text="Sales Dashboard" column-span="2" row-span="2">
                        <c1-flex-grid auto-generate-columns="false" is-read-only="true" headers-visibility="Column"
                        allow-resizing="None" selection-mode="Row" id="salesDashboardFGrid" selection-changed="gridSelectionChanged">
                            <c1-flex-grid-column binding="Country" width="150"></c1-flex-grid-column>
                            <c1-flex-grid-column binding="Sales" format="c0" header="Current Year(mil.)" width="*"></c1-flex-grid-column>
                            <c1-items-source source-collection="@Model" width="150"></c1-items-source>
                        </c1-flex-grid>
                    </c1-auto-grid-tile>
                    <c1-auto-grid-tile header-text="Country" column-span="2" row-span="1" show-header="false" show-toolbar="false">
                    </c1-auto-grid-tile>
                </c1-auto-grid-group>
            </c1-auto-grid-layout>
        </c1-dashboard-layout>
    

Build and Run the Project

  1. Configure the RouteConfig.cs file to set the default navigation path by setting the controller to Dashboard and action to Index.
  2. Click Build | Build Solution to build the project.
  3. Press F5 to run the project.
Back to Top