This wiki shows information for Grouper developers (or perhaps customizers) to work with the new Grouper v2.2 UI.
Button to call ajax
There are two ways to call ajax
Search form (with modal results)
Combobox
To use the new combobox, there are several parts:
Combobox - JSP custom tag
Geneerally you need an idBase (some unique id for combos on that page), a width (via style), and an operation (which can include dynamic params). Note, there are other options like sending other form elements during the filter jax operation
<grouper:combobox2 idBase="parentFolderCombo" style="width: 30em" filterOperation="../app/UiV2Stem.stemCopyParentFolderFilter?stemId=${grouperRequestContainer.stemContainer.guiStem.stem.id}"/>
Combobox - filter ajax method
There is a helper logic structure to easily do the combobox ajax logic, here is an example:
/** * combo filter copy parent folder * @param request * @param response */ public void stemCopyParentFolderFilter(final HttpServletRequest request, HttpServletResponse response) { //run the combo logic DojoComboLogic.logic(request, response, new DojoComboQueryLogicBase<Stem>() { /** * */ @Override public Stem lookup(HttpServletRequest request, GrouperSession grouperSession, String query) { Subject loggedInSubject = grouperSession.getSubject(); Stem theStem = new StemFinder().addPrivilege(NamingPrivilege.STEM).assignSubject(loggedInSubject) .assignFindByUuidOrName(true).assignScope(query).findStem(); return theStem; } /** * */ @Override public Collection<Stem> search(HttpServletRequest request, GrouperSession grouperSession, String query) { Subject loggedInSubject = grouperSession.getSubject(); QueryOptions queryOptions = QueryOptions.create(null, null, 1, 50); return new StemFinder().addPrivilege(NamingPrivilege.STEM).assignScope(query).assignSubject(loggedInSubject) .assignSplitScope(true).assignQueryOptions(queryOptions).findStems(); } /** * * @param t * @return */ @Override public String retrieveId(GrouperSession grouperSession, Stem t) { return t.getId(); } /** * */ @Override public String retrieveLabel(GrouperSession grouperSession, Stem t) { return t.getDisplayName(); } /** * */ @Override public String retrieveHtmlLabel(GrouperSession grouperSession, Stem t) { //description could be null? String label = GrouperUiUtils.escapeHtml(t.getDisplayName(), true); String htmlLabel = "<img src=\"../../grouperExternal/public/assets/images/folder.gif\" /> " + label; return htmlLabel; } /** * */ @Override public String initialValidationError(HttpServletRequest request, GrouperSession grouperSession) { Stem stem = retrieveStemHelper(request, true).getStem(); if (stem == null) { return TextContainer.retrieveFromRequest().getText().get("stemCopyInsufficientPrivileges"); } return null; } }); }
Combobox submit form
Then the form that has the combobox is submitted, process the data. You do this by appending "Name" to the id label. Also, if the user typed something in, but didnt select anything, append "NameDisplay" to the id base.
String parentFolderId = request.getParameter("parentFolderComboName"); //just get what they typed in if (StringUtils.isBlank(parentFolderId)) { parentFolderId = request.getParameter("parentFolderComboNameDisplay"); }
Combobox control from ajax
If you need to set an ID and label to the combobox from ajax, you can do this: (not sure if this works btw)
dijit.byId('parentFolderComboId').set('value', 123); dijit.byId('parentFolderComboId').set('displayedValue', 'Some label');
dfs