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