Dynamically change field depending on value of parent


This plugin allows you to dynamically change fields options by their parent fields.

For example, there are 3 fields: brand, phone, OS. When the phone brand changes, the phone field will change its options to show only the phone that belongs to that brand. When the phone changes, the OS field will change accordingly.

  1. Add 3 custom fields in your trac.ini file:
    tcf_brand = text
    tcf_brand.label = Brand
    tcf_brand.order = 3
    tcf_phone = text
    tcf_phone.label = Phone
    tcf_phone.order = 4
    tcf_os = text
    tcf_os.label = OS
    tcf_os.order = 5
  2. Go to Admin -> Chained Fields, edit the configuration:
        "tcf_brand": {
            "Nokia": {
                    "5800": {
                            "Symbian": {},
                            "Android": {}
            "SE": {
                    "": {
                            "": {}
            "Apple": {
                    "iPhone": {
                            "OS X": {},
                            "OS": {}
                    "iPhone 3G": {
                            "OS X": {},
                            "other": {}


  • If there are no options for some fields, like "SE" above, you still need to supply the full structure, with empty string as keys.
  • It supports any fields after [7793].

The list of applicable phones changes based on the selections made in the Brand and OS fields:

Bugs/Feature Requests

Existing bugs and feature requests for TracTicketChainedFieldsPlugin are here.

If you have any issues, create a new ticket.


10 / 16


3 / 6


Download the zipped source from here.


You can check out TracTicketChainedFieldsPlugin from here using Subversion, or browse the source with Trac.


General instructions on installing Trac plugins can be found on the TracPlugins page.

Simplejson is a requirement for Python < 2.6, and it should be installed automatically if required when running easy_install.

  1. Uninstall TracTicketTemplate if you have it installed before.
  2. Change to the directory containing
  3. If you want to install this plugin globally, this will install this plugin to the Python path:
    python install
  4. If you want to install this plugin to the Trac instance only:
    • python bdist_egg
    • copy the generated egg file to the trac instance's plugin directory:
      cp dist/*.egg /srv/trac/env/plugins
  5. Add the follwing line to the components section of the trac.ini file:
    tcf.* = enabled
    hide_empty_fields = false
    chained_fields = tcf_brand, tcf_phone, tcf_os
    chained_fields = component, tcf_brand, tcf_phone, tcf_os
    for non-tcf_ starting fields.

hide_empty_fields is the option which enable "hide fields when there are no supplied options", default is false. See #5638 for more details.

Recent Changes

14692 by rjollos on 2015-06-18 06:14:53
0.2dev: PEP-0008 changes.
14691 by rjollos on 2015-06-18 05:32:35
0.2dev: Properly left strip field- token. Fixes #12405.
13753 by rjollos on 2014-03-15 22:02:59
0.2dev: Executed on source code.


Author: richard
Maintainer: Richard Liao

Last modified 5 weeks ago Last modified on Sep 16, 2016, 9:23:06 AM

Attachments (1)

Download all attachments as: .zip