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

Last change on this file since 7937 was 7937, checked in by Nicklas Nordborg, 14 months ago

References #2246: Sticky table headers

Implemented for some more list pages.

  • Property svn:eol-style set to native
  • Property svn:keywords set to Date Id
File size: 14.0 KB
Line 
1<%-- $Id: list_history.jsp 7937 2021-04-30 10:57:18Z 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"
123      stickyheaders="time"
124      >
125      <tbl:hidden 
126        name="source_id"
127        value="<%=String.valueOf(sourceId)%>" 
128      />
129      <tbl:hidden 
130        name="source_type" 
131        value="<%=sourceType.name()%>" 
132      />
133      <tbl:columndef 
134         id="id"
135        clazz="uniquecol"
136         property="id"
137         datatype="int"
138         title="ID"
139         sortable="true" 
140         filterable="true"
141         exportable="true"
142      />
143      <tbl:columndef 
144        id="time"
145        property="$hst.time"
146        exportproperty="changeHistory.time"
147        datatype="timestamp"
148        title="Time"
149        sortable="true" 
150        filterable="true"
151        exportable="true"
152        show="always" 
153      />
154      <%
155      Enumeration<String, String> types = new Enumeration<String, String>();
156      for (ChangeType ct : ChangeType.values())
157      {
158        types.add(Integer.toString(ct.getValue()), ct.toString());
159      }
160      %>
161      <tbl:columndef 
162        id="changeType"
163        property="changeType"
164        datatype="int"
165        title="Type"
166        sortable="true" 
167        filterable="true"
168        exportable="true"
169        enumeration="<%=types%>"
170      />
171      <tbl:columndef 
172        id="user"
173        property="$hst.user.name"
174        exportproperty="changeHistory.user.name"
175        datatype="string"
176        title="User"
177        sortable="true" 
178        filterable="true"
179        exportable="true"
180      />
181      <tbl:columndef 
182        id="session"
183        property="$hst.session.loginTime"
184        exportproperty="changeHistory.session.loginTime"
185        datatype="date"
186        title="Session"
187        sortable="true" 
188        filterable="true"
189        exportable="true"
190      />
191      <tbl:columndef 
192        id="client"
193        property="$hst.client.name"
194        exportproperty="changeHistory.client.name"
195        datatype="string"
196        title="Client"
197        sortable="true" 
198        filterable="true"
199        exportable="true"
200      />
201      <tbl:columndef 
202        id="project"
203        property="$hst.project.name"
204        exportproperty="changeHistory.project.name"
205        datatype="string"
206        title="Project"
207        sortable="true" 
208        filterable="true"
209        exportable="true"
210      />
211      <tbl:columndef 
212        id="plugin"
213        property="$hst.plugin.name"
214        exportproperty="changeHistory.plugin.name"
215        datatype="string"
216        title="Plugin"
217        sortable="true"
218        filterable="true"
219        exportable="true"
220      />
221      <tbl:columndef 
222        id="job"
223        property="$hst.job.name"
224        exportproperty="changeHistory.job.name"
225        datatype="string"
226        title="Job"
227        sortable="true" 
228        filterable="true"
229        exportable="true"
230      />
231      <tbl:columndef 
232        id="changeInfo"
233        property="changeInfo"
234        datatype="string"
235        title="Information" 
236        sortable="true" 
237        filterable="true" 
238        exportable="true"
239      />
240      <%
241      if (sc.hasPermission(Permission.READ, Item.CHANGEHISTORY_VALUES))
242      {
243        %>
244        <tbl:columndef
245          id="oldValue"
246          property="oldValue"
247          datatype="string"
248          title="Old value"
249          sortable="true" 
250          filterable="true"
251          exportable="true"
252        />
253        <tbl:columndef
254          id="newValue"
255          property="newValue"
256          datatype="string"
257          title="New value"
258          sortable="true" 
259          filterable="true" 
260          exportable="true"
261        />
262        <%
263      }
264      %>
265      <tbl:columndef 
266        id="xt-columns" 
267        extensions="<%=columnsInvoker%>" 
268        jspcontext="<%=jspContext%>" 
269      />
270      <div class="panelgroup bg-filled-50 bottomborder">
271        <tbl:toolbar
272          visible="<%=mode.hasToolbar()%>"
273          subclass="bottomborder"
274          >
275          <tbl:button 
276            id="btnColumns"
277            image="columns.png" 
278            title="Columns&hellip;" 
279            tooltip="Show, hide and re-order columns" 
280          />
281          <tbl:button 
282            id="btnExport"
283            data-plugin-type="EXPORT"
284            image="export.png" 
285            title="Export&hellip;" 
286            tooltip="Export data" 
287            visible="<%=pluginCount.containsKey(Plugin.MainType.EXPORT)%>"
288          />
289          <ext:render extensions="<%=invoker%>" context="<%=jspContext%>" 
290            wrapper="<%=new PrefixSuffixRenderer<ButtonAction>(jspContext, "<td>", "</td>") %>"/>
291        </tbl:toolbar>
292        <tbl:panel>
293          <tbl:presetselector />
294          <tbl:navigator
295            page="<%=cc.getPage()%>" 
296            rowsperpage="<%=cc.getRowsPerPage()%>" 
297            totalrows="<%=history == null ? 0 : history.getTotalCount()%>" 
298            visible="<%=mode.hasNavigator()%>"
299          />
300        </tbl:panel>
301      </div>
302      <tbl:data>
303        <tbl:headers>
304          <tbl:headerrow>
305            <tbl:header clazz="row-index bg-filled-100" />
306            <tbl:columnheaders />
307          </tbl:headerrow>
308          <%
309          int numFilters = cc.getNumPropertyFilters();
310          int numRows = cc.getFilterRows();
311          for (int filterNo = 0; filterNo < numRows; filterNo++)
312          {
313            boolean lastRow = filterNo == numRows-1;
314            %>
315            <tbl:headerrow>
316              <tbl:header subclass="row-index bg-filled-100">
317                <div class="index-<%=mode.getName()%>">
318                  <div class="index"></div>
319                  <div class="check">
320                    <base:icon 
321                      subclass="link table-check"
322                      image="check_uncheck.png" 
323                      tooltip="Toggle all (use CTRL, ALT or SHIFT to check/uncheck)" 
324                      visible="<%=lastRow && mode.hasCheck()%>"
325                    />
326                  </div>
327                  <div class="icons">
328                    <base:icon
329                      subclass="link table-filter-row-action"
330                      image="add.png"
331                      tooltip="Add extra filter row"
332                      visible="<%=lastRow%>"
333                    /><base:icon
334                      subclass="link table-filter-row-action"
335                      image="remove.png"
336                      tooltip="Remove this filter row"
337                      visible="<%=numRows > 1 || numFilters > 0 %>"
338                      data-remove-row="<%=filterNo%>"
339                    />
340                  </div>
341                </div>
342              </tbl:header>
343              <tbl:propertyfilter row="<%=filterNo%>" />
344            </tbl:headerrow>
345            <%
346          }
347          %>
348          <tbl:columnsubtitles />
349        </tbl:headers>
350        <tbl:rows>
351          <%
352          if (cc.getMessage() != null)
353          {
354            %>
355            <tbl:panel subclass="bg-filled-50">
356              <div class="messagecontainer error"><%=cc.getMessage()%></div>
357            </tbl:panel>
358            <%
359            cc.setMessage(null);
360          }
361          int index = cc.getPage()*cc.getRowsPerPage();
362          int selectedItemId = cc.getId();
363          if (history != null)
364          {           
365            while (history.hasNext())
366            {
367              ChangeHistory item = history.next();
368              int itemId = item.getId();
369              String tooltip = mode.isSelectionMode() ? 
370                  "Select this item" : "View this item";
371              index++;
372              numListed++;
373              %>
374              <tbl:row>
375                <tbl:header clazz="row-index bg-filled-100">
376                  <div class="index-<%=mode.getName()%>">
377                    <div class="index <%=index>999?"index-smaller":""%>"><%=index%></div>
378                    <div class="check">
379                      <base:input
380                        type="checkbox" 
381                        name="<%=itemId%>" 
382                        value="<%=itemId%>" 
383                        checked="<%=cc.getSelected().contains(itemId)%>"
384                        visible="<%=mode.hasCheck()%>"
385                      />
386                      <base:input 
387                        type="radio" 
388                        name="item_id" 
389                        value="<%=itemId%>" 
390                        checked="<%=selectedItemId == itemId%>"
391                        visible="<%=mode.hasRadio()%>"
392                      />
393                    </div>
394                    <div class="icons">
395                    </div>
396                  </div>
397                </tbl:header>
398                <tbl:cell column="time"><div 
399                    class="link table-item"
400                    data-item-id="<%=itemId%>"
401                    data-no-edit="1" tabindex="0"
402                    title="<%=tooltip%>" style="white-space: nowrap;"><%=dateFormatter.format(item.getTime())%></div>
403                  </tbl:cell>
404                <tbl:cell column="id"><%=item.getId()%></tbl:cell>
405                <tbl:cell column="changeType"><%=item.getChangeType()%></tbl:cell>
406                <tbl:cell column="changeInfo"><%=HTML.niceFormat(item.getChangeInfo())%></tbl:cell>
407                <tbl:cell column="oldValue"><%=HTML.niceFormat(item.getOldValue())%></tbl:cell>
408                <tbl:cell column="newValue"><%=HTML.niceFormat(item.getNewValue())%></tbl:cell>
409                <tbl:cell column="user"><%=ChangeHistoryUtil.getUser(dc, item, mode.hasPropertyLink(), mode.hasEditLink())%></tbl:cell>
410                <tbl:cell column="session"><%=ChangeHistoryUtil.getSession(dc, item, mode.hasPropertyLink(), mode.hasEditLink())%></tbl:cell>
411                <tbl:cell column="client"><%=ChangeHistoryUtil.getClient(dc, item, mode.hasPropertyLink(), mode.hasEditLink())%></tbl:cell>
412                <tbl:cell column="project"><%=ChangeHistoryUtil.getProject(dc, item, mode.hasPropertyLink(), mode.hasEditLink())%></tbl:cell>
413                <tbl:cell column="plugin"><%=ChangeHistoryUtil.getPlugin(dc, item, mode.hasPropertyLink(), mode.hasEditLink())%></tbl:cell>
414                <tbl:cell column="job"><%=ChangeHistoryUtil.getJob(dc, item, mode.hasPropertyLink(), mode.hasEditLink())%></tbl:cell>
415                <tbl:xt-cells dc="<%=dc%>" item="<%=item%>">
416                  <tbl:cell column="xt-columns" />
417                </tbl:xt-cells>
418              </tbl:row>
419              <%
420              }
421            }
422          if (numListed == 0)
423          {
424            %>
425            <tbl:panel subclass="bg-filled-50">
426              <div class="messagecontainer note">
427              <%=history == null || history.getTotalCount() == 0 ? "No history entries were found" : "No history entries on this page. Please select another page!" %>
428              </div>
429            </tbl:panel>
430            <%
431          }
432          %>
433        </tbl:rows>
434      </tbl:data>
435    </tbl:table>
436     
437     
438  </base:body>
439  </base:page>
440  <%
441}
442finally
443{
444  if (dc != null) dc.close();
445}
446
447%>
Note: See TracBrowser for help on using the repository browser.