Фильтрация эпопей с доски Канбан

Вначале я хотел бы сказать, что я прочитал Rally Kanban - скрывающие Epic Stories, но у меня все еще возникают проблемы с реализацией моего фильтра на основе процесса фильтрации из приложения Оценочная комиссия. В настоящее время я пытаюсь добавить фильтр элементов в свой объект запроса для моего картона. Объект запроса вызывает this._getItems, чтобы вернуть массив элементов для фильтрации. Насколько я могу судить, запрос вызывает функцию, загружается на секунду или две, а затем не отображает результатов. Любые предложения, предложения или альтернативные решения приветствуются.

Вот мой код

$that._redisplayBoard = function() {


            that._getAndStorePrefData(displayBoard);

            this._getItems = function(callback) {

            //Build types based on checkbox selections
            var queries = [];

                    queries.push({key:"HierarchicalRequirement",
                        type: "HierarchicalRequirement",
                        fetch: "Name,FormattedID,Owner,ObjectID,Rank,PlanEstimate,Children,Ready,Blocked",
                        order: "Rank"

                    });



            function bucketItems(results) {
                var items = [];

                rally.forEach(queries, function(query) {
                    if (results[query.key]) {
                        rally.forEach(results[query.key], function(item) {
                            //exclude epic stories since estimates cannot be altered
                            if ((item._type !== 'HierarchicalRequirement') ||
                                    (item._type === 'HierarchicalRequirement' && item.Children.length === 0)) {
                                items = items.concat(item);

                            }
                        });
      }
                });


               callback(items);
                }

                 rallyDataSource.findAll(queries, bucketItems);

            };

            function displayBoard() {

                artifactTypes = [];



                var cardboardConfig = {

                    types: [],

                    items: that._getItems,

                    attribute: kanbanField,

                    sortAscending: true,

                    maxCardsPerColumn: 200,

                    order: "Rank",

                    cardRenderer: KanbanCardRenderer,

                    cardOptions: {

                        showTaskCompletion: showTaskCompletion,

                        showAgeAfter: showAgeAfter

                    },

                    columnRenderer: KanbanColumnRenderer,

                    columns: columns,

                    fetch: "Name,FormattedID,Owner,ObjectID,Rank,Ready,Blocked,LastUpdateDate,Tags,State,Priority,StoryType,Children"

                };



                if (showTaskCompletion) {

                    cardboardConfig.fetch += ",Tasks";

                }



                if (hideLastColumnIfReleased) {

                    cardboardConfig.query = new rally.sdk.util.Query("Release = null").or(kanbanField + " != " + '"' + lastState + '"');

                }



                if (filterByTagsDropdown && filterByTagsDropdown.getDisplayedValue()) {

                    cardboardConfig.cardOptions.filterBy = { field: FILTER_FIELD, value: filterByTagsDropdown.getDisplayedValue() };

                }



                cardboardConfig.types.push("HierarchicalRequirement");



                if (cardboard) {

                    cardboard.destroy();

                }



                artifactTypes = cardboardConfig.types;






                cardboard = new rally.sdk.ui.CardBoard(cardboardConfig, rallyDataSource);




                cardboard.addEventListener("preUpdate", that._onBeforeItemUpdated); 
                cardboard.addEventListener("onDataRetrieved", function(cardboard,args){ console.log(args.items); }); 

                cardboard.display("kanbanBoard");

            }

        };


        that.display = function(element) {



            //Build app layout

            this._createLayout(element);



            //Redisplay the board

            this._redisplayBoard();

        };

    };

3 ответа

Решение

Ответ Марка вызвал неясный сбой, когда был вызван картон.setItems (FilterItems). Однако, поскольку код фильтрации фактически манипулирует реальными ссылками, оказывается, что метод setItems() на самом деле не нужен. Я вытащил его, и теперь он фильтруется правильно.

Подсказка Пера Charles Ferentchak в Ралли Канбан - сокрытие эпических историй

Вот как я подошел к этому после намека Чарльза на каталог ралли Канбан. Во-первых, измените оператор fetch внутри boardConfig так, чтобы он включал коллекцию Children, таким образом:

      fetch: "Name,FormattedID,Children,Owner,ObjectID,Rank,Ready,Blocked,LastUpdateDate,Tags,State"

Далее, между этим утверждением:

      cardboard.addEventListener("preUpdate", that._onBeforeItemUpdated);   

И это утверждение:

     cardboard.display("kanbanBoard");

Добавьте следующий прослушиватель событий и обратный вызов:

    cardboard.addEventListener("onDataRetrieved", 
        function(cardboard, args){
            // Grab items hash
            filteredItems = args.items;

            // loop through hash keys (states)
            for (var key in filteredItems) {

                // Grab the workproducts objects (Stories, defects)                 
                workproducts = filteredItems[key];
                // Array to hold filtered results, childless work products
                childlessWorkProducts = new Array();
                // loop through 'em and filter for the childless
                for (i=0;i<workproducts.length;i++) {
                    thisWorkProduct = workproducts[i];                      
                    // Check first if it's a User Story, since Defects don't have children
                    if (thisWorkProduct._type == "HierarchicalRequirement") {
                        if (thisWorkProduct.Children.length === 0 ) {
                            childlessWorkProducts.push(thisWorkProduct);
                        }
                    } else {
                        // If it's a Defect, it has no children so push it
                        childlessWorkProducts.push(thisWorkProduct);
                    } 
                }
                filteredItems[key] = childlessWorkProducts;
            }
            // un-necessary call to cardboard.setItems() was here - removed
        }
    );

Этот обратный вызов должен фильтровать только для элементов конечного узла.

Не уверен, что это ваша проблема, но ваша картонная конфигурация не устанавливает поле запроса. Выборка - это тип всех данных, которые нужно извлечь. Если вы хотите отфильтровать их, добавьте значение "query:" в объект конфигурации. Что-то вроде:

        var cardboardConfig = {
         types: ["PortfolioItem", "HierarchicalRequirement", "Feature"],
         attribute: dropdownAttribute,
         fetch:"Name,FormattedID,Owner,ObjectID,ClassofService",
         query : fullQuery,
         cardRenderer: PriorityCardRenderer
    };

Где fullQuery может быть создан с использованием объекта запроса Rally. Вы найдете его, выполнив поиск в SDK. Надеюсь, что это может помочь.

Другие вопросы по тегам