source: branches/3.18-stable/www/common/history/list_history.jsp @ 7932

Last change on this file since 7932 was 7932, checked in by Nicklas Nordborg, 14 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: 13.9 KB
Line 
1<%-- $Id: list_history.jsp 7932 2021-04-28 07:16:56Z nicklas $
2  ------------------------------------------------------------------
3  Copyright (C) 2006 Jari Häkkinen, Nicklas Nordborg, Martin Svensson
4
5  This file is part of BASE - BioArray Software Environment.
6  Available at http://base.thep.lu.se/
7
8  BASE is free software; you can redistribute it and/or
9  modify it under the terms of the GNU General Public License
10  as published by the Free Software Foundation; either version 3
11  of the License, or (at your option) any later version.
12
13  BASE is distributed in the hope that it will be useful,
14  but WITHOUT ANY WARRANTY; without even the implied warranty of
15  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
16  GNU General Public License for more details.
17
18  You should have received a copy of the GNU General Public License
19  along with BASE. If not, see <http://www.gnu.org/licenses/>.
20  ------------------------------------------------------------------
21
22  @author Nicklas
23  @version 2.0
24--%>
25<%@ page pageEncoding="UTF-8" session="false"
26  import="net.sf.basedb.core.SessionControl"
27  import="net.sf.basedb.core.DbControl"
28  import="net.sf.basedb.core.Item"
29  import="net.sf.basedb.core.BasicItem"
30  import="net.sf.basedb.core.ChangeHistory"
31  import="net.sf.basedb.core.Permission"
32  import="net.sf.basedb.core.Nameable"
33  import="net.sf.basedb.core.ItemContext"
34  import="net.sf.basedb.core.ItemQuery"
35  import="net.sf.basedb.core.ItemResultIterator"
36  import="net.sf.basedb.core.PermissionDeniedException"
37  import="net.sf.basedb.core.PluginDefinition"
38  import="net.sf.basedb.core.query.Orders"
39  import="net.sf.basedb.core.query.Hql"
40  import="net.sf.basedb.core.plugin.GuiContext"
41  import="net.sf.basedb.core.plugin.Plugin"
42  import="net.sf.basedb.core.log.ChangeType"
43  import="net.sf.basedb.util.Values"
44  import="net.sf.basedb.util.Enumeration"
45  import="net.sf.basedb.util.formatter.Formatter"
46  import="net.sf.basedb.clients.web.Base"
47  import="net.sf.basedb.clients.web.ModeInfo"
48  import="net.sf.basedb.clients.web.ChangeHistoryUtil"
49  import="net.sf.basedb.clients.web.util.HTML"
50  import="net.sf.basedb.clients.web.formatter.FormatterFactory"
51  import="net.sf.basedb.clients.web.extensions.ExtensionsControl"
52  import="net.sf.basedb.clients.web.extensions.JspContext"
53  import="net.sf.basedb.clients.web.extensions.renderer.PrefixSuffixRenderer"
54  import="net.sf.basedb.clients.web.extensions.toolbar.ButtonAction" 
55  import="net.sf.basedb.clients.web.extensions.toolbar.ToolbarUtil"
56  import="net.sf.basedb.clients.web.extensions.list.ListColumnAction"
57  import="net.sf.basedb.clients.web.extensions.list.ListColumnUtil"
58  import="net.sf.basedb.util.extensions.ExtensionsInvoker"
59  import="java.util.List"
60  import="java.util.Date"
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.CHANGEHISTORY;
68  private static final GuiContext guiContext = new GuiContext(itemType, GuiContext.Type.LIST);
69%>
70<%
71final SessionControl sc = Base.getExistingSessionControl(pageContext, true);
72final String ID = sc.getId();
73final ItemContext cc = Base.getAndSetCurrentContext(sc, itemType, null, null);
74
75final Item sourceType = Item.valueOf(request.getParameter("source_type"));
76final int sourceId = Values.getInt(request.getParameter("source_id"));
77final float scale = Base.getScale(sc);
78final ModeInfo mode = ModeInfo.get(request.getParameter("mode"));
79final String callback = request.getParameter("callback");
80final String title = mode.generateTitle("history entry", "history entries");
81final DbControl dc = sc.newDbControl();
82ItemResultIterator<ChangeHistory> history = null;
83
84try
85{
86  final BasicItem source = sourceType.getById(dc, sourceId); 
87  Map<Plugin.MainType, Integer> pluginCount = PluginDefinition.countPlugins(dc, guiContext);
88  JspContext jspContext = ExtensionsControl.createContext(dc, pageContext, guiContext, null);
89  try
90  {
91    final ItemQuery<ChangeHistory> query = 
92      Base.getConfiguredQuery(dc, cc, jspContext, true, ChangeHistory.getHistoryOf(source), mode);
93    query.order(cc.getSortDirection().sortBy(Hql.property("id")));
94    history = query.iterate(dc);
95    //cc.setMessage(query.toString());
96  }
97  catch (Throwable t)
98  {
99    cc.setMessage(t.getMessage());
100    t.printStackTrace();
101  }
102  Formatter<Date> dateFormatter = FormatterFactory.getDateTimeFormatter(sc);
103  ExtensionsInvoker<ButtonAction> invoker = ToolbarUtil.useExtensions(jspContext);
104  ExtensionsInvoker<ListColumnAction<ChangeHistory,?>> columnsInvoker = ListColumnUtil.useExtensions(jspContext);
105  int numListed = 0;
106  %>
107  <base:page type="iframe" id="list-history">
108  <base:head scripts="table.js,menu.js,~history.js" styles="table.css,toolbar.css,menu.css">
109    <ext:scripts context="<%=jspContext%>" />
110    <ext:stylesheets context="<%=jspContext%>" />
111  </base:head>
112  <base:body>
113    <tbl:table 
114      id="history"
115      columns="<%=cc.getSetting("columns")%>"
116      sortby="<%=cc.getSortProperty()%>" 
117      direction="<%=cc.getSortDirection()%>"
118      action="index.jsp"
119      sc="<%=sc%>"
120      item="<%=itemType%>"
121      filterrows="<%=cc.getFilterRows()%>"
122      subclass="fulltable sticky-headers"
123      >
124      <tbl:hidden 
125        name="source_id"
126        value="<%=String.valueOf(sourceId)%>" 
127      />
128      <tbl:hidden 
129        name="source_type" 
130        value="<%=sourceType.name()%>" 
131      />
132      <tbl:columndef 
133         id="id"
134        clazz="uniquecol"
135         property="id"
136         datatype="int"
137         title="ID"
138         sortable="true" 
139         filterable="true"
140         exportable="true"
141      />
142      <tbl:columndef 
143        id="time"
144        property="$hst.time"
145        exportproperty="changeHistory.time"
146        datatype="timestamp"
147        title="Time"
148        sortable="true" 
149        filterable="true"
150        exportable="true"
151        show="always" 
152      />
153      <%
154      Enumeration<String, String> types = new Enumeration<String, String>();
155      for (ChangeType ct : ChangeType.values())
156      {
157        types.add(Integer.toString(ct.getValue()), ct.toString());
158      }
159      %>
160      <tbl:columndef 
161        id="changeType"
162        property="changeType"
163        datatype="int"
164        title="Type"
165        sortable="true" 
166        filterable="true"
167        exportable="true"
168        enumeration="<%=types%>"
169      />
170      <tbl:columndef 
171        id="user"
172        property="$hst.user.name"
173        exportproperty="changeHistory.user.name"
174        datatype="string"
175        title="User"
176        sortable="true" 
177        filterable="true"
178        exportable="true"
179      />
180      <tbl:columndef 
181        id="session"
182        property="$hst.session.loginTime"
183        exportproperty="changeHistory.session.loginTime"
184        datatype="date"
185        title="Session"
186        sortable="true" 
187        filterable="true"
188        exportable="true"
189      />
190      <tbl:columndef 
191        id="client"
192        property="$hst.client.name"
193        exportproperty="changeHistory.client.name"
194        datatype="string"
195        title="Client"
196        sortable="true" 
197        filterable="true"
198        exportable="true"
199      />
200      <tbl:columndef 
201        id="project"
202        property="$hst.project.name"
203        exportproperty="changeHistory.project.name"
204        datatype="string"
205        title="Project"
206        sortable="true" 
207        filterable="true"
208        exportable="true"
209      />
210      <tbl:columndef 
211        id="plugin"
212        property="$hst.plugin.name"
213        exportproperty="changeHistory.plugin.name"
214        datatype="string"
215        title="Plugin"
216        sortable="true"
217        filterable="true"
218        exportable="true"
219      />
220      <tbl:columndef 
221        id="job"
222        property="$hst.job.name"
223        exportproperty="changeHistory.job.name"
224        datatype="string"
225        title="Job"
226        sortable="true" 
227        filterable="true"
228        exportable="true"
229      />
230      <tbl:columndef 
231        id="changeInfo"
232        property="changeInfo"
233        datatype="string"
234        title="Information" 
235        sortable="true" 
236        filterable="true" 
237        exportable="true"
238      />
239      <%
240      if (sc.hasPermission(Permission.READ, Item.CHANGEHISTORY_VALUES))
241      {
242        %>
243        <tbl:columndef
244          id="oldValue"
245          property="oldValue"
246          datatype="string"
247          title="Old value"
248          sortable="true" 
249          filterable="true"
250          exportable="true"
251        />
252        <tbl:columndef
253          id="newValue"
254          property="newValue"
255          datatype="string"
256          title="New value"
257          sortable="true" 
258          filterable="true" 
259          exportable="true"
260        />
261        <%
262      }
263      %>
264      <tbl:columndef 
265        id="xt-columns" 
266        extensions="<%=columnsInvoker%>" 
267        jspcontext="<%=jspContext%>" 
268      />
269      <div class="panelgroup bg-filled-50 bottomborder">
270        <tbl:toolbar
271          visible="<%=mode.hasToolbar()%>"
272          subclass="bottomborder"
273          >
274          <tbl:button 
275            id="btnColumns"
276            image="columns.png" 
277            title="Columns&hellip;" 
278            tooltip="Show, hide and re-order columns" 
279          />
280          <tbl:button 
281            id="btnExport"
282            data-plugin-type="EXPORT"
283            image="export.png" 
284            title="Export&hellip;" 
285            tooltip="Export data" 
286            visible="<%=pluginCount.containsKey(Plugin.MainType.EXPORT)%>"
287          />
288          <ext:render extensions="<%=invoker%>" context="<%=jspContext%>" 
289            wrapper="<%=new PrefixSuffixRenderer<ButtonAction>(jspContext, "<td>", "</td>") %>"/>
290        </tbl:toolbar>
291        <tbl:panel>
292          <tbl:presetselector />
293          <tbl:navigator
294            page="<%=cc.getPage()%>" 
295            rowsperpage="<%=cc.getRowsPerPage()%>" 
296            totalrows="<%=history == null ? 0 : history.getTotalCount()%>" 
297            visible="<%=mode.hasNavigator()%>"
298          />
299        </tbl:panel>
300      </div>
301      <tbl:data>
302        <tbl:headers>
303          <tbl:headerrow>
304            <tbl:header colspan="3" />
305            <tbl:columnheaders />
306          </tbl:headerrow>
307          <%
308          int numFilters = cc.getNumPropertyFilters();
309          int numRows = cc.getFilterRows();
310          for (int filterNo = 0; filterNo < numRows; filterNo++)
311          {
312            boolean lastRow = filterNo == numRows-1;
313            %>
314            <tbl:headerrow>
315              <tbl:header subclass="index" />
316              <tbl:header 
317                subclass="check" 
318                visible="<%=mode.hasCheck()%>"
319                ><base:icon 
320                  subclass="link table-check"
321                  image="check_uncheck.png" 
322                  tooltip="Toggle all (use CTRL, ALT or SHIFT to check/uncheck)" 
323                  visible="<%=lastRow%>"
324                /></tbl:header>
325              <tbl:header 
326                subclass="check" 
327                visible="<%=mode.hasRadio()%>"
328                />
329              <tbl:header 
330                subclass="icons" 
331                visible="<%=mode.hasIcons()%>"
332                >
333                <base:icon
334                  subclass="link table-filter-row-action"
335                  image="add.png"
336                  tooltip="Add extra filter row"
337                  visible="<%=lastRow%>"
338                /><base:icon
339                  subclass="link table-filter-row-action"
340                  image="remove.png"
341                  tooltip="Remove this filter row"
342                  visible="<%=numRows > 1 || numFilters > 0 %>"
343                  data-remove-row="<%=filterNo%>"
344                />
345              </tbl:header>
346              <tbl:propertyfilter row="<%=filterNo%>" />
347            </tbl:headerrow>
348            <%
349          }
350          %>
351          <tbl:columnsubtitles />
352        </tbl:headers>
353        <tbl:rows>
354          <%
355          if (cc.getMessage() != null)
356          {
357            %>
358            <tbl:panel subclass="bg-filled-50">
359              <div class="messagecontainer error"><%=cc.getMessage()%></div>
360            </tbl:panel>
361            <%
362            cc.setMessage(null);
363          }
364          int index = cc.getPage()*cc.getRowsPerPage();
365          int selectedItemId = cc.getId();
366          if (history != null)
367          {           
368            while (history.hasNext())
369            {
370              ChangeHistory item = history.next();
371              int itemId = item.getId();
372              String tooltip = mode.isSelectionMode() ? 
373                  "Select this item" : "View this item";
374              index++;
375              numListed++;
376              %>
377              <tbl:row>
378                <tbl:header 
379                  clazz="index"
380                  ><%=index%></tbl:header>
381                <tbl:header 
382                  clazz="check" 
383                  visible="<%=mode.hasCheck()%>"
384                  ><input 
385                    type="checkbox" 
386                    name="<%=itemId%>" 
387                    value="<%=itemId%>" 
388                    <%=cc.getSelected().contains(itemId) ? "checked" : ""%> 
389                  ></tbl:header>
390                <tbl:header 
391                  clazz="check" 
392                  visible="<%=mode.hasRadio()%>"
393                  ><input 
394                    type="radio" 
395                    name="item_id" 
396                    value="<%=itemId%>" 
397                    <%=selectedItemId == itemId ? "checked" : ""%>
398                  ></tbl:header>
399                <tbl:header 
400                  clazz="icons" 
401                  visible="<%=mode.hasIcons()%>"
402                  >&nbsp;</tbl:header>
403                <tbl:cell column="time"><div 
404                    class="link table-item"
405                    data-item-id="<%=itemId%>"
406                    data-no-edit="1" tabindex="0"
407                    title="<%=tooltip%>"><%=dateFormatter.format(item.getTime())%></div>
408                  </tbl:cell>
409                <tbl:cell column="id"><%=item.getId()%></tbl:cell>
410                <tbl:cell column="changeType"><%=item.getChangeType()%></tbl:cell>
411                <tbl:cell column="changeInfo"><%=HTML.niceFormat(item.getChangeInfo())%></tbl:cell>
412                <tbl:cell column="oldValue"><%=HTML.niceFormat(item.getOldValue())%></tbl:cell>
413                <tbl:cell column="newValue"><%=HTML.niceFormat(item.getNewValue())%></tbl:cell>
414                <tbl:cell column="user"><%=ChangeHistoryUtil.getUser(dc, item, mode.hasPropertyLink(), mode.hasEditLink())%></tbl:cell>
415                <tbl:cell column="session"><%=ChangeHistoryUtil.getSession(dc, item, mode.hasPropertyLink(), mode.hasEditLink())%></tbl:cell>
416                <tbl:cell column="client"><%=ChangeHistoryUtil.getClient(dc, item, mode.hasPropertyLink(), mode.hasEditLink())%></tbl:cell>
417                <tbl:cell column="project"><%=ChangeHistoryUtil.getProject(dc, item, mode.hasPropertyLink(), mode.hasEditLink())%></tbl:cell>
418                <tbl:cell column="plugin"><%=ChangeHistoryUtil.getPlugin(dc, item, mode.hasPropertyLink(), mode.hasEditLink())%></tbl:cell>
419                <tbl:cell column="job"><%=ChangeHistoryUtil.getJob(dc, item, mode.hasPropertyLink(), mode.hasEditLink())%></tbl:cell>
420                <tbl:xt-cells dc="<%=dc%>" item="<%=item%>">
421                  <tbl:cell column="xt-columns" />
422                </tbl:xt-cells>
423              </tbl:row>
424              <%
425              }
426            }
427          if (numListed == 0)
428          {
429            %>
430            <tbl:panel subclass="bg-filled-50">
431              <div class="messagecontainer note">
432              <%=history == null || history.getTotalCount() == 0 ? "No history entries were found" : "No history entries on this page. Please select another page!" %>
433              </div>
434            </tbl:panel>
435            <%
436          }
437          %>
438        </tbl:rows>
439      </tbl:data>
440    </tbl:table>
441     
442     
443  </base:body>
444  </base:page>
445  <%
446}
447finally
448{
449  if (dc != null) dc.close();
450}
451
452%>
Note: See TracBrowser for help on using the repository browser.