Friday, 12 April 2013

Gwt context menu


Example for gwt context menu.
here explains how to create a context menu in gwt .Using Cell list for context menu items. the below code listens  the right click event of a panel and shows a pop-up-panel 

                private MenuCell contextMenuItem = new MenuCell();
                private CellListResource resource = GWT.create(CellListResource.class);
                  private CellList<String>  contextMenuItems = new CellList<String>(contextMenuItem, resource);
                  private PopupPanel contextMenu; //using popupPanel  as a context menu
                private SingleSelectionModel<String> contextMenuSelectionModel = new SingleSelectionModel<String>();

                 private Panel topContainer;    // the container to be right clicked

                 public void onModuleLoad(){
                                 
                                   topContainer=new Panel();

                                   List<String> menuItmes=new ArrayList<String>()
                                
                                   menuItmes.add("menu item 1");
                                   menuItmes.add("menu item  2");
                                    menuItmes.add("menu item 3");
                                    menuItmes.add("menu  item 4");
                               
                                   contextMenuItems.setSelectionModel(contextMenuSelectionModel);
                                contextMenuItems.setRowCount(menuItems.size(), true);
                                contextMenuItems.setRowData(0, menuItems);

                                Panel p = new VerticalPanel();
                                p.add(contextMenuItems);    

                                    contextMenu = new PopupPanel(true);
                                    contextMenu.setStyleName("contextMenu");
                                contextMenu.add(p);
                                contextMenu.hide();
               

                                  topContainer.addHandler(new ContextMenuHandler() {
                 
                                     @Override
                                     public void onContextMenu(ContextMenuEvent event) {

                                   event.getNativeEvent().stopPropagation();
               event.getNativeEvent().preventDefault();
                                   contextMenu.setPopupPosition(event.getNativeEvent().getClientX(),
                                                                event.getNativeEvent().getClientY());
                                   contextMenu.show();
                               
                                     }
                                     }, ContextMenuEvent.getType());
               
                                         contextMenuSelectionModel
                                                                .addSelectionChangeHandler(new SelectionChangeEvent.Handler() {

                                                                                @Override
                                                                                public void onSelectionChange(SelectionChangeEvent event) {
                                                                                                 // changed the context menu selection 
                                                                      Window.alert("Selected item is" + contextMenuSelectionModel.getSelectedObject());
                                                           
                                                                                          
                                                                                            
                                                                                               }               
                                                                });
                                   RootPanel.get().add(topContainer);

                         
}

Representation of a single cell
                class MenuCell extends AbstractCell<String> {

              @Override
              public void render(com.google.gwt.cell.client.Cell.Context context,
                           String value, SafeHtmlBuilder sb) {

                     SafeHtml html = SafeHtmlUtils
                                  .fromSafeConstant("<div class='cell'> " + value
                                                + "</div>");

                     sb.append(html);

              }

       }


Customization of cell style
public interface CellListResource extends  CellList.Resources {
      
         @Source({"myCellList.css"})
         CellList.Style cellListStyle();
      
}


myCellList.css
.cellListWidget {

}

.cellListEvenItem {
  cursor: pointer;
  zoom: 1;
}

.cellListOddItem {
  cursor: pointer;
  zoom: 1;
}

.cellListKeyboardSelectedItem {
  background: white;
}

@sprite .cellListSelectedItem {
  gwt-image: 'cellListSelectedBackground';
  background-color: white;
  color: white;
  height: auto;
  overflow: visible;
}





Basic style sheet (in war folder)

.cell:hover {
    border-color: #afd2fd;
    border-style: solid;
    border-width: 1px;
    background-color: #e1eefd;
    color: black;
      
}
.cell{
      
          border-color: white;
    border-style: solid;
    border-width: 1px;
       /*padding: 3px 29px 3px 10px;*/
      
       font-size: 11px;
    padding: 3px 61px 3px 41px;

}
.contextMenu {
    background-color: white;
    border-color: #979797;
    border-style: solid;
    border-width: 1px;
    box-shadow: 2px 3px 5px -3px black;
    padding: 3px;

}

-->

2 comments:

  1. Hi, I want to use your menu and everything ist fine, but the css does not work. The backgroiund of the menu is always empty.

    ReplyDelete
  2. Hello karsten
    Its working properly for me..please check is path to css correct

    ReplyDelete