From 7eb2aabe9a06be50d5f79d529680cb6e7d2ac717 Mon Sep 17 00:00:00 2001 From: Mark W <24956497+ndg63276@users.noreply.github.com> Date: Mon, 16 Dec 2024 10:42:26 +0000 Subject: [PATCH] Merge pre-release/2024-R5.3 (and pre-release/2024-R5.2) into master (#882) * LIMS-1498: Change name of processed data archive (#855) * LIMS-1469: Fix download button on old summary page (#840) * LIMS-1463: Always display Mesh3D data collections as grid scans (#845) * LIMS-1515: Add energy value to data collections (#853) * LIMS-261: Allow download of PDB files (#857) * LIMS-1529: Fix fast ep model viewer (#858) * LIMS-753: Allow LN2 topups as part of dewar history (#856) * LIMS-1530: Add To Queue Fails when Not Completed filter applied (#864) * LIMS-1530: Add To Queue Fails when Not Completed filter applied * LIMS-1552: Remove old jquery (#871) * LIMS-1500: Set the dispatch request email recipients based on the dewar barcode (#848) * LIMS-1458: Fix GitHub warnings (#841) --------- Co-authored-by: Mark Williams Co-authored-by: Guilherme Francisco --- api/scripts/mtz2map.sh | 16 +- api/src/Page/Cell.php | 8 +- api/src/Page/DC.php | 38 +++- api/src/Page/Download.php | 10 +- api/src/Page/Sample.php | 16 ++ api/src/Page/Shipment.php | 196 ++++++++++-------- client/src/js/models/protein.js | 2 +- client/src/js/models/visit.js | 8 +- client/src/js/modules/cell/views/beamlines.js | 31 ++- .../js/modules/dc/models/autointegration.js | 6 +- client/src/js/modules/dc/models/dccomment.js | 8 +- client/src/js/modules/dc/views/reprocess2.js | 9 +- .../js/modules/dc/views/reprocessoverview.js | 8 +- .../src/js/modules/dc/views/samplechanger.js | 4 +- client/src/js/modules/dc/views/summary.js | 2 +- .../src/js/modules/fault/models/component.js | 6 +- client/src/js/modules/fault/models/fault.js | 8 +- .../js/modules/fault/models/subcomponent.js | 6 +- client/src/js/modules/fault/models/system.js | 4 +- .../modules/imaging/views/queuecontainer.js | 7 +- client/src/js/modules/samples/views/pdbs.js | 23 +- .../shipment/models/containerreport.js | 2 +- .../js/modules/shipment/models/dewarreport.js | 4 +- .../shipment/views/containerregistry.js | 6 +- .../src/js/modules/shipment/views/manifest.js | 8 +- .../src/js/modules/shipment/views/migrate.js | 12 +- client/src/js/modules/shipment/views/plate.js | 10 +- .../src/js/modules/shipment/views/regdewar.js | 16 +- .../shipment/views/registeredcontainer.js | 12 +- .../src/js/modules/summary/views/summary.vue | 4 +- .../src/js/modules/types/xpdf/views/plan.js | 4 +- client/src/js/templates/dc/dc.html | 2 +- client/src/js/templates/dc/edge.html | 10 +- client/src/js/templates/dc/grid.html | 2 +- client/src/js/templates/dc/mca.html | 4 +- client/src/js/tpl.js | 2 +- client/src/js/utils/editable.js | 4 +- client/src/js/utils/xhrimage.js | 4 +- client/src/js/views/log.js | 2 +- 39 files changed, 294 insertions(+), 230 deletions(-) diff --git a/api/scripts/mtz2map.sh b/api/scripts/mtz2map.sh index 00542447d..1d25a72a4 100755 --- a/api/scripts/mtz2map.sh +++ b/api/scripts/mtz2map.sh @@ -14,6 +14,14 @@ else fi fi +#export CCP4_MASTER=/dls_sw/apps/ccp4/ +export CCP4_MASTER=$5 +export CINCL=$CCP4_MASTER/include +export CLIBD=$CCP4_MASTER/lib/data + +export CCP4_SCR=/tmp +export root=$CCP4_MASTER/bin + if [ $3 == 'dimple' -o $3 == 'mrbump' ]; then if [ -f $4 ]; then @@ -28,14 +36,6 @@ else fi fi -#export CCP4_MASTER=/dls_sw/apps/ccp4/ -export CCP4_MASTER=$5 -export CINCL=$CCP4_MASTER/include -export CLIBD=$CCP4_MASTER/lib/data - -export CCP4_SCR=/tmp -export root=$CCP4_MASTER/bin - if [ $3 == 'dimple' ]; then if $root/mtzinfo $mtz | grep -q PH2FOFCWT; then diff --git a/api/src/Page/Cell.php b/api/src/Page/Cell.php index 80fbcc071..e0e0b7d4b 100644 --- a/api/src/Page/Cell.php +++ b/api/src/Page/Cell.php @@ -274,8 +274,8 @@ function _beamlines() $pdb = $this->db->pq("SELECT TO_CHAR(p.pdbdate, 'YYYY') as year, $replace as bl, count(p.pdbentryid) as count FROM pdbentry p WHERE p.pdbdate > TO_DATE('2010-05', 'YYYY-MM') - GROUP BY $replace, TO_CHAR(p.pdbdate, 'YYYY') - ORDER BY TO_CHAR(p.pdbdate, 'YYYY')"); + GROUP BY bl, year + ORDER BY year, bl"); $isp = $this->db->pq("SELECT TO_CHAR(p.pdbdate, 'YYYY') as year, CASE WHEN p.autoprocprogramid > 0 THEN UPPER(s.beamlinename) ELSE $replace END as bl, count(p.pdbentryid) as count FROM pdbentry p @@ -284,8 +284,8 @@ function _beamlines() INNER JOIN datacollectiongroup dcg ON dcg.datacollectiongroupid = dc.datacollectiongroupid INNER JOIN blsession s ON s.sessionid = dcg.sessionid WHERE p.pdbdate > TO_DATE('2010-05', 'YYYY-MM') - GROUP BY CASE WHEN p.autoprocprogramid > 0 THEN UPPER(s.beamlinename) ELSE $replace END, TO_CHAR(p.pdbdate, 'YYYY') - ORDER BY TO_CHAR(p.pdbdate, 'YYYY')"); + GROUP BY bl, year + ORDER BY year, bl"); foreach ($pdb as $i => &$s) { $s['COUNT'] = intval(($s['COUNT'])); diff --git a/api/src/Page/DC.php b/api/src/Page/DC.php index 34e59f5f2..165e53c6d 100644 --- a/api/src/Page/DC.php +++ b/api/src/Page/DC.php @@ -62,6 +62,8 @@ class DC extends Page array('/dat/:id', 'get', '_plot'), ); + const EVTOA = 12398.4198; + # ------------------------------------------------------------------------ # Data Collection AJAX Requests # This is pretty crazy, it will return unioned data collections, energy @@ -422,9 +424,12 @@ function _data_collections($single = null) dc.transmission, dc.axisrange, dc.wavelength, + ".self::EVTOA."/dc.wavelength as energy, dc.comments, 1 as epk, 1 as ein, + 1 as wpk, + 1 as win, dc.xtalsnapshotfullpath1 as x1, dc.xtalsnapshotfullpath2 as x2, dc.xtalsnapshotfullpath3 as x3, @@ -556,9 +561,12 @@ function _data_collections($single = null) min(dc.transmission) as transmission, min(dc.axisrange) as axisrange, min(dc.wavelength) as wavelength, + ".self::EVTOA."/min(dc.wavelength) as energy, min(dc.comments) as comments, 1 as epk, 1 as ein, + 1 as wpk, + 1 as win, min(dc.xtalsnapshotfullpath1) as x1, min(dc.xtalsnapshotfullpath2) as x2, min(dc.xtalsnapshotfullpath3) as x3, @@ -705,17 +713,20 @@ function _data_collections($single = null) es.energyscanid, 1, es.element, - es.peakfprime, + es.peakfprime as resolution, es.exposuretime, es.axisposition, - es.peakfdoubleprime, + es.peakfdoubleprime as numimg, es.starttime as st, es.transmissionfactor, - es.inflectionfprime, - es.inflectionfdoubleprime, + es.inflectionfprime as axisrange, + es.inflectionfdoubleprime as wavelength, + 1 as energy, es.comments, es.peakenergy, es.inflectionenergy, + ".self::EVTOA."/es.peakenergy as wpk, + ".self::EVTOA."/es.inflectionenergy as win, 'A', 'A', 'A', @@ -805,10 +816,13 @@ function _data_collections($single = null) TO_CHAR(xrf.starttime, 'DD-MM-YYYY HH24:MI:SS') as st, xrf.beamtransmission, 1, - xrf.energy, + ".self::EVTOA."/xrf.energy as wavelength, + xrf.energy as energy, xrf.comments, 1, 1, + 1 as wpk, + 1 as win, 'A', 'A', 'A', @@ -899,9 +913,12 @@ function _data_collections($single = null) 1, 1, 1, + 1 as energy, 'A', 1, 1, + 1 as wpk, + 1 as win, r.xtalsnapshotbefore, r.xtalsnapshotafter, 'A', @@ -974,7 +991,7 @@ function _data_collections($single = null) // Data collections if ($dc['TYPE'] == 'data') { - $nf = array(1 => array('AXISSTART', 'CHISTART', 'PHI', 'OVERLAP'), 2 => array('RESOLUTION', 'TRANSMISSION', 'AXISRANGE', 'TOTALDOSE'), 4 => array('WAVELENGTH', 'EXPOSURETIME')); + $nf = array(0 => array('ENERGY'), 1 => array('AXISSTART', 'CHISTART', 'PHI', 'OVERLAP'), 2 => array('RESOLUTION', 'TRANSMISSION', 'AXISRANGE', 'TOTALDOSE'), 4 => array('WAVELENGTH', 'EXPOSURETIME')); $dc['DIRFULL'] = $dc['DIR']; $dc['DIR'] = preg_replace('/.*\/' . $this->arg('prop') . '-' . $dc['VN'] . '\//', '', $dc['DIR']); @@ -993,9 +1010,10 @@ function _data_collections($single = null) $dc['DCT'] = 'Data Collection'; } - if ($dc['DCT'] == 'Mesh') + if ($dc['DCT'] == 'Mesh' || $dc['DCT'] == 'Mesh3D' || + ($dc['DCT'] != 'Serial Fixed' && $dc['DCT'] != 'Serial Jet' && $dc['AXISRANGE'] == 0 && $dc['NI'] > 1) + ) { $dc['DCT'] = 'Grid Scan'; - if ($dc['DCT'] != 'Serial Fixed' && $dc['DCT'] != 'Serial Jet' && $dc['AXISRANGE'] == 0 && $dc['NI'] > 1) { $dc['TYPE'] = 'grid'; } //$this->profile('dc'); @@ -1010,12 +1028,12 @@ function _data_collections($single = null) $dc['FILETEMPLATE'] = preg_replace('/.*\/' . $this->arg('prop') . '-' . $dc['VN'] . '\//', '', $dc['FILETEMPLATE']); - $nf = array(2 => array('EXPOSURETIME', 'AXISSTART', 'RESOLUTION', 'TRANSMISSION')); + $nf = array(1 => array('EPK', 'EIN'), 2 => array('AXISRANGE', 'WAVELENGTH', 'EXPOSURETIME', 'AXISSTART', 'RESOLUTION', 'TRANSMISSION', 'NUMIMG'), 5 => array('WPK', 'WIN')); $this->profile('edge'); // MCA Scans } else if ($dc['TYPE'] == 'mca') { - $nf = array(2 => array('EXPOSURETIME', 'WAVELENGTH', 'TRANSMISSION')); + $nf = array(0 => array('ENERGY'), 2 => array('EXPOSURETIME', 'TRANSMISSION'), 4 => array('WAVELENGTH')); $dc['DIRFULL'] = $dc['DIR']; $dc['DIR'] = preg_replace('/.*\/\d\d\d\d\/\w\w\d+-\d+\//', '', $dc['DIR']); diff --git a/api/src/Page/Download.php b/api/src/Page/Download.php index a1ed29bca..6333e6b0e 100644 --- a/api/src/Page/Download.php +++ b/api/src/Page/Download.php @@ -92,9 +92,7 @@ function _download_visit() $this->_error('There doesnt seem to be a data archive available for this visit'); } - # ------------------------------------------------------------------------ - # Download mtz/log file for Fast DP / XIA2 - # TODO: Delete me + # This method either returns a list of plots from MX auto processing tools (n_obs, n_uniq, completeness etc.) # Or returns a specific plot based on auto processing attachment id (aid). # Individual plotly format Graphs can be returned via an aid, but will not be included in the list of plots (as their format is different) @@ -468,14 +466,14 @@ function _get_autoproc_archive() $aps = $this->db->union( array( - "SELECT app.autoprocprogramid, app.processingprograms, app.processingstatus + "SELECT app.autoprocprogramid, app.processingprograms, app.processingstatus, dc.imageprefix, dc.datacollectionnumber FROM autoprocintegration api INNER JOIN autoprocprogram app ON api.autoprocprogramid = app.autoprocprogramid INNER JOIN datacollection dc ON dc.datacollectionid = api.datacollectionid INNER JOIN datacollectiongroup dcg ON dcg.datacollectiongroupid = dc.datacollectiongroupid INNER JOIN blsession s ON s.sessionid = dcg.sessionid WHERE s.proposalid=:1 AND app.autoprocprogramid=:2", - "SELECT app.autoprocprogramid, app.processingprograms, app.processingstatus + "SELECT app.autoprocprogramid, app.processingprograms, app.processingstatus, dc.imageprefix, dc.datacollectionnumber FROM autoprocprogram app INNER JOIN processingjob pj on pj.processingjobid = app.processingjobid INNER JOIN datacollection dc ON dc.datacollectionid = pj.datacollectionid @@ -497,7 +495,7 @@ function _get_autoproc_archive() } $clean_program = preg_replace('/[^A-Za-z0-9\-]/', '', $ap['PROCESSINGPROGRAMS']); - $zipName = $this->arg('AUTOPROCPROGRAMID') . '_' . $clean_program; + $zipName = $this->arg('AUTOPROCPROGRAMID') . '_' . $ap['IMAGEPREFIX'] . '_' . $ap['DATACOLLECTIONNUMBER'] . '_' . $clean_program; $this->_streamZipFile($files, $zipName); } diff --git a/api/src/Page/Sample.php b/api/src/Page/Sample.php index d1a051493..4d2093fff 100644 --- a/api/src/Page/Sample.php +++ b/api/src/Page/Sample.php @@ -195,6 +195,7 @@ class Sample extends Page array('/pdbs(/pid/:pid)', 'get', '_get_pdbs'), array('/pdbs', 'post', '_add_pdb'), array('/pdbs(/:pdbid)', 'delete', '_remove_pdb'), + array('/pdbs/download/:pdbid', 'get', '_download_pdb'), array('/concentrationtypes', 'get', '_concentration_types'), array('/componenttypes', 'get', '_component_types'), @@ -2062,6 +2063,21 @@ function _get_pdbs() $this->_output($rows); } + # ------------------------------------------------------------------------ + # Download a pdb file + function _download_pdb() + { + if (!$this->has_arg('pdbid')) + $this->_error('No PDB id specified'); + + $pdb = $this->db->pq("SELECT name, contents FROM pdb WHERE pdbid = :1", array($this->arg('pdbid'))); + $pdb = $pdb[0]; + + header('Content-Type:text/plain'); + header('Content-Disposition:attachment;filename='.$pdb['NAME']); + print $pdb['CONTENTS']; + } + # ------------------------------------------------------------------------ # Add a new pdb function _add_pdb() diff --git a/api/src/Page/Shipment.php b/api/src/Page/Shipment.php index fdb44b725..24fbeea13 100644 --- a/api/src/Page/Shipment.php +++ b/api/src/Page/Shipment.php @@ -484,10 +484,10 @@ function _add_history() if (!$this->has_arg('BARCODE')) $this->_error('No barcode specified'); - if (!$this->has_arg('LOCATION')) - $this->_error('No location specified'); + if (!$this->has_arg('LOCATION') && !$this->has_arg('STATUS')) + $this->_error('No location or status specified'); - $dew = $this->db->pq("SELECT CONCAT(pe.givenname, ' ', pe.familyname) as lcout, pe.emailaddress as lcoutemail, CONCAT(CONCAT(pe2.givenname, ' '), pe2.familyname) as lcret, pe2.emailaddress as lcretemail, CONCAT(p.proposalcode, p.proposalnumber, '-', e.visit_number) as firstexp, TO_CHAR(e.startdate, 'DD-MM-YYYY HH24:MI') as firstexpst, e.beamlinename, e.beamlineoperator, d.dewarid, d.trackingnumberfromsynchrotron, s.shippingid, s.shippingname, p.proposalcode, CONCAT(p.proposalcode, p.proposalnumber) as prop, d.barcode, d.facilitycode, d.firstexperimentid, d.dewarstatus + $dew = $this->db->pq("SELECT CONCAT(pe.givenname, ' ', pe.familyname) as lcout, pe.emailaddress as lcoutemail, CONCAT(CONCAT(pe2.givenname, ' '), pe2.familyname) as lcret, pe2.emailaddress as lcretemail, CONCAT(p.proposalcode, p.proposalnumber, '-', e.visit_number) as firstexp, TO_CHAR(e.startdate, 'DD-MM-YYYY HH24:MI') as firstexpst, e.beamlinename, e.beamlineoperator, d.dewarid, d.trackingnumberfromsynchrotron, s.shippingid, s.shippingname, p.proposalcode, CONCAT(p.proposalcode, p.proposalnumber) as prop, d.barcode, d.facilitycode, d.firstexperimentid, d.dewarstatus, d.storagelocation FROM dewar d INNER JOIN shipping s ON s.shippingid = d.shippingid LEFT OUTER JOIN labcontact c ON s.sendinglabcontactid = c.labcontactid @@ -505,15 +505,9 @@ function _add_history() $track = $this->has_arg('TRACKINGNUMBERFROMSYNCHROTRON') ? $this->arg('TRACKINGNUMBERFROMSYNCHROTRON') : $dew['TRACKINGNUMBERFROMSYNCHROTRON']; - // What was the last history entry for this dewar? - // If it's come from a beamline, register flag so we can e-mail further down... - $last_history_results = $this->db->pq("SELECT storageLocation FROM dewartransporthistory WHERE dewarId = :1 ORDER BY DewarTransportHistoryId DESC LIMIT 1", array($dew['DEWARID'])); - - if (sizeof($last_history_results)) { - $last_history = $last_history_results[0]; - // We only add data to dewar history in lower case from this method. - // If that ever changes, update this to become case insensitive search - $last_location = $last_history['STORAGELOCATION']; + if ($this->has_arg('LOCATION')) { + // If it's come from a beamline, register flag so we can e-mail further down... + $last_location = $dew['STORAGELOCATION']; if (!isset($dewar_complete_email_locations) || !is_array($dewar_complete_email_locations)) { $bls = $this->_get_beamlines_from_type('all'); $send_return_email = in_array($last_location, $bls); @@ -521,99 +515,103 @@ function _add_history() $email_location = $dewar_complete_email_locations[$last_location]; $send_return_email = preg_match($email_location, strtolower($this->arg('LOCATION'))); } + // If dewar status is dispatch-requested - don't change it. + // This way the dewar can be moved between storage locations and keep the record that a user requested the dispatch + // Default status is 'at-facility' + $dewarstatus = strtolower($dew['DEWARSTATUS']) == 'dispatch-requested' ? 'dispatch-requested' : 'at facility'; + $dewarlocation = $this->arg('LOCATION'); + } else { - // No history - could be a new dewar, so not necessarily an error... - if ($this->debug) - error_log("No previous dewar transport history for DewarId " . $dew['DEWARID']); + // just a status given + $dewarstatus = $this->arg('STATUS'); + $dewarlocation = $dew['STORAGELOCATION']; } - // If dewar status is dispatch-requested - don't change it. - // This way the dewar can be moved between storage locations and keep the record that a user requested the dispatch - // Default status is 'at-facility' - $dewarstatus = strtolower($dew['DEWARSTATUS']) == 'dispatch-requested' ? 'dispatch-requested' : 'at facility'; - $this->db->pq("INSERT INTO dewartransporthistory (dewartransporthistoryid,dewarid,dewarstatus,storagelocation,arrivaldate) VALUES (s_dewartransporthistory.nextval,:1,lower(:2),lower(:3),CURRENT_TIMESTAMP) RETURNING dewartransporthistoryid INTO :id", array($dew['DEWARID'], $dewarstatus, $this->arg('LOCATION'))); + $this->db->pq("INSERT INTO dewartransporthistory (dewartransporthistoryid,dewarid,dewarstatus,storagelocation,arrivaldate) VALUES (s_dewartransporthistory.nextval,:1,lower(:2),lower(:3),CURRENT_TIMESTAMP) RETURNING dewartransporthistoryid INTO :id", array($dew['DEWARID'], $dewarstatus, $dewarlocation)); $dhid = $this->db->id(); - $this->db->pq("UPDATE dewar set dewarstatus=lower(:4), storagelocation=lower(:2), trackingnumberfromsynchrotron=:3 WHERE dewarid=:1", array($dew['DEWARID'], $this->arg('LOCATION'), $track, $dewarstatus)); - $this->db->pq("UPDATE shipping set shippingstatus=lower(:2) WHERE shippingid=:1", array($dew['SHIPPINGID'], $dewarstatus)); - - $containers = $this->db->pq("SELECT containerid - FROM container - WHERE dewarid=:1", array($dew['DEWARID'])); - foreach ($containers as $c) { - $this->db->pq("INSERT INTO containerhistory (containerid,status) VALUES (:1,:2)", array($c['CONTAINERID'], 'at facility')); - } - - // Email - // EHCs, local contact(s), labcontact, dh, pa - $dew['NOW'] = strftime('%d-%m-%Y %H:%M'); - $dew['INCONTACTS'] = $in_contacts; - $dew['TRACKINGNUMBERFROMSYNCHROTRON'] = $track; - - if (strtolower($this->arg('LOCATION')) == 'stores-in' && $dew['LCOUTEMAIL']) { - $lcs = $this->db->pq("SELECT p.login - FROM person p - INNER JOIN session_has_person shp ON shp.personid = p.personid - WHERE shp.sessionid=:1 AND (shp.role = 'Local Contact' OR shp.role = 'Local Contact 2')", array($dew['FIRSTEXPERIMENTID'])); - $emails = array($dew['LCOUTEMAIL'], $arrival_email); - foreach ($lcs as $lc) { - array_push($emails, $this->_get_email($lc['LOGIN'])); - } + if ($this->has_arg('LOCATION')) { + $this->db->pq("UPDATE dewar set dewarstatus=lower(:4), storagelocation=lower(:2), trackingnumberfromsynchrotron=:3 WHERE dewarid=:1", array($dew['DEWARID'], $this->arg('LOCATION'), $track, $dewarstatus)); + $this->db->pq("UPDATE shipping set shippingstatus=lower(:2) WHERE shippingid=:1", array($dew['SHIPPINGID'], $dewarstatus)); - $email = new Email($dew['PROPOSALCODE'] == 'in' ? 'dewar-stores-in-in' : 'dewar-stores-in', '*** Dewar Received for ' . $dew['PROP'] . ' at ' . $dew['NOW'] . ' ***'); - $email->data = $dew; - $email->send(implode(', ', $emails)); - } + $containers = $this->db->pq("SELECT containerid + FROM container + WHERE dewarid=:1", array($dew['DEWARID'])); + foreach ($containers as $c) { + $this->db->pq("INSERT INTO containerhistory (containerid,status) VALUES (:1,:2)", array($c['CONTAINERID'], 'at facility')); + } - if (strtolower($this->arg('LOCATION')) == 'stores-out' && $dew['LCRETEMAIL']) { - $email = new Email('dewar-stores-out', '*** Dewar ready to leave Synchrotron ***'); - $email->data = $dew; - $email->send($dew['LCRETEMAIL']); - } + // Email + // EHCs, local contact(s), labcontact, dh, pa + $dew['NOW'] = strftime('%d-%m-%Y %H:%M'); + $dew['INCONTACTS'] = $in_contacts; + $dew['TRACKINGNUMBERFROMSYNCHROTRON'] = $track; + + if (strtolower($this->arg('LOCATION')) == 'stores-in' && $dew['LCOUTEMAIL']) { + $lcs = $this->db->pq("SELECT p.login + FROM person p + INNER JOIN session_has_person shp ON shp.personid = p.personid + WHERE shp.sessionid=:1 AND (shp.role = 'Local Contact' OR shp.role = 'Local Contact 2')", array($dew['FIRSTEXPERIMENTID'])); + $emails = array($dew['LCOUTEMAIL'], $arrival_email); + foreach ($lcs as $lc) { + array_push($emails, $this->_get_email($lc['LOGIN'])); + } - if (strpos(strtolower($this->arg('LOCATION')), '-rack') !== false && $dew['LCRETEMAIL']) { - $dew['LOCATION'] = $this->arg('LOCATION'); + $email = new Email($dew['PROPOSALCODE'] == 'in' ? 'dewar-stores-in-in' : 'dewar-stores-in', '*** Dewar Received for ' . $dew['PROP'] . ' at ' . $dew['NOW'] . ' ***'); + $email->data = $dew; + $email->send(implode(', ', $emails)); + } - $email = new Email('dewar-rack', '*** Dewar now outside Beamline ***'); - $email->data = $dew; - $email->send($dew['LCRETEMAIL']); - } + if (strtolower($this->arg('LOCATION')) == 'stores-out' && $dew['LCRETEMAIL']) { + $email = new Email('dewar-stores-out', '*** Dewar ready to leave Synchrotron ***'); + $email->data = $dew; + $email->send($dew['LCRETEMAIL']); + } - if ($dew['LCRETEMAIL'] && $send_return_email) { - // Any data collections for this dewar's containers? - // Note this counts data collection ids for containers and uses the DataCollection.SESSIONID to determine the session/visit - // Should work for UDC (where container.sessionid is set) as well as any normal scheduled session (where container.sessionid is not set) - $rows = $this->db->pq("SELECT CONCAT(p.proposalcode, p.proposalnumber, '-', ses.visit_number) as visit, dc.sessionid, count(dc.datacollectionid) as dccount - FROM Dewar d - INNER JOIN Container c on c.dewarid = d.dewarid - INNER JOIN BLSample bls ON bls.containerid = c.containerid - INNER JOIN DataCollection dc ON dc.blsampleid = bls.blsampleid - INNER JOIN BLSession ses ON dc.sessionid = ses.sessionid - INNER JOIN Proposal p ON p.proposalid = ses.proposalid - WHERE d.dewarid = :1 - GROUP BY dc.sessionid", array($dew['DEWARID'])); + if (strpos(strtolower($this->arg('LOCATION')), '-rack') !== false && $dew['LCRETEMAIL']) { + $dew['LOCATION'] = $this->arg('LOCATION'); - if (sizeof($rows)) - $dew['DC'] = $rows; + $email = new Email('dewar-rack', '*** Dewar now outside Beamline ***'); + $email->data = $dew; + $email->send($dew['LCRETEMAIL']); + } - $cc = array($dewar_complete_email ? $dewar_complete_email : null); + if ($dew['LCRETEMAIL'] && $send_return_email) { + // Any data collections for this dewar's containers? + // Note this counts data collection ids for containers and uses the DataCollection.SESSIONID to determine the session/visit + // Should work for UDC (where container.sessionid is set) as well as any normal scheduled session (where container.sessionid is not set) + $rows = $this->db->pq("SELECT CONCAT(p.proposalcode, p.proposalnumber, '-', ses.visit_number) as visit, dc.sessionid, count(dc.datacollectionid) as dccount + FROM Dewar d + INNER JOIN Container c on c.dewarid = d.dewarid + INNER JOIN BLSample bls ON bls.containerid = c.containerid + INNER JOIN DataCollection dc ON dc.blsampleid = bls.blsampleid + INNER JOIN BLSession ses ON dc.sessionid = ses.sessionid + INNER JOIN Proposal p ON p.proposalid = ses.proposalid + WHERE d.dewarid = :1 + GROUP BY dc.sessionid", array($dew['DEWARID'])); + + if (sizeof($rows)) + $dew['DC'] = $rows; + + $cc = array($dewar_complete_email ? $dewar_complete_email : null); + + $owners = $this->db->pq("SELECT p.emailaddress + FROM Container c + INNER JOIN Person p ON c.ownerId = p.personId + WHERE c.dewarId = :1 + GROUP BY p.emailaddress", array($dew['DEWARID'])); + + foreach ($owners as $owner) { + if ($owner['EMAILADDRESS'] != '') array_push($cc, $owner['EMAILADDRESS']); + } - $owners = $this->db->pq("SELECT p.emailaddress - FROM Container c - INNER JOIN Person p ON c.ownerId = p.personId - WHERE c.dewarId = :1 - GROUP BY p.emailaddress", array($dew['DEWARID'])); + // Log the event if debugging + if ($this->debug) error_log("Dewar " . $dew['DEWARID'] . " back from beamline..."); - foreach ($owners as $owner) { - if ($owner['EMAILADDRESS'] != '') array_push($cc, $owner['EMAILADDRESS']); + $email = new Email('storage-rack', '*** Visit finished, dewar awaiting instructions ***'); + $email->data = $dew; + $email->send($dew['LCRETEMAIL'], implode(', ', $cc)); } - - // Log the event if debugging - if ($this->debug) error_log("Dewar " . $dew['DEWARID'] . " back from beamline..."); - - $email = new Email('storage-rack', '*** Visit finished, dewar awaiting instructions ***'); - $email->data = $dew; - $email->send($dew['LCRETEMAIL'], implode(', ', $cc)); } $this->_output(array('DEWARHISTORYID' => $dhid)); @@ -1147,6 +1145,7 @@ function _dispatch_dewar() global $facility_country; global $facility_courier_countries; global $dispatch_email; + global $dispatch_email_regex; global $dispatch_email_intl; global $use_shipping_service; global $shipping_service_links_in_emails; @@ -1315,6 +1314,14 @@ function _dispatch_dewar() $local_contact_email = $this->has_arg('LCEMAIL') ? $this->args['LCEMAIL'] : ''; if ($local_contact_email) $recpts .= ', ' . $local_contact_email; + if (!is_null($dispatch_email_regex)) { + foreach ($dispatch_email_regex as $address => $pattern) { + if (preg_match($pattern, $data['BARCODE'])) { + $recpts .= ', ' . $address; + } + } + } + $email->send($recpts); // Update the dewar status and storage location @@ -1343,6 +1350,7 @@ function _dispatch_dewar() function _dispatch_dewar_confirmation() { global $dispatch_email; + global $dispatch_email_regex; global $shipping_service_app_url; if (!$this->has_arg('did')) @@ -1405,6 +1413,14 @@ function _dispatch_dewar_confirmation() $local_contact_email = $this->has_arg('LCEMAIL') ? $this->args['LCEMAIL'] : ''; if ($local_contact_email) $recpts .= ', ' . $local_contact_email; + if (!is_null($dispatch_email_regex)) { + foreach ($dispatch_email_regex as $address => $pattern) { + if (preg_match($pattern, $data['BARCODE'])) { + $recpts .= ', ' . $address; + } + } + } + $email->send($recpts); // Also update the dewar status and storage location to keep it in sync with history... diff --git a/client/src/js/models/protein.js b/client/src/js/models/protein.js index 8cafd4338..2ef5f4758 100644 --- a/client/src/js/models/protein.js +++ b/client/src/js/models/protein.js @@ -16,7 +16,7 @@ define(['backbone', 'markdown'], function(Backbone, markdown) { }, refreshOptions: function() { - if (this.get('SEQUENCE')) this.attributes.SEQUENCEMD = markdown.toHTML(this.get('SEQUENCE')) + if (this.get('SEQUENCE')) this.set('SEQUENCEMD', markdown.toHTML(this.get('SEQUENCE'))) }, validation: { diff --git a/client/src/js/models/visit.js b/client/src/js/models/visit.js index ef8a86874..f62f49407 100644 --- a/client/src/js/models/visit.js +++ b/client/src/js/models/visit.js @@ -51,10 +51,10 @@ define(['backbone', 'backbone-validation', 'luxon'], function(Backbone, BackBone addDate: function() { var { DateTime } = luxon - this.attributes.ENISO = DateTime.fromISO(this.get('ENISO'), { zone: this.dateTimeZone }) - this.attributes.STISO = DateTime.fromISO(this.get('STISO'), { zone: this.dateTimeZone }) - this.attributes.LEN = Number(this.attributes.ENISO.diff(this.attributes.STISO)/(3600*1000)).toFixed(2); - this.attributes.VISITDETAIL = this.get('VISIT')+' ('+this.get('BL')+': '+this.get('ST')+')' + this.set('ENISO', DateTime.fromISO(this.get('ENISO'), { zone: this.dateTimeZone })) + this.set('STISO', DateTime.fromISO(this.get('STISO'), { zone: this.dateTimeZone })) + this.set('LEN', Number(this.get('ENISO').diff(this.get('STISO'))/(3600*1000)).toFixed(2)) + this.set('VISITDETAIL', this.get('VISIT')+' ('+this.get('BL')+': '+this.get('ST')+')') }, dateTimeZone: 'Europe/London' diff --git a/client/src/js/modules/cell/views/beamlines.js b/client/src/js/modules/cell/views/beamlines.js index d5481b991..1fd4470af 100644 --- a/client/src/js/modules/cell/views/beamlines.js +++ b/client/src/js/modules/cell/views/beamlines.js @@ -30,28 +30,27 @@ define(['marionette', 'utils', }) var bl = [] + var data = {} _.each(bls, function(i, b) { + data[b] = {} bl.push(b) ticks.push([bl.length-1, b]) + _.each(years, function(x, y) { + data[b][y] = 0 + }) }) - _.each(this.model.get('data')[did], function(v, i) { - var y = yrs.indexOf(v.YEAR) - var b = bl.indexOf(v.BL) - //console.log('d', y, b) - d[y].data.push([b, v.COUNT]) - }) - - function ascsort(a,b) { - if (a[0] == b[0]) return 0 - else return (a[0] < b[0]) ? -1 : 1 - } - - _.each(d, function(d,i) { - d.data.sort(ascsort) - }) + _.each(this.model.get('data')[did], function(v, i) { + data[v.BL][v.YEAR] = v.COUNT + }) - console.log(d) + _.each(data, function(el, beamline) { + _.each(el, function(count, year) { + var y = yrs.indexOf(year) + var b = bl.indexOf(beamline) + d[y].data.push([b, count]) + }) + }) var options = { series: { diff --git a/client/src/js/modules/dc/models/autointegration.js b/client/src/js/modules/dc/models/autointegration.js index 6bf2df8e5..b47510ea2 100644 --- a/client/src/js/modules/dc/models/autointegration.js +++ b/client/src/js/modules/dc/models/autointegration.js @@ -13,13 +13,13 @@ define(['backbone'], function(Backbone){ var shells = this.get('SHELLS') if (!shells) return - this.attributes.CLASS = { RMERGE: {}, RMEAS: {}, COMPLETENESS: {} } + this.set('CLASS', { RMERGE: {}, RMEAS: {}, COMPLETENESS: {} }) _.each(['overall', 'innerShell', 'outerShell'], function(k) { var c = shells[k] ? shells[k].COMPLETENESS : null - this.attributes.CLASS.COMPLETENESS[k] = c > 95 ? 'active' : (c > 80 ? 'minor' : 'inactive') + this.set('CLASS[COMPLETENESS[k]]', c > 95 ? 'active' : (c > 80 ? 'minor' : 'inactive')) var r = shells[k] ? shells[k].RMEAS : null - this.attributes.CLASS.RMEAS[k] = r < 0.5 ? 'active' : (r < 0.6 ? 'minor' : 'inactive') + this.set('CLASS[RMEAS[k]]', r < 0.5 ? 'active' : (r < 0.6 ? 'minor' : 'inactive')) }, this) }, diff --git a/client/src/js/modules/dc/models/dccomment.js b/client/src/js/modules/dc/models/dccomment.js index 2a7913eee..41e8bc75b 100644 --- a/client/src/js/modules/dc/models/dccomment.js +++ b/client/src/js/modules/dc/models/dccomment.js @@ -27,11 +27,11 @@ define(['backbone', 'markdown'], function(Backbone, markdown) { }, addDate: function() { - this.attributes.CREATETIMEISO = new Date(this.get('CREATETIME')) - this.attributes.MODTIMEISO = new Date(this.get('MODTIME')) - if (this.get('COMMENTS')) this.attributes.COMMENTSMD = markdown.toHTML(this.get('COMMENTS')) + this.set('CREATETIMEISO', new Date(this.get('CREATETIME'))) + this.set('MODTIMEISO', new Date(this.get('MODTIME'))) + if (this.get('COMMENTS')) this.set('COMMENTSMD', markdown.toHTML(this.get('COMMENTS'))) } }) -}) \ No newline at end of file +}) diff --git a/client/src/js/modules/dc/views/reprocess2.js b/client/src/js/modules/dc/views/reprocess2.js index 6dee03148..0b1b13aff 100644 --- a/client/src/js/modules/dc/views/reprocess2.js +++ b/client/src/js/modules/dc/views/reprocess2.js @@ -162,8 +162,8 @@ define(['backbone', 'marionette', 'views/dialog', if (e) e.preventDefault() if (this.aps.length) { - var e = this.aps.at(0) - var c = e.get('CELL') + const a = this.aps.at(0) + const c = a.get('CELL') this.ui.a.val(c['CELL_A']).trigger('change') this.ui.b.val(c['CELL_B']).trigger('change') @@ -172,7 +172,7 @@ define(['backbone', 'marionette', 'views/dialog', this.ui.be.val(c['CELL_BE']).trigger('change') this.ui.ga.val(c['CELL_GA']).trigger('change') - this.ui.sg.val(e['SG']).trigger('change') + this.ui.sg.val(a['SG']).trigger('change') } }, @@ -300,11 +300,11 @@ define(['backbone', 'marionette', 'views/dialog', } var self = this + var reqs = [] // Integrate individually if (this.ui.ind.is(':checked')) { var jobs = 0 - var reqs = [] var rps = [] _.each(s, function(sw) { var p = this.pipelines.findWhere({ VALUE: sw.get('PIPELINE') }) @@ -405,7 +405,6 @@ define(['backbone', 'marionette', 'views/dialog', return } - var reqs = [] reqs.push(reprocessing.save({}, { success: function() { var reprocessingparams = new ReprocessingParameters() diff --git a/client/src/js/modules/dc/views/reprocessoverview.js b/client/src/js/modules/dc/views/reprocessoverview.js index 50970dc61..1f78946e1 100644 --- a/client/src/js/modules/dc/views/reprocessoverview.js +++ b/client/src/js/modules/dc/views/reprocessoverview.js @@ -53,14 +53,14 @@ define(['marionette', }, render: function() { - var columns = [ + var pcolumns = [ { name: 'PARAMETERKEY', label: 'Key', cell: 'string', editable: false }, { name: 'PARAMETERVALUE', label: 'Value', cell: 'string', editable: false }, ] var ptable = new TableView({ collection: this.params, - columns: columns, + columns: pcolumns, loading: false, pages: false, backgrid: { emptyText: 'No parameters found' }, @@ -68,14 +68,14 @@ define(['marionette', this.$el.html(ptable.render().$el) - var columns = [ + var scolumns = [ { label: 'Files', cell: table.TemplateCell, editable: false, template: '<%-IMAGEDIRECTORY%><%-IMAGEPREFIX%>_<%-DATACOLLECTIONNUMBER%>' }, { label: 'Image #', cell: table.TemplateCell, editable: false, template: '<%-STARTIMAGE%> - <%-ENDIMAGE%>' }, ] var stable = new TableView({ collection: this.sweeps, - columns: columns, + columns: scolumns, loading: false, pages: false, backgrid: { emptyText: 'No image sweeps found' }, diff --git a/client/src/js/modules/dc/views/samplechanger.js b/client/src/js/modules/dc/views/samplechanger.js index a76a7c267..2ab1e9fd3 100644 --- a/client/src/js/modules/dc/views/samplechanger.js +++ b/client/src/js/modules/dc/views/samplechanger.js @@ -162,11 +162,11 @@ define(['marionette', 'utils/canvas', 'utils', // Draw Grid this.ctx.clearRect(0, 0, this.canvas.width, this.canvas.height) //this.ctx.drawImage(this.numbers, 0, 0, this.canvas.width, this.canvas.height) - for (var j = 0; j < this.sc; j++) { + for (var n = 0; n < this.sc; n++) { this.ctx.fillStyle = '#000' this.ctx.font = "11px Arial" this.ctx.lineWidth = 1 - this.ctx.fillText(j+1,10,this.sh*j+this.tpad+4); + this.ctx.fillText(n+1,10,this.sh*n+this.tpad+4); } for (var i = 0; i < this.positions; i++) { diff --git a/client/src/js/modules/dc/views/summary.js b/client/src/js/modules/dc/views/summary.js index bf7116830..670ad84b4 100644 --- a/client/src/js/modules/dc/views/summary.js +++ b/client/src/js/modules/dc/views/summary.js @@ -125,7 +125,7 @@ define(['marionette', { label: 'Resolution', cell: APCell, template: '<%-SHELLS.overall.RLOW%> - <%-SHELLS.overall.RHIGH%>
<%-SHELLS.innerShell.RLOW%> - <%-SHELLS.innerShell.RHIGH%>
<%-SHELLS.outerShell.RLOW%> - <%-SHELLS.outerShell.RHIGH%>', editable: false }, { label: 'Rmeas', cell: APCell, template: '<%-SHELLS.overall.RMEAS%>
<%-SHELLS.innerShell.RMEAS%>
<%-SHELLS.outerShell.RMEAS%>', editable: false }, { label: 'Completeness', cell: APCell, template: '<%-SHELLS.overall.COMPLETENESS%>
<%-SHELLS.innerShell.COMPLETENESS%>
<%-SHELLS.outerShell.COMPLETENESS%>', editable: false }, - { label: '', cell: APCell, template: ' Download MTZ file', editable: false }, + { label: '', cell: APCell, template: ' Download autoprocessing archive', editable: false }, ] diff --git a/client/src/js/modules/fault/models/component.js b/client/src/js/modules/fault/models/component.js index 7f4a66ab7..54b26121d 100644 --- a/client/src/js/modules/fault/models/component.js +++ b/client/src/js/modules/fault/models/component.js @@ -8,15 +8,15 @@ define(['backbone'], function(Backbone) { }, initialize: function(options) { this.on('change', this._add_id, this) - this._add_id() + this._add_id() }, urlRoot: '/fault/com', idAttribute: 'COMPONENTID', _add_id: function() { - this.attributes.ID = this.get('COMPONENTID') + this.set('ID', this.get('COMPONENTID')) }, }) -}) \ No newline at end of file +}) diff --git a/client/src/js/modules/fault/models/fault.js b/client/src/js/modules/fault/models/fault.js index 9d9c94d1d..acf9dfd05 100644 --- a/client/src/js/modules/fault/models/fault.js +++ b/client/src/js/modules/fault/models/fault.js @@ -22,11 +22,11 @@ define(['backbone', 'markdown', 'models/wfile'], function(Backbone, markdown, Fi }, refreshOptions: function() { - this.attributes.RESOLVEDTEXT = this.resolvedOptions[this.get('RESOLVED')] - this.attributes.BEAMTIMELOSTTEXT = this.btlOptions[this.get('BEAMTIMELOST')] + this.set('RESOLVEDTEXT', this.resolvedOptions[this.get('RESOLVED')]) + this.set('BEAMTIMELOSTTEXT', this.btlOptions[this.get('BEAMTIMELOST')]) - if (this.get('DESCRIPTION')) this.attributes.DESCRIPTIONMD = markdown.toHTML(this.get('DESCRIPTION')) - if (this.get('RESOLUTION')) this.attributes.RESOLUTIONMD = markdown.toHTML(this.get('RESOLUTION')) + if (this.get('DESCRIPTION')) this.set('DESCRIPTIONMD', markdown.toHTML(this.get('DESCRIPTION'))) + if (this.get('RESOLUTION')) this.set('RESOLUTIONMD', markdown.toHTML(this.get('RESOLUTION'))) }, validation: { diff --git a/client/src/js/modules/fault/models/subcomponent.js b/client/src/js/modules/fault/models/subcomponent.js index f96e950af..1c6856212 100644 --- a/client/src/js/modules/fault/models/subcomponent.js +++ b/client/src/js/modules/fault/models/subcomponent.js @@ -8,12 +8,12 @@ define(['backbone'], function(Backbone) { }, initialize: function(options) { this.on('change', this._add_id, this) - this._add_id() + this._add_id() }, urlRoot: '/fault/scom', idAttribute: 'SUBCOMPONENTID', _add_id: function() { - this.attributes.ID = this.get('SUBCOMPONENTID') + this.set('ID', this.get('SUBCOMPONENTID')) }, }) -}) \ No newline at end of file +}) diff --git a/client/src/js/modules/fault/models/system.js b/client/src/js/modules/fault/models/system.js index bd4f02f6c..5a59cd5be 100644 --- a/client/src/js/modules/fault/models/system.js +++ b/client/src/js/modules/fault/models/system.js @@ -13,8 +13,8 @@ define(['backbone'], function(Backbone) { urlRoot: '/fault/sys', idAttribute: 'SYSTEMID', _add_id: function() { - this.attributes.ID = this.get('SYSTEMID') + this.set('ID', this.get('SYSTEMID')) }, }) -}) \ No newline at end of file +}) diff --git a/client/src/js/modules/imaging/views/queuecontainer.js b/client/src/js/modules/imaging/views/queuecontainer.js index 9de3e613f..49c2dd2ef 100644 --- a/client/src/js/modules/imaging/views/queuecontainer.js +++ b/client/src/js/modules/imaging/views/queuecontainer.js @@ -692,10 +692,11 @@ define(['marionette', }, applyModel: function(modelParameter, isLimitedToSelected) { + var models = null if (isLimitedToSelected) { - var models = this.qsubsamples.where({ isGridSelected: true }) + models = this.qsubsamples.where({ isGridSelected: true }) } else { - var models = this.qsubsamples.fullCollection.toArray() + models = this.qsubsamples.fullCollection.toArray() } _.each(models, function(model) { if (modelParameter.get('EXPERIMENTKIND') !== model.get('EXPERIMENTKIND')) return @@ -773,7 +774,7 @@ define(['marionette', }, refreshSubSamples: function() { - this.subsamples.fetch() + this.subsamples.fetch().done(this.onSubsamplesReady.bind(this)) }, initialize: function() { diff --git a/client/src/js/modules/samples/views/pdbs.js b/client/src/js/modules/samples/views/pdbs.js index 28708ce93..bbbd52b22 100644 --- a/client/src/js/modules/samples/views/pdbs.js +++ b/client/src/js/modules/samples/views/pdbs.js @@ -1,15 +1,28 @@ -define(['marionette'], function(Marionette) { +define(['marionette', 'utils'], function(Marionette, utils) { var UserItem = Marionette.ItemView.extend({ - template: _.template('<%-NAME%> <% if (CODE) { %>[CODE]<% } else { %>[File]<% } %> Delete'), + template: _.template(''), tagName: 'li', attributes: { 'data-testid': 'protein-pdb-list-item' }, events: { - 'click a.delete': 'deleteUser', + 'click a.delete': 'deletePDB', + 'click a.download': utils.signHandler, }, - deleteUser: function(e) { + render: function() { + UserItem.__super__.render.call(this) + const linkButton = ' EBI' + const deleteButton = ' Delete' + const downloadButton = ' Download' + if (this.model.get('CODE')) { + this.$el.append(this.model.get('NAME')+' [Code] '+linkButton+' '+deleteButton+'') + } else { + this.$el.append(this.model.get('NAME')+' [File] '+downloadButton+' '+deleteButton+'') + } + }, + + deletePDB: function(e) { this.model.destroy() }, }) @@ -30,4 +43,4 @@ define(['marionette'], function(Marionette) { }) -}) \ No newline at end of file +}) diff --git a/client/src/js/modules/shipment/models/containerreport.js b/client/src/js/modules/shipment/models/containerreport.js index 29d7c8085..33cf734f3 100644 --- a/client/src/js/modules/shipment/models/containerreport.js +++ b/client/src/js/modules/shipment/models/containerreport.js @@ -14,7 +14,7 @@ define(['backbone', 'markdown', 'models/wfile'], function(Backbone, markdown, Fi }, refreshOptions: function() { - if (this.get('REPORT')) this.attributes.REPORTMD = markdown.toHTML(this.get('REPORT')) + if (this.get('REPORT')) this.set('REPORTMD', markdown.toHTML(this.get('REPORT'))) }, validation: { diff --git a/client/src/js/modules/shipment/models/dewarreport.js b/client/src/js/modules/shipment/models/dewarreport.js index b167c0c6d..6ace09e45 100644 --- a/client/src/js/modules/shipment/models/dewarreport.js +++ b/client/src/js/modules/shipment/models/dewarreport.js @@ -14,7 +14,7 @@ define(['backbone', 'markdown', 'models/wfile'], function(Backbone, markdown, Fi }, refreshOptions: function() { - if (this.get('REPORT')) this.attributes.REPORTMD = markdown.toHTML(this.get('REPORT')) + if (this.get('REPORT')) this.set('REPORTMD', markdown.toHTML(this.get('REPORT'))) }, validation: { @@ -37,4 +37,4 @@ define(['backbone', 'markdown', 'models/wfile'], function(Backbone, markdown, Fi } } }, File)) -}) \ No newline at end of file +}) diff --git a/client/src/js/modules/shipment/views/containerregistry.js b/client/src/js/modules/shipment/views/containerregistry.js index 4bfc20f89..e350702c7 100644 --- a/client/src/js/modules/shipment/views/containerregistry.js +++ b/client/src/js/modules/shipment/views/containerregistry.js @@ -116,7 +116,7 @@ define(['marionette', this.listenTo(this.proposals, 'backgrid:selected', this.selectModel, this) this.proposals.fetch() - var columns = [ + var columns2 = [ { label: '', cell: 'select-row', headerCell: 'select-all', editable: false }, { name: 'PROPOSALCODE', label: 'Code', cell: 'string', editable: false }, { name: 'PROPOSALNUMBER', label: 'Number', cell: 'string', editable: false }, @@ -126,7 +126,7 @@ define(['marionette', this.table2 = new TableView({ collection: this.proposals, - columns: columns, tableClass: 'proposals', filter: 's', search: options.params.s, loading: true, noPageUrl: true, noSearchUrl: true, + columns: columns2, tableClass: 'proposals', filter: 's', search: options.params.s, loading: true, noPageUrl: true, noSearchUrl: true, backgrid: { emptyText: 'No proposals found' } }) @@ -175,4 +175,4 @@ define(['marionette', } }) -}) \ No newline at end of file +}) diff --git a/client/src/js/modules/shipment/views/manifest.js b/client/src/js/modules/shipment/views/manifest.js index ff40fd8db..748df41bc 100644 --- a/client/src/js/modules/shipment/views/manifest.js +++ b/client/src/js/modules/shipment/views/manifest.js @@ -57,14 +57,14 @@ define(['marionette', var d = new Date() _.each([d.getFullYear(), d.getFullYear()-1], function(y) { _.each(_.range(1,13), function(m) { - var m = (m < 10 ? ('0'+m) : m)+'-'+y + m = (m < 10 ? ('0'+m) : m)+'-'+y this.ui.month.append('') }, this) }, this) - var m = d.getMonth() +1 - var cur = (m < 10 ? ('0'+m) : m)+'-'+d.getFullYear() + var mon = d.getMonth() +1 + var cur = (mon < 10 ? ('0'+mon) : mon)+'-'+d.getFullYear() this.ui.month.val(cur) var columns = [ @@ -95,4 +95,4 @@ define(['marionette', }) -}) \ No newline at end of file +}) diff --git a/client/src/js/modules/shipment/views/migrate.js b/client/src/js/modules/shipment/views/migrate.js index a2fda3305..4710668e0 100644 --- a/client/src/js/modules/shipment/views/migrate.js +++ b/client/src/js/modules/shipment/views/migrate.js @@ -232,20 +232,20 @@ define(['marionette', var validOnly = app.options.get('valid_components') - if (!validOnly) { - this.rprots.show(new TableView({ + if (!validOnly) { + this.rprots.show(new TableView({ collection: this.proteins, - columns: columns, + columns: columns, tableClass: 'proteins', filter: 's', loading: true, noSearchUrl: false, backgrid: { emptyText: 'No proteins found' } - })) + })) } - var columns = [ + var columns2 = [ { label: '', cell: 'select-row', headerCell: 'select-all', editable: false }, { name: 'CARDNAME', label: 'Card Name', cell: 'string', editable: false }, { name: 'GIVENNAME', label: 'First Name', cell: 'string', editable: false }, @@ -260,7 +260,7 @@ define(['marionette', this.rconts.show(new TableView({ collection: this.contacts, - columns: columns, + columns: columns2, tableClass: 'labcontacts', filter: 's', loading: true, diff --git a/client/src/js/modules/shipment/views/plate.js b/client/src/js/modules/shipment/views/plate.js index f0bb321f5..b29f44f2f 100644 --- a/client/src/js/modules/shipment/views/plate.js +++ b/client/src/js/modules/shipment/views/plate.js @@ -192,9 +192,9 @@ define(['marionette', 'backbone', 'utils', 'backbone-validation'], function(Mari var sampleid = i*this.pt.dropTotal()+did+1 var sample = this.collection.findWhere({ LOCATION: sampleid.toString() }) + var im = null - if (sample && (this.showImageStatus || this.showMaxScore) && this.inspectionimages) var im = this.inspectionimages.findWhere({ BLSAMPLEID: sample.get('BLSAMPLEID') }) - else var im = null + if (sample && (this.showImageStatus || this.showMaxScore) && this.inspectionimages) im = this.inspectionimages.findWhere({ BLSAMPLEID: sample.get('BLSAMPLEID') }) this.ctx.beginPath() this.ctx.lineWidth = 1; @@ -273,10 +273,12 @@ define(['marionette', 'backbone', 'utils', 'backbone-validation'], function(Mari } } + var isc = null + // Show image score if (sample && this.showImageStatus) { if (im) { - var isc = im.get('SCORECOLOUR') + isc = im.get('SCORECOLOUR') if (isc){ this.ctx.fillStyle = isc this.ctx.fill() @@ -287,7 +289,7 @@ define(['marionette', 'backbone', 'utils', 'backbone-validation'], function(Mari // Show max image score if (sample && this.showMaxScore) { if (im) { - var isc = im.get('MAXSCORECOLOUR') + isc = im.get('MAXSCORECOLOUR') if (isc){ this.ctx.fillStyle = isc this.ctx.fill() diff --git a/client/src/js/modules/shipment/views/regdewar.js b/client/src/js/modules/shipment/views/regdewar.js index 76252e088..69a2e053c 100644 --- a/client/src/js/modules/shipment/views/regdewar.js +++ b/client/src/js/modules/shipment/views/regdewar.js @@ -99,7 +99,7 @@ define(['marionette', this.dewars.queryParams.all = 1 this.dewars.fetch().done(this.getHistory.bind(this)) - var columns = [ + var columns2 = [ { name: 'CODE', label: 'Name', cell: 'string', editable: false }, { label: 'Shipment', cell: table.TemplateCell, editable: false, template: '<%-SHIPPINGNAME%>' }, { name: 'EXP', label: 'First Exp', cell: 'string', editable: false }, @@ -113,12 +113,12 @@ define(['marionette', if (app.mobile()) { _.each([0,1,3,6,7], function(v) { - columns[v].renderable = false + columns2[v].renderable = false }) } this.dewtable = new TableView({ collection: this.dewars, - columns: columns, tableClass: 'dewars', loading: true, + columns: columns2, tableClass: 'dewars', loading: true, backgrid: { emptyText: 'No dewars found' } }) @@ -126,14 +126,14 @@ define(['marionette', this.listenTo(this.reports, 'sync', this.setupPopups, this) this.reports.fetch() - var columns = [ + var columns3 = [ { name: 'BLTIMESTAMP', label: 'Time / Date', cell: 'string', editable: false }, { name: 'REPORT', label: 'Report', cell: 'string', editable: false }, { label: 'Image', cell: ImageCell, editable: false }, ] this.reptable = new TableView({ collection: this.reports, - columns: columns, tableClass: 'samples', loading: true, + columns: columns3, tableClass: 'samples', loading: true, backgrid: { emptyText: 'No reports found' } }) @@ -141,7 +141,7 @@ define(['marionette', this.proposals.queryParams.DEWARREGISTRYID = this.model.get('DEWARREGISTRYID') this.proposals.fetch() - var columns = [ + var columns4 = [ { name: 'PROPOSAL', label: 'Proposal', cell: 'string', editable: false }, { name: 'GIVENNAME', label: 'Given Name', cell: 'string', editable: false }, { name: 'FAMILYNAME', label: 'Family Name', cell: 'string', editable: false }, @@ -150,12 +150,12 @@ define(['marionette', ] if (app.staff) { - columns.push({ name: '', label: '', cell: DeleteCell, editable: false }) + columns4.push({ name: '', label: '', cell: DeleteCell, editable: false }) } this.proptable = new TableView({ collection: this.proposals, - columns: columns, + columns: columns4, }) }, diff --git a/client/src/js/modules/shipment/views/registeredcontainer.js b/client/src/js/modules/shipment/views/registeredcontainer.js index c8779c2d2..3d30a56bb 100644 --- a/client/src/js/modules/shipment/views/registeredcontainer.js +++ b/client/src/js/modules/shipment/views/registeredcontainer.js @@ -175,7 +175,7 @@ define(['marionette', this.containers.queryParams.all = 1 this.containers.fetch().done(this.getHistory.bind(this)) - var columns = [ + var columns2 = [ // { label: 'Name', cell: table.TemplateCell, editable: false, template: '<%-NAME%>' }, { name: 'NAME', label: 'Name', cell: 'string', editable: false }, { name: 'BLTIMESTAMP', label: 'Created', cell: 'string', editable: false }, @@ -189,12 +189,12 @@ define(['marionette', if (app.mobile()) { _.each([4,6], function(v) { - columns[v].renderable = false + columns2[v].renderable = false }) } this.conttable = new TableView({ collection: this.containers, - columns: columns, tableClass: 'containers', loading: true, + columns: columns2, tableClass: 'containers', loading: true, backgrid: { row: ClickableRow, emptyText: 'No containers found' } }) @@ -202,7 +202,7 @@ define(['marionette', this.listenTo(this.reports, 'sync', this.setupPopups, this) this.reports.fetch() - var columns = [ + var columns3 = [ { name: 'RECORDTIMESTAMP', label: 'Time / Date', cell: 'string', editable: false }, { name: 'REPORTER', label: 'Reporter', cell: 'string', editable: false }, { name: 'REPORT', label: 'Report', cell: 'string', editable: false }, @@ -210,7 +210,7 @@ define(['marionette', ] this.reptable = new TableView({ collection: this.reports, - columns: columns, tableClass: 'reports', loading: true, + columns: columns3, tableClass: 'reports', loading: true, backgrid: { emptyText: 'No reports found' } }) @@ -248,4 +248,4 @@ define(['marionette', }) -}) \ No newline at end of file +}) diff --git a/client/src/js/modules/summary/views/summary.vue b/client/src/js/modules/summary/views/summary.vue index e57f83fed..9eb3ebcae 100644 --- a/client/src/js/modules/summary/views/summary.vue +++ b/client/src/js/modules/summary/views/summary.vue @@ -397,8 +397,8 @@

- +

--> diff --git a/client/src/js/modules/types/xpdf/views/plan.js b/client/src/js/modules/types/xpdf/views/plan.js index b5e6c9819..9fb017219 100644 --- a/client/src/js/modules/types/xpdf/views/plan.js +++ b/client/src/js/modules/types/xpdf/views/plan.js @@ -558,7 +558,7 @@ define(['marionette', this.asmps.show(this.table) - var columns = [ + var columns2 = [ { label: '', cell: CollapseExpandCell, editable: false, template: '' }, { label: '#', cell: table.TemplateCell, editable: false, template: '<%-parseInt(PLANORDER)+1%>' }, { label: 'Instance', cell: table.TemplateCell, editable: false, template: '<%-SAMPLE%>' }, @@ -570,7 +570,7 @@ define(['marionette', this.table2 = new SortableTableView({ collection: this.datacollectionplans, - columns: columns, + columns: columns2, tableClass: 'subsamples', loading: true, // Below overrides the SortableRow in the SortableTableView which breaks drag and drop events diff --git a/client/src/js/templates/dc/dc.html b/client/src/js/templates/dc/dc.html index 4237f4515..b23bb657a 100644 --- a/client/src/js/templates/dc/dc.html +++ b/client/src/js/templates/dc/dc.html @@ -24,7 +24,7 @@

<% if (SI != 1 ) { %>
  • First Image: <%-SI%>
  • <% } %> <% if ((KAPPA && KAPPA !=0) || (PHI && PHI != 0) || (CHISTART && CHISTART !=0)) { %>
  • <% if (KAPPA != null) { %>κ: <%-KAPPA%>°<% } %> <% if (PHI != null) { %>φ: <%-PHI%>°<% } %> <% if (CHISTART != null) { %>χ: <%-CHISTART%>°<% } %>
  • <% } %>
  • Resolution: <%-RESOLUTION%>Å
  • -
  • Wavelength: <%-WAVELENGTH%>Å
  • +
  • Wavelength: <%-WAVELENGTH%>Å (<%-ENERGY%>eV)
  • Exposure: <%-EXPOSURETIME%>s
  • <%if (DCC > 1 && TOTALDOSE) { %>
  • Total Dose: <%-TOTALDOSE%>MGy
  • diff --git a/client/src/js/templates/dc/edge.html b/client/src/js/templates/dc/edge.html index 1349e0ba5..4e2697a12 100644 --- a/client/src/js/templates/dc/edge.html +++ b/client/src/js/templates/dc/edge.html @@ -9,11 +9,11 @@

      -
    • Scan File: <%-FILETEMPLATE%>
    • -
    • E(Peak): <%-EPK.toFixed(1) %>eV (<% print ((12398.4193/EPK).toFixed(4)) %>Å)
    • -
    • f’’: <%-NUMIMG%> / f’: <%-RESOLUTION%>e
    • -
    • E(Inf): <%-EIN.toFixed(1) %>eV (<% print((12398.4193/EIN).toFixed(4)) %>Å)
    • -
    • f’’: <%-WAVELENGTH%> / f’: <%-AXISRANGE%>e
    • +
    • Scan File: <%-FILETEMPLATE%>
    • +
    • E(Peak): <%-EPK%>eV (<%-WPK%>Å)
    • +
    • f’’: <%-NUMIMG%>e- / f’: <%-RESOLUTION%>e-
    • +
    • E(Inf): <%-EIN%>eV (<%-WIN%>Å)
    • +
    • f’’: <%-WAVELENGTH%>e- / f’: <%-AXISRANGE%>e-
    • Exposure: <%-EXPOSURETIME%>s
    • Transmission: <%-TRANSMISSION%>%
    • Beamsize: <%-BSX%>x<%-BSY%>μm
    • diff --git a/client/src/js/templates/dc/grid.html b/client/src/js/templates/dc/grid.html index 4232c7392..996258409 100644 --- a/client/src/js/templates/dc/grid.html +++ b/client/src/js/templates/dc/grid.html @@ -8,7 +8,7 @@

    • &<%-ROTATIONAXIS%>; Start: <%-AXISSTART%>°
    • <% if ((KAPPA && KAPPA !=0) || (PHI && PHI != 0) || (CHISTART && CHISTART !=0)) { %>
    • <% if (KAPPA != null) { %>κ: <%-KAPPA%>°<% } %> <% if (PHI != null) { %>φ: <%-PHI%>°<% } %> <% if (CHISTART != null) { %>χ: <%-CHISTART%>°<% } %>
    • <% } %>
    • Resolution: <%-RESOLUTION%>Å
    • -
    • Wavelength: <%-WAVELENGTH%>Å
    • +
    • Wavelength: <%-WAVELENGTH%>Å (<%-ENERGY%>eV)
    • Exposure: <%-EXPOSURETIME%>s
    • Transmission: <%-TRANSMISSION%>%
    • Beamsize: <%-BSX%>x<%-BSY%>μm
    • diff --git a/client/src/js/templates/dc/mca.html b/client/src/js/templates/dc/mca.html index 69da71439..9bea88fde 100644 --- a/client/src/js/templates/dc/mca.html +++ b/client/src/js/templates/dc/mca.html @@ -10,11 +10,11 @@

        -
      • Energy: <%-WAVELENGTH%>eV
      • +
      • Energy: <%-ENERGY%>eV (<%-WAVELENGTH%>Å)
      • Exposure: <%-EXPOSURETIME%>s
      • Transmission: <%-TRANSMISSION%>%
      • Beamsize: <%-BSX%>x<%-BSY%>μm
      • Axis Position: <%-AXISSTART%>°
      • Comment: <%-COMMENTS%>
      - \ No newline at end of file + diff --git a/client/src/js/tpl.js b/client/src/js/tpl.js index 593984020..cbca02479 100644 --- a/client/src/js/tpl.js +++ b/client/src/js/tpl.js @@ -92,7 +92,7 @@ source + '}'; return template; - }; + } define(function () { diff --git a/client/src/js/utils/editable.js b/client/src/js/utils/editable.js index 622779b54..a33d32027 100644 --- a/client/src/js/utils/editable.js +++ b/client/src/js/utils/editable.js @@ -175,7 +175,9 @@ define(['marionette', if (xhr.responseText) { try { json = $.parseJSON(xhr.responseText) - } catch(err) {} + } catch(err) { + console.log('Error parsing JSON') + } } if (json.message) app.alert({ message: json.message }) else app.alert({ message: 'Something went wrong' }) diff --git a/client/src/js/utils/xhrimage.js b/client/src/js/utils/xhrimage.js index 532c28363..63ca0244d 100644 --- a/client/src/js/utils/xhrimage.js +++ b/client/src/js/utils/xhrimage.js @@ -38,7 +38,7 @@ define(['marionette'], function() { } var h = xhr.getAllResponseHeaders() - var m = h.match(/^Content-Type\:\s*(.*?)$/mi) + var m = h.match(/^Content-Type:\s*(.*?)$/mi) var mimeType = m[1] || 'image/png'; var blob = new Blob([this.response], { type: mimeType }) @@ -80,4 +80,4 @@ define(['marionette'], function() { return XHRImage -}) \ No newline at end of file +}) diff --git a/client/src/js/views/log.js b/client/src/js/views/log.js index 258637569..a553e6a9f 100644 --- a/client/src/js/views/log.js +++ b/client/src/js/views/log.js @@ -47,7 +47,7 @@ define(['marionette', 'views/dialog'], function(Marionette, DialogView) { } var h = xhr.getAllResponseHeaders() - var m = h.match(/^Content-Type\:\s*(.*?)$/mi) + var m = h.match(/^Content-Type:\s*(.*?)$/mi) var mimeType = m[1] || 'image/png' if (mimeType == 'application/pdf' || mimeType == 'image/png') {