Class: Labware
Overview
Labware represents a physical object which moves around the lab.
It has one or more receptacles.
rubocop:disable Metrics/ClassLength
Defined Under Namespace
Classes: CommentsController
Instance Attribute Summary collapse
Class Method Summary
collapse
Instance Method Summary
collapse
included
included
included, #unsaved_uuid!, #uuid
#after_comment_addition
Methods inherited from Asset
#asset_type_for_request_types, #barcode_number, #compatible_purposes, #contained_samples, #details, #generate_barcode, #get_qc_result_value_for, #has_stock_asset?, #label, #label=, #original_stock_plates, #prefix, #printable?, #printable_target, #register_stock!, #request_types, #type, #update_from_qc
#has_many_events, #has_many_lab_events, #has_one_event_with_family
#event_date, #fluidigm_stamp_date, #gel_qc_date, #pico_date, #qc_started_date, #sequenom_stamp_date
alias_association, convert_labware_to_receptacle_for, find_by_id_or_name, find_by_id_or_name!
Methods included from Squishify
extended
Instance Attribute Details
#storage_location_service ⇒ Object
Returns the value of attribute storage_location_service.
12
13
14
|
# File 'app/models/labware.rb', line 12
def storage_location_service
@storage_location_service
end
|
Class Method Details
.find_by_barcode(source_barcode) ⇒ Object
Also known as:
find_from_barcode
322
323
324
|
# File 'app/models/labware.rb', line 322
def find_by_barcode(source_barcode)
with_barcode(source_barcode).first
end
|
.find_from_any_barcode(source_barcode) ⇒ Object
311
312
313
314
315
316
317
318
319
320
|
# File 'app/models/labware.rb', line 311
def find_from_any_barcode(source_barcode)
if source_barcode.blank?
nil
elsif /\A[0-9]{1,7}\z/.match?(source_barcode)
joins(:barcodes).order(:id).find_by('barcodes.barcode LIKE "__?_"', source_barcode)
else
find_by_barcode(source_barcode)
end
end
|
.labwhere_locations(labware_barcodes) ⇒ Object
Bulk retrieves locations for multiple labwares at once
Returns hash { labware barcode => location string, .. } e.g. { 'DN1234' => 'Sanger - Room 1 - Shelf 2' }
Hash has blank values where location was not found for a particular barcode
Or raises LabWhereClient::LabwhereException if Labwhere response is unexpected
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
|
# File 'app/models/labware.rb', line 292
def labwhere_locations(labware_barcodes) info_from_labwhere = LabWhereClient::LabwareSearch.find_locations_by_barcodes(labware_barcodes)
if info_from_labwhere.blank?
raise LabWhereClient::LabwhereException, 'Labwhere service did not return information'
end
barcodes_to_parentage =
info_from_labwhere.labwares.each_with_object({}) { |info, obj| obj[info.barcode] = info.location.location_info }
unless labware_barcodes.count == barcodes_to_parentage.count
labware_barcodes.each do |barcode|
barcodes_to_parentage[barcode] ||= ''
end
end
barcodes_to_parentage
end
|
.search_for_count_of_labware(params) ⇒ Object
167
168
169
170
171
172
173
174
175
|
# File 'app/models/labware.rb', line 167
def self.search_for_count_of_labware(params)
(params[:faculty_sponsor_ids] || nil)
.with_study_id(params[:study_id] || nil)
.with_plate_purpose_ids(params[:plate_purpose_ids] || nil)
.created_between(params[:start_date], params[:end_date])
.filter_by_barcode(params[:barcodes] || nil)
.distinct
.count
end
|
.search_for_labware(params) ⇒ Object
158
159
160
161
162
163
164
165
|
# File 'app/models/labware.rb', line 158
def self.search_for_labware(params)
(params[:faculty_sponsor_ids] || nil)
.with_study_id(params[:study_id] || nil)
.with_plate_purpose_ids(params[:plate_purpose_ids] || nil)
.created_between(params[:start_date], params[:end_date])
.filter_by_barcode(params[:barcodes] || nil)
.distinct
end
|
Instance Method Details
#ancestor_of_purpose(ancestor_purpose_id) ⇒ Object
214
215
216
217
218
|
# File 'app/models/labware.rb', line 214
def ancestor_of_purpose(ancestor_purpose_id)
return self if plate_purpose_id == ancestor_purpose_id
ancestors.order(id: :desc).find_by(plate_purpose_id: ancestor_purpose_id)
end
|
#ancestors_of_purpose(ancestor_purpose_id) ⇒ Object
220
221
222
223
224
|
# File 'app/models/labware.rb', line 220
def ancestors_of_purpose(ancestor_purpose_id)
return [self] if plate_purpose_id == ancestor_purpose_id
ancestors.order(id: :desc).where(plate_purpose_id: ancestor_purpose_id)
end
|
#child ⇒ Object
332
333
334
|
# File 'app/models/labware.rb', line 332
def child
children.last
end
|
#display_name ⇒ Object
253
254
255
|
# File 'app/models/labware.rb', line 253
def display_name
name.presence || "#{sti_type} #{id}"
end
|
#external_identifier ⇒ Object
210
211
212
|
# File 'app/models/labware.rb', line 210
def external_identifier
"#{sti_type}#{id}"
end
|
#generate_name(new_name) ⇒ Object
Note:
Overridden on subclasses to append the asset id to the name
via on_create callbacks
Assigns name
249
250
251
|
# File 'app/models/labware.rb', line 249
def generate_name(new_name)
self.name = new_name
end
|
#labware ⇒ Object
Labware reflects the physical piece of plastic corresponding to an asset
262
263
264
|
# File 'app/models/labware.rb', line 262
def labware
self
end
|
#labwhere_location ⇒ Object
257
258
259
|
# File 'app/models/labware.rb', line 257
def labwhere_location
@labwhere_location ||= lookup_labwhere_location
end
|
#parent ⇒ Object
328
329
330
|
# File 'app/models/labware.rb', line 328
def parent
parents.first
end
|
#received_date ⇒ Object
274
275
276
277
278
279
280
|
# File 'app/models/labware.rb', line 274
def received_date
asset_audits &.where('`key` = ? AND message LIKE ?', 'slf_receive_plates', '%Reception fridge%')
&.order(:created_at)
&.last
&.created_at
end
|
#retention_instructions ⇒ Object
282
283
284
|
# File 'app/models/labware.rb', line 282
def retention_instructions
@retention_instructions ||= obtain_retention_instructions
end
|
#role ⇒ Object
234
235
236
|
# File 'app/models/labware.rb', line 234
def role
(requests_as_source.first || in_progress_requests.first)&.role
end
|
#scanned_in_date ⇒ Object
270
271
272
|
# File 'app/models/labware.rb', line 270
def scanned_in_date
scanned_into_lab_event.try(:content) || ''
end
|
#source_plate ⇒ Object
238
239
240
|
# File 'app/models/labware.rb', line 238
def source_plate
@source_plate ||= purpose&.source_plate(self)
end
|
#source_plates ⇒ Object
242
243
244
|
# File 'app/models/labware.rb', line 242
def source_plates
@source_plates ||= purpose&.source_plates(self)
end
|
#spiked_in_buffer ⇒ Object
Gets the relevant SpikedBuffer tube, if one exists, by using the two associations.
A direct parent SpikedBuffer tube is used if it exists, otherwise the most recent ancestor.
This was necessary to avoid affecting historical data, for which the direct parent should be used,
even though there is another ancestor that was created more recently.
230
231
232
|
# File 'app/models/labware.rb', line 230
def spiked_in_buffer
direct_spiked_in_buffer || most_recent_spiked_in_buffer
end
|
#state ⇒ Object
Provided for API compatibility
206
207
208
|
# File 'app/models/labware.rb', line 206
def state
nil
end
|
#storage_location ⇒ Object
266
267
268
|
# File 'app/models/labware.rb', line 266
def storage_location
@storage_location ||= obtain_storage_location
end
|