trabajo-afectivo/app/models/overview.rb

116 lines
2.9 KiB
Ruby
Raw Normal View History

2016-10-19 03:11:36 +00:00
# Copyright (C) 2012-2016 Zammad Foundation, http://zammad-foundation.org/
class Overview < ApplicationModel
include ChecksClientNotification
include ChecksLatestChangeObserved
include ChecksConditionValidation
include CanSeed
include Overview::Assets
2017-04-19 19:54:04 +00:00
has_and_belongs_to_many :roles, after_add: :cache_update, after_remove: :cache_update, class_name: 'Role'
has_and_belongs_to_many :users, after_add: :cache_update, after_remove: :cache_update, class_name: 'User'
2012-04-10 14:06:46 +00:00
store :condition
store :order
store :view
validates :name, presence: true
validates :roles, presence: true
before_create :fill_link_on_create, :fill_prio
before_update :fill_link_on_update, :rearrangement
private
def rearrangement
# rearrange only in case of changed prio
return true if !changes['prio']
previous_ordered_ids = self.class.all.order(
prio: :asc,
updated_at: :desc
).pluck(:id)
rearranged_prio = 0
previous_ordered_ids.each do |overview_id|
# don't process currently updated overview
next if id == overview_id
rearranged_prio += 1
# increase rearranged prio by one to avoid a collition
# with the changed prio of current instance
if rearranged_prio == prio
rearranged_prio += 1
end
# don't start rearranging logic for overviews that have already been rearranged
self.class.without_callback(:update, :before, :rearrangement) do
# fetch and update overview only if prio needs to change
overview = self.class.where(
id: overview_id
).where.not(
prio: rearranged_prio
).take
next if overview.blank?
overview.update!(prio: rearranged_prio)
end
end
end
def fill_prio
return true if prio.present?
self.prio = Overview.count + 1
true
end
def fill_link_on_create
self.link = if link.present?
link_name(link)
else
link_name(name)
end
true
end
def fill_link_on_update
return true if !changes['name'] && !changes['link']
self.link = if link.present?
link_name(link)
else
link_name(name)
end
true
end
def link_name(name)
local_link = name.downcase
2017-09-08 08:28:34 +00:00
local_link = local_link.parameterize(separator: '_')
local_link.gsub!(/\s/, '_')
local_link.gsub!(/_+/, '_')
2017-11-23 08:09:44 +00:00
local_link = CGI.escape(local_link)
if local_link.blank?
local_link = id || rand(999)
end
check = true
count = 0
local_lookup_link = local_link
while check
count += 1
exists = Overview.find_by(link: local_lookup_link)
2018-04-12 14:57:37 +00:00
if exists && exists.id != id
local_lookup_link = "#{local_link}_#{count}"
else
check = false
local_link = local_lookup_link
end
end
local_link
end
end