0

コンテンツ タイプのメニュー項目を設定する INavigationFilter の実装があります。問題は、メソッド Filter() が 2 つのスレッドから 2 回呼び出され、最終的に 2 倍のメニュー項目が作成されることです。

ここにログがあります:

2012-10-15 18:35:50,650 [14] Zulatm.WebPlants.Handlers.TaxonomyNavigationFilter - フィルタリング ホーム 2012-10-15 18:35:50,651 [14] Zulatm.WebPlants.Handlers.TaxonomyNavigationFilter - フィルタリング 2012-10-15 18:35:50,665 [37] Zulatm.WebPlants.Handlers.TaxonomyNavigationFilter - フィルタリング ホーム 2012-10-15 18:35:50,666 [37] Zulatm.WebPlants.Handlers.TaxonomyNavigationFilter - フィルタリング 2012-10-15 18:35:50,693 [37] Zulatm.WebPlants.Handlers.TaxonomyNavigationFilter - 降伏アイテム ロックプラント、位置 5。2012-10-15 18:35:50,698 [37] Zulatm.WebPlants.Handlers.TaxonomyNavigationFilter - 降伏アイテム 水生植物、位置 7。 10-15 18:35:50,700 [37] Zulatm.WebPlants.Handlers.TaxonomyNavigationFilter - 降伏項目湿地植物、位置 6. 2012-10-15 18:35:50,702 [14] Zulatm.WebPlants.Handlers。TaxonomyNavigationFilter - 降伏アイテム ロックプラント、位置 5。2012-10-15 18:35:50,704 [14] Zulatm.WebPlants.Handlers.TaxonomyNavigationFilter - 降伏アイテム 水生植物、位置 7。 14] Zulatm.WebPlants.Handlers.TaxonomyNavigationFilter - 降伏項目湿地植物、位置 6。2012-10-15 18:35:50,708 [14] Zulatm.WebPlants.Handlers.TaxonomyNavigationFilter - 降伏項目草本植物、位置 4。 -15 18:35:50,710 [14] Zulatm.WebPlants.Handlers.TaxonomyNavigationFilter - 降伏アイテム 木本植物、位置 3。 & コケ、位置 1. 2012-10-15 18:35:50,712 [37] Zulatm.WebPlants.Handlers.TaxonomyNavigationFilter - 収量アイテム 草本植物、位置 4. 2012-10-15 18:35:50,714 [14] Zulatm.WebPlants.Handlers.TaxonomyNavigationFilter - 降伏アイテム Ferns & Allies、位置 2。 3. 2012-10-15 18:35:50,724 [37] Zulatm.WebPlants.Handlers.TaxonomyNavigationFilter - 降伏アイテム地衣とコケ、位置 1. 2012-10-15 18:35:50,726 [37] Zulatm.WebPlants.Handlers .TaxonomyNavigationFilter - 降伏アイテム Ferns & Allies、位置 2。TaxonomyNavigationFilter - 降伏アイテムの地衣類とコケ、位置 1。TaxonomyNavigationFilter - 降伏アイテムの地衣類とコケ、位置 1。

次のコードの:

public IEnumerable<MenuItem> Filter(IEnumerable<MenuItem> menuItems) {

             foreach (var item in menuItems) {
                 Logger.Debug(string.Format("Filtering {0}", item.Text));
                 if (item.Content != null && item.Content.ContentItem.ContentType == "TaxonomyNavigationMenuItem") {
                     var taxonomyCatalogId = _contentManager
                         .Query("Taxonomy")
                         .Where<TitlePartRecord>(t => t.Title == Migrations.STR_catalogTaxonomyName)
                         .List().Single().Id;

                     IEnumerable<TermPart> termParts = _contentManager
                         .Query<TermPart, TermPartRecord>()
                         .Where(record => record.TaxonomyId == taxonomyCatalogId)
                         .List();

                     var termsOnZeroLevel = termParts.Where(part => part.GetLevels() == 0);

                     foreach (var termPart in termsOnZeroLevel) {
                         var termMenuItem = new MenuItem();

                         InitializeTermMenuItem(termMenuItem, termPart, termParts);

                         Logger.Debug(string.Format("Yielding item {0}, position {1}.", termMenuItem.Text, termMenuItem.Position) );
                         yield return termMenuItem;
                     }
                 }
                 yield return item;
             }
        }

アップデート。

private void InitializeTermMenuItem(MenuItem termMenuItem, TermPart currentTerm, IEnumerable<TermPart> allTerms, string parentPosition = "") {

var currentPosition =
                string.IsNullOrWhiteSpace(parentPosition)
                    ? currentTerm.Weight.ToString()
                    : string.Join(".", parentPosition, currentTerm.Weight);

        termMenuItem.RouteValues = new RouteValueDictionary(
            new {
                action = "Item",
                controller = "Home",
                area = "Contrib.Taxonomies",
                termPath = currentTerm.Slug
            });
        termMenuItem.Text = T(currentTerm.As<TitlePart>().Title);
        termMenuItem.Classes.Add("MyTaxonomyClass" + currentTerm.As<TitlePart>().Title);
        termMenuItem.Position = currentPosition;
        termMenuItem.Items = new List<MenuItem>();

        var childMenuItems = new List<MenuItem>();
        termMenuItem.Items = childMenuItems;
        foreach (var childTerm in allTerms.Where(p => p.Path.StartsWith(currentTerm.FullPath))) {
            var newChildMenuItem = new MenuItem();
            InitializeTermMenuItem(newChildMenuItem, childTerm, allTerms, currentPosition);
                childMenuItems.Add(newChildMenuItem);
            }
 }

更新 2。

public int UpdateFrom11() {
    ContentDefinitionManager.AlterTypeDefinition(
        "TaxonomyNavigationMenuItem",
        cfg => cfg
                   .WithPart("MenuPart")
                   .WithPart("CommonPart")
                   .DisplayedAs("Taxonomy catalog menu item")
                   .WithSetting("Description", "Injects taxonomy categories as menu items")
                   .WithSetting("Stereotype", "MenuItem")
        );
    return 12;
}

public int UpdateFrom12() {
    ContentDefinitionManager.AlterTypeDefinition(
        "TaxonomyNavigationMenuItem",
        cfg => cfg.WithPart("IdentityPart"));
    return 13;
}
4

1 に答える 1

0

わかりました、それを修正しました。MenuItem.Content を初期化し、2 番目のコピーを削除しました。次のコードが現在のメニュー項目のコピーを生成したため、これは役に立ちました。それを見つけるのに時間がかかりました。

MenuWidgetPartDriver.Display(..):

var localized = new List<MenuItem>();
foreach(var menuItem in menuItems) {
    // if there is no associated content, it as culture neutral
    if(menuItem.Content == null) {
        localized.Add(menuItem);
    }

    // if the menu item is culture neutral or of the current culture
    if (String.IsNullOrEmpty(menuItem.Culture) || String.Equals(menuItem.Culture, currentCulture, StringComparison.OrdinalIgnoreCase)) {
        localized.Add(menuItem);
    }
}

menuItems = localized;
于 2012-10-18T16:44:45.893 に答える