source: branches/3.18-stable/www/admin/groups/list_groups.jsp @ 7932

Last change on this file since 7932 was 7932, checked in by Nicklas Nordborg, 6 months ago

References #2246: Sticky table headers

Implemented for all item list pages and a few other places:

  • Extensions installation dialog
  • Administrate / Services list page
  • Batch inherit annotations
  • Manage list presets
  • List of changed item in view job dialog


  • Property svn:eol-style set to native
  • Property svn:keywords set to Date Id
File size: 16.7 KB
Line 
1<%-- $Id: list_groups.jsp 7932 2021-04-28 07:16:56Z nicklas $
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 pageEncoding="UTF-8" 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.ButtonAction" 
58  import="net.sf.basedb.clients.web.extensions.toolbar.ToolbarUtil"
59  import="net.sf.basedb.clients.web.extensions.list.ListColumnAction"
60  import="net.sf.basedb.clients.web.extensions.list.ListColumnUtil"
61  import="net.sf.basedb.util.extensions.ExtensionsInvoker"
62  import="java.util.Date"
63  import="java.util.List"
64  import="java.util.Map"
65%>
66<%@ taglib prefix="base" uri="/WEB-INF/base.tld" %>
67<%@ taglib prefix="tbl" uri="/WEB-INF/table.tld" %>
68<%@ taglib prefix="ext" uri="/WEB-INF/extensions.tld" %>
69<%!
70  private static final Item itemType = Item.GROUP;
71  private static final GuiContext guiContext = new GuiContext(itemType, GuiContext.Type.LIST);
72%>
73<%
74final SessionControl sc = Base.getExistingSessionControl(pageContext, Permission.DENIED, itemType);
75final String ID = sc.getId();
76final boolean createPermission = sc.hasPermission(Permission.CREATE, itemType);
77final boolean writePermission = sc.hasPermission(Permission.WRITE, itemType);
78final boolean deletePermission = sc.hasPermission(Permission.DELETE, itemType);
79final ItemContext cc = Base.getAndSetCurrentContext(sc, itemType, null, null);
80
81final ModeInfo mode = ModeInfo.get(request.getParameter("mode"));
82final String callback = request.getParameter("callback");
83final String title = mode.generateTitle("group", "groups");
84final DbControl dc = sc.newDbControl();
85ItemResultIterator<Group> groups = null;
86try
87{
88  Formatter<Date> dateFormatter = FormatterFactory.getDateFormatter(sc);
89  // Query for groups relatated to the current group
90  final ItemQuery<Group> groupQuery = Group.getQuery();
91  groupQuery.include(cc.getInclude());
92  groupQuery.join(Hql.innerJoin("parents", "p"));
93  groupQuery.restrict(Restrictions.eq(Hql.alias("p"), Expressions.parameter("group")));
94  groupQuery.order(Orders.asc(Hql.property("name"))); 
95
96  // Query for users relatated to the current group
97  final ItemQuery<User> userQuery = User.getQuery();
98  userQuery.include(cc.getInclude());
99  userQuery.join(Hql.innerJoin("groups", "grp"));
100  userQuery.restrict(Restrictions.eq(Hql.alias("grp"), Expressions.parameter("group")));
101  userQuery.order(Orders.asc(Hql.property("name"))); 
102
103  Map<Plugin.MainType, Integer> pluginCount = PluginDefinition.countPlugins(dc, guiContext);
104  JspContext jspContext = ExtensionsControl.createContext(dc, pageContext, guiContext, null);
105  try
106  {
107    final ItemQuery<Group> query = Base.getConfiguredQuery(dc, cc, jspContext, true, Group.getQuery(), mode);
108    groups = query.iterate(dc);
109  }
110  catch (Throwable t)
111  {
112    cc.setMessage(t.getMessage());
113  }
114  int numListed = 0;
115  ExtensionsInvoker<ButtonAction> invoker = ToolbarUtil.useExtensions(jspContext);
116  ExtensionsInvoker<ListColumnAction<Group,?>> columnsInvoker = ListColumnUtil.useExtensions(jspContext);
117  %>
118  <base:page title="<%=title==null ? "Groups" : title%>" type="<%=mode.getPageType()%>" id="list-page">
119  <base:head scripts="table.js,~groups.js" styles="table.css,toolbar.css">
120    <ext:scripts context="<%=jspContext%>" />
121    <ext:stylesheets context="<%=jspContext%>" />
122  </base:head>
123 
124  <base:body>
125    <h1><%=title==null ? "Groups" : title%></h1>
126    <div class="content">
127    <tbl:table 
128      id="groups" 
129      columns="<%=cc.getSetting("columns")%>"
130      sortby="<%=cc.getSortProperty()%>" 
131      direction="<%=cc.getSortDirection()%>"
132      action="index.jsp"
133      sc="<%=sc%>"
134      item="<%=itemType%>"
135      filterrows="<%=cc.getFilterRows()%>"
136      subclass="fulltable sticky-headers"
137      >
138      <tbl:hidden 
139        name="mode" 
140        value="<%=mode.getName()%>" 
141      />
142      <tbl:hidden 
143        name="callback" 
144        value="<%=callback%>" 
145        skip="<%=callback == null%>" 
146      />
147      <tbl:columndef 
148        id="name"
149        property="name"
150        datatype="string"
151        title="Name"
152        sortable="true" 
153        filterable="true"
154        exportable="true"
155        show="always" 
156      />
157      <tbl:columndef 
158        id="id"
159        clazz="uniquecol"
160        property="id"
161        datatype="int"
162        title="ID"
163        sortable="true"
164        filterable="true"
165        exportable="true"
166      />
167      <tbl:columndef 
168        id="entryDate"
169        property="entryDate"
170        datatype="date"
171        title="Registered"
172        sortable="true" 
173        filterable="true"
174        exportable="true"
175        formatter="<%=dateFormatter%>"
176      />
177      <tbl:columndef 
178        id="systemId"
179        clazz="uniquecol"
180        property="systemId"
181        datatype="string"
182        title="System ID"
183        sortable="true"
184        filterable="true"
185        exportable="true"
186      />
187      <tbl:columndef 
188        id="quota"
189        property="quota.name"
190        datatype="string"
191        title="Quota"
192        sortable="true" 
193        filterable="true"
194        exportable="true"
195      />
196      <tbl:columndef 
197        id="isDefault"
198        property="default"
199        datatype="boolean"
200        title="Is default"
201        sortable="true" 
202        filterable="true"
203        exportable="true"
204      />
205      <tbl:columndef 
206        id="hiddenMembers"
207        property="hiddenMembers"
208        datatype="boolean"
209        title="Hidden members"
210        sortable="true" 
211        filterable="true"
212        exportable="true"
213      />
214      <tbl:columndef
215        id="users"
216        title="Users"
217        property="&users(name)"
218        datatype="string"
219        filterable="true"
220        exportable="true"
221      />
222      <tbl:columndef
223        id="groups"
224        title="Groups"
225        property="&children(name)"
226        datatype="string"
227        filterable="true"
228        exportable="true"
229      />
230      <tbl:columndef 
231        id="description"
232        property="description"
233        datatype="string"
234        title="Description" 
235        sortable="true" 
236        filterable="true" 
237        exportable="true"
238      />
239      <tbl:columndef 
240        id="xt-columns" 
241        extensions="<%=columnsInvoker%>" 
242        jspcontext="<%=jspContext%>" 
243      />
244      <div class="panelgroup bg-filled-50 bottomborder">
245        <tbl:toolbar
246          subclass="bottomborder"
247          visible="<%=mode.hasToolbar()%>"
248          >
249          <tbl:button 
250            id="btnNewItem"
251            disabled="<%=!createPermission%>" 
252            image="new.png" 
253            title="New&hellip;" 
254            tooltip="<%=createPermission ? "Create new group" : "You do not have permission to create groups"%>" 
255          />
256          <tbl:button 
257            id="btnDeleteItems"
258            disabled="<%=!deletePermission%>" 
259            image="delete.png" 
260            title="Delete" 
261            tooltip="<%=deletePermission ? "Delete the selected items" : "You do not have permission to delete groups" %>" 
262          />
263          <tbl:button 
264            id="btnRestoreItems"
265            disabled="<%=!writePermission%>" 
266            image="restore.png" 
267            title="Restore" 
268            tooltip="<%=writePermission ? "Restore the selected (deleted) items" : "You do not have permission to edit groups" %>" 
269          />
270          <tbl:button 
271            id="btnColumns"
272            image="columns.png" 
273            title="Columns&hellip;" 
274            tooltip="Show, hide and re-order columns" 
275          />
276          <tbl:button 
277            id="btnImport"
278            data-plugin-type="IMPORT"
279            image="import.png" 
280            title="Import&hellip;" 
281            tooltip="Import data" 
282            visible="<%=pluginCount.containsKey(Plugin.MainType.IMPORT)%>"
283          />
284          <tbl:button 
285            id="btnExport"
286            data-plugin-type="EXPORT"
287            image="export.png" 
288            title="Export&hellip;" 
289            tooltip="Export data" 
290            visible="<%=pluginCount.containsKey(Plugin.MainType.EXPORT)%>"
291          />
292          <tbl:button 
293            id="btnRunPlugin"
294            data-plugin-type="OTHER"
295            image="runplugin.png" 
296            title="Run plugin&hellip;" 
297            tooltip="Run a plugin" 
298            visible="<%=pluginCount.containsKey(Plugin.MainType.OTHER)%>"
299          />
300          <ext:render extensions="<%=invoker%>" context="<%=jspContext%>" 
301            wrapper="<%=new PrefixSuffixRenderer<ButtonAction>(jspContext, "<td>", "</td>") %>"/>
302        </tbl:toolbar>
303        <tbl:panel>
304          <tbl:presetselector />
305          <tbl:navigator
306            page="<%=cc.getPage()%>" 
307            rowsperpage="<%=cc.getRowsPerPage()%>" 
308            totalrows="<%=groups == null ? 0 : groups.getTotalCount()%>" 
309            visible="<%=mode.hasNavigator()%>"
310          />
311        </tbl:panel>
312      </div>
313      <tbl:data>
314        <tbl:headers>
315          <tbl:headerrow>
316            <tbl:header colspan="3" />
317            <tbl:columnheaders />
318          </tbl:headerrow>
319          <%
320          int numFilters = cc.getNumPropertyFilters();
321          int numRows = cc.getFilterRows();
322          for (int filterNo = 0; filterNo < numRows; filterNo++)
323          {
324            boolean lastRow = filterNo == numRows-1;
325            %>
326            <tbl:headerrow>
327              <tbl:header subclass="index" />
328              <tbl:header 
329                subclass="check" 
330                visible="<%=mode.hasCheck()%>"
331                ><base:icon 
332                  subclass="link table-check"
333                  image="check_uncheck.png" 
334                  tooltip="Toggle all (use CTRL, ALT or SHIFT to check/uncheck)" 
335                  visible="<%=lastRow%>"
336                /></tbl:header>
337              <tbl:header 
338                subclass="check" 
339                visible="<%=mode.hasRadio()%>"
340                />
341              <tbl:header 
342                subclass="icons" 
343                visible="<%=mode.hasIcons()%>"
344                >
345                <base:icon
346                  subclass="link table-filter-row-action"
347                  image="add.png"
348                  tooltip="Add extra filter row"
349                  visible="<%=lastRow%>"
350                /><base:icon
351                  subclass="link table-filter-row-action"
352                  image="remove.png"
353                  tooltip="Remove this filter row"
354                  visible="<%=numRows > 1 || numFilters > 0 %>"
355                  data-remove-row="<%=filterNo%>"
356                />
357              </tbl:header>
358              <tbl:propertyfilter row="<%=filterNo%>" />
359            </tbl:headerrow>
360            <%
361          }
362          %>
363          <tbl:columnsubtitles />
364        </tbl:headers>
365        <tbl:rows>
366          <%
367          if (cc.getMessage() != null)
368          {
369            %>
370            <tbl:panel subclass="bg-filled-50">
371              <div class="messagecontainer error"><%=cc.getMessage()%></div>
372            </tbl:panel>
373            <%
374            cc.setMessage(null);
375          }
376          int index = cc.getPage()*cc.getRowsPerPage();
377          int selectedItemId = cc.getId();
378          if (groups != null)
379          {           
380            while (groups.hasNext())
381            {
382              Group item = groups.next();
383              int itemId = item.getId();
384              String name = HTML.encodeTags(item.getName());
385              String tooltip = mode.isSelectionMode() ? 
386                  "Select this item" : "View this item" + (writePermission ? " (use CTRL, ALT or SHIFT to edit)" : "");
387             
388              index++;
389              numListed++;
390              %>
391              <tbl:row>
392                <tbl:header 
393                  clazz="index"
394                  ><%=index%></tbl:header>
395                <tbl:header 
396                  clazz="check" 
397                  visible="<%=mode.hasCheck()%>"
398                  ><input 
399                    type="checkbox" 
400                    name="<%=itemId%>" 
401                    value="<%=itemId%>" 
402                    title="<%=name%>" 
403                    <%=cc.getSelected().contains(itemId) ? "checked" : ""%> 
404                  ></tbl:header>
405                <tbl:header 
406                  clazz="check" 
407                  visible="<%=mode.hasRadio()%>"
408                  ><input 
409                    type="radio" 
410                    name="item_id" 
411                    value="<%=itemId%>" 
412                    title="<%=name%>" 
413                    <%=selectedItemId == itemId ? "checked" : ""%>
414                  ></tbl:header>
415                <tbl:header 
416                  clazz="icons" 
417                  visible="<%=mode.hasIcons()%>"
418                  ><base:icon 
419                    image="deleted.png"
420                    id="<%="delete."+itemId %>"
421                    subclass="<%=deletePermission ? "table-delete-item" : "disabled" %>"
422                    data-item-id="<%=itemId%>"
423                    tooltip="This item has been scheduled for deletion" 
424                    visible="<%=item.isRemoved()%>"
425                  /><base:icon
426                    image="systemitem.png"
427                    tooltip="This item is a system item"
428                    visible="<%=item.isSystemItem()%>" 
429                  />&nbsp;</tbl:header>
430                <tbl:cell column="name"><div 
431                  class="link table-item"
432                  data-item-id="<%=itemId %>"
433                  data-no-edit="<%=writePermission ? 0 : 1 %>"
434                  tabindex="0" 
435                  title="<%=tooltip%>"><%=name%></div></tbl:cell>
436                <tbl:cell column="id"><%=item.getId()%></tbl:cell>
437                <tbl:cell column="entryDate" value="<%=item.getEntryDate()%>" />
438                <tbl:cell column="systemId"><%=HTML.encodeTags(item.getSystemId())%></tbl:cell>
439                <tbl:cell column="quota"
440                  ><base:propertyvalue 
441                    item="<%=item%>" 
442                    property="quota"
443                    enableEditLink="<%=mode.hasEditLink()%>" 
444                    enablePropertyLink="<%=mode.hasPropertyLink()%>"
445                  /></tbl:cell>
446                <tbl:cell column="isDefault"><%=item.isDefault() ? "yes" : "no" %></tbl:cell>
447                <tbl:cell column="hiddenMembers"><%=item.hasHiddenMembers() ? "yes" : "no" %></tbl:cell>
448                <tbl:cell column="description"><%=HTML.encodeTags(item.getDescription())%></tbl:cell>
449                <tbl:cell column="groups">
450                  <%
451                  groupQuery.setParameter("group", itemId, Type.INT);
452                  try
453                  {
454                    String separator = "";
455                    for (Group g : groupQuery.list(dc))
456                    {
457                      out.write(separator);
458                      if (mode.hasPropertyLink())
459                      {
460                        out.write(Base.getLinkedName(ID, g, false, mode.hasEditLink()));
461                      }
462                      else
463                      {
464                        out.write(HTML.encodeTags(g.getName()));
465                      }
466                      separator = ", ";
467                    }
468                  }
469                  catch (Throwable t)
470                  {
471                    %>
472                    <div class="error"><%=t.getMessage()%></div>
473                    <%
474                  }
475                  %>
476                </tbl:cell>
477                <tbl:cell column="users">
478                  <%
479                  userQuery.setParameter("group", itemId, Type.INT);
480                  try
481                  {
482                    String separator = "";
483                    for (User u : userQuery.list(dc))
484                    {
485                      out.write(separator);
486                      if (mode.hasPropertyLink())
487                      {
488                        out.write(Base.getLinkedName(ID, u, false, mode.hasEditLink()));
489                      }
490                      else
491                      {
492                        out.write(HTML.encodeTags(u.getName()));
493                      }
494                      separator = ", ";
495                    }
496                  }
497                  catch (Throwable t)
498                  {
499                    %>
500                    <div class="error"><%=t.getMessage()%></div>
501                    <%
502                  }
503                  %>
504                </tbl:cell>
505                <tbl:xt-cells dc="<%=dc%>" item="<%=item%>">
506                  <tbl:cell column="xt-columns" />
507                </tbl:xt-cells>
508              </tbl:row>
509              <%
510              }
511            }
512          if (numListed == 0)
513          {
514            %>
515            <tbl:panel subclass="bg-filled-50">
516              <div class="messagecontainer note">
517              <%=groups == null || groups.getTotalCount() == 0 ? "No groups were found" : "No groups on this page. Please select another page!" %>
518              </div>
519            </tbl:panel>
520            <%
521          }
522          %>
523        </tbl:rows>
524      </tbl:data>
525    </tbl:table>
526    </div>
527   
528    <base:buttongroup subclass="dialogbuttons">
529      <base:button id="btnOk" title="Ok" visible="<%=mode.hasOkButton()%>" />
530      <base:button id="close" title="Cancel" visible="<%=mode.hasCancelButton()%>" />
531      <base:button id="close" title="Close" visible="<%=mode.hasCloseButton()%>" />
532    </base:buttongroup>
533   
534  </base:body>
535  </base:page>
536  <%
537}
538finally
539{
540  if (groups != null) groups.close();
541  if (dc != null) dc.close();
542}
543%>
Note: See TracBrowser for help on using the repository browser.