Class: SchemaDotOrg::SchemaType

Inherits:
ValidatedObject::Base
  • Object
show all
Defined in:
lib/schema_dot_org.rb

Overview

Abstract base class for all the Schema.org types.

Constant Summary collapse

EXCLUDED_INSTANCE_VARIABLES =
i[@context_for_validation @validation_context @errors].freeze
ROOT_ATTR =
{ "@context" => "https://schema.org" }.freeze
UNQUALIFIED_CLASS_NAME_REGEX =
/([^:]+)$/

Instance Method Summary collapse

Instance Method Details

#_to_json_structObject



85
86
87
# File 'lib/schema_dot_org.rb', line 85

def _to_json_struct
  attrs_and_values
end

#attrsObject



136
137
138
# File 'lib/schema_dot_org.rb', line 136

def attrs
  instance_variables.reject{ |v| EXCLUDED_INSTANCE_VARIABLES.include?(v) }
end

#attrs_and_valuesObject



103
104
105
106
107
108
109
110
111
112
# File 'lib/schema_dot_org.rb', line 103

def attrs_and_values
  attrs.map do |attr|
    # Clean up and andle the `query-input` attribute, which
    # doesn't follow the normal camelCase convention.
    attr_name   = snake_case_to_lower_camel_case(attr.to_s.delete_prefix('@')).sub('queryInput', 'query-input')
    attr_value = instance_variable_get(attr)

    [attr_name, resolve_value(attr_value)]
  end.to_h
end

#is_schema_type?(object) ⇒ Boolean

Returns:

  • (Boolean)


141
142
143
# File 'lib/schema_dot_org.rb', line 141

def is_schema_type?(object)
  object.class.module_parent == SchemaDotOrg
end

#object_to_json_struct(object) ⇒ Object



97
98
99
100
# File 'lib/schema_dot_org.rb', line 97

def object_to_json_struct(object)
  return nil unless object
  object.to_json_struct
end

#rails_production?Boolean

Returns:

  • (Boolean)


146
147
148
# File 'lib/schema_dot_org.rb', line 146

def rails_production?
  defined?(Rails) && Rails.env.production?
end

#resolve_value(value) ⇒ Object



115
116
117
118
119
120
121
122
123
124
125
126
127
128
# File 'lib/schema_dot_org.rb', line 115

def resolve_value(value)
  if value.is_a?(Array)
    value.map { |v| resolve_value(v) }

  elsif value.is_a?(Date)
    value.to_s

  elsif is_schema_type?(value)
    value.to_json_struct

  else
    value
  end
end

#snake_case_to_lower_camel_case(snake_case) ⇒ Object



131
132
133
# File 'lib/schema_dot_org.rb', line 131

def snake_case_to_lower_camel_case(snake_case)
  snake_case.to_s.split('_').map.with_index { |s, i| i.zero? ? s : s.capitalize }.join
end

#to_json(pretty: false, as_root: false) ⇒ Object



67
68
69
70
71
72
73
74
75
# File 'lib/schema_dot_org.rb', line 67

def to_json(pretty: false, as_root: false)
  structure = as_root ? ROOT_ATTR.merge(to_json_struct) : to_json_struct

  if pretty
    JSON.pretty_generate(structure)
  else
    structure.to_json
  end
end

#to_json_ld(pretty: false) ⇒ Object



62
63
64
# File 'lib/schema_dot_org.rb', line 62

def to_json_ld(pretty: false)
  "<script type=\"application/ld+json\">\n" + to_json(pretty: pretty, as_root: true) + "\n</script>"
end

#to_json_structObject

Use the class name to create the “@type” attribute.

Returns:

  • a hash structure representing json.



80
81
82
# File 'lib/schema_dot_org.rb', line 80

def to_json_struct
  { "@type" => un_namespaced_classname }.merge(_to_json_struct.reject { |_, v| v.blank? })
end

#to_sObject



50
51
52
53
54
55
56
57
58
59
# File 'lib/schema_dot_org.rb', line 50

def to_s
  json_string = to_json_ld(pretty: (!rails_production? && !ENV['SCHEMA_DOT_ORG_MINIFIED_JSON']))

  # Mark as safe if we're in Rails
  if json_string.respond_to?(:html_safe)
    json_string.html_safe
  else
    json_string
  end
end

#un_namespaced_classnameObject

Returns the classname without the module namespace.

Returns:

  • the classname without the module namespace.



91
92
93
94
# File 'lib/schema_dot_org.rb', line 91

def un_namespaced_classname
  self.class.name =~ UNQUALIFIED_CLASS_NAME_REGEX
  Regexp.last_match(1)
end