source: trunk/www/admin/groups/list_groups.jsp @ 4906

Last change on this file since 4906 was 4906, checked in by Martin Svensson, 13 years ago

References #1128 More item-pages updated

  • Property svn:eol-style set to native
  • Property svn:keywords set to Date Id
File size: 16.8 KB
Line 
1<%-- $Id: list_groups.jsp 4906 2009-04-24 13:53:14Z martin $
2  ------------------------------------------------------------------
3  Copyright (C) 2006 Jari Häkkinen, Nicklas Nordborg, Martin Svensson
4  Copyright (C) 2007 Johan Enell, Nicklas Nordborg
5
6  This file is part of BASE - BioArray Software Environment.
7  Available at http://base.thep.lu.se/
8
9  BASE is free software; you can redistribute it and/or
10  modify it under the terms of the GNU General Public License
11  as published by the Free Software Foundation; either version 3
12  of the License, or (at your option) any later version.
13
14  BASE is distributed in the hope that it will be useful,
15  but WITHOUT ANY WARRANTY; without even the implied warranty of
16  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
17  GNU General Public License for more details.
18
19  You should have received a copy of the GNU General Public License
20  along with BASE. If not, see <http://www.gnu.org/licenses/>.
21  ------------------------------------------------------------------
22
23  @author Nicklas
24  @version 2.0
25--%>
26<%@ page session="false"
27  import="net.sf.basedb.core.SessionControl"
28  import="net.sf.basedb.core.DbControl"
29  import="net.sf.basedb.core.Item"
30  import="net.sf.basedb.core.Group"
31  import="net.sf.basedb.core.User"
32  import="net.sf.basedb.core.ItemQuery"
33  import="net.sf.basedb.core.Include"
34  import="net.sf.basedb.core.ItemResultIterator"
35  import="net.sf.basedb.core.ItemResultList"
36  import="net.sf.basedb.core.ItemContext"
37  import="net.sf.basedb.core.Permission"
38  import="net.sf.basedb.core.Type"
39  import="net.sf.basedb.core.PluginDefinition"
40  import="net.sf.basedb.core.query.Orders"
41  import="net.sf.basedb.core.query.Hql"
42  import="net.sf.basedb.core.query.Restrictions"
43  import="net.sf.basedb.core.query.Expressions"
44  import="net.sf.basedb.core.plugin.GuiContext"
45  import="net.sf.basedb.core.plugin.Plugin"
46  import="net.sf.basedb.util.Enumeration"
47  import="net.sf.basedb.clients.web.Base"
48  import="net.sf.basedb.clients.web.PermissionUtil"
49  import="net.sf.basedb.clients.web.ModeInfo"
50  import="net.sf.basedb.clients.web.util.HTML"
51  import="net.sf.basedb.util.Values"
52  import="net.sf.basedb.util.formatter.Formatter"
53  import="net.sf.basedb.clients.web.formatter.FormatterFactory"
54  import="net.sf.basedb.clients.web.extensions.ExtensionsControl"
55  import="net.sf.basedb.clients.web.extensions.JspContext"
56  import="net.sf.basedb.clients.web.extensions.renderer.PrefixSuffixRenderer"
57  import="net.sf.basedb.clients.web.extensions.toolbar.ToolbarUtil"
58  import="net.sf.basedb.util.extensions.ExtensionsInvoker"
59  import="java.util.Date"
60  import="java.util.List"
61  import="java.util.Map"
62%>
63<%@ taglib prefix="base" uri="/WEB-INF/base.tld" %>
64<%@ taglib prefix="tbl" uri="/WEB-INF/table.tld" %>
65<%@ taglib prefix="ext" uri="/WEB-INF/extensions.tld" %>
66<%!
67  private static final Item itemType = Item.GROUP;
68  private static final GuiContext guiContext = new GuiContext(itemType, GuiContext.Type.LIST);
69%>
70<%
71final SessionControl sc = Base.getExistingSessionControl(pageContext, Permission.DENIED, itemType);
72final String ID = sc.getId();
73final boolean createPermission = sc.hasPermission(Permission.CREATE, itemType);
74final boolean writePermission = sc.hasPermission(Permission.WRITE, itemType);
75final boolean deletePermission = sc.hasPermission(Permission.DELETE, itemType);
76final ItemContext cc = Base.getAndSetCurrentContext(sc, itemType, null, null);
77
78final ModeInfo mode = ModeInfo.get(request.getParameter("mode"));
79final String callback = request.getParameter("callback");
80final String title = mode.generateTitle("group", "groups");
81final DbControl dc = sc.newDbControl();
82ItemResultIterator<Group> groups = null;
83try
84{
85  Formatter<Date> dateFormatter = FormatterFactory.getDateFormatter(sc);
86  // Query for groups relatated to the current group
87  final ItemQuery<Group> groupQuery = Group.getQuery();
88  groupQuery.include(cc.getInclude());
89  groupQuery.join(Hql.innerJoin("parents", "p"));
90  groupQuery.restrict(Restrictions.eq(Hql.alias("p"), Expressions.parameter("group")));
91  groupQuery.order(Orders.asc(Hql.property("name"))); 
92
93  // Query for users relatated to the current group
94  final ItemQuery<User> userQuery = User.getQuery();
95  userQuery.include(cc.getInclude());
96  userQuery.join(Hql.innerJoin("groups", "grp"));
97  userQuery.restrict(Restrictions.eq(Hql.alias("grp"), Expressions.parameter("group")));
98  userQuery.order(Orders.asc(Hql.property("name"))); 
99
100  Map<Plugin.MainType, Integer> pluginCount = PluginDefinition.countPlugins(dc, guiContext);
101  try
102  {
103    final ItemQuery<Group> query = Base.getConfiguredQuery(cc, true, Group.getQuery(), mode);
104    groups = query.iterate(dc);
105  }
106  catch (Throwable t)
107  {
108    cc.setMessage(t.getMessage());
109  }
110  int numListed = 0;
111  JspContext jspContext = ExtensionsControl.createContext(dc, pageContext, guiContext, null);
112  ExtensionsInvoker invoker = ToolbarUtil.useExtensions(jspContext);
113  %>
114  <base:page title="<%=title==null ? "Groups" : title%>" type="<%=mode.getPageType()%>">
115  <base:head scripts="menu.js,table.js" styles="menu.css,table.css">
116    <ext:scripts context="<%=jspContext%>" />
117    <ext:stylesheets context="<%=jspContext%>" />
118    <script language="JavaScript">
119    var submitPage = 'index.jsp';
120    var formId = 'groups';
121    function newItem()
122    {
123      Main.viewOrEditItem('<%=ID%>', '<%=itemType.name()%>', 0, true);
124    }
125    function editItem(itemId)
126    {
127      Main.viewOrEditItem('<%=ID%>', '<%=itemType.name()%>', itemId, true);
128    }
129    function viewItem(itemId)
130    {
131      Main.viewOrEditItem('<%=ID%>', '<%=itemType.name()%>', itemId, false);
132    }
133    function itemOnClick(evt, itemId)
134    {
135      Table.itemOnClick(formId, evt, itemId, '<%=mode.getName()%>', viewItem, editItem, returnSelected);
136    }
137    function deleteItems()
138    {
139      var frm = document.forms[formId];
140      if (Forms.numChecked(frm) == 0)
141      {
142        alert('Please select at least one item in the list');
143        return;
144      }
145      frm.action = submitPage;
146      frm.cmd.value = 'DeleteItems';
147      frm.submit();
148    }
149    function restoreItems()
150    {
151      var frm = document.forms[formId];
152      if (Forms.numChecked(frm) == 0)
153      {
154        alert('Please select at least one item in the list');
155        return;
156      }
157      frm.action = submitPage;
158      frm.cmd.value = 'RestoreItems';
159      frm.submit();
160    }
161    function deleteItemPermanently(itemId)
162    {
163      Main.deleteItemPermanently('<%=ID%>', true, '<%=itemType.name()%>', itemId);
164    }
165    function configureColumns()
166    {
167      Table.configureColumns('<%=ID%>', formId, '<%=itemType.name()%>', '<%=(String)cc.getObject("defaultColumns")%>');
168    }
169    function runPlugin(cmd)
170    {
171      Table.submitToPopup(formId, cmd, 740, 540);
172    }
173    function returnSelected()
174    {
175      Table.returnSelected(formId, <%=callback != null ? "window.opener."+callback : "null" %>);
176      window.close();
177    }
178    function presetOnChange()
179    {
180      Table.presetOnChange('<%=ID%>', formId, '<%=itemType.name()%>', '<%=(String)cc.getObject("defaultColumns")%>');
181    }
182    </script>
183  </base:head>
184 
185  <base:body>
186    <%
187    if (cc.getMessage() != null)
188    {
189      %>
190      <div class="error"><%=cc.getMessage()%></div>
191      <%
192      cc.setMessage(null);
193    }
194    %>
195    <tbl:table 
196      id="groups" 
197      clazz="itemlist" 
198      columns="<%=cc.getSetting("columns")%>"
199      sortby="<%=cc.getSortProperty()%>" 
200      direction="<%=cc.getSortDirection()%>"
201      title="<%=title%>"
202      action="index.jsp"
203      sc="<%=sc%>"
204      item="<%=itemType%>"
205      >
206      <tbl:hidden 
207        name="mode" 
208        value="<%=mode.getName()%>" 
209      />
210      <tbl:hidden 
211        name="callback" 
212        value="<%=callback%>" 
213        skip="<%=callback == null%>" 
214      />
215      <tbl:columndef 
216        id="name"
217        property="name"
218        datatype="string"
219        title="Name"
220        sortable="true" 
221        filterable="true"
222        exportable="true"
223        show="always" 
224      />
225      <tbl:columndef 
226        id="id"
227        clazz="uniquecol"
228        property="id"
229        datatype="int"
230        title="ID"
231        sortable="true"
232        filterable="true"
233        exportable="true"
234      />
235      <tbl:columndef 
236        id="entryDate"
237        property="entryDate"
238        datatype="date"
239        title="Registered"
240        sortable="true" 
241        filterable="true"
242        exportable="true"
243        formatter="<%=dateFormatter%>"
244      />
245      <tbl:columndef 
246        id="systemId"
247        clazz="uniquecol"
248        property="systemId"
249        datatype="string"
250        title="System ID"
251        sortable="true"
252        filterable="true"
253        exportable="true"
254      />
255      <tbl:columndef 
256        id="quota"
257        property="quota.name"
258        datatype="string"
259        title="Quota"
260        sortable="true" 
261        filterable="true"
262        exportable="true"
263      />
264      <tbl:columndef 
265        id="isDefault"
266        property="default"
267        datatype="boolean"
268        title="Is default"
269        sortable="true" 
270        filterable="true"
271        exportable="true"
272      />
273      <tbl:columndef
274        id="users"
275        title="Users"
276        property="&users(name)"
277        datatype="string"
278        filterable="true"
279        exportable="true"
280      />
281      <tbl:columndef
282        id="groups"
283        title="Groups"
284        property="&children(name)"
285        datatype="string"
286        filterable="true"
287        exportable="true"
288      />
289      <tbl:columndef 
290        id="description"
291        property="description"
292        datatype="string"
293        title="Description" 
294        sortable="true" 
295        filterable="true" 
296        exportable="true"
297      />
298      <tbl:toolbar
299        visible="<%=mode.hasToolbar()%>"
300        >
301        <tbl:button 
302          disabled="<%=createPermission ? false : true%>" 
303          image="<%=createPermission ? "new.gif" : "new_disabled.gif"%>" 
304          onclick="newItem()" 
305          title="New&hellip;" 
306          tooltip="<%=createPermission ? "Create new group" : "You do not have permission to create groups"%>" 
307        />
308        <tbl:button 
309          disabled="<%=deletePermission ? false : true%>" 
310          image="<%=deletePermission ? "delete.gif" : "delete_disabled.gif"%>" 
311          onclick="deleteItems()" 
312          title="Delete" 
313          tooltip="<%=deletePermission ? "Delete the selected items" : "You do not have permission to delete groups" %>" 
314        />
315        <tbl:button 
316          disabled="<%=writePermission ? false : true%>" 
317          image="<%=writePermission ? "restore.gif" : "restore_disabled.gif"%>" 
318          onclick="restoreItems()" 
319          title="Restore" 
320          tooltip="<%=writePermission ? "Restore the selected (deleted) items" : "You do not have permission to edit groups" %>" 
321        />
322        <tbl:button 
323          image="columns.gif" 
324          onclick="configureColumns()" 
325          title="Columns&hellip;" 
326          tooltip="Show, hide and re-order columns" 
327        />
328        <tbl:button 
329          image="import.gif" 
330          onclick="runPlugin('ImportItems')" 
331          title="Import&hellip;" 
332          tooltip="Import data" 
333          visible="<%=pluginCount.containsKey(Plugin.MainType.IMPORT)%>"
334        />
335        <tbl:button 
336          image="export.gif" 
337          onclick="runPlugin('ExportItems')" 
338          title="Export&hellip;" 
339          tooltip="Export data" 
340          visible="<%=pluginCount.containsKey(Plugin.MainType.EXPORT)%>"
341        />
342        <tbl:button 
343          image="runplugin.gif" 
344          onclick="runPlugin('RunListPlugin')" 
345          title="Run plugin&hellip;" 
346          tooltip="Run a plugin" 
347          visible="<%=pluginCount.containsKey(Plugin.MainType.OTHER)%>"
348        />
349        <ext:render extensions="<%=invoker%>" context="<%=jspContext%>" 
350          wrapper="<%=new PrefixSuffixRenderer(jspContext, "<td>", "</td>") %>"/>
351      </tbl:toolbar>
352      <tbl:navigator
353        page="<%=cc.getPage()%>" 
354        rowsperpage="<%=cc.getRowsPerPage()%>" 
355        totalrows="<%=groups == null ? 0 : groups.getTotalCount()%>" 
356        visible="<%=mode.hasNavigator()%>"
357      />
358      <tbl:data>
359        <tbl:columns>
360        <tbl:presetselector 
361          clazz="columnheader"
362          colspan="3"
363          onchange="presetOnChange()"
364        />
365        </tbl:columns>
366
367        <tr>
368          <tbl:header 
369            clazz="index"
370            >&nbsp;</tbl:header>
371          <tbl:header 
372            clazz="check" 
373            visible="<%=mode.hasCheck()%>"
374            ><base:icon 
375              image="check_uncheck.gif" 
376              tooltip="Check/uncheck all" 
377              onclick="Forms.checkUncheck(document.forms[formId])" style="align: left;"
378            /></tbl:header>
379          <tbl:header 
380            clazz="check" 
381            visible="<%=mode.hasRadio()%>"
382            >&nbsp;</tbl:header>
383          <tbl:header 
384            clazz="icons" 
385            visible="<%=mode.hasIcons()%>"
386            >&nbsp;</tbl:header>
387          <tbl:propertyfilter />
388        </tr>
389         
390          <tbl:rows>
391          <%
392          int index = cc.getPage()*cc.getRowsPerPage();
393          int selectedItemId = cc.getId();
394          if (groups != null)
395          {           
396            while (groups.hasNext())
397            {
398              Group item = groups.next();
399              int itemId = item.getId();
400              String name = HTML.encodeTags(item.getName());
401              String tooltip = mode.isSelectionMode() ? 
402                  "Select this item" : "View this item" + (writePermission ? " (use CTRL, ALT or SHIFT to edit)" : "");
403              String deletePermanently = "deleteItemPermanently("+itemId+")";
404              index++;
405              numListed++;
406              %>
407              <tbl:row>
408                <tbl:header 
409                  clazz="index"
410                  ><%=index%></tbl:header>
411                <tbl:header 
412                  clazz="check" 
413                  visible="<%=mode.hasCheck()%>"
414                  ><input 
415                    type="checkbox" 
416                    name="<%=itemId%>" 
417                    value="<%=itemId%>" 
418                    title="<%=name%>" 
419                    <%=cc.getSelected().contains(itemId) ? "checked" : ""%> 
420                  ></tbl:header>
421                <tbl:header 
422                  clazz="check" 
423                  visible="<%=mode.hasRadio()%>"
424                  ><input 
425                    type="radio" 
426                    name="item_id" 
427                    value="<%=itemId%>" 
428                    title="<%=name%>" 
429                    <%=selectedItemId == itemId ? "checked" : ""%>
430                  ></tbl:header>
431                <tbl:header 
432                  clazz="icons" 
433                  visible="<%=mode.hasIcons()%>"
434                  ><base:icon 
435                    image="<%=deletePermission ? "deleted.gif" : "deleted_disabled.gif"%>"
436                    onclick="<%=deletePermission ? deletePermanently : null%>"
437                    tooltip="This item has been scheduled for deletion" 
438                    visible="<%=item.isRemoved()%>"
439                  /><base:icon
440                    image="systemitem.gif"
441                    tooltip="This item is a system item"
442                    visible="<%=item.isSystemItem()%>" 
443                  />&nbsp;</tbl:header>
444                <tbl:cell column="name"><div class="link" 
445                  onclick="itemOnClick(<%=writePermission ? "event" : null%>, <%=itemId%>)" 
446                  title="<%=tooltip%>"><%=name%></div></tbl:cell>
447                <tbl:cell column="id"><%=item.getId()%></tbl:cell>
448                <tbl:cell column="entryDate" value="<%=item.getEntryDate()%>" />
449                <tbl:cell column="systemId"><%=HTML.encodeTags(item.getSystemId())%></tbl:cell>
450                <tbl:cell column="quota"
451                  ><base:propertyvalue 
452                    item="<%=item%>" 
453                    property="quota"
454                    enableEditLink="<%=mode.hasEditLink()%>" 
455                    enablePropertyLink="<%=mode.hasPropertyLink()%>"
456                  /></tbl:cell>
457                <tbl:cell column="isDefault"><%=item.isDefault() ? "yes" : "no" %></tbl:cell>
458                <tbl:cell column="description"><%=HTML.encodeTags(item.getDescription())%></tbl:cell>
459                <tbl:cell column="groups">
460                  <%
461                  groupQuery.setParameter("group", itemId, Type.INT);
462                  try
463                  {
464                    String separator = "";
465                    for (Group g : groupQuery.list(dc))
466                    {
467                      out.write(separator);
468                      if (mode.hasPropertyLink())
469                      {
470                        out.write(Base.getLinkedName(ID, g, false, mode.hasEditLink()));
471                      }
472                      else
473                      {
474                        out.write(HTML.encodeTags(g.getName()));
475                      }
476                      separator = ", ";
477                    }
478                  }
479                  catch (Throwable t)
480                  {
481                    %>
482                    <div class="error"><%=t.getMessage()%></div>
483                    <%
484                  }
485                  %>
486                </tbl:cell>
487                <tbl:cell column="users">
488                  <%
489                  userQuery.setParameter("group", itemId, Type.INT);
490                  try
491                  {
492                    String separator = "";
493                    for (User u : userQuery.list(dc))
494                    {
495                      out.write(separator);
496                      if (mode.hasPropertyLink())
497                      {
498                        out.write(Base.getLinkedName(ID, u, false, mode.hasEditLink()));
499                      }
500                      else
501                      {
502                        out.write(HTML.encodeTags(u.getName()));
503                      }
504                      separator = ", ";
505                    }
506                  }
507                  catch (Throwable t)
508                  {
509                    %>
510                    <div class="error"><%=t.getMessage()%></div>
511                    <%
512                  }
513                  %>
514                </tbl:cell>
515              </tbl:row>
516              <%
517              }
518            }
519          %>
520          </tbl:rows>
521      </tbl:data>
522      <%
523      if (numListed == 0)
524      {
525        %>
526        <tbl:panel><%=groups == null || groups.getTotalCount() == 0 ? "No groups were found" : "No groups on this page. Please select another page!" %></tbl:panel>
527        <%
528      }
529      else
530      {
531        %>
532        <tbl:navigator
533          page="<%=cc.getPage()%>" 
534          rowsperpage="<%=cc.getRowsPerPage()%>" 
535          totalrows="<%=groups == null ? 0 : groups.getTotalCount()%>" 
536          visible="<%=mode.hasNavigator()%>"
537          locked="true"
538        />
539        <%
540      }
541      %>
542    </tbl:table>
543    <base:buttongroup align="center" clazz="fixedatbottom">
544      <base:button onclick="returnSelected();" title="Ok" visible="<%=mode.hasOkButton()%>" />
545      <base:button onclick="window.close();" title="Cancel" visible="<%=mode.hasCancelButton()%>" />
546      <base:button onclick="window.close();" title="Close" visible="<%=mode.hasCloseButton()%>" />
547    </base:buttongroup>
548    <br><br><br>
549  </base:body>
550  </base:page>
551  <%
552}
553finally
554{
555  if (groups != null) groups.close();
556  if (dc != null) dc.close();
557}
558%>
Note: See TracBrowser for help on using the repository browser.