source: branches/3.18-stable/www/admin/quantities/list_quantities.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: 16.2 KB
Line 
1<%-- $Id: list_quantities.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
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.Type"
31  import="net.sf.basedb.core.Quantity"
32  import="net.sf.basedb.core.Quantity"
33  import="net.sf.basedb.core.Unit"
34  import="net.sf.basedb.core.Include"
35  import="net.sf.basedb.core.ItemQuery"
36  import="net.sf.basedb.core.ItemResultIterator"
37  import="net.sf.basedb.core.ItemResultList"
38  import="net.sf.basedb.core.ItemContext"
39  import="net.sf.basedb.core.Permission"
40  import="net.sf.basedb.core.PluginDefinition"
41  import="net.sf.basedb.core.query.Orders"
42  import="net.sf.basedb.core.query.Hql"
43  import="net.sf.basedb.core.query.Restrictions"
44  import="net.sf.basedb.core.query.Expressions"
45  import="net.sf.basedb.core.plugin.GuiContext"
46  import="net.sf.basedb.core.plugin.Plugin"
47  import="net.sf.basedb.util.Enumeration"
48  import="net.sf.basedb.clients.web.Base"
49  import="net.sf.basedb.clients.web.PermissionUtil"
50  import="net.sf.basedb.clients.web.ModeInfo"
51  import="net.sf.basedb.clients.web.util.HTML"
52  import="net.sf.basedb.util.Values"
53  import="net.sf.basedb.clients.web.extensions.ExtensionsControl"
54  import="net.sf.basedb.clients.web.extensions.JspContext"
55  import="net.sf.basedb.clients.web.extensions.renderer.PrefixSuffixRenderer"
56  import="net.sf.basedb.clients.web.extensions.toolbar.ButtonAction" 
57  import="net.sf.basedb.clients.web.extensions.toolbar.ToolbarUtil"
58  import="net.sf.basedb.clients.web.extensions.list.ListColumnAction"
59  import="net.sf.basedb.clients.web.extensions.list.ListColumnUtil"
60  import="net.sf.basedb.util.extensions.ExtensionsInvoker"
61  import="java.util.List"
62  import="java.util.Map"
63%>
64<%@ taglib prefix="base" uri="/WEB-INF/base.tld" %>
65<%@ taglib prefix="tbl" uri="/WEB-INF/table.tld" %>
66<%@ taglib prefix="ext" uri="/WEB-INF/extensions.tld" %>
67<%!
68  private static final Item itemType = Item.QUANTITY;
69  private static final GuiContext guiContext = new GuiContext(itemType, GuiContext.Type.LIST);
70%>
71<%
72final SessionControl sc = Base.getExistingSessionControl(pageContext, Permission.DENIED, itemType);
73final String ID = sc.getId();
74final boolean createPermission = sc.hasPermission(Permission.CREATE, itemType);
75final boolean writePermission = sc.hasPermission(Permission.WRITE, itemType);
76final boolean deletePermission = sc.hasPermission(Permission.DELETE, itemType);
77final ItemContext cc = Base.getAndSetCurrentContext(sc, itemType, null, null);
78
79final ModeInfo mode = ModeInfo.get(request.getParameter("mode"));
80final String callback = request.getParameter("callback");
81final String title = mode.generateTitle("Quantity", "Quantities");
82final DbControl dc = sc.newDbControl();
83ItemResultIterator<Quantity> quantities = null;
84try
85{
86  // Query for units relatated to the current quantity
87  final ItemQuery<Unit> unitQuery = Unit.getQuery();
88  unitQuery.include(cc.getInclude());
89  unitQuery.restrict(Restrictions.eq(Hql.property("quantity"), Expressions.parameter("quantity")));
90  unitQuery.order(Orders.desc(Hql.property("referenceFactor")));
91  unitQuery.order(Orders.asc(Hql.property("displaySymbol"))); 
92  final boolean createUnitPermission = sc.hasPermission(Permission.CREATE, Item.UNIT); 
93
94  Map<Plugin.MainType, Integer> pluginCount = PluginDefinition.countPlugins(dc, guiContext);
95  JspContext jspContext = ExtensionsControl.createContext(dc, pageContext, guiContext, null);
96  try
97  {
98    final ItemQuery<Quantity> query = Base.getConfiguredQuery(dc, cc, jspContext, true, Quantity.getQuery(), mode);
99    quantities = query.iterate(dc);
100  }
101  catch (Throwable t)
102  {
103    cc.setMessage(t.getMessage());
104  }
105  int numListed = 0;
106  ExtensionsInvoker<ButtonAction> invoker = ToolbarUtil.useExtensions(jspContext);
107  ExtensionsInvoker<ListColumnAction<Quantity,?>> columnsInvoker = ListColumnUtil.useExtensions(jspContext);
108  %>
109  <base:page title="<%=title==null ? "Quantities" : title%>" type="<%=mode.getPageType()%>" id="list-page">
110  <base:head scripts="table.js,~quantities.js" styles="table.css,toolbar.css">
111    <ext:scripts context="<%=jspContext%>" />
112    <ext:stylesheets context="<%=jspContext%>" />
113  </base:head>
114 
115  <base:body>
116    <h1><%=title==null ? "Quantities" : title%></h1>
117    <div class="content">
118    <tbl:table 
119      id="quantities" 
120      columns="<%=cc.getSetting("columns")%>"
121      sortby="<%=cc.getSortProperty()%>" 
122      direction="<%=cc.getSortDirection()%>"
123      action="index.jsp"
124      sc="<%=sc%>"
125      item="<%=itemType%>"
126      filterrows="<%=cc.getFilterRows()%>"
127      subclass="fulltable sticky-headers"
128      >
129      <tbl:hidden 
130        name="mode" 
131        value="<%=mode.getName()%>" 
132      />
133      <tbl:hidden 
134        name="callback" 
135        value="<%=callback%>" 
136        skip="<%=callback == null%>" 
137      />
138      <tbl:columndef 
139        id="name"
140        property="name"
141        datatype="string"
142        title="Name"
143        sortable="true" 
144        filterable="true"
145        exportable="true"
146        show="always" 
147      />
148      <tbl:columndef 
149        id="id"
150        clazz="uniquecol"
151        property="id"
152        datatype="int"
153        title="ID"
154        sortable="true"
155        filterable="true"
156        exportable="true"
157      />
158      <tbl:columndef 
159        id="systemId"
160        clazz="uniquecol"
161        property="systemId"
162        datatype="string"
163        title="System ID"
164        sortable="true"
165        filterable="true"
166        exportable="true"
167      />
168      <tbl:columndef 
169        id="referenceUnit"
170        property="referenceUnit"
171        datatype="string"
172        title="Reference unit"
173        sortable="true" 
174        filterable="true"
175        exportable="true"
176      />
177      <tbl:columndef
178        id="units"
179        title="Units"
180        property="&units(displaySymbol)"
181        datatype="string"
182        filterable="true"
183        exportable="true"
184      />
185      <tbl:columndef
186        id="formulas"
187        title="Conversion formulas"
188      />
189      <tbl:columndef 
190        id="description"
191        property="description"
192        datatype="string"
193        title="Description" 
194        sortable="true" 
195        filterable="true" 
196        exportable="true"
197      />
198      <tbl:columndef 
199        id="xt-columns" 
200        extensions="<%=columnsInvoker%>" 
201        jspcontext="<%=jspContext%>" 
202      />
203      <div class="panelgroup bg-filled-50 bottomborder">
204        <tbl:toolbar
205          subclass="bottomborder"
206          visible="<%=mode.hasToolbar()%>"
207          >
208          <tbl:button 
209            id="btnNewItem"
210            disabled="<%=!createPermission%>" 
211            image="new.png" 
212            title="New&hellip;" 
213            tooltip="<%=createPermission ? "Create new quantity" : "You do not have permission to create quantities"%>" 
214          />
215          <tbl:button 
216            id="btnDeleteItems"
217            disabled="<%=!deletePermission%>" 
218            image="delete.png" 
219            title="Delete" 
220            tooltip="<%=deletePermission ? "Delete the selected items" : "You do not have permission to delete quantities" %>" 
221          />
222          <tbl:button 
223            id="btnRestoreItems"
224            disabled="<%=!writePermission%>" 
225            image="restore.png" 
226            title="Restore" 
227            tooltip="<%=writePermission ? "Restore the selected (deleted) items" : "You do not have permission to edit quantities" %>" 
228          />
229          <tbl:button 
230            id="btnColumns"
231            image="columns.png" 
232            title="Columns&hellip;" 
233            tooltip="Show, hide and re-order columns" 
234          />
235          <tbl:button 
236            id="btnImport"
237            data-plugin-type="IMPORT"
238            image="import.png" 
239            title="Import&hellip;" 
240            tooltip="Import data" 
241            visible="<%=pluginCount.containsKey(Plugin.MainType.IMPORT)%>"
242          />
243          <tbl:button 
244            id="btnExport"
245            data-plugin-type="EXPORT"
246            image="export.png" 
247            title="Export&hellip;" 
248            tooltip="Export data" 
249            visible="<%=pluginCount.containsKey(Plugin.MainType.EXPORT)%>"
250          />
251          <tbl:button 
252            id="btnRunPlugin"
253            data-plugin-type="OTHER"
254            image="runplugin.png" 
255            title="Run plugin&hellip;" 
256            tooltip="Run a plugin" 
257            visible="<%=pluginCount.containsKey(Plugin.MainType.OTHER)%>"
258          />
259          <ext:render extensions="<%=invoker%>" context="<%=jspContext%>" 
260            wrapper="<%=new PrefixSuffixRenderer<ButtonAction>(jspContext, "<td>", "</td>") %>"/>
261        </tbl:toolbar>
262        <tbl:panel>
263          <tbl:presetselector />
264          <tbl:navigator
265            page="<%=cc.getPage()%>" 
266            rowsperpage="<%=cc.getRowsPerPage()%>" 
267            totalrows="<%=quantities == null ? 0 : quantities.getTotalCount()%>" 
268            visible="<%=mode.hasNavigator()%>"
269          />
270        </tbl:panel>
271      </div>
272      <tbl:data>
273        <tbl:headers>
274          <tbl:headerrow>
275            <tbl:header colspan="3" />
276            <tbl:columnheaders />
277          </tbl:headerrow>
278          <%
279          int numFilters = cc.getNumPropertyFilters();
280          int numRows = cc.getFilterRows();
281          for (int filterNo = 0; filterNo < numRows; filterNo++)
282          {
283            boolean lastRow = filterNo == numRows-1;
284            %>
285            <tbl:headerrow>
286              <tbl:header subclass="index" />
287              <tbl:header 
288                subclass="check" 
289                visible="<%=mode.hasCheck()%>"
290                ><base:icon 
291                  subclass="link table-check"
292                  image="check_uncheck.png" 
293                  tooltip="Toggle all (use CTRL, ALT or SHIFT to check/uncheck)" 
294                  visible="<%=lastRow%>"
295                /></tbl:header>
296              <tbl:header 
297                subclass="check" 
298                visible="<%=mode.hasRadio()%>"
299                />
300              <tbl:header 
301                subclass="icons" 
302                visible="<%=mode.hasIcons()%>"
303                >
304                <base:icon
305                  subclass="link table-filter-row-action"
306                  image="add.png"
307                  tooltip="Add extra filter row"
308                  visible="<%=lastRow%>"
309                /><base:icon
310                  subclass="link table-filter-row-action"
311                  image="remove.png"
312                  tooltip="Remove this filter row"
313                  visible="<%=numRows > 1 || numFilters > 0 %>"
314                  data-remove-row="<%=filterNo%>"
315                />
316              </tbl:header>
317              <tbl:propertyfilter row="<%=filterNo%>" />
318            </tbl:headerrow>
319            <%
320          }
321          %>
322          <tbl:columnsubtitles />
323        </tbl:headers>
324        <tbl:rows>
325          <%
326          if (cc.getMessage() != null)
327          {
328            %>
329            <tbl:panel subclass="bg-filled-50">
330              <div class="messagecontainer error"><%=cc.getMessage()%></div>
331            </tbl:panel>
332            <%
333            cc.setMessage(null);
334          }
335          int index = cc.getPage()*cc.getRowsPerPage();
336          int selectedItemId = cc.getId();
337          if (quantities != null)
338          {           
339            while (quantities.hasNext())
340            {
341              Quantity item = quantities.next();
342              int itemId = item.getId();
343              boolean usePermission = item.hasPermission(Permission.USE);
344              String name = HTML.encodeTags(item.getName());
345              String tooltip = mode.isSelectionMode() ? 
346                  "Select this item" : "View this item" + (writePermission ? " (use CTRL, ALT or SHIFT to edit)" : "");
347             
348              index++;
349              numListed++;
350              %>
351              <tbl:row>
352                <tbl:header 
353                  clazz="index"
354                  ><%=index%></tbl:header>
355                <tbl:header 
356                  clazz="check" 
357                  visible="<%=mode.hasCheck()%>"
358                  ><input 
359                    type="checkbox" 
360                    name="<%=itemId%>" 
361                    value="<%=itemId%>" 
362                    title="<%=name%>" 
363                    <%=cc.getSelected().contains(itemId) ? "checked" : ""%> 
364                  ></tbl:header>
365                <tbl:header 
366                  clazz="check" 
367                  visible="<%=mode.hasRadio()%>"
368                  ><input 
369                    type="radio" 
370                    name="item_id" 
371                    value="<%=itemId%>" 
372                    title="<%=name%>" 
373                    <%=selectedItemId == itemId ? "checked" : ""%>
374                  ></tbl:header>
375                <tbl:header 
376                  clazz="icons" 
377                  visible="<%=mode.hasIcons()%>"
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                  />&nbsp;</tbl:header>
390                <tbl:cell column="name"><div 
391                  class="link table-item"
392                  data-item-id="<%=itemId%>"
393                  data-no-edit="<%=writePermission ? 0 : 1 %>" 
394                  tabindex="0"
395                  title="<%=tooltip%>"><%=name%></div></tbl:cell>
396                <tbl:cell column="id"><%=item.getId()%></tbl:cell>
397                <tbl:cell column="systemId"><%=HTML.encodeTags(item.getSystemId())%></tbl:cell>
398                <tbl:cell column="referenceUnit"><%=HTML.encodeTags(item.getReferenceUnit())%></tbl:cell>
399                <tbl:cell column="units">
400                  <%
401                  unitQuery.setParameter("quantity", itemId, Type.INT);
402                  try
403                  {
404                    String separator = "";
405                    for (Unit u : unitQuery.list(dc))
406                    {
407                      out.write(separator);
408                      if (mode.hasPropertyLink())
409                      {
410                        out.write(Base.getLink(ID, u.getDisplaySymbol(), Item.UNIT, u.getId(), 
411                          mode.hasEditLink(), u.getName() + "; click to view"));
412                      }
413                      else
414                      {
415                        out.write(HTML.encodeTags(u.getName()));
416                      }
417                      separator = ", ";
418                    }
419                  }
420                  catch (Throwable t)
421                  {
422                    %>
423                    <div class="error"><%=t.getMessage()%></div>
424                    <%
425                  }
426                  %>
427                  <base:icon
428                    id="<%="new-unit."+itemId%>"
429                    subclass="auto-init"
430                    data-auto-init="new-unit"
431                    data-item-id="<%=itemId%>"
432                    image="add.png" 
433                    tooltip="Create new unit" 
434                    visible="<%=mode.hasEditLink() && createUnitPermission && usePermission %>"
435                  />
436                </tbl:cell>
437                <tbl:cell column="formulas">
438                  <%
439                  unitQuery.setParameter("quantity", itemId, Type.INT);
440                  try
441                  {
442                    for (Unit u : unitQuery.list(dc))
443                    {
444                      if (mode.hasPropertyLink())
445                      {
446                        out.write(Base.getLink(ID, "1&nbsp;" + u.getDisplaySymbol(), Item.UNIT, u.getId(), 
447                          mode.hasEditLink(), u.getName() + "; click to view"));
448                      }
449                      else
450                      {
451                        out.write("1&nbsp;" + u.getDisplaySymbol());
452                      }
453                      out.write("&nbsp;=&nbsp;");
454                      if (u.getReferenceFactor() != 1.0)
455                      {
456                        out.write(u.getReferenceFactor() + " × ");
457                      }
458                      out.write(item.getReferenceUnit());
459                      if (u.getReferenceOffset() != 0.0)
460                      {
461                        out.write(" + " + u.getReferenceOffset());
462                      }
463                      out.write("<br>");
464                    }
465                  }
466                  catch (Throwable t)
467                  {
468                    %>
469                    <div class="error"><%=t.getMessage()%></div>
470                    <%
471                  }
472                  %>
473                </tbl:cell>
474                <tbl:cell column="description"><%=HTML.encodeTags(item.getDescription())%></tbl:cell>
475                <tbl:xt-cells dc="<%=dc%>" item="<%=item%>">
476                  <tbl:cell column="xt-columns" />
477                </tbl:xt-cells>
478              </tbl:row>
479              <%
480              }
481            }
482          if (numListed == 0)
483          {
484            %>
485            <tbl:panel subclass="bg-filled-50">
486              <div class="messagecontainer note">
487              <%=quantities == null || quantities.getTotalCount() == 0 ? "No quantities were found" : "No quantities on this page. Please select another page!" %>
488              </div>
489            </tbl:panel>
490            <%
491          }
492          %>
493        </tbl:rows>
494      </tbl:data>
495    </tbl:table>
496    </div>
497   
498    <base:buttongroup subclass="dialogbuttons">
499      <base:button id="btnOk" title="Ok" visible="<%=mode.hasOkButton()%>" />
500      <base:button id="close" title="Cancel" visible="<%=mode.hasCancelButton()%>" />
501      <base:button id="close" title="Close" visible="<%=mode.hasCloseButton()%>" />
502    </base:buttongroup>
503   
504  </base:body>
505  </base:page>
506  <%
507}
508finally
509{
510  if (quantities != null) quantities.close();
511  if (dc != null) dc.close();
512}
513%>
Note: See TracBrowser for help on using the repository browser.