source: branches/3.18-stable/www/views/sessions/list_sessions.jsp @ 7938

Last change on this file since 7938 was 7938, checked in by Nicklas Nordborg, 3 months ago

References #2246: Sticky table headers

Implemented for all items in the "View" menu.

  • Property svn:eol-style set to native
  • Property svn:keywords set to Date Id
File size: 14.5 KB
Line 
1<%-- $Id: list_sessions.jsp 7938 2021-05-03 11:20:19Z nicklas $
2  ------------------------------------------------------------------
3  Copyright (C) 2006 Jari Häkkinen, Nicklas Nordborg, Martin Svensson
4  Copyright (C) 2007 Johan Enell
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.Session"
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.PluginDefinition"
39  import="net.sf.basedb.core.PermissionDeniedException"
40  import="net.sf.basedb.core.query.Hql"
41  import="net.sf.basedb.core.query.Restrictions"
42  import="net.sf.basedb.core.query.Expressions"
43  import="net.sf.basedb.core.plugin.GuiContext"
44  import="net.sf.basedb.core.plugin.Plugin"
45  import="net.sf.basedb.util.Enumeration"
46  import="net.sf.basedb.clients.web.Base"
47  import="net.sf.basedb.clients.web.ModeInfo"
48  import="net.sf.basedb.clients.web.PermissionUtil"
49  import="net.sf.basedb.clients.web.util.HTML"
50  import="net.sf.basedb.util.EmailUtil"
51  import="net.sf.basedb.util.GeoLocation"
52  import="net.sf.basedb.util.Values"
53  import="net.sf.basedb.util.formatter.Formatter"
54  import="net.sf.basedb.clients.web.formatter.FormatterFactory"
55  import="net.sf.basedb.clients.web.extensions.ExtensionsControl"
56  import="net.sf.basedb.clients.web.extensions.JspContext"
57  import="net.sf.basedb.clients.web.extensions.renderer.PrefixSuffixRenderer"
58  import="net.sf.basedb.clients.web.extensions.toolbar.ButtonAction" 
59  import="net.sf.basedb.clients.web.extensions.toolbar.ToolbarUtil"
60  import="net.sf.basedb.clients.web.extensions.list.ListColumnAction"
61  import="net.sf.basedb.clients.web.extensions.list.ListColumnUtil"
62  import="net.sf.basedb.util.extensions.ExtensionsInvoker"
63  import="java.util.List"
64  import="java.util.Map"
65  import="java.util.Date"
66%>
67<%@ taglib prefix="base" uri="/WEB-INF/base.tld" %>
68<%@ taglib prefix="tbl" uri="/WEB-INF/table.tld" %>
69<%@ taglib prefix="ext" uri="/WEB-INF/extensions.tld" %>
70<%!
71  private static final Item itemType = Item.SESSION;
72  private static final GuiContext guiContext = new GuiContext(itemType, GuiContext.Type.LIST);
73%>
74<%
75final SessionControl sc = Base.getExistingSessionControl(pageContext, Permission.DENIED, itemType);
76final String ID = sc.getId();
77final boolean createPermission = sc.hasPermission(Permission.CREATE, itemType);
78final ItemContext cc = Base.getAndSetCurrentContext(sc, itemType, null, null);
79
80final ModeInfo mode = ModeInfo.get(request.getParameter("mode"));
81final String callback = request.getParameter("callback");
82final String title = mode.generateTitle("session", "sessions");
83final DbControl dc = sc.newDbControl();
84ItemResultIterator<Session> sessions = null;
85try
86{
87  final User user = User.getById(dc, sc.getLoggedInUserId());
88
89  Map<Plugin.MainType, Integer> pluginCount = PluginDefinition.countPlugins(dc, guiContext);
90  JspContext jspContext = ExtensionsControl.createContext(dc, pageContext, guiContext, null);
91  try
92  {
93    final ItemQuery<Session> query = Base.getConfiguredQuery(dc, cc, jspContext, true, Session.getQuery(cc.getInclude().contains(Include.OTHERS) ? null : user), mode);
94    sessions = query.iterate(dc);
95  }
96  catch (Throwable t)
97  {
98    cc.setMessage(t.getMessage());
99  }
100  int numListed = 0;
101  Formatter<Date> dateTimeFormatter = FormatterFactory.getDateTimeFormatter(sc);
102  ExtensionsInvoker<ButtonAction> invoker = ToolbarUtil.useExtensions(jspContext);
103  ExtensionsInvoker<ListColumnAction<Session,?>> columnsInvoker = ListColumnUtil.useExtensions(jspContext);
104  %>
105  <base:page title="<%=title==null ? "Sessions" : title%>" type="<%=mode.getPageType()%>" id="list-page">
106  <base:head scripts="table.js,~sessions.js" styles="table.css,toolbar.css">
107    <ext:scripts context="<%=jspContext%>" />
108    <ext:stylesheets context="<%=jspContext%>" />
109  </base:head>
110 
111  <base:body>
112    <h1><%=title==null ? "Sessions" : title%></h1>
113    <div class="content">
114    <tbl:table 
115      id="sessions" 
116      columns="<%=cc.getSetting("columns")%>"
117      sortby="<%=cc.getSortProperty()%>" 
118      direction="<%=cc.getSortDirection()%>"
119      action="index.jsp"
120      sc="<%=sc%>"
121      item="<%=itemType%>"
122      filterrows="<%=cc.getFilterRows()%>"
123      subclass="fulltable"
124      stickyheaders="loginTime"
125      >
126      <tbl:hidden 
127        name="mode" 
128        value="<%=mode.getName()%>" 
129      />
130      <tbl:hidden 
131        name="callback" 
132        value="<%=callback%>" 
133        skip="<%=callback == null%>" 
134      />
135      <tbl:columndef 
136        id="id"
137        clazz="uniquecol"
138        property="id"
139        datatype="int"
140        title="ID"
141        sortable="true"
142        filterable="true"
143        exportable="true"
144      />
145      <tbl:columndef 
146        id="loginTime"
147        property="loginTime"
148        datatype="timestamp"
149        title="Login time"
150        sortable="true" 
151        filterable="true"
152        exportable="true"
153        show="always" 
154      />
155      <tbl:columndef 
156        id="logoutTime"
157        property="logoutTime"
158        datatype="timestamp"
159        title="Logout time"
160        sortable="true" 
161        filterable="true"
162        exportable="true"
163        formatter="<%=dateTimeFormatter%>"
164      />
165      <tbl:columndef 
166        id="impersonated"
167        property="impersonated"
168        datatype="boolean"
169        title="Impersonated"
170        sortable="true" 
171        filterable="true"
172        exportable="true"
173      />
174      <tbl:columndef 
175        id="client"
176        property="client.name"
177        datatype="string"
178        title="Client application" 
179        sortable="true" 
180        filterable="true" 
181        exportable="true"
182      />
183      <tbl:columndef 
184        id="device"
185        property="device.name"
186        datatype="string"
187        title="Device" 
188        sortable="true" 
189        filterable="true" 
190        exportable="true"
191      />
192      <tbl:columndef 
193        id="authenticationMethod"
194        property="authenticationMethod"
195        datatype="string"
196        title="Authentication method" 
197        sortable="true" 
198        filterable="true" 
199        exportable="true"
200      />
201      <tbl:columndef 
202        id="remoteId"
203        property="remoteId"
204        datatype="string"
205        title="Remote ID" 
206        sortable="true" 
207        filterable="true" 
208        exportable="true"
209      />
210      <tbl:columndef 
211        id="location"
212        property="location"
213        datatype="string"
214        title="Location" 
215        sortable="true" 
216        filterable="true" 
217        exportable="true"
218      />
219      <tbl:columndef 
220        id="comment"
221        property="loginComment"
222        datatype="string"
223        title="Comment" 
224        sortable="true" 
225        filterable="true" 
226        exportable="true"
227      />
228      <tbl:columndef 
229        id="user"
230        property="user.name"
231        datatype="string"
232        title="User" 
233        sortable="true" 
234        filterable="true" 
235        exportable="true"
236      />
237      <tbl:columndef
238        id="permission"
239        title="Permission"
240      />
241      <tbl:columndef 
242        id="xt-columns" 
243        extensions="<%=columnsInvoker%>" 
244        jspcontext="<%=jspContext%>" 
245      />
246      <div class="panelgroup bg-filled-50 bottomborder">
247        <tbl:toolbar
248          subclass="bottomborder"
249          visible="<%=mode.hasToolbar()%>"
250          >
251          <tbl:button 
252            id="btnColumns"
253            image="columns.png" 
254            title="Columns&hellip;" 
255            tooltip="Show, hide and re-order columns" 
256          />
257          <tbl:button 
258            id="btnExport"
259            data-plugin-type="EXPORT"
260            image="export.png" 
261            title="Export&hellip;" 
262            tooltip="Export data" 
263            visible="<%=pluginCount.containsKey(Plugin.MainType.EXPORT)%>"
264          />
265          <tbl:button 
266            id="btnRunPlugin"
267            data-plugin-type="OTHER"
268            image="runplugin.png" 
269            title="Run plugin&hellip;" 
270            tooltip="Run a plugin" 
271            visible="<%=pluginCount.containsKey(Plugin.MainType.OTHER)%>"
272          />
273          <ext:render extensions="<%=invoker%>" context="<%=jspContext%>" 
274            wrapper="<%=new PrefixSuffixRenderer<ButtonAction>(jspContext, "<td>", "</td>") %>"/>
275        </tbl:toolbar>
276        <tbl:panel>
277          <tbl:presetselector />
278          <tbl:navigator
279            page="<%=cc.getPage()%>" 
280            rowsperpage="<%=cc.getRowsPerPage()%>" 
281            totalrows="<%=sessions == null ? 0 : sessions.getTotalCount()%>" 
282            visible="<%=mode.hasNavigator()%>"
283          />
284        </tbl:panel>
285      </div>
286      <tbl:data>
287        <tbl:headers>
288          <tbl:headerrow>
289            <tbl:header clazz="row-index bg-filled-100" />
290            <tbl:columnheaders />
291          </tbl:headerrow>
292          <%
293          int numFilters = cc.getNumPropertyFilters();
294          int numRows = cc.getFilterRows();
295          for (int filterNo = 0; filterNo < numRows; filterNo++)
296          {
297            boolean lastRow = filterNo == numRows-1;
298            %>
299            <tbl:headerrow>
300              <tbl:header subclass="row-index bg-filled-100">
301                <div class="index-<%=mode.getName()%>">
302                  <div class="index"></div>
303                  <div class="check">
304                    <base:icon 
305                      subclass="link table-check"
306                      image="check_uncheck.png" 
307                      tooltip="Toggle all (use CTRL, ALT or SHIFT to check/uncheck)" 
308                      visible="<%=lastRow && mode.hasCheck()%>"
309                    />
310                  </div>
311                  <div class="icons">
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                  </div>
325                </div>
326              </tbl:header>
327              <tbl:propertyfilter row="<%=filterNo%>" />
328            </tbl:headerrow>
329            <%
330          }
331          %>
332          <tbl:columnsubtitles />
333        </tbl:headers>
334        <tbl:rows>
335          <%
336          if (cc.getMessage() != null)
337          {
338            %>
339            <tbl:panel subclass="bg-filled-50">
340              <div class="messagecontainer error"><%=cc.getMessage()%></div>
341            </tbl:panel>
342            <%
343            cc.setMessage(null);
344          }
345          int index = cc.getPage()*cc.getRowsPerPage();
346          int selectedItemId = cc.getId();
347          if (sessions != null)
348          {
349            String tooltip = mode.isSelectionMode() ?
350              "Select this item" : "View this item";
351            while (sessions.hasNext())
352            {
353              Session item = sessions.next();
354              int itemId = item.getId();
355              String name = "TODO";
356              index++;
357              numListed++;
358              %>
359              <tbl:row>
360                <tbl:header clazz="row-index bg-filled-100">
361                  <div class="index-<%=mode.getName()%>">
362                    <div class="index <%=index>999?"index-smaller":""%>"><%=index%></div>
363                    <div class="check">
364                      <base:input
365                        type="checkbox" 
366                        name="<%=itemId%>" 
367                        value="<%=itemId%>" 
368                        title="<%=name%>" 
369                        checked="<%=cc.getSelected().contains(itemId)%>"
370                        visible="<%=mode.hasCheck()%>"
371                      />
372                      <base:input 
373                        type="radio" 
374                        name="item_id" 
375                        value="<%=itemId%>" 
376                        title="<%=name%>" 
377                        checked="<%=selectedItemId == itemId%>"
378                        visible="<%=mode.hasRadio()%>"
379                      />
380                    </div>
381                    <div class="icons"></div>
382                  </div>
383                </tbl:header>
384                <tbl:cell column="id"><%=item.getId()%></tbl:cell>
385                <tbl:cell column="loginTime"><div 
386                  class="link table-item"
387                  data-item-id="<%=itemId%>"
388                  data-no-edit="1"
389                  tabindex="0"
390                  title="<%=tooltip%>"><%=dateTimeFormatter.format(item.getLoginTime())%></div></tbl:cell>
391                <tbl:cell column="logoutTime" value="<%=item.getLogoutTime()%>" />
392                <tbl:cell column="impersonated"><%=item.getImpersonated()%></tbl:cell>
393                <tbl:cell column="authenticationMethod"><%=HTML.encodeTags(item.getAuthenticationMethod())%></tbl:cell>
394                <tbl:cell column="remoteId"><%=HTML.encodeTags(item.getRemoteId())%></tbl:cell>
395                <tbl:cell column="location"><%=HTML.encodeTags(item.getLocation())%>
396                  <% String mapURL = GeoLocation.getURLToMap(item.getLocationLatitude(), item.getLocationLongitude()); %>
397                  <base:icon href="<%=mapURL%>" image="map.png" tooltip="Show map" visible="<%=mapURL != null %>"/>               
398                </tbl:cell>
399                <tbl:cell column="comment"><%=HTML.encodeTags(item.getLoginComment())%></tbl:cell>
400                <tbl:cell column="user"
401                  ><base:propertyvalue 
402                    item="<%=item%>" 
403                    property="user"
404                    enableEditLink="<%=mode.hasEditLink()%>" 
405                    enablePropertyLink="<%=mode.hasPropertyLink()%>"
406                  /></tbl:cell>
407                <tbl:cell column="client"
408                  ><base:propertyvalue 
409                    item="<%=item%>" 
410                    property="client"
411                    enableEditLink="<%=mode.hasEditLink()%>" 
412                    enablePropertyLink="<%=mode.hasPropertyLink()%>"
413                  /></tbl:cell>
414                <tbl:cell column="device"
415                  ><base:propertyvalue 
416                    item="<%=item%>" 
417                    property="device"
418                    nulltext="<i>- unknown -</i>"
419                    enableEditLink="<%=mode.hasEditLink()%>" 
420                    enablePropertyLink="<%=mode.hasPropertyLink()%>"
421                  /></tbl:cell>
422                <tbl:cell column="permission"><%=PermissionUtil.getShortPermissions(item)%></tbl:cell>
423                <tbl:xt-cells dc="<%=dc%>" item="<%=item%>">
424                  <tbl:cell column="xt-columns" />
425                </tbl:xt-cells>
426            </tbl:row>
427            <%
428            }
429          }
430          if (numListed == 0)
431          {
432            %>
433            <tbl:panel subclass="bg-filled-50">
434              <div class="messagecontainer note">
435              <%=sessions == null || sessions.getTotalCount() == 0 ? "No sessions were found" : "No sessions on this page. Please select another page!" %>
436              </div>
437            </tbl:panel>
438            <%
439          }
440          %>
441        </tbl:rows>
442      </tbl:data>
443    </tbl:table>
444    </div>
445   
446    <base:buttongroup subclass="dialogbuttons">
447      <base:button id="btnOk" title="Ok" visible="<%=mode.hasOkButton()%>" />
448      <base:button id="close" title="Cancel" visible="<%=mode.hasCancelButton()%>" />
449      <base:button id="close" title="Close" visible="<%=mode.hasCloseButton()%>" />
450    </base:buttongroup>
451   
452  </base:body>
453  </base:page>
454  <%
455}
456finally
457{
458  if (sessions != null) sessions.close();
459  if (dc != null) dc.close();
460}
461%>
Note: See TracBrowser for help on using the repository browser.