metamaps--metamaps/app/models/topic.rb

132 lines
3.5 KiB
Ruby
Raw Normal View History

2016-09-24 03:00:46 +00:00
# frozen_string_literal: true
class Topic < ApplicationRecord
2016-02-03 13:38:41 +00:00
include TopicsHelper
belongs_to :user
belongs_to :defer_to_map, class_name: 'Map', foreign_key: 'defer_to_map_id'
2016-02-03 13:38:41 +00:00
has_many :synapses1, class_name: 'Synapse', foreign_key: 'node1_id', dependent: :destroy
has_many :synapses2, class_name: 'Synapse', foreign_key: 'node2_id', dependent: :destroy
has_many :topics1, through: :synapses2, source: :topic1
has_many :topics2, through: :synapses1, source: :topic2
2016-02-03 13:38:41 +00:00
has_many :mappings, as: :mappable, dependent: :destroy
has_many :maps, through: :mappings
2016-02-03 13:38:41 +00:00
belongs_to :metacode
2016-02-03 13:38:41 +00:00
validates :permission, presence: true
validates :permission, inclusion: { in: Perm::ISSIONS.map(&:to_s) }
2016-02-03 13:38:41 +00:00
# This method associates the attribute ":image" with a file attachment
has_attached_file :image
# , styles: {
2016-02-03 13:38:41 +00:00
# thumb: '100x100>',
# square: '200x200#',
# medium: '300x300>'
# }
2016-02-03 13:38:41 +00:00
# Validate the attached image is image/jpg, image/png, etc
validates_attachment_content_type :image, content_type: /\Aimage\/.*\Z/
2016-02-03 13:38:41 +00:00
# This method associates the attribute ":image" with a file attachment
has_attached_file :audio
# Validate the attached audio is audio/wav, audio/mp3, etc
validates_attachment_content_type :audio, content_type: /\Aaudio\/.*\Z/
2016-02-03 13:38:41 +00:00
def synapses
synapses1 + synapses2
2016-02-03 13:38:41 +00:00
end
2016-02-03 13:38:41 +00:00
def relatives
topics1 + topics2
2016-02-03 13:38:41 +00:00
end
scope :relatives, ->(topic_id = nil, user = nil) {
2016-09-05 03:55:19 +00:00
# should only see topics through *visible* synapses
# e.g. Topic A (commons) -> synapse (private) -> Topic B (commons) must be filtered out
synapses = Pundit.policy_scope(user, Synapse.where(node1_id: topic_id)).pluck(:node2_id)
synapses += Pundit.policy_scope(user, Synapse.where(node2_id: topic_id)).pluck(:node1_id)
where(id: synapses.uniq)
}
delegate :name, to: :user, prefix: true
2016-02-03 13:38:41 +00:00
def user_image
user.image.url
end
def map_count
maps.count
end
def synapse_count
synapses.count
end
def inmaps
maps.map(&:name)
end
def inmapsLinks
maps.map(&:id)
end
def calculated_permission
2016-09-24 04:59:42 +00:00
defer_to_map&.permission || permission
end
def as_json(_options = {})
super(methods: [:user_name, :user_image, :map_count, :synapse_count, :inmaps, :inmapsLinks, :calculated_permission, :collaborator_ids])
end
def collaborator_ids
if defer_to_map
defer_to_map.editors.select { |mapper| mapper != user }.map(&:id)
else
[]
end
2016-02-03 13:38:41 +00:00
end
# TODO: move to a decorator?
def synapses_csv(output_format = 'array')
output = []
synapses.each do |synapse|
if synapse.category == 'from-to'
if synapse.node1_id == id
output << synapse.node1_id.to_s + '->' + synapse.node2_id.to_s
elsif synapse.node2_id == id
output << synapse.node2_id.to_s + '<-' + synapse.node1_id.to_s
else
raise 'invalid synapse on topic in synapse_csv'
end
elsif synapse.category == 'both'
if synapse.node1_id == id
output << synapse.node1_id.to_s + '<->' + synapse.node2_id.to_s
elsif synapse.node2_id == id
output << synapse.node2_id.to_s + '<->' + synapse.node1_id.to_s
else
raise 'invalid synapse on topic in synapse_csv'
end
end
end
if output_format == 'array'
return output
elsif output_format == 'text'
return output.join('; ')
else
raise 'invalid argument to synapses_csv'
end
output
end
2016-02-03 13:38:41 +00:00
def topic_autocomplete_method
"Get: #{name}"
2016-02-03 13:38:41 +00:00
end
2016-02-03 13:38:41 +00:00
def mk_permission
Perm.short(permission)
end
end