The Grid Menu (also known as the Hamburger Menu) is now part of Slickgrid-Universal and is enabled by default).
How to use it?
It's Enabled by default
Technically, it's enable by default and so you don't have to do anything to enjoy it. However if you want to customize the content of the Grid Menu, then continue reading.
The Grid Menu comes, by default, with a Column Picker. This brings an easy way to show/hide certain column(s) from the grid. This functionality was copied from the Column Picker Plugin and brought over to the Grid Menu.
Custom Commands
The Grid Menu also comes, by default, with a list of built-in custom commands (all their positionOrder are in the reserved range of 40 to 60)
Clear all Filters (you can hide it with hideClearAllFiltersCommand: true)
Clear all Sorting (you can hide it with hideClearAllSortingCommand: true)
Toggle the Filter Row (you can hide it with hideToggleFilterCommand: true)
Export to CSV (you can hide it with hideExportCsvCommand: true)
_Export to Text Delimited (you can hide it with hideExportTextDelimitedCommand: true)
Refresh Dataset, only shown when using Backend Service API (you can hide it with hideRefreshDatasetCommand: true)
This section is called Custom Commands because you can also customize this section with your own commands. To do that, you need to fill in 2 properties (an array of commandItems and define onGridMenuCommand callback) in your Grid Options. For example, Slickgrid-Universal is configured by default with these settings (you can overwrite any one of them):
this.gridOptions = { enableAutoResize:true, enableGridMenu:true,// <<-- this will automatically add extra custom commands enableFiltering:true, gridMenu: { commandTitle:'Custom Commands', columnTitle:'Columns', iconCssClass:'mdi mdi-dots-vertical', menuWidth:17, resizeOnShowHeaderRow:true, commandItems: [ { iconCssClass:'mdi mdi-filter-remove-outline', title:'Clear All Filters', disabled:false, command:'clear-filter' }, { iconCssClass:'mdi-flip-vertical', title:'Toggle Filter Row', disabled:false, command:'toggle-filter' },// you can add sub-menus by adding nested `commandItems` {// we can also have multiple nested sub-menus command:'export', title:'Exports', positionOrder:99, commandItems: [ { command:'exports-txt', title:'Text (tab delimited)' }, { command:'sub-menu', title:'Excel', cssClass:'green', subMenuTitle:'available formats', subMenuTitleCssClass:'text-italic orange', commandItems: [ { command:'exports-csv', title:'Excel (csv)' }, { command:'exports-xlsx', title:'Excel (xlsx)' }, ] } ] }, ],onCommand: (e, args) => {if (args.command ==='toggle-filter') {this.gridObj.setHeaderRowVisibility(!this.gridObj.getOptions().showHeaderRow); } elseif (args.command ==='clear-filter') {this.filterService.clearFilters();this.dataviewObj.refresh(); } } }};
Events
There are multiple events/callback hooks which are accessible from the Grid Options