Plone/Zope 在一个内容类型上使用两个工作流,我可以在状态栏中显示与用户角色相关的当前 state/states 吗?

Plone/Zope Using two workflows on a content type, can I show the current state/states relevant to the user's role in the status bar?

我在 Zope 管理器中创建了两个工作流程:A_Workflow、B_Workflow 并将其分配给内容类型 'contract'。

A_Workflow有两种状态: 待批准(初始) 已批准

有一个批准过渡 (approve_a) 过渡到 A Approved 和一个收回过渡 (retract_a) 通过所需的权限过渡到 Pending A Approval 只有 A_Manager 可以做到。

B_Workflow有两种状态: 等待 B 批准(初始) B 已批准

有一个批准过渡 (approve_b) 过渡到 B Approved 和一个收回过渡 (retract_b) 过渡到 Pending B Approval 只有通过所需的许可 B_Manager可以做到。

贡献者创建了一个合约,第一个状态是Pending A Approval。 当我以 A_Manager 身份登录和以 B_Manager 身份登录时,我可以看到适当的转换可用。然而,a B_Manager 只能看到 A_Workflow 的状态,尽管 B_Workflow 的状态发生变化(当状态为 Pending B Approval 时显示 Approve B,当状态为 Pending B Approval 时显示 Retract B状态是 B 批准)

如果这是一个尴尬的问题,我深表歉意,但是否可以在状态栏中显示正确的状态?如果可以,我该怎么办?

据我了解,您似乎使用了 工作流链 (分配给一种内容类型的两个或更多工作流)。

此功能或多或少被隐藏和未使用(尽管它有效)但 Plone UI 不以任何方式支持它:您可以依靠它来确保安全,但只有 "main"(链中的第一个)工作流由 Plone UI.

使用

要查看这两种状态,您需要自定义 Plone 工作流菜单。 只是猜测:提供一个覆盖 the ones in plone.app.contentmenu.

的新菜单

注意:自定义菜单不是一项复杂的任务,但您需要一些样板,例如使用 z3c.unconfigure 或 overrides.zcml

在此处查看示例(此用于 "add new item" 菜单):https://github.com/keul/collective.factorymenu/tree/master/src/collective/factorymenu

我们实际上经常为项目使用链式工作流。一个常见的用例是有第二个工作流来控制项目的 "featured" 状态。通过这种方式,内容贡献者可以请求将项目作为特色,但 editor/reviewer 可以批准特色。

我们有一个产品允许工作流下拉列表显示所有链接的工作流及其转换。我刚刚向 PyPI 发布了一个版本:

https://pypi.python.org/pypi/sixfeetup.workflow.chained

但您可以在 github 存储库中报告问题:

https://github.com/sixfeetup/sixfeetup.workflow.chained

让我们知道这是否适合您。