Context Menu in ASP.NET MVC TreeGrid

18 Sep 20203 minutes to read

The Context menu in TreeGrid control is used to manipulate (add, edit and delete) the TreeGrid rows. In TreeGrid, context menu can be enabled with ContextMenuSettings property. The ContextMenuSettings property contains two inner properties ShowContextMenu and ContextMenuItems.

The ShowContextMenu property is used to enable or disable the context menu, default value for this property is false.

The ContextMenuItems property is used to add the menu items to context menu, this property renders Add and Delete by default when the menu items are not provided.

  • CSHTML
  • @(Html.EJ().TreeGrid("treegrid1")
    	.EditSettings(edit=>
    	 { 
         edit.AllowEditing(true);
         edit.EditMode(TreeGridEditMode.RowEditing);
    	 })
      .ContextMenuSettings(context =>
      {
          context.ShowContextMenu(true);
          context.ContextMenuItems(new List<TreeGridContextMenuItems>(){
              TreeGridContextMenuItems.Add,
              TreeGridContextMenuItems.Edit,
              TreeGridContextMenuItems.Delete
          });
      })
    )
    @(Html.EJ().ScriptManager())

    The following screenshot displays the Context menu in TreeGrid control.

    Context Menu Image

    ContextMenu Customization

    The Context menu can be customized by adding a new custom menu item to it. In TreeGrid, context menu can be customized using the ContextMenuOpen client-side event. This event is triggered when the context menu is rendered with mouse right click action. The following properties are available in the event.

    • headerText: Display text for menu item.
    • iconPath: Image location for menu item.
    • eventHandler: Client-side event for menu item click.
  • CSHTML
  • @(Html.EJ().TreeGrid("treegrid1")
      .ContextMenuSettings(context =>
        {
          context.ShowContextMenu(true);                       
        })
      .ClientSideEvents(eve=>
        {
          eve.ContextMenuOpen("contextMenuOpen");            
        })
      )
    @(Html.EJ().ScriptManager())
    <script type=”text/javascript”>
    function contextMenuOpen(args) {
            args.contextMenuItems.push({
                headerText: "Custom Menu",
                iconPath: "url(../content/images/treegrid/Folder.png)",
                eventHandler: customMenuClick,
            });
        }
    function customMenuClick(args) {
      //Bind actions for custom menu here
    }
    </script>

    The following screenshot displays the customization of Context menu in TreeGrid control.

    ContextMenu Customization Image

    Header Context Menu

    Header context menu can be enabled by setting ShowContextMenu as true. The default value of the ShowContextMenu property is false.

    Following options are shown in header context menu.

    • Column Chooser - Display all the column names; you can enable or disable a column by select or deselect the respective column name in the column chooser menu. This option is default option of header context menu.
    • Sort Ascending & Sort Descending - Used to sort the items in the column. These menu options will be displayed only when you enable the AllowSorting property. To perform multilevel sorting, the AllowMultiSorting property should be enabled.
    • Freeze, Unfreeze & Freeze Preceding Columns - Used to freeze or unfreeze the columns. These set of menu options will be displayed in all the columns when IsFrozen property is enabled in any of the columns. However you can control the visibility of these menu options in a particular column by enabling/disabling the AllowFreezing property of that specific column.

    The below code snippet explains how to enable header context menu in TreeGrid

  • CSHTML
  • @(Html.EJ().TreeGrid("treegrid1")	
      .AllowSorting(true)
      .Columns(co =>
        {        
            co.Field("StartDate").HeaderText("Start Date").IsFrozen(true).EditType(TreeGridEditingType.Datepicker).Add();
        })
      .ContextMenuSettings(context =>
      {
          context.ShowContextMenu(true);      
      })
      )
    @(Html.EJ().ScriptManager())

    The following screenshot displays the Header context menu in TreeGrid control.

    Header Context Menu Image