From a73094b4db8935c01bb92fa9c64b783e4f7c5c25 Mon Sep 17 00:00:00 2001 From: Justin Coyne Date: Tue, 6 Feb 2024 11:04:24 -0600 Subject: [PATCH] Add a time type attribute --- app/values/blacklight/types.rb | 14 ++++++++++++++ spec/models/solr_document_spec.rb | 8 ++++++-- 2 files changed, 20 insertions(+), 2 deletions(-) diff --git a/app/values/blacklight/types.rb b/app/values/blacklight/types.rb index 2dedcbd9e8..8ca7234d54 100644 --- a/app/values/blacklight/types.rb +++ b/app/values/blacklight/types.rb @@ -69,6 +69,19 @@ def cast(input) end end + class Time < Value + def cast(input) + value = super + return if value.blank? + + begin + ::Time.parse(value.to_s) # rubocop:disable Rails/TimeZone + rescue ArgumentError + Rails.logger&.info "Unable to parse time: #{value.inspect}" + end + end + end + class Boolean < Value def cast(input) ActiveModel::Type::Boolean.new.cast(super) @@ -110,6 +123,7 @@ def cast(input) register :boolean, Boolean register :string, String register :date, Date + register :time, Time register :array, Array register :json, JsonValue register :html, Html diff --git a/spec/models/solr_document_spec.rb b/spec/models/solr_document_spec.rb index b8176f1596..1d16fbafb6 100644 --- a/spec/models/solr_document_spec.rb +++ b/spec/models/solr_document_spec.rb @@ -49,6 +49,7 @@ attribute :author, :array, 'author_tesim', of: :string attribute :first_author, :select, 'author_tesim', by: :min attribute :date, :date, field: 'date_dtsi' + attribute :time, :time, field: 'date_dtsi' attribute :whatever, :string, default: ->(*) { 'default_value' } end end @@ -56,14 +57,17 @@ doc_class.new(id: '123', title_tesim: ['Good Omens'], author_tesim: ['Neil Gaiman', 'Terry Pratchett'], - date_dtsi: '1990-01-01T00:00:00Z') + date_dtsi: '1990-01-01T17:23:13Z') end it "casts the attributes" do expect(document.title).to eq 'Good Omens' expect(document.author).to eq ['Neil Gaiman', 'Terry Pratchett'] expect(document.first_author).to eq 'Neil Gaiman' - expect(document.date).to eq Date.new(1990) + expect(document.date).to be_a Date + expect(document.date.to_s).to eq '1990-01-01' + expect(document.time).to be_a Time + expect(document.time.to_s).to eq '1990-01-01 17:23:13 UTC' expect(document.whatever).to eq 'default_value' end