Sha256: 68cf061864dc04546dc1b0dca47ed4dffc5d7d7083fefe110aa8ec16d6b3f7e1

Contents?: true

Size: 1.3 KB

Versions: 2

Compression:

Stored size: 1.3 KB

Contents

require 'betterdocs/dsl/representer'
require 'betterdocs/dsl/common'
require 'betterdocs/dsl/naming'
require 'betterdocs/dsl/json_type_mapper'

class Betterdocs::Dsl::Result::Property < Betterdocs::Dsl::Representer
  extend Tins::DSLAccessor
  include Betterdocs::Dsl::Common
  include Betterdocs::Dsl::Naming

  dsl_accessor :represent_with

  dsl_accessor :description, 'TODO'

  dsl_accessor :example, 'TODO'

  dsl_accessor :types do [] end

  def initialize(representer, name, options, &block)
    super
    types Betterdocs::Dsl::JsonTypeMapper.map_types(types)
    if sr = sub_representer?
      sr < Betterdocs::ResultRepresenter or
        raise TypeError, "#{sr.inspect} is not a Betterdocs::Result subclass"
    end
  end

  def sub_representer?
    represent_with
  end

  def actual_property_name
    (options[:as] || name).to_s
  end

  def assign(result, object)
    assign?(object) or return
    result[actual_property_name] = compute_value(object)
  end

  def compute_value(object)
    value = object.__send__(name)
    value.nil? and return
    if represent_with
      represent_with.hashify(value)
    elsif ActiveSupport::TimeWithZone === value
      value.extend Betterdocs::JsonTimeWithZone
    else
      value
    end
  end

  def add_to_collector(collector)
    collector.properties[name] = self
  end
end

Version data entries

2 entries across 2 versions & 1 rubygems

Version Path
betterdocs-0.4.0 lib/betterdocs/dsl/result/property.rb
betterdocs-0.3.0 lib/betterdocs/dsl/result/property.rb