如何将本地Trac项目菜单添加到templates / site.html?

时间:2012-10-11 01:02:15

标签: trac

我在同一台服务器上有多个具有不同环境的Trac项目。我希望在每个项目页面的顶部都有一个指向所有项目的链接列表,这样我就可以在它们之间快速切换,而不必在/ projects /上找到顶级列表。

理想的解决方案是:

  1. 不需要在每次加载页面时加载所有Trac环境。
  2. 在添加新项目时自动更新。
  3. 只需要编辑配置和/或模板或添加插件。
  4. 为Trac 0.11工作。

3 个答案:

答案 0 :(得分:2)

NavAddPluggin允许自定义主trac导航栏。您可以为项目的每个trac添加菜单选项。要添加新菜单项,以下内容将添加到trac.ini file

[navadd]
add_items = project1
project1.target = mainnav
project1.title = Project One
project1.url = http://webserver/trac_project_1

要对订单进行排序,请修改mainnav

中的trac.ini选项

mainnav = project1,wiki,timeline,roadmap,browser,tickets,newticket,search

答案 1 :(得分:1)

要回答如何使用site.html添加meny的问题,这里有一个非常基本的顶部标题可以帮助您入门 - 粘贴到site.html占位符:

<!--! A top header -->
<py:match path="body" once="True">
<body py:attrs="select('@*')">
    <div id="top">
        <a py:if="req.href() != '/one'" href="/one">one</a>
        <a py:if="req.href() != '/two'" href="/two">two</a>
        <a py:if="req.href() != '/three'" href="/three">three</a>
    </div>
    ${select('*|comment()|text()')}
</body>
</py:match>

该示例使用非常简单的逻辑并隐藏当前项目。您可能希望采用不同的方式,通常使用突出显示或类似方法。

有关高级示例,请参阅Trac Layout Recipe。这是edgewall.org使用的布局,用于在各种项目之间切换(Trac,Genshi,Babel,Bitten)。

答案 2 :(得分:0)

sudo_o描述的方法可能是你最好的选择。它将为您提供一些非常好地集成到Trac界面中的东西。

但是,我想提一个你可能觉得有用的快速替代品。您可以在每个Trac页面的左上角配置徽标,以便在单击时链接到特定页面。许多Trac安装使用它来链接回起始页面。但是,该链接是可配置的,您可以将其指向项目列表页面。在trac.ini文件中:

[header_logo]
src = site/your_logo.png
link = /url/to/projects/page
alt = Click to load projects listing

此方法可让您轻松访问项目列表,而无需在Trac菜单中添加任何额外条目。添加或删除项目时,您不必修改每个trac.ini文件来更新链接。缺点是它需要额外的点击才能进入另一个项目,而且有些用户可能觉得这个方法不直观(设置alt属性有点帮助)。