0

在我的申请中,我有职位。每个位置都有一个父位置和多个子位置。如何导航树并找到同一代中的所有位置?

目前我有这个:

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
4

1 回答 1

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
于 2016-05-26T14:47:34.617 回答