time.rb 1.2 KB
Newer Older
1 2
# frozen_string_literal: true

3
module ActiveModel
4 5
  module Type
    class Time < Value # :nodoc:
6
      include Helpers::TimeValue
7
      include Helpers::AcceptsMultiparameterTime.new(
8
        defaults: { 1 => 2000, 2 => 1, 3 => 1, 4 => 0, 5 => 0 }
9
      )
10 11 12 13 14

      def type
        :time
      end

15 16 17 18 19 20
      def user_input_in_time_zone(value)
        return unless value.present?

        case value
        when ::String
          value = "2000-01-01 #{value}"
21 22
          time_hash = ::Date._parse(value)
          return if time_hash[:hour].nil?
23 24 25 26 27 28 29
        when ::Time
          value = value.change(year: 2000, day: 1, month: 1)
        end

        super(value)
      end

30 31
      private

32
        def cast_value(value)
33
          return apply_seconds_precision(value) unless value.is_a?(::String)
34 35
          return if value.empty?

36
          dummy_time_value = value.sub(/\A(\d\d\d\d-\d\d-\d\d |)/, "2000-01-01 ")
37 38 39 40 41 42

          fast_string_to_time(dummy_time_value) || begin
            time_hash = ::Date._parse(dummy_time_value)
            return if time_hash[:hour].nil?
            new_time(*time_hash.values_at(:year, :mon, :mday, :hour, :min, :sec, :sec_fraction, :offset))
          end
43
        end
44 45 46
    end
  end
end