forked from ArctosDB/arctos
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathcontainerPositions.cfm
463 lines (447 loc) · 16.9 KB
/
containerPositions.cfm
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
<cfinclude template="/includes/_header.cfm">
<style>
input.activeCell {
background-color:#FF0000;
}
input.hasData {
background-color:#FFFF00;
}
div.ccellDiv {
width:100%;
height:100%;
border:1px solid black;
background-color:#F4F4F4;
}
span.labelSpan {
border:1px solid black;
font-size:x-small;
background-color:#CCCCCC;
}
span.innerSpan {
font-size:x-small;
text-align:center;
}
</style>
<script>
function checkSave (boxID,content) {
var boxID;
var content;
if (content.length > 0) {
alert(content)
}
}
function moveContainer (boxID,barcode) {
var container_id = document.getElementById('container_id').value;
var box_position = boxID.replace('barcode','');
var psnIdEl = "position_id" + box_position;
var position_idStr = "document.getElementById('" + psnIdEl + "').value";
var position_id = eval(position_idStr);
jQuery.getJSON("/component/functions.cfc",
{
method : "moveContainer",
box_position : box_position,
position_id : position_id,
barcode : barcode,
acceptableChildContainerType: $("#acceptableChildContainerType").val(),
returnformat : "json",
queryformat : 'column'
},
success_moveContainer
);
}
function success_moveContainer (result) {
var resArray=result.split("|");
var box_position = resArray[0];
var msg = resArray[1];
if (box_position > 0) {
var thePositionStr = "document.getElementById('barcode" + box_position + "')";
var thisBarcodeTextBox = eval(thePositionStr);
var thisVal = thisBarcodeTextBox.value;
thisBarcodeTextBox.style.display = 'none';
var theSpanStr = "document.getElementById('theSpan" + box_position + "')";
var theSpan = eval(theSpanStr);
var nn = document.createTextNode(thisVal);
var br = document.createElement("BR");
var label = document.createTextNode(msg);
theSpan.appendChild(nn);
theSpan.appendChild(br);
theSpan.appendChild(label);
} else{
var absPosn = Math.abs(box_position);
alert("Error! Position " + absPosn + " save was not successful. The error is: \n" + msg);
}
}
</script>
<cfif action is "nothing">
<cfoutput>
<cfset title = 'scan items into positions in containers'>
<cfquery name="aBox" datasource="user_login" username="#session.dbuser#" password="#decrypt(session.epw,session.sessionKey)#">
select * from container where container_id=#container_id#
</cfquery>
<!--- default is....---->
<cfset taborder="horizontal">
<!---- figure out what they're trying to do and set some variables ---->
<cfif aBox.number_positions is 100 AND aBox.container_type is "freezer box">
<cfset acceptableChildContainerType="cryovial">
<cfset goodPositionType = "position">
<cfset numberRows = 10>
<cfset numberColumns = 10>
<cfelseif aBox.number_positions is 81 AND aBox.container_type is "freezer box">
<cfset acceptableChildContainerType="cryovial">
<cfset goodPositionType = "position">
<cfset numberRows = 9>
<cfset numberColumns = 9>
<cfelseif aBox.number_positions is 25 AND aBox.container_type is "freezer box">
<cfset acceptableChildContainerType="cryovial">
<cfset goodPositionType = "position">
<cfset numberRows = 5>
<cfset numberColumns = 5>
<cfelseif aBox.number_positions is 169 AND aBox.container_type is "freezer box">
<cfset acceptableChildContainerType="cryovial">
<cfset goodPositionType = "position">
<cfset numberRows = 13>
<cfset numberColumns = 13>
<cfelseif aBox.number_positions is 48 AND aBox.container_type is "freezer">
<cfset acceptableChildContainerType="freezer rack">
<cfset goodPositionType = "position">
<cfset numberRows = 12>
<cfset numberColumns = 4>
<cfelseif aBox.number_positions is 33 AND aBox.container_type is "freezer">
<cfset acceptableChildContainerType="freezer rack">
<cfset goodPositionType = "position">
<cfset numberRows = 11>
<cfset numberColumns = 3>
<cfelseif aBox.number_positions is 100 AND aBox.container_type is "slide box">
<cfset acceptableChildContainerType="slide">
<cfset goodPositionType = "position">
<cfset numberRows = 50>
<cfset numberColumns = 2>
<cfset taborder="vertical">
<cfelse>
<!--- this form can do nothing useful ---->
<div class="error">
This application won't do what you want to do.
<p>
You must have a container with positons. (Edit Container, set number of positions.)
</p>
What this form will scan into or create positions for:
<ul>
<li>freezer box - 100 positions - 10 rows, 10 columns, holds <strong>cryovial</strong></li>
<li>freezer box - 81 positions - 9 rows, 9 columns, holds <strong>cryovial</strong></li>
<li>freezer box - 25 positions - 5 rows, 5 columns, holds <strong>cryovial</strong></li>
<li>freezer box - 169 positions - 13 rows, 13 columns, holds <strong>cryovial</strong></li>
<li>freezer - 48 positions - 12 rows, 4 columns, holds <strong>freezer rack</strong></li>
<li>freezer - 33 positions - 11 rows, 3 columns, holds <strong>freezer rack</strong></li>
<li>slide box - 100 positions - 50 rows, 2 columns, holds <strong>slide</strong></li>
</ul>
<p>
If you have that and you're still getting this error, <a href="/contact.cfm">contact us</a>.
</p>
</div>
<cfabort>
</cfif>
<!---global--->
<!---- see is positions are used ---->
<cfquery name="whatPosAreUsed" datasource="user_login" username="#session.dbuser#" password="#decrypt(session.epw,session.sessionKey)#">
select container_id, container_type, label from container
where parent_container_id = #aBox.container_id#
</cfquery>
<cfif whatPosAreUsed.recordcount is 0>
There's nothing in this container.
<br>You can create positions in empty position-appropriate containers.
<form name="allnewPos" method="post" action="containerPositions.cfm">
<input type="hidden" name="action" value="allNewPositions">
<input type="hidden" name="container_type" value="#aBox.container_type#">
<input type="hidden" name="container_id" value="#aBox.container_id#">
<input type="hidden" name="number_positions" value="#aBox.number_positions#">
<input type="submit" value="Create all new positions" class="insBtn">
</form>
<cfabort>
</cfif>
<!--- there's something in the box - what? ---->
<cfquery name="uContentType" dbtype="query">
select container_type from whatPosAreUsed
group by container_type
</cfquery>
<cfif uContentType.recordcount is not 1 or uContentType.container_type is not goodPositionType>
<div class="error">
There is a problem with the positions in this box.
<br>It contains things other than positions, or inappropriate position types.
This application can't handle that! Get rid of things that
aren't container_type '#goodPositionType#' or submit a bug report if you feel this container should
hold the things listed below:
<ul>
<cfloop query="uContentType">
<li>#container_type#</li>
</cfloop>
</ul>
</div>
<cfabort>
</cfif>
<!----it's all positions ---->
<cfif whatPosAreUsed.recordcount is not aBox.number_positions>
<div class="error">
There is a problem with the positions in this box. Aborting....
</div>
<cfabort>
</cfif>
<cfloop query="whatPosAreUsed">
<cfif not isnumeric(label)>
<div class="error">
Some position labels aren't numeric
</div>
<cfabort>
</cfif>
</cfloop>
<!---- made it through the checks, now actually do stuff --->
<cfquery name="positionContents" datasource="user_login" username="#session.dbuser#" password="#decrypt(session.epw,session.sessionKey)#">
select
posCon.container_id ,
posCon.label contentLabel,
posCon.barcode posConBc,
pos.label label,
pos.container_id position_id
from
container posCon,
container pos
where
pos.container_id = posCon.parent_container_id (+) and
pos.parent_container_id = #container_id#
</cfquery>
<p style="font-weight: bold;">
This parent container is:
<br>Label: <strong>#abox.label#</strong>
<br>Barcode:
<strong>#aBox.barcode#</strong>
<br> Type:
<strong>#aBox.container_type#</strong>
</p>
<p>
Use this form to:
<ul>
<li>Scan cryovials into freezer boxes</li>
<li>Turn cryovial labels into cryovials while scanning them into freezer boxes</li>
<li>Turn slide labels into slides while scanning them into slide boxes</li>
<li>Scan slides into slide boxes</li>
</ul>
</p>
<p>
Save happens when you tab out of a cell. You can set your scanner to send a tab after data. Make sure you deal with anything
that turns red.
</p>
<form name="newScans" method="post" action="containerPositions.cfm" onsubmit="return false;">
<input type="hidden" name="action" value="moveScans">
<input type="hidden" name="number_positions" value="#aBox.number_positions#">
<input type="hidden" name="container_id" id="container_id" value="#aBox.container_id#">
<input type="hidden" name="acceptableChildContainerType" id="acceptableChildContainerType" value="#acceptableChildContainerType#">
<cfset thisCellNumber=1>
<table cellpadding="0" cellspacing="0" border="1">
<cfloop from="1" to="#numberRows#" index="currentrow">
<tr>
<cfloop from="1" to="#numberColumns#" index="currentcolumn">
<td>
<!--- now, we can get the contents of this cell
First, get the container_id for this label from a
cached query, then get the contents from the DB
---->
<cfquery name="thisPos" dbtype="query">
select container_id, position_id,contentLabel,posConBc from positionContents
where label = '#thisCellNumber#'
</cfquery>
<cfif taborder is "vertical">
<cfset thisTabIndex=((currentcolumn -1) * numberRows) + currentrow>
<cfelse>
<cfset thisTabIndex=thisCellNumber>
</cfif>
<div class="ccellDiv">
<span class="labelSpan">
#thisTabIndex#
</span>
<span class="innerSpan" id="theSpan#thisTabIndex#">
<cfif len(thisPos.container_id) gt 0>
<br>#thisPos.contentLabel#
<br>#thisPos.posConBc#
<cfelse>
Barcode:<br>
<input type="hidden"
name="position_id#thisTabIndex#"
id="position_id#thisTabIndex#"
value="#thisPos.position_id#">
<input type="text"
onFocus="this.className='activeCell'"
onChange="moveContainer('barcode#thisTabIndex#',this.value)"
name="barcode#thisTabIndex#"
id="barcode#thisTabIndex#"
size="6"
style="font-size:small;"
tabindex="#thisTabIndex#">
</cfif>
</span>
</div>
<cfset thisCellNumber=thisCellNumber+1>
</td>
</cfloop>
</tr>
</cfloop>
</table>
</form>
</cfoutput>
</cfif>
<!------------------------------------------------------------------------------>
<cfif #action# is "moveScans">
<!--- generate a list of child/parent/timestamp and put it into the standard container upload table ---->
<cfoutput>
<cfset oops = "">
<cfquery name="cleanup" datasource="user_login" username="#session.dbuser#" password="#decrypt(session.epw,session.sessionKey)#">
delete from cf_temp_container_location
</cfquery>
<cftransaction>
<cfloop from="1" to="#number_positions#" index="bc">
<cfset thisContainerId = "">
<cfif isdefined("barcode" & bc)>
<cfset thisBarcode = #evaluate("barcode" & bc)#>
<cfset thisParentId = #evaluate("position_id" & bc)#>
<cfif len(#thisBarcode#) gt 0>
<cfquery name="thisID" datasource="user_login" username="#session.dbuser#" password="#decrypt(session.epw,session.sessionKey)#">
select container_id from container where barcode='#thisBarcode#'
<!--- we should only be putting cyrovials in box positions ---->
AND container_type = 'cryovial'
</cfquery>
<cfif #thisID.recordcount# is 0>
<!--- see if it's a label --->
<cfquery name="isLabel" datasource="user_login" username="#session.dbuser#" password="#decrypt(session.epw,session.sessionKey)#">
select container_id from container where barcode='#thisBarcode#'
AND container_type = 'cryovial label'
</cfquery>
<cfif #isLabel.recordcount# is 1>
<!--- switch --->
<cfquery name="update" datasource="user_login" username="#session.dbuser#" password="#decrypt(session.epw,session.sessionKey)#">
update container set container_type='cryovial'
where container_id=#isLabel.container_id#
</cfquery>
<cfset thisContainerId = #isLabel.container_id#>
</cfif>
<cfset thisContainerId = #isLabel.container_id#>
<cfelseif #thisID.recordcount# is 1>
<cfset thisContainerId = #thisID.container_id#>
<cfelse>
bad juju<cfabort>
</cfif>
<cfif len(#thisContainerId#) gt 0>
<cfquery name="putItIn" datasource="user_login" username="#session.dbuser#" password="#decrypt(session.epw,session.sessionKey)#">
INSERT INTO cf_temp_container_location (
CONTAINER_ID,
PARENT_CONTAINER_ID,
TIMESTAMP )
VALUES (
#thisContainerId#,
#thisParentId#,
sysdate)
</cfquery>
<cfelse>
<cfset oops = "#oops#; no container matched barcode #thisBarcode#!">
</cfif>
</cfif>
</cfif>
</cfloop>
</cftransaction>
<CFIF LEN(#oops#) gt 0>
<!--- cleanup on isle no container.... ---->
<cfquery name="cleanup" datasource="user_login" username="#session.dbuser#" password="#decrypt(session.epw,session.sessionKey)#">
delete from cf_temp_container_location
</cfquery>
<hr><font color="##FF0000">#oops#</font>
<cfelse>
<!--- check these, move them, and tell the user to go back ---->
<!---- include the mover over application ---->
<cfset action="update">
<cfinclude template="/LoadBarcodes.cfm">
<cflocation url="containerPositions.cfm?container_id=#container_id#">
</CFIF>
</cfoutput>
</cfif>
<!------------------------------------------------------------------------------>
<cfif #action# is "allNewPositions">
<cfoutput>
<cfif #number_positions# is 100 and #container_type# is "freezer box">
<cfset position_label = "position">
<cfset width = 1.2>
<cfset length = 1.2>
<cfset height = 4.9>
<cfelseif #number_positions# is "48" and #container_type# is "freezer">
<cfset position_label = "position">
<cfset width = 14>
<cfset height = 80>
<cfset length = 14>
<cfelseif #number_positions# is "33" and #container_type# is "freezer">
<cfset position_label = "position">
<cfset width = 14>
<cfset height = 80>
<cfset length = 14>
<cfelseif #number_positions# is 25 AND #container_type# is "freezer box">
<cfset position_label = "position">
<cfset width = 1.2>
<cfset length = 1.2>
<cfset height = 4.9>
<cfelseif #number_positions# is 81 AND #container_type# is "freezer box">
<cfset position_label = "position">
<cfset width = 1.2>
<cfset length = 1.2>
<cfset height = 4.9>
<cfelseif number_positions is 169 AND container_type is "freezer box">
<cfset position_label = "position">
<cfset width = 1.2>
<cfset length = 1.2>
<cfset height = 4.9>
<cfelseif #number_positions# is 100 AND #container_type# is "slide box">
<cfset position_label = "position">
<cfset width = 3>
<cfset length = 78>
<cfset height = 27>
<cfelse>
<hr><font color="##FF0000">I can't deal with #number_positions# positions in a #container_type#!</font>
<cfabort>
</cfif>
<cfquery name="isThere" datasource="user_login" username="#session.dbuser#" password="#decrypt(session.epw,session.sessionKey)#">
select count(*) c from container where parent_container_id=#container_id#
</cfquery>
<cfif isThere.c gt 0>
<div class="error">
There are already #isThere.recordcount# containers in this container. Aborting....
</div>
<cfabort>
</cfif>
<!--- there is nothing in this box, make all positions ---->
<cftransaction>
<!--- make number_positions new containers, lock them, and put them in this box ---->
<cfloop from="1" to="#number_positions#" index="i">
<cfquery name="new" datasource="user_login" username="#session.dbuser#" password="#decrypt(session.epw,session.sessionKey)#">
INSERT INTO container (
CONTAINER_ID,
PARENT_CONTAINER_ID,
CONTAINER_TYPE,
LABEL,
WIDTH,
HEIGHT,
length,
NUMBER_POSITIONS,
LOCKED_POSITION,
institution_acronym)
VALUES (
sq_container_id.nextval,
#container_id#,
'#position_label#',
'#i#',
#width#,
#height#,
#length#,
1,
1,
'UAM')
</cfquery>
</cfloop>
</cftransaction>
<cflocation url="containerPositions.cfm?container_id=#container_id#">
</cfoutput>
</cfif>
<cfinclude template="/includes/_footer.cfm">