diff --git a/src/main/java/com/simibubi/create/Create.java b/src/main/java/com/simibubi/create/Create.java
index d539a32de..963301a5e 100644
--- a/src/main/java/com/simibubi/create/Create.java
+++ b/src/main/java/com/simibubi/create/Create.java
@@ -39,8 +39,10 @@ import com.simibubi.create.infrastructure.data.CreateDatagen;
import com.simibubi.create.infrastructure.worldgen.AllFeatures;
import com.simibubi.create.infrastructure.worldgen.AllPlacementModifiers;
+import net.minecraft.resources.ResourceKey;
import net.minecraft.resources.ResourceLocation;
import net.minecraft.world.entity.Entity;
+import net.minecraft.world.item.CreativeModeTab;
import net.minecraft.world.level.Level;
import net.minecraftforge.api.distmarker.Dist;
import net.minecraftforge.common.ForgeMod;
@@ -74,7 +76,8 @@ public class Create {
* Other mods should not use this field! If you are an addon developer, create your own instance of
* {@link CreateRegistrate}.
*/
- public static final CreateRegistrate REGISTRATE = CreateRegistrate.create(ID);
+ public static final CreateRegistrate REGISTRATE = CreateRegistrate.create(ID)
+ .defaultCreativeTab((ResourceKey) null);
static {
REGISTRATE.setTooltipModifierFactory(item -> {
diff --git a/src/main/java/com/simibubi/create/content/logistics/filter/ItemAttribute.java b/src/main/java/com/simibubi/create/content/logistics/filter/ItemAttribute.java
index bdb1a442f..d33b89bd5 100644
--- a/src/main/java/com/simibubi/create/content/logistics/filter/ItemAttribute.java
+++ b/src/main/java/com/simibubi/create/content/logistics/filter/ItemAttribute.java
@@ -13,6 +13,7 @@ import org.apache.commons.lang3.StringUtils;
import org.jetbrains.annotations.Nullable;
import com.simibubi.create.AllRecipeTypes;
+import com.simibubi.create.Create;
import com.simibubi.create.content.kinetics.fan.processing.AllFanProcessingTypes;
import com.simibubi.create.content.logistics.filter.attribute.BookAuthorAttribute;
import com.simibubi.create.content.logistics.filter.attribute.BookCopyAttribute;
@@ -36,20 +37,20 @@ import net.minecraft.world.Container;
import net.minecraft.world.entity.EquipmentSlot;
import net.minecraft.world.entity.LivingEntity;
import net.minecraft.world.item.BlockItem;
+import net.minecraft.world.item.CreativeModeTab;
+import net.minecraft.world.item.CreativeModeTabs;
import net.minecraft.world.item.Item;
import net.minecraft.world.item.ItemStack;
import net.minecraft.world.item.crafting.Recipe;
import net.minecraft.world.item.crafting.RecipeType;
-import net.minecraft.world.item.CreativeModeTab;
-import net.minecraft.world.item.CreativeModeTabs;
import net.minecraft.world.item.enchantment.EnchantmentHelper;
import net.minecraft.world.level.Level;
import net.minecraft.world.level.block.ComposterBlock;
import net.minecraft.world.level.block.entity.AbstractFurnaceBlockEntity;
import net.minecraftforge.api.distmarker.Dist;
import net.minecraftforge.api.distmarker.OnlyIn;
-import net.minecraftforge.common.capabilities.ForgeCapabilities;
import net.minecraftforge.common.CreativeModeTabRegistry;
+import net.minecraftforge.common.capabilities.ForgeCapabilities;
import net.minecraftforge.fml.ModContainer;
import net.minecraftforge.fml.ModList;
import net.minecraftforge.forgespi.language.IModInfo;
@@ -286,17 +287,50 @@ public interface ItemAttribute {
this.group = group;
}
+ @Override
+ public boolean appliesTo(ItemStack stack, Level world) {
+ if (group == null)
+ return false;
+
+ if (group.getDisplayItems()
+ .isEmpty()
+ && group.getSearchTabDisplayItems()
+ .isEmpty()) {
+
+ try {
+ group.buildContents(new CreativeModeTab.ItemDisplayParameters(world.enabledFeatures(), false,
+ world.registryAccess()));
+ } catch (RuntimeException | LinkageError e) {
+ Create.LOGGER.error("Attribute Filter: Item Group crashed while building contents.",
+ group.getDisplayName()
+ .getString(),
+ e);
+ group = null;
+ return false;
+ }
+
+ }
+
+ return tabContainsItem(group, stack);
+ }
+
@Override
public boolean appliesTo(ItemStack stack) {
- return group != null && group.contains(stack);
+ return false;
}
@Override
public List listAttributesOf(ItemStack stack) {
- return CreativeModeTabs.tabs().stream()
- .filter(tab -> !tab.hasSearchBar() && tab.contains(stack))
- .map(tab -> (ItemAttribute)new InItemGroup(tab))
- .toList();
+ return CreativeModeTabs.tabs()
+ .stream()
+ .filter(tab -> tab.getType() == CreativeModeTab.Type.CATEGORY)
+ .filter(tab -> tabContainsItem(tab, stack))
+ .map(tab -> (ItemAttribute) new InItemGroup(tab))
+ .toList();
+ }
+
+ private static boolean tabContainsItem(CreativeModeTab tab, ItemStack stack) {
+ return tab.contains(stack) || tab.contains(new ItemStack(stack.getItem()));
}
@Override