JIRA自定义一个优雅的可多选下拉列表

公司PMO最新发布的规范,需要在每个JIRA故事里输入涉及上线的应用系统名称,最开始就是自定义了一个最简单的文本框,让Owner自己填写,多个系统逗号分隔。后来在数据统计的过程中发现系统应用名每个人写的千奇百怪,难于对齐。所以考虑将所有的系统应用名称导入到JIRA中,让Owner直接选择减少出错概率。但是JIRA内嵌的几个标准自定义控件,实在是不好用。

自定义字段的路径是:右上角的“JIRA管理” ->“问题”->“自定义字段”->”添加”,可多选的字段类型如下:

image

image

  1. 多个checkbox的复选框,对于我们上百个的微服务系统,全部陈列到一个页面,那简直没法看,故而放弃。

  2. Select List(多选)是个带垂直滚动条的多选框,这个控件也有问题,若上百个系统在里面滚动,多选需要按住Ctrl来多选,而且在滚动过程中,如果不小心没按住Ctrl,之前其他人选择的系统名称,可能就丢了,不直观。

  3. Select List(级联) 场景不合适,忽略。

    checkbox 和 多选列表效果如下图所示。

image.png

那么有没有一种更优雅的方式,可以在下拉列表中多选,而且每次选择后可以有直观的提示我选择了哪些呢?当然有!而且只需要简单的几行代码。步骤如下:

1.继续之前的路径,在自定义字段界面,仍然选择Select List(多选);

2.名称随便输入一个你想要在Issue编辑页上显示的名字,比如我这里是叫”Related Applications“;

3. 描述文本框留空,本文最关键的几行代码就是要存到这个“描述”里;选项先随便填入一个,确定即可;

4. 进入JIRA的数据库中,运行如下SQL,找到这个ID,比如是12000;

select id from customfield where cfname='Related Applications'; //cfname就是刚才你自定义字段的名称

5.复制如下的代码,将里面的替换为上一步从数据库里查询到的ID,比如customfield_

替换后变为(注意不要不小心加入空格啥的)

customfield_12000

<script type="text/javascript">
(function($) {
   AJS.$("#customfield_<cf-id> option[value='-1']").remove(); //Removes the default value "None"

   function convertMulti(id){
       if (AJS.$('#'+id+"-textarea").length == 0){
           new AJS.MultiSelect({
               element: $("#"+id),
               itemAttrDisplayed: "label",
               errorMessage: AJS.params.multiselectComponentsError });
       }
   }

   AJS.toInit(function(){ 
       convertMulti("customfield_<cf-id>");
   })

   JIRA.bind(JIRA.Events.NEW_CONTENT_ADDED, function (e, context) {
       AJS.$("#customfield_<cf-id> option[value='-1']").remove();
       convertMulti("customfield_<cf-id>");
   });})(AJS.$);
</script>

6. 从JIRA管理重新进入”自定义字段”,选择”编辑”,将上一步全局替换完毕的代码黏贴到“描述”中,保存;

7. 退出继续对自定义字段“配置”多个可选项,手动一个一个添加吧…

我曾经试过直接在数据库表 customfieldoption中插入,后来会引起ID冲突,全部回滚了。如果真的太多选项,你可以网页抓一下network找到那个jspa接口,自己写代码调用接口也可以。反正尽量不要直接操作数据库。

优雅的下拉列表

大功告成!!!

欢迎关注我的公众号

You forgot to set the qrcode for Alipay. Please set it in _config.yml.
You forgot to set the qrcode for Wechat. Please set it in _config.yml.
You forgot to set the business and currency_code for Paypal. Please set it in _config.yml.
You forgot to set the url Patreon. Please set it in _config.yml.
Your browser is out-of-date!

Update your browser to view this website correctly. Update my browser now

×