source: branches/3.18-stable/www/admin/roles/list_roles.jsp @ 7939

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

References #2246: Sticky table headers

It should now be implemented on all list pages.

  • Property svn:eol-style set to native
  • Property svn:keywords set to Date Id
File size: 14.9 KB
Line 
1<%-- $Id: list_roles.jsp 7939 2021-05-04 07:30:31Z 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"
130      stickyheaders="name"
131      >
132      <tbl:hidden 
133        name="mode" 
134        value="<%=mode.getName()%>" 
135      />
136      <tbl:hidden 
137        name="callback" 
138        value="<%=callback%>" 
139        skip="<%=callback == null%>" 
140      />
141      <tbl:columndef 
142        id="name"
143        property="name"
144        datatype="string"
145        title="Name"
146        sortable="true" 
147        filterable="true"
148        exportable="true"
149        show="always" 
150      />
151      <tbl:columndef 
152        id="id"
153        clazz="uniquecol"
154        property="id"
155        datatype="int"
156        title="ID"
157        sortable="true"
158        filterable="true"
159        exportable="true"
160      />
161      <tbl:columndef 
162        id="entryDate"
163        property="entryDate"
164        datatype="date"
165        title="Registered"
166        sortable="true" 
167        filterable="true"
168        exportable="true"
169        formatter="<%=dateFormatter%>"
170      />
171      <tbl:columndef 
172        id="systemId"
173        clazz="uniquecol"
174        property="systemId"
175        datatype="string"
176        title="System ID"
177        sortable="true"
178        filterable="true"
179        exportable="true"
180      />
181      <tbl:columndef 
182        id="isDefault"
183        property="default"
184        datatype="boolean"
185        title="Is default"
186        sortable="true" 
187        filterable="true"
188        exportable="true"
189      />
190      <tbl:columndef
191        id="users"
192        title="Users"
193        property="&users(name)"
194        datatype="string"
195        filterable="true"
196        exportable="true"
197      />
198      <tbl:columndef 
199        id="description"
200        property="description"
201        datatype="string"
202        title="Description" 
203        sortable="true" 
204        filterable="true" 
205        exportable="true"
206      />
207      <tbl:columndef 
208        id="xt-columns" 
209        extensions="<%=columnsInvoker%>" 
210        jspcontext="<%=jspContext%>" 
211      />
212      <div class="panelgroup bg-filled-50 bottomborder">
213        <tbl:toolbar
214          subclass="bottomborder"
215          visible="<%=mode.hasToolbar()%>"
216          >
217          <tbl:button 
218            id="btnNewItem"
219            disabled="<%=!createPermission%>" 
220            image="new.png" 
221            title="New&hellip;" 
222            tooltip="<%=createPermission ? "Create new group" : "You do not have permission to create groups"%>" 
223          />
224          <tbl:button 
225            id="btnDeleteItems"
226            disabled="<%=!deletePermission%>" 
227            image="delete.png" 
228            title="Delete" 
229            tooltip="<%=deletePermission ? "Delete the selected items" : "You do not have permission to delete groups" %>" 
230          />
231          <tbl:button 
232            id="btnRestoreItems"
233            disabled="<%=!writePermission%>" 
234            image="restore.png" 
235            title="Restore" 
236            tooltip="<%=writePermission ? "Restore the selected (deleted) items" : "You do not have permission to edit groups" %>" 
237          />
238          <tbl:button 
239            id="btnColumns"
240            image="columns.png" 
241            title="Columns&hellip;" 
242            tooltip="Show, hide and re-order columns" 
243          />
244          <tbl:button 
245            id="btnImport"
246            data-plugin-type="IMPORT"
247            image="import.png" 
248            title="Import&hellip;" 
249            tooltip="Import data" 
250            visible="<%=pluginCount.containsKey(Plugin.MainType.IMPORT)%>"
251          />
252          <tbl:button 
253            id="btnExport"
254            data-plugin-type="EXPORT"
255            image="export.png" 
256            title="Export&hellip;" 
257            tooltip="Export data" 
258            visible="<%=pluginCount.containsKey(Plugin.MainType.EXPORT)%>"
259          />
260          <tbl:button 
261            id="btnRunPlugin"
262            data-plugin-type="OTHER"
263            image="runplugin.png" 
264            title="Run plugin&hellip;" 
265            tooltip="Run a plugin" 
266            visible="<%=pluginCount.containsKey(Plugin.MainType.OTHER)%>"
267          />
268          <ext:render extensions="<%=invoker%>" context="<%=jspContext%>" 
269            wrapper="<%=new PrefixSuffixRenderer<ButtonAction>(jspContext, "<td>", "</td>") %>"/>
270        </tbl:toolbar>
271        <tbl:panel>
272          <tbl:presetselector />
273          <tbl:navigator
274            page="<%=cc.getPage()%>" 
275            rowsperpage="<%=cc.getRowsPerPage()%>" 
276            totalrows="<%=roles == null ? 0 : roles.getTotalCount()%>" 
277            visible="<%=mode.hasNavigator()%>"
278          />
279        </tbl:panel>
280      </div>
281      <tbl:data>
282        <tbl:headers>
283          <tbl:headerrow>
284            <tbl:header clazz="row-index bg-filled-100" />
285            <tbl:columnheaders />
286          </tbl:headerrow>
287          <%
288          int numFilters = cc.getNumPropertyFilters();
289          int numRows = cc.getFilterRows();
290          for (int filterNo = 0; filterNo < numRows; filterNo++)
291          {
292            boolean lastRow = filterNo == numRows-1;
293            %>
294            <tbl:headerrow>
295              <tbl:header subclass="row-index bg-filled-100">
296                <div class="index-<%=mode.getName()%>">
297                  <div class="index"></div>
298                  <div class="check">
299                    <base:icon 
300                      subclass="link table-check"
301                      image="check_uncheck.png" 
302                      tooltip="Toggle all (use CTRL, ALT or SHIFT to check/uncheck)" 
303                      visible="<%=lastRow && mode.hasCheck()%>"
304                    />
305                  </div>
306                  <div class="icons">
307                    <base:icon
308                      subclass="link table-filter-row-action"
309                      image="add.png"
310                      tooltip="Add extra filter row"
311                      visible="<%=lastRow%>"
312                    /><base:icon
313                      subclass="link table-filter-row-action"
314                      image="remove.png"
315                      tooltip="Remove this filter row"
316                      visible="<%=numRows > 1 || numFilters > 0 %>"
317                      data-remove-row="<%=filterNo%>"
318                    />
319                  </div>
320                </div>
321              </tbl:header>
322              <tbl:propertyfilter row="<%=filterNo%>" />
323            </tbl:headerrow>
324            <%
325          }
326          %>
327          <tbl:columnsubtitles />
328        </tbl:headers>
329        <tbl:rows>
330          <%
331          if (cc.getMessage() != null)
332          {
333            %>
334            <tbl:panel subclass="bg-filled-50">
335              <div class="messagecontainer error"><%=cc.getMessage()%></div>
336            </tbl:panel>
337            <%
338            cc.setMessage(null);
339          }
340          int index = cc.getPage()*cc.getRowsPerPage();
341          int selectedItemId = cc.getId();
342          if (roles != null)
343          {           
344            while (roles.hasNext())
345            {
346              Role item = roles.next();
347              int itemId = item.getId();
348              String name = HTML.encodeTags(item.getName());
349              String tooltip = mode.isSelectionMode() ? 
350                  "Select this item" : "View this item" + (writePermission ? " (use CTRL, ALT or SHIFT to edit)" : "");
351             
352              index++;
353              numListed++;
354              %>
355              <tbl:row>
356                <tbl:header clazz="row-index bg-filled-100">
357                  <div class="index-<%=mode.getName()%>">
358                    <div class="index <%=index>999?"index-smaller":""%>"><%=index%></div>
359                    <div class="check">
360                      <base:input
361                        type="checkbox" 
362                        name="<%=itemId%>" 
363                        value="<%=itemId%>" 
364                        title="<%=name%>" 
365                        checked="<%=cc.getSelected().contains(itemId)%>"
366                        visible="<%=mode.hasCheck()%>"
367                      />
368                      <base:input 
369                        type="radio" 
370                        name="item_id" 
371                        value="<%=itemId%>" 
372                        title="<%=name%>" 
373                        checked="<%=selectedItemId == itemId%>"
374                        visible="<%=mode.hasRadio()%>"
375                      />
376                    </div>
377                    <div class="icons">
378                      <base:icon 
379                        image="deleted.png"
380                        id="<%="delete."+itemId %>"
381                        subclass="<%=deletePermission ? "table-delete-item" : "disabled" %>"
382                        data-item-id="<%=itemId%>"
383                        tooltip="This item has been scheduled for deletion" 
384                        visible="<%=item.isRemoved()%>"
385                      /><base:icon
386                        image="systemitem.png"
387                        tooltip="This item is a system item"
388                        visible="<%=item.isSystemItem()%>" 
389                      />
390                    </div>
391                  </div>
392                </tbl:header>
393                <tbl:cell column="name"><div 
394                  class="link table-item"
395                  data-item-id="<%=itemId%>"
396                  data-no-edit="<%=writePermission ? 0 : 1%>" 
397                  tabindex="0"
398                  title="<%=tooltip%>"><%=name%></div></tbl:cell>
399                <tbl:cell column="id"><%=item.getId()%></tbl:cell>
400                <tbl:cell column="entryDate" value="<%=item.getEntryDate()%>" />
401                <tbl:cell column="systemId"><%=HTML.encodeTags(item.getSystemId())%></tbl:cell>
402                <tbl:cell column="isDefault"><%=item.isDefault() ? "yes" : "no" %></tbl:cell>
403                <tbl:cell column="users">
404                  <%
405                  userQuery.setParameter("role", itemId, Type.INT);
406                  try
407                  {
408                    String separator = "";
409                    for (User u : userQuery.list(dc))
410                    {
411                      out.write(separator);
412                      if (mode.hasPropertyLink())
413                      {
414                        out.write(Base.getLinkedName(ID, u, false, mode.hasEditLink()));
415                      }
416                      else
417                      {
418                        out.write(HTML.encodeTags(u.getName()));
419                      }
420                      separator = ", ";
421                    }
422                  }
423                  catch (Throwable t)
424                  {
425                    %>
426                    <div class="error"><%=t.getMessage()%></div>
427                    <%
428                  }
429                  %>
430                </tbl:cell>
431                <tbl:cell column="description"><%=HTML.encodeTags(item.getDescription())%></tbl:cell>
432                <tbl:xt-cells dc="<%=dc%>" item="<%=item%>">
433                  <tbl:cell column="xt-columns" />
434                </tbl:xt-cells>
435              </tbl:row>
436              <%
437              }
438            }
439          if (numListed == 0)
440          {
441            %>
442            <tbl:panel subclass="bg-filled-50">
443              <div class="messagecontainer note">
444              <%=roles == null || roles.getTotalCount() == 0 ? "No roles were found" : "No roles on this page. Please select another page!" %>
445              </div>
446            </tbl:panel>
447            <%
448          }
449          %>
450          </tbl:rows>
451      </tbl:data>
452    </tbl:table>
453    </div>
454   
455    <base:buttongroup subclass="dialogbuttons">
456      <base:button id="btnOk" title="Ok" visible="<%=mode.hasOkButton()%>" />
457      <base:button id="close" title="Cancel" visible="<%=mode.hasCancelButton()%>" />
458      <base:button id="close" title="Close" visible="<%=mode.hasCloseButton()%>" />
459    </base:buttongroup>
460   
461  </base:body>
462  </base:page>
463  <%
464}
465finally
466{
467  if (roles != null) roles.close();
468  if (dc != null) dc.close();
469}
470%>
Note: See TracBrowser for help on using the repository browser.