在我的申请表中,我有职位。每个职位都有一个父母和多个子女职位。如何导航树并查找同一代中的所有位置?
目前我有这个:
def org_chart_level
ps = self
level = 10
while ps do
break if ps.reports_to == nil
ps = ps.reports_to
level += 10
end
if self.reports_to
siblings = self.reports_to.responsible_for
else
siblings = [self]
puts siblings
end
"#{level}-#{siblings.index(self) + 1}"
end
这几乎是有效的,因为它可以给我一个位置的级别,它可以告诉我父母的兄弟姐妹,但它无法告诉我这一代中的兄弟姐妹。
每个职位的预期水平。
1.1
-2.1
-3.1
-2.2
-3.2
实际水平:
1.1
-2.1
-3.1
-2.2
-3.1
答案 0 :(得分:0)
我最终在保存之前将位置生成存储在数据库中。
before_save :find_generation
def find_generation
ps = self
i = 0
while ps do
break if ps.reports_to == nil
ps = ps.reports_to
i += 1
end
self.generation = i
end
然后当我需要生成组织结构图级别时:
def org_chart_level
ps = self
level = 10
while ps do
break if ps.reports_to == nil
ps = ps.reports_to
level += 10
end
generation = organization.positions.where(generation: self.generation) #position belongs to organization.
"#{level}-#{generation.index(self) + 1}"
end