1

我之前问了一个问题,引起了一些很好的反应。

这是之前的问题

根据那里给出的一些建议,我尝试移动以下控制器逻辑

 if params[:concept][:consulted_legal] == 0 && params[:concept][:consulted_marketing] == 1
  @concept.attributes = {:status => 'Awaiting Compliance Approval'}
elsif params[:concept][:consulted_marketing] == 0 && params[:concept][:consulted_legal] == 1 
  @concept.attributes = {:status => 'Awaiting Marketing Approval'}
elsif params[:concept][:consulted_marketing] == 0 && params[:concept][:consulted_legal] == 0
  @concept.attributes = {:status => 'Awaiting Marketing & Legal Approval'}
else
  @concept.attributes = {:status => 'Pending Approval'}
end

进入模型,如下所示:

def set_status
if status.blank?
  if (consulted_legal == true) && (consulted_marketing == true)
      status = "Pending Approval"
  elsif (consulted_legal == true) && (consulted_marketing == false)
    status = "Awaiting Marketing Approval"
  elsif (consulted_legal == false) && (consulted_marketing == true)
    status = "Awaiting Legal Approval"
  elsif (consulted_legal == false) && (consulted_marketing == false)
    status = "Awaiting Marketing & Legal Approval"
  end
end
true # Needs to return true for the update to go through    
  end

我从 before_save 回调中调用它。

默认情况下,consulted_legal 和consulted_marketing 属性都设置为false 而不是null,这就是为什么我在这里测试== false 或true,而不是询问

if consulted_legal?

例如。

但是,这种逻辑似乎不起作用。如果我检查该对象,则永远不会将状态设置为任何内容。谁能发现为什么会发生这种情况?例如,我是否知道模型中的属性是如何被错误访问的?

TIA

4

2 回答 2

6

而不是status =尝试self.status =。我发现我需要使用self.来更改模型中的模型属性。

最好errors.empty?在结尾而不是true,因此如果您errors.add_to_base将来使用,您的set_status方法已准备好中止保存。

编辑:
您可能还想查看acts_as_state_machine. 它看起来像一个插件,正是你正在做的事情。

于 2009-01-23T16:28:47.827 回答
1

您是否从用户输入设置参数?

如果它们未定义为布尔数据库列,那么您将为它们分配一个字符串,该字符串永远不会等于 true。

于 2009-01-23T16:30:11.427 回答