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