ASP.NET Core MVC コントロールヘルプ
スキャフォールディング : FlexGrid

ASP.NET MVCのComponentOne FlexGridコントロールをスキャフォールディングする手順は、次のとおりです。

  1. データソースを設定します。アプリケーションでのデータソースの設定方法については、トピック「ASP.NET MVCコントロールのスキャフォールディング」を参照してください。
  2. ソリューションエクスプローラーで、プロジェクト名を右クリックし、[追加]→[新規スキャフォールディングアイテム]を選択します。[スキャフォールディングを追加]ウィザードが表示されます。

  3. [スキャフォールディングを追加]ウィザードで、[共通]を選択し、右ペインからC1 スキャフォールダーを選択します。


    [共通]→[MVC]→[コントローラー]、または[共通]→[MVC]→[ビュー]を選択し、C1 スキャフォールダーを選択して、コントローラーまたはビューだけを追加することもできます。

  4. [追加]をクリックします。

  5. FlexGridコントロールを選択し、[次へ]を選択します。


    [C1 ASP.NET MVC FlexGrid]ウィザードが表示され、デフォルトで[全般]タブが選択されます。

  6. [全般]タブで、モデルを次のように指定します。

    1. [コントローラー名][ビュー名]を入力します。
    2. ドロップダウンリストから[モデルクラス]を選択します。リストには、手順1で追加したC1NWind.edmxモデルに加えて、アプリケーションで使用できるすべてのモデルタイプが表示されます。この例では、[製品]を選択して、FlexGridに製品を挿入します。
    3. ドロップダウンリストから[データコンテキストクラス]を選択します。この例では、C1NWindEntitiesを選択します。

  7. [列]タブに移動し、FlexGridコントロールの列を指定します。デフォルトでは、[列の自動生成]がオンになっています。オフにすると、列を追加および削除したり、最終的なビューに表示する順序になるように上下に移動することができます。この例では、次の図に示すように列を選択します。


  8. [編集]タブに移動し、[編集を許可]チェックボックスと[削除を許可]チェックボックスをオンにします。

  9. [グループ化]タブに移動します。[グループ設定]で、[グループの説明]から[グループの表示]チェックボックスと[カテゴリID]チェックボックスをオンにし、[グループヘッダーの書式]に「Group by Category ID」という名前を付けます。

  10. [フィルタリング]タブに移動し、[フィルタ処理を許可]チェックボックスをオンにします。他の設定は、デフォルトのままにします。

  11. [ソート]タブに移動し、設定はデフォルトのままにします。[ソートを許可]チェックボックスと[ソートを表示]チェックボックスはどちらもオンにします。

  12. [クライアント側イベント]タブに移動し、[編集の開始]チェックボックスをオンにします。

  13. [追加]をクリックします。選択したモデルのコントローラーとビューがプロジェクトに追加されます。コントローラーとビューに対して生成されるコードは、次のようになります。

    FlexGrid1Controller.cs
    FlexGrid1Controller.cs
    コードのコピー
    using System;
    using System.Collections.Generic;
    using System.Linq;
    using C1.Web.Mvc;
    using C1.Web.Mvc.Serializition;
    using System.Data;
    using System.Data.Entity;
    using System.Data.Entity.Validation;
    using System.Web;
    using System.Web.Mvc;
    // このコードは、C1スキャフォールダによって生成しました。
    namespace C1MvcWebAppScaffolding.Controllers
    {
    public partial class FlexGridController : Controller
        {
    private C1MvcWebAppScaffolding.Models.C1NWindEntities db = new C1MvcWebAppScaffolding.Models.C1NWindEntities();
    public ActionResult Index()
    {
    var model = db.Products;
    return View(model);
    }
    public ActionResult FlexGrid_Update([C1JsonRequest]CollectionViewEditRequest <C1MvcWebAppScaffolding.Models.Product> requestData)
    {
    return Update(requestData, db.Products);
    }
    private ActionResult Update<T>(CollectionViewEditRequest<T> requestData, DbSet<T> data) where T : class
    {
    return this.C1Json(CollectionViewHelper.Edit<T>(requestData, item =>
    {
      string error = string.Empty;
      bool success = true;
      try
      {
      db.Entry(item as object).State = EntityState.Modified;
      db.SaveChanges();
      }
      catch (DbEntityValidationException e)
      {
      error = string.Join(",", e.EntityValidationErrors.Select(result =>
      {
       return string.Join(",", result.ValidationErrors.Select
       (err => err.ErrorMessage));
      }));
      success = false;
      }
      catch (Exception e)
      {
      error = e.Message;
      success = false;
      }
      return new CollectionViewItemResult<T>
      {
      Error = error,
      Success = success && ModelState.IsValid,
      Data = item
      };
    }, () => data.ToList<T>()));
    }
    public ActionResult FlexGrid_Delete([C1JsonRequest]CollectionViewEditRequest <C1MvcWebAppScaffolding.Models.Product> requestData)
    {
    return Delete(requestData, db.Products, item => new object[] { item.ProductID });
    }
    private ActionResult Delete<T> (CollectionViewEditRequest<T> requestData,
    DbSet<T> data, Func<T, object[]> getKeys) where T : class
    {
    return this.C1Json(CollectionViewHelper.Edit<T>(requestData, item =>
    {
      string error = string.Empty;
      bool success = true;
      try
      {
      var resultItem = data.Find(getKeys(item));
      data.Remove(resultItem);
      db.SaveChanges();
      }
      catch (DbEntityValidationException e)
      {
      error = string.Join(",", e.EntityValidationErrors.Select(result =>
      {
       return string.Join(",", result.ValidationErrors.Select
         (err => err.ErrorMessage));
      }));
      success = false;
      }
      catch (Exception e)
      {
      error = e.Message;
      success = false;
      }
      return new CollectionViewItemResult<T>
      {
      Error = error,
      Success = success && ModelState.IsValid,
      Data = item
      };
    }, () => data.ToList<T>()));
    }
        }
    }
    
     

    Index

    Razor (Index.cshtml)
    コードのコピー
    @using C1.Web.Mvc
    @using C1.Web.Mvc.Fluent?
    @using C1.Web.Mvc.Grid
    @model IEnumerable<C1MvcWebAppScaffolding.Models.Product>
        <script type="text/javascript">
    function beginningEdit(sender, e) {
      // beginningEditのイベントハンドラを実装します。
        }
        </script>
    @(Html.C1().FlexGrid<C1MvcWebAppScaffolding.Models.Product>()
        .Id("flexgrid")
        .Bind(bl => { bl.Bind(Model)
        .Update(Url.Action("FlexGrid_Update"))
        .Delete(Url.Action("FlexGrid_Delete"))
        .GroupBy("CategoryID")
        ;})
        .AutoGenerateColumns(false)
        .Columns(bl =>
        {
        bl.Add(cb => cb.Binding("ProductName"));
        bl.Add(cb => cb.Binding("CategoryID"));
        bl.Add(cb => cb.Binding("QuantityPerUnit"));
        bl.Add(cb => cb.Binding("UnitPrice"));
        bl.Add(cb => cb.Binding("UnitsInStock"));
        bl.Add(cb => cb.Binding("UnitsOnOrder"));
        bl.Add(cb => cb.Binding("Discontinued"));
        })
        .AllowDelete(true)
        .GroupHeaderFormat("Group by Category ID")
        .Filterable(f => { f
        .DefaultFilterType(FilterType.Both)
        ;})
        .OnClientBeginningEdit("beginningEdit")
    )
    
    HTML
    コードのコピー
    @using C1.Web.Mvc
    @using C1.Web.Mvc.Grid
    @addTagHelper *, C1.AspNetCore.Mvc
    @model IEnumerable<C1MvcApplication1.Models.Product>
        <script type="text/javascript">
        function beginningEdit(sender, e) {
        // beginningEditのイベントハンドラを実装します。
        }
        </script>
    <c1-flex-grid id="flexgrid" auto-generate-columns="false"
     allow-delete="true" group-header-format="Group by Category ID"
      beginning-edit="beginningEdit">
        <c1-items-source source-collection="Model" update-action-url=
       "@(Url.Action("FlexGrid_Update"))"
    delete-action-url="@(Url.Action("FlexGrid_Delete"))"
           group-by="CategoryID"></c1-items-source>
        <c1-flex-grid-column binding="ProductName">
    </c1-flex-grid-column>
        <c1-flex-grid-column binding="CategoryID">
    </c1-flex-grid-column>
        <c1-flex-grid-column binding="QuantityPerUnit">
    </c1-flex-grid-column>
        <c1-flex-grid-column binding="UnitPrice">
    </c1-flex-grid-column>
        <c1-flex-grid-column binding="UnitsInStock">
    </c1-flex-grid-column>
        <c1-flex-grid-column binding="UnitsOnOrder">
    </c1-flex-grid-column>
        <c1-flex-grid-column binding="Discontinued">
    </c1-flex-grid-column>
        <c1-flex-grid-filter default-filter-type="FilterType.Both">
    </c1-flex-grid-filter>
    </c1-flex-grid>
    
  14. プロジェクトを実行します。