Rebooting Advancements

- Reworked basic advancement tree, to be continued
- Removed unused trigger and damage source for sandpaper
- Added some new crate assets
This commit is contained in:
simibubi 2020-05-06 20:24:04 +02:00
parent ef541493c5
commit 6c3c0600d3
107 changed files with 2020 additions and 863 deletions

View file

@ -74,6 +74,7 @@ import com.simibubi.create.modules.logistics.block.diodes.ToggleLatchBlock;
import com.simibubi.create.modules.logistics.block.extractor.ExtractorBlock; import com.simibubi.create.modules.logistics.block.extractor.ExtractorBlock;
import com.simibubi.create.modules.logistics.block.extractor.LinkedExtractorBlock; import com.simibubi.create.modules.logistics.block.extractor.LinkedExtractorBlock;
import com.simibubi.create.modules.logistics.block.funnel.FunnelBlock; import com.simibubi.create.modules.logistics.block.funnel.FunnelBlock;
import com.simibubi.create.modules.logistics.block.inventories.CrateBlock;
import com.simibubi.create.modules.logistics.block.inventories.FlexcrateBlock; import com.simibubi.create.modules.logistics.block.inventories.FlexcrateBlock;
import com.simibubi.create.modules.logistics.block.transposer.LinkedTransposerBlock; import com.simibubi.create.modules.logistics.block.transposer.LinkedTransposerBlock;
import com.simibubi.create.modules.logistics.block.transposer.TransposerBlock; import com.simibubi.create.modules.logistics.block.transposer.TransposerBlock;
@ -85,7 +86,6 @@ import com.simibubi.create.modules.palettes.HorizontalCTGlassBlock;
import com.simibubi.create.modules.palettes.LayeredCTBlock; import com.simibubi.create.modules.palettes.LayeredCTBlock;
import com.simibubi.create.modules.palettes.ScoriaBlock; import com.simibubi.create.modules.palettes.ScoriaBlock;
import com.simibubi.create.modules.palettes.VerticalCTGlassBlock; import com.simibubi.create.modules.palettes.VerticalCTGlassBlock;
import com.simibubi.create.modules.schematics.block.CreativeCrateBlock;
import com.simibubi.create.modules.schematics.block.SchematicTableBlock; import com.simibubi.create.modules.schematics.block.SchematicTableBlock;
import com.simibubi.create.modules.schematics.block.SchematicannonBlock; import com.simibubi.create.modules.schematics.block.SchematicannonBlock;
@ -115,7 +115,6 @@ public enum AllBlocks {
__SCHEMATICS__(), __SCHEMATICS__(),
SCHEMATICANNON(new SchematicannonBlock()), SCHEMATICANNON(new SchematicannonBlock()),
CREATIVE_CRATE(new CreativeCrateBlock()),
SCHEMATIC_TABLE(new SchematicTableBlock()), SCHEMATIC_TABLE(new SchematicTableBlock()),
__CONTRAPTIONS__(), __CONTRAPTIONS__(),
@ -183,7 +182,10 @@ public enum AllBlocks {
CONTACT(new ContactBlock()), CONTACT(new ContactBlock()),
REDSTONE_BRIDGE(new RedstoneLinkBlock()), REDSTONE_BRIDGE(new RedstoneLinkBlock()),
STOCKSWITCH(new StockswitchBlock()), STOCKSWITCH(new StockswitchBlock()),
WAREHOUSE_CRATE(new CrateBlock(Properties.from(Blocks.ANDESITE))),
FLEXCRATE(new FlexcrateBlock()), FLEXCRATE(new FlexcrateBlock()),
FILTERED_CRATE(new CrateBlock(Properties.from(Blocks.ANDESITE))),
CREATIVE_CRATE(new CrateBlock(Properties.from(Blocks.ANDESITE))),
EXTRACTOR(new ExtractorBlock()), EXTRACTOR(new ExtractorBlock()),
VERTICAL_EXTRACTOR(new ExtractorBlock.Vertical()), VERTICAL_EXTRACTOR(new ExtractorBlock.Vertical()),
LINKED_EXTRACTOR(new LinkedExtractorBlock()), LINKED_EXTRACTOR(new LinkedExtractorBlock()),

View file

@ -0,0 +1,314 @@
package com.simibubi.create.data;
import java.io.IOException;
import java.nio.file.Path;
import java.util.Set;
import java.util.function.Consumer;
import org.apache.logging.log4j.LogManager;
import org.apache.logging.log4j.Logger;
import com.google.common.collect.Sets;
import com.google.gson.Gson;
import com.google.gson.GsonBuilder;
import com.simibubi.create.AllBlocks;
import com.simibubi.create.AllItems;
import com.simibubi.create.Create;
import com.simibubi.create.foundation.advancement.AllTriggers;
import com.simibubi.create.foundation.advancement.KineticBlockTrigger;
import net.minecraft.advancements.Advancement;
import net.minecraft.advancements.Advancement.Builder;
import net.minecraft.advancements.FrameType;
import net.minecraft.advancements.IRequirementsStrategy;
import net.minecraft.advancements.criterion.InventoryChangeTrigger;
import net.minecraft.advancements.criterion.PlacedBlockTrigger;
import net.minecraft.block.Block;
import net.minecraft.block.Blocks;
import net.minecraft.data.DataGenerator;
import net.minecraft.data.DirectoryCache;
import net.minecraft.data.IDataProvider;
import net.minecraft.item.Items;
import net.minecraft.util.IItemProvider;
import net.minecraft.util.ResourceLocation;
import net.minecraft.util.text.TranslationTextComponent;
@SuppressWarnings("unused") // dont warn about unused avancements
public class CreateAdvancements implements IDataProvider {
static final String LANG = "advancement." + Create.ID + ".";
public void register(Consumer<Advancement> t) {
String id = Create.ID;
Advancement root = Advancement.Builder
.builder()
.withDisplay(AllItems.BRASS_HAND.asStack(), new TranslationTextComponent(LANG + "root"),
new TranslationTextComponent(LANG + "root.desc"),
new ResourceLocation(Create.ID, "textures/block/scoria_bricks.png"), FrameType.TASK, false,
false, false)
.withCriterion("0", InventoryChangeTrigger.Instance.forItems(new IItemProvider[] {}))
.register(t, id + ":root");
Advancement andesite_alloy = advancement("andesite_alloy", AllItems.ANDESITE_ALLOY.get(), TaskType.NORMAL)
.withParent(root)
.withCriterion("0", itemGathered(AllItems.ANDESITE_ALLOY.get()))
.register(t, id + ":andesite_alloy");
kineticsBranch(t, andesite_alloy);
Advancement water_wheel = advancement("water_wheel", AllBlocks.WATER_WHEEL.get(), TaskType.NORMAL)
.withParent(andesite_alloy)
.withCriterion("0", placeBlock(AllBlocks.WATER_WHEEL.get()))
.withCriterion("1", AllTriggers.WATER_WHEEL.instance())
.register(t, id + ":water_wheel");
Advancement lava_wheel = advancement("lava_wheel", Items.LAVA_BUCKET, TaskType.SECRET)
.withParent(water_wheel)
.withCriterion("0", AllTriggers.LAVA_WHEEL.instance())
.register(t, id + ":lava_wheel");
Advancement millstone = kinecticAdvancement("millstone", AllBlocks.MILLSTONE, TaskType.NORMAL)
.withParent(andesite_alloy)
.register(t, id + ":millstone");
Advancement andesite_casing = advancement("andesite_casing", AllBlocks.ANDESITE_CASING.get(), TaskType.GOAL)
.withParent(andesite_alloy)
.withCriterion("0", itemGathered(AllBlocks.ANDESITE_CASING.get()))
.register(t, id + ":andesite_casing");
andesiteExpertLane(t, andesite_casing);
Advancement drill = kinecticAdvancement("drill", AllBlocks.DRILL, TaskType.NORMAL)
.withParent(andesite_casing)
.register(t, id + ":drill");
Advancement press = advancement("press", AllBlocks.MECHANICAL_PRESS.get(), TaskType.MILESTONE)
.withParent(andesite_casing)
.withCriterion("0", AllTriggers.BONK.instance())
.register(t, id + ":press");
Advancement rose_quartz = itemAdvancement("polished_rose_quartz", AllItems.POLISHED_ROSE_QUARTZ, TaskType.NORMAL)
.withParent(andesite_casing)
.register(t, id + ":polished_rose_quartz");
Advancement electron_tube = itemAdvancement("electron_tube", AllItems.ELECTRON_TUBE, TaskType.NORMAL)
.withParent(rose_quartz)
.register(t, id + ":electron_tube");
Advancement saw =
kinecticAdvancement("saw", AllBlocks.SAW, TaskType.NORMAL).withParent(press).register(t, id + ":saw");
Advancement basin = advancement("basin", AllBlocks.BASIN.get(), TaskType.NORMAL)
.withParent(press)
.withCriterion("0", placeBlock(AllBlocks.BASIN.get()))
.withCriterion("1", AllTriggers.BASIN_THROW.instance())
.register(t, id + ":basin");
Advancement mixer = advancement("mixer", AllBlocks.MECHANICAL_MIXER.get(), TaskType.MILESTONE)
.withCriterion("0", placeBlock(AllBlocks.MECHANICAL_MIXER.get()))
.withCriterion("1", isPowered(AllBlocks.MECHANICAL_MIXER.get()))
.withCriterion("2", AllTriggers.MIXER_MIX.instance())
.withParent(basin)
.register(t, id + ":mixer");
Advancement compact = advancement("compact", Blocks.IRON_BLOCK, TaskType.NORMAL)
.withCriterion("0", AllTriggers.PRESS_COMPACT.instance())
.withParent(basin)
.register(t, id + ":compact");
Advancement brass = itemAdvancement("brass", AllItems.BRASS_INGOT, TaskType.NORMAL)
.withParent(mixer)
.register(t, id + ":brass");
brassAge(t, brass);
}
void kineticsBranch(Consumer<Advancement> t, Advancement root) {
String id = Create.ID;
Advancement its_alive = advancement("its_alive", AllBlocks.COGWHEEL.get(), TaskType.NORMAL)
.withParent(root)
.withCriterion("0", AllTriggers.ROTATION.instance())
.register(t, id + ":its_alive");
Advancement belt = advancement("belt", AllItems.BELT_CONNECTOR.get(), TaskType.NORMAL)
.withParent(its_alive)
.withCriterion("0", AllTriggers.CONNECT_BELT.instance())
.register(t, id + ":belt");
Advancement wrench = itemAdvancement("wrench", AllItems.WRENCH, TaskType.NORMAL)
.withParent(its_alive)
.register(t, id + ":wrench");
Advancement goggles = itemAdvancement("goggles", AllItems.GOGGLES, TaskType.NORMAL)
.withParent(its_alive)
.register(t, id + ":goggles");
Advancement speed_gauge = kinecticAdvancement("speed_gauge", AllBlocks.SPEED_GAUGE, TaskType.NORMAL)
.withParent(goggles)
.register(t, id + ":speed_gauge");
Advancement stress_gauge = kinecticAdvancement("stress_gauge", AllBlocks.STRESS_GAUGE, TaskType.NORMAL)
.withParent(goggles)
.register(t, id + ":stress_gauge");
Advancement shifting_gears = advancement("shifting_gears", AllBlocks.LARGE_COGWHEEL.get(), TaskType.NORMAL)
.withParent(its_alive)
.withCriterion("0", AllTriggers.SHIFTING_GEARS.instance())
.register(t, id + ":shifting_gears");
Advancement overstressed = advancement("overstressed", Items.BARRIER, TaskType.SECRET)
.withParent(its_alive)
.withCriterion("0", AllTriggers.OVERSTRESSED.instance())
.register(t, id + ":overstressed");
}
void brassAge(Consumer<Advancement> t, Advancement root) {
String id = Create.ID;
Advancement brass_casing = advancement("brass_casing", AllBlocks.BRASS_CASING.get(), TaskType.GOAL)
.withParent(root)
.withCriterion("0", itemGathered(AllBlocks.BRASS_CASING.get()))
.register(t, id + ":brass_casing");
Advancement crafter = kinecticAdvancement("crafter", AllBlocks.MECHANICAL_CRAFTER, TaskType.MILESTONE)
.withParent(brass_casing)
.register(t, id + ":crafter");
Advancement deployer = kinecticAdvancement("deployer", AllBlocks.DEPLOYER, TaskType.GOAL)
.withParent(brass_casing)
.register(t, id + ":deployer");
Advancement fist_bump = advancement("fist_bump", AllBlocks.LARGE_COGWHEEL.get(), TaskType.SECRET)
.withParent(deployer)
.withCriterion("0", AllTriggers.DEPLOYER_BOOP.instance())
.register(t, id + ":fist_bump");
Advancement crushing_wheel = advancement("crushing_wheel", AllBlocks.CRUSHING_WHEEL.get(), TaskType.MILESTONE)
.withParent(crafter)
.withCriterion("0", itemGathered(AllBlocks.CRUSHING_WHEEL.get()))
.register(t, id + ":crushing_wheel");
Advancement chromatic_compound =
itemAdvancement("chromatic_compound", AllItems.CHROMATIC_COMPOUND, TaskType.NORMAL)
.withParent(crushing_wheel)
.register(t, id + ":chromatic_compound");
Advancement shadow_steel =
itemAdvancement("shadow_steel", AllItems.SHADOW_STEEL, TaskType.GOAL)
.withParent(chromatic_compound)
.register(t, id + ":shadow_steel");
Advancement refined_radiance =
itemAdvancement("refined_radiance", AllItems.REFINED_RADIANCE, TaskType.GOAL)
.withParent(chromatic_compound)
.register(t, id + ":refined_radiance");
}
private void andesiteExpertLane(Consumer<Advancement> t, Advancement root) {
String id = Create.ID;
Advancement expert_lane_1 = advancement("expert_lane_1", Blocks.ANDESITE, TaskType.SILENT_GATE)
.withParent(root)
.withCriterion("0", itemGathered(AllBlocks.ANDESITE_CASING.get()))
.register(t, id + ":expert_lane_1");
}
// Datagen
private static final Logger LOGGER = LogManager.getLogger();
private static final Gson GSON = (new GsonBuilder()).setPrettyPrinting().create();
private final DataGenerator generator;
public CreateAdvancements(DataGenerator generatorIn) {
this.generator = generatorIn;
}
@Override
public void act(DirectoryCache cache) throws IOException {
Path path = this.generator.getOutputFolder();
Set<ResourceLocation> set = Sets.newHashSet();
Consumer<Advancement> consumer = (p_204017_3_) -> {
if (!set.add(p_204017_3_.getId()))
throw new IllegalStateException("Duplicate advancement " + p_204017_3_.getId());
Path path1 = getPath(path, p_204017_3_);
try {
IDataProvider.save(GSON, cache, p_204017_3_.copy().serialize(), path1);
} catch (IOException ioexception) {
LOGGER.error("Couldn't save advancement {}", path1, ioexception);
}
};
register(consumer);
}
private static Path getPath(Path pathIn, Advancement advancementIn) {
return pathIn
.resolve("data/" + advancementIn.getId().getNamespace() + "/advancements/"
+ advancementIn.getId().getPath() + ".json");
}
@Override
public String getName() {
return "CreateAdvancements";
}
public PlacedBlockTrigger.Instance placeBlock(Block block) {
return PlacedBlockTrigger.Instance.placedBlock(block);
}
public KineticBlockTrigger.Instance isPowered(Block block) {
return AllTriggers.KINETIC_BLOCK.forBlock(block);
}
public InventoryChangeTrigger.Instance itemGathered(IItemProvider itemprovider) {
return InventoryChangeTrigger.Instance.forItems(itemprovider);
}
static enum TaskType {
NORMAL(FrameType.TASK, true, false, false),
MILESTONE(FrameType.TASK, true, true, false),
GOAL(FrameType.GOAL, true, true, false),
SECRET(FrameType.GOAL, true, true, true),
SILENT_GATE(FrameType.CHALLENGE, false, false, false),
;
private FrameType frame;
private boolean toast;
private boolean announce;
private boolean hide;
private TaskType(FrameType frame, boolean toast, boolean announce, boolean hide) {
this.frame = frame;
this.toast = toast;
this.announce = announce;
this.hide = hide;
}
}
public Builder kinecticAdvancement(String name, AllBlocks block, TaskType type) {
return advancement(name, block.get(), type)
.withCriterion("0", placeBlock(block.get()))
.withCriterion("1", isPowered(block.get()));
}
public Builder advancement(String name, IItemProvider icon, TaskType type) {
return Advancement.Builder
.builder()
.withDisplay(icon, new TranslationTextComponent(LANG + name),
new TranslationTextComponent(LANG + name + ".desc"), null, type.frame, type.toast,
type.announce, type.hide);
}
public Builder itemAdvancement(String name, AllItems item, TaskType type) {
return advancement(name, item.get(), type).withCriterion("0", itemGathered(item.get()));
}
}

View file

@ -15,17 +15,27 @@ public class AllTriggers {
private static List<CriterionTriggerBase<?>> triggers = new LinkedList<>(); private static List<CriterionTriggerBase<?>> triggers = new LinkedList<>();
public static SandpaperUseTrigger SANDPAPER_USE = add(new SandpaperUseTrigger("sandpaper_use")); public static KineticBlockTrigger KINETIC_BLOCK = add(new KineticBlockTrigger("kinetic_block"));
public static SimpleTrigger DEPLOYER_BOOP = simple("deployer");
public static SimpleTrigger ABSORBED_LIGHT = simple("light_absorbed"); public static SimpleTrigger
public static SimpleTrigger SPEED_READ = simple("speed_read"); ROTATION = simple("rotation"),
public static SimpleTrigger OVERSTRESSED = simple("overstressed"); OVERSTRESSED = simple("overstressed"),
public static SimpleTrigger ROTATION = simple("rotation"); SHIFTING_GEARS = simple("shifting_gears"),
CONNECT_BELT = simple("connect_belt"),
BONK = simple("bonk"),
WATER_WHEEL = simple("water_wheel"),
LAVA_WHEEL = simple("lava_wheel"),
DEPLOYER_BOOP = simple("deployer"),
ABSORBED_LIGHT = simple("light_absorbed"),
SPEED_READ = simple("speed_read"),
BASIN_THROW = simple("basin"),
PRESS_COMPACT = simple("compact"),
MIXER_MIX = simple("mixer");
private static SimpleTrigger simple(String id) { private static SimpleTrigger simple(String id) {
return add(new SimpleTrigger(id)); return add(new SimpleTrigger(id));
} }
private static <T extends CriterionTriggerBase<?>> T add(T instance) { private static <T extends CriterionTriggerBase<?>> T add(T instance) {
triggers.add(instance); triggers.add(instance);
return instance; return instance;
@ -35,19 +45,29 @@ public class AllTriggers {
triggers.forEach(CriteriaTriggers::register); triggers.forEach(CriteriaTriggers::register);
} }
public static void triggerForNearbyPlayers(SimpleTrigger trigger, World world, BlockPos pos, int range) { public static void triggerFor(ITriggerable trigger, PlayerEntity player) {
if (player instanceof ServerPlayerEntity)
trigger.trigger((ServerPlayerEntity) player);
}
public static void triggerForNearbyPlayers(ITriggerable trigger, World world, BlockPos pos, int range) {
triggerForNearbyPlayers(trigger, world, pos, range, player -> true); triggerForNearbyPlayers(trigger, world, pos, range, player -> true);
} }
public static void triggerForNearbyPlayers(SimpleTrigger trigger, World world, BlockPos pos, int range, public static void triggerForNearbyPlayers(ITriggerable trigger, World world, BlockPos pos, int range,
Predicate<PlayerEntity> playerFilter) { Predicate<PlayerEntity> playerFilter) {
if (world == null) if (world == null)
return; return;
if (world.isRemote) if (world.isRemote)
return; return;
List<ServerPlayerEntity> players = List<ServerPlayerEntity> players = getPlayersInRange(world, pos, range);
world.getEntitiesWithinAABB(ServerPlayerEntity.class, new AxisAlignedBB(pos).grow(range));
players.stream().filter(playerFilter).forEach(trigger::trigger); players.stream().filter(playerFilter).forEach(trigger::trigger);
} }
public static List<ServerPlayerEntity> getPlayersInRange(World world, BlockPos pos, int range) {
List<ServerPlayerEntity> players =
world.getEntitiesWithinAABB(ServerPlayerEntity.class, new AxisAlignedBB(pos).grow(range));
return players;
}
} }

View file

@ -0,0 +1,9 @@
package com.simibubi.create.foundation.advancement;
import net.minecraft.entity.player.ServerPlayerEntity;
public interface ITriggerable {
public void trigger(ServerPlayerEntity player);
}

View file

@ -0,0 +1,76 @@
package com.simibubi.create.foundation.advancement;
import java.util.Arrays;
import java.util.List;
import java.util.function.Supplier;
import com.google.gson.JsonDeserializationContext;
import com.google.gson.JsonElement;
import com.google.gson.JsonObject;
import com.google.gson.JsonSyntaxException;
import com.simibubi.create.Create;
import net.minecraft.block.Block;
import net.minecraft.block.BlockState;
import net.minecraft.entity.player.ServerPlayerEntity;
import net.minecraft.util.JSONUtils;
import net.minecraft.util.ResourceLocation;
import net.minecraft.util.registry.Registry;
public class KineticBlockTrigger extends CriterionTriggerBase<KineticBlockTrigger.Instance> {
private static final ResourceLocation ID = new ResourceLocation(Create.ID, "kinetic_block");
public KineticBlockTrigger(String id) {
super(id);
}
public Instance forBlock(Block block) {
return new Instance(block);
}
@Override
@SuppressWarnings("deprecation")
public Instance deserializeInstance(JsonObject json, JsonDeserializationContext context) {
Block block = null;
if (json.has("block")) {
ResourceLocation resourcelocation = new ResourceLocation(JSONUtils.getString(json, "block"));
block = Registry.BLOCK.getValue(resourcelocation).orElseThrow(() -> {
return new JsonSyntaxException("Unknown block type '" + resourcelocation + "'");
});
}
return new Instance(block);
}
public void trigger(ServerPlayerEntity player, BlockState state) {
trigger(player, Arrays.asList(() -> state.getBlock()));
}
public static class Instance extends CriterionTriggerBase.Instance {
private final Block block;
public Instance(Block block) {
super(KineticBlockTrigger.ID);
this.block = block;
}
@Override
protected boolean test(List<Supplier<Object>> suppliers) {
if (suppliers.isEmpty())
return false;
return block == suppliers.get(0).get();
}
@Override
@SuppressWarnings("deprecation")
public JsonElement serialize() {
JsonObject jsonobject = new JsonObject();
if (this.block != null)
jsonobject.addProperty("block", Registry.BLOCK.getKey(this.block).toString());
return jsonobject;
}
}
}

View file

@ -1,47 +0,0 @@
package com.simibubi.create.foundation.advancement;
import java.util.Arrays;
import java.util.List;
import java.util.function.Supplier;
import com.google.gson.JsonDeserializationContext;
import com.google.gson.JsonObject;
import net.minecraft.advancements.criterion.ItemPredicate;
import net.minecraft.entity.player.ServerPlayerEntity;
import net.minecraft.item.ItemStack;
import net.minecraft.util.ResourceLocation;
public class SandpaperUseTrigger extends CriterionTriggerBase<SandpaperUseTrigger.Instance> {
public SandpaperUseTrigger(String id) {
super(id);
}
@Override
public Instance deserializeInstance(JsonObject json, JsonDeserializationContext context) {
return new SandpaperUseTrigger.Instance(getId(), ItemPredicate.deserialize(json.get("target")),ItemPredicate.deserialize(json.get("result")));
}
public void trigger(ServerPlayerEntity player, ItemStack target, ItemStack result){
trigger(player, Arrays.asList(() -> target, () -> result));
}
public static class Instance extends CriterionTriggerBase.Instance {
private final ItemPredicate target;
private final ItemPredicate result;
public Instance(ResourceLocation idIn, ItemPredicate target, ItemPredicate result) {
super(idIn);
this.target = target;
this.result = result;
}
@Override
protected boolean test(List<Supplier<Object>> suppliers) {
return this.target.test((ItemStack) suppliers.get(0).get()) &&
this.result.test((ItemStack) suppliers.get(1).get());
}
}
}

View file

@ -9,7 +9,7 @@ import com.google.gson.JsonObject;
import net.minecraft.entity.player.ServerPlayerEntity; import net.minecraft.entity.player.ServerPlayerEntity;
import net.minecraft.util.ResourceLocation; import net.minecraft.util.ResourceLocation;
public class SimpleTrigger extends CriterionTriggerBase<SimpleTrigger.Instance> { public class SimpleTrigger extends CriterionTriggerBase<SimpleTrigger.Instance> implements ITriggerable {
public SimpleTrigger(String id) { public SimpleTrigger(String id) {
super(id); super(id);
@ -23,6 +23,10 @@ public class SimpleTrigger extends CriterionTriggerBase<SimpleTrigger.Instance>
public void trigger(ServerPlayerEntity player){ public void trigger(ServerPlayerEntity player){
super.trigger(player, null); super.trigger(player, null);
} }
public Instance instance() {
return new Instance(getId());
}
public static class Instance extends CriterionTriggerBase.Instance { public static class Instance extends CriterionTriggerBase.Instance {

View file

@ -1,5 +1,7 @@
package com.simibubi.create.foundation.utility.data; package com.simibubi.create.foundation.utility.data;
import com.simibubi.create.data.CreateAdvancements;
import net.minecraft.data.DataGenerator; import net.minecraft.data.DataGenerator;
import net.minecraftforge.eventbus.api.SubscribeEvent; import net.minecraftforge.eventbus.api.SubscribeEvent;
import net.minecraftforge.fml.common.Mod; import net.minecraftforge.fml.common.Mod;
@ -11,9 +13,9 @@ public class Generator {
@SubscribeEvent @SubscribeEvent
public static void gatherData(GatherDataEvent event){ public static void gatherData(GatherDataEvent event){
DataGenerator gen = event.getGenerator(); DataGenerator gen = event.getGenerator();
//gen.addProvider(AllSoundEvents.CUCKOO_PIG);
gen.addProvider(new AllBlocksTagProvider(gen)); gen.addProvider(new AllBlocksTagProvider(gen));
gen.addProvider(new AllItemsTagProvider(gen)); gen.addProvider(new AllItemsTagProvider(gen));
gen.addProvider(new CreateAdvancements(gen));
} }
} }

View file

@ -166,9 +166,13 @@ public abstract class KineticTileEntity extends SmartTileEntity
public void onSpeedChanged(float previousSpeed) { public void onSpeedChanged(float previousSpeed) {
boolean fromOrToZero = (previousSpeed == 0) != (getSpeed() == 0); boolean fromOrToZero = (previousSpeed == 0) != (getSpeed() == 0);
boolean directionSwap = !fromOrToZero && Math.signum(previousSpeed) != Math.signum(getSpeed()); boolean directionSwap = !fromOrToZero && Math.signum(previousSpeed) != Math.signum(getSpeed());
if (fromOrToZero || directionSwap) { if (fromOrToZero || directionSwap)
flickerTally = getFlickerScore() + 5; flickerTally = getFlickerScore() + 5;
}
if (fromOrToZero && previousSpeed == 0 && !world.isRemote)
AllTriggers
.getPlayersInRange(world, pos, 4)
.forEach(p -> AllTriggers.KINETIC_BLOCK.trigger(p, getBlockState()));
} }
@Override @Override
@ -368,8 +372,7 @@ public abstract class KineticTileEntity extends SmartTileEntity
} }
@Override @Override
public void addBehaviours(List<TileEntityBehaviour> behaviours) { public void addBehaviours(List<TileEntityBehaviour> behaviours) {}
}
@Override @Override
public boolean hasFastRenderer() { public boolean hasFastRenderer() {
@ -382,8 +385,9 @@ public abstract class KineticTileEntity extends SmartTileEntity
if (overStressed && AllConfigs.CLIENT.enableOverstressedTooltip.get()) { if (overStressed && AllConfigs.CLIENT.enableOverstressedTooltip.get()) {
tooltip.add(spacing + GOLD + Lang.translate("gui.stress_gauge.overstressed")); tooltip.add(spacing + GOLD + Lang.translate("gui.stress_gauge.overstressed"));
String hint = Lang.translate("gui.contraptions.network_overstressed", String hint = Lang
I18n.format(getBlockState().getBlock().getTranslationKey())); .translate("gui.contraptions.network_overstressed",
I18n.format(getBlockState().getBlock().getTranslationKey()));
List<String> cutString = TooltipHelper.cutString(spacing + hint, GRAY, TextFormatting.WHITE); List<String> cutString = TooltipHelper.cutString(spacing + hint, GRAY, TextFormatting.WHITE);
for (int i = 0; i < cutString.size(); i++) for (int i = 0; i < cutString.size(); i++)
tooltip.add((i == 0 ? "" : spacing) + cutString.get(i)); tooltip.add((i == 0 ? "" : spacing) + cutString.get(i));
@ -392,8 +396,9 @@ public abstract class KineticTileEntity extends SmartTileEntity
if (notFastEnough) { if (notFastEnough) {
tooltip.add(spacing + GOLD + Lang.translate("tooltip.speedRequirement")); tooltip.add(spacing + GOLD + Lang.translate("tooltip.speedRequirement"));
String hint = Lang.translate("gui.contraptions.not_fast_enough", String hint = Lang
I18n.format(getBlockState().getBlock().getTranslationKey())); .translate("gui.contraptions.not_fast_enough",
I18n.format(getBlockState().getBlock().getTranslationKey()));
List<String> cutString = TooltipHelper.cutString(spacing + hint, GRAY, TextFormatting.WHITE); List<String> cutString = TooltipHelper.cutString(spacing + hint, GRAY, TextFormatting.WHITE);
for (int i = 0; i < cutString.size(); i++) for (int i = 0; i < cutString.size(); i++)
tooltip.add((i == 0 ? "" : spacing) + cutString.get(i)); tooltip.add((i == 0 ? "" : spacing) + cutString.get(i));
@ -417,10 +422,14 @@ public abstract class KineticTileEntity extends SmartTileEntity
String stressString = String stressString =
spacing + "%s%s" + Lang.translate("generic.unit.stress") + " " + TextFormatting.DARK_GRAY + "%s"; spacing + "%s%s" + Lang.translate("generic.unit.stress") + " " + TextFormatting.DARK_GRAY + "%s";
tooltip.add(String.format(stressString, TextFormatting.AQUA, IHaveGoggleInformation.format(stressAtBase), tooltip
Lang.translate("gui.goggles.base_value"))); .add(String
tooltip.add(String.format(stressString, TextFormatting.GRAY, IHaveGoggleInformation.format(stressTotal), .format(stressString, TextFormatting.AQUA, IHaveGoggleInformation.format(stressAtBase),
Lang.translate("gui.goggles.at_current_speed"))); Lang.translate("gui.goggles.base_value")));
tooltip
.add(String
.format(stressString, TextFormatting.GRAY, IHaveGoggleInformation.format(stressTotal),
Lang.translate("gui.goggles.at_current_speed")));
added = true; added = true;
} }

View file

@ -7,6 +7,7 @@ import java.util.Optional;
import com.simibubi.create.AllRecipes; import com.simibubi.create.AllRecipes;
import com.simibubi.create.AllSoundEvents; import com.simibubi.create.AllSoundEvents;
import com.simibubi.create.AllTileEntities; import com.simibubi.create.AllTileEntities;
import com.simibubi.create.foundation.advancement.AllTriggers;
import com.simibubi.create.foundation.item.ItemHelper; import com.simibubi.create.foundation.item.ItemHelper;
import com.simibubi.create.foundation.utility.VecHelper; import com.simibubi.create.foundation.utility.VecHelper;
import com.simibubi.create.modules.contraptions.processing.BasinOperatingTileEntity; import com.simibubi.create.modules.contraptions.processing.BasinOperatingTileEntity;
@ -163,8 +164,10 @@ public class MechanicalPressTileEntity extends BasinOperatingTileEntity {
pressedItems.add(itemEntity.getItem()); pressedItems.add(itemEntity.getItem());
sendData(); sendData();
Optional<PressingRecipe> recipe = getRecipe(itemEntity.getItem()); Optional<PressingRecipe> recipe = getRecipe(itemEntity.getItem());
if (recipe.isPresent()) if (recipe.isPresent()) {
InWorldProcessing.applyRecipeOn(itemEntity, recipe.get()); InWorldProcessing.applyRecipeOn(itemEntity, recipe.get());
AllTriggers.triggerForNearbyPlayers(AllTriggers.BONK, world, pos, 4);
}
} }
} }
} }

View file

@ -2,11 +2,13 @@ package com.simibubi.create.modules.contraptions.components.waterwheel;
import com.simibubi.create.AllBlocks; import com.simibubi.create.AllBlocks;
import com.simibubi.create.config.AllConfigs; import com.simibubi.create.config.AllConfigs;
import com.simibubi.create.foundation.advancement.AllTriggers;
import com.simibubi.create.foundation.block.ITE; import com.simibubi.create.foundation.block.ITE;
import com.simibubi.create.modules.contraptions.base.HorizontalKineticBlock; import com.simibubi.create.modules.contraptions.base.HorizontalKineticBlock;
import net.minecraft.block.BlockState; import net.minecraft.block.BlockState;
import net.minecraft.block.Blocks; import net.minecraft.block.Blocks;
import net.minecraft.fluid.Fluids;
import net.minecraft.fluid.IFluidState; import net.minecraft.fluid.IFluidState;
import net.minecraft.item.BlockItemUseContext; import net.minecraft.item.BlockItemUseContext;
import net.minecraft.tileentity.TileEntity; import net.minecraft.tileentity.TileEntity;
@ -109,6 +111,12 @@ public class WaterWheelBlock extends HorizontalKineticBlock implements ITE<Water
if (f.getAxis() == Axis.Z) if (f.getAxis() == Axis.Z)
flowStrength = flow.y > 0 ^ !clockwise ? -flow.y * clockwiseMultiplier : -flow.y; flowStrength = flow.y > 0 ^ !clockwise ? -flow.y * clockwiseMultiplier : -flow.y;
} }
if (te.getSpeed() == 0 && flowStrength != 0 && !world.isRemote) {
AllTriggers.triggerForNearbyPlayers(AllTriggers.WATER_WHEEL, world, pos, 5);
if (fluid.getFluid() == Fluids.FLOWING_LAVA ||fluid.getFluid() == Fluids.LAVA)
AllTriggers.triggerForNearbyPlayers(AllTriggers.LAVA_WHEEL, world, pos, 5);
}
te.setFlow(f, (float) (flowStrength * AllConfigs.SERVER.kinetics.waterWheelSpeed.get() / 2f)); te.setFlow(f, (float) (flowStrength * AllConfigs.SERVER.kinetics.waterWheelSpeed.get() / 2f));
}); });
@ -125,8 +133,8 @@ public class WaterWheelBlock extends HorizontalKineticBlock implements ITE<Water
if (AllBlocks.WATER_WHEEL.typeOf(placedOn)) if (AllBlocks.WATER_WHEEL.typeOf(placedOn))
return getDefaultState().with(HORIZONTAL_FACING, placedOn.get(HORIZONTAL_FACING)); return getDefaultState().with(HORIZONTAL_FACING, placedOn.get(HORIZONTAL_FACING));
if (facing.getAxis().isHorizontal()) if (facing.getAxis().isHorizontal())
return getDefaultState().with(HORIZONTAL_FACING, return getDefaultState()
context.isPlacerSneaking() ? facing.getOpposite() : facing); .with(HORIZONTAL_FACING, context.isPlacerSneaking() ? facing.getOpposite() : facing);
return super.getStateForPlacement(context); return super.getStateForPlacement(context);
} }

View file

@ -1,6 +1,7 @@
package com.simibubi.create.modules.contraptions.processing; package com.simibubi.create.modules.contraptions.processing;
import com.simibubi.create.AllBlocks; import com.simibubi.create.AllBlocks;
import com.simibubi.create.foundation.advancement.AllTriggers;
import com.simibubi.create.foundation.block.ITE; import com.simibubi.create.foundation.block.ITE;
import com.simibubi.create.foundation.item.ItemHelper; import com.simibubi.create.foundation.item.ItemHelper;
import com.simibubi.create.foundation.utility.AllShapes; import com.simibubi.create.foundation.utility.AllShapes;
@ -80,6 +81,11 @@ public class BasinBlock extends Block implements ITE<BasinTileEntity> {
if (insertItem.isEmpty()) { if (insertItem.isEmpty()) {
itemEntity.remove(); itemEntity.remove();
if (!itemEntity.world.isRemote)
AllTriggers
.triggerForNearbyPlayers(AllTriggers.BASIN_THROW, itemEntity.world,
itemEntity.getPosition(), 3);
return; return;
} }

View file

@ -5,6 +5,9 @@ import java.util.List;
import java.util.Optional; import java.util.Optional;
import java.util.stream.Collectors; import java.util.stream.Collectors;
import com.simibubi.create.AllTileEntities;
import com.simibubi.create.foundation.advancement.AllTriggers;
import com.simibubi.create.foundation.advancement.SimpleTrigger;
import com.simibubi.create.foundation.behaviour.base.TileEntityBehaviour; import com.simibubi.create.foundation.behaviour.base.TileEntityBehaviour;
import com.simibubi.create.foundation.behaviour.simple.DeferralBehaviour; import com.simibubi.create.foundation.behaviour.simple.DeferralBehaviour;
import com.simibubi.create.foundation.utility.recipe.RecipeFinder; import com.simibubi.create.foundation.utility.recipe.RecipeFinder;
@ -149,6 +152,13 @@ public abstract class BasinOperatingTileEntity extends KineticTileEntity {
// something wasn't found // something wasn't found
return; return;
} }
if (!world.isRemote) {
SimpleTrigger trigger = AllTriggers.MIXER_MIX;
if (getType() == AllTileEntities.MECHANICAL_PRESS.type)
trigger = AllTriggers.PRESS_COMPACT;
AllTriggers.triggerForNearbyPlayers(trigger, world, pos, 4);
}
ItemHandlerHelper.insertItemStacked(outputs, lastRecipe.getRecipeOutput().copy(), false); ItemHandlerHelper.insertItemStacked(outputs, lastRecipe.getRecipeOutput().copy(), false);
containers.forEach(stack -> ItemHandlerHelper.insertItemStacked(outputs, stack, false)); containers.forEach(stack -> ItemHandlerHelper.insertItemStacked(outputs, stack, false));

View file

@ -5,6 +5,7 @@ import java.util.List;
import com.simibubi.create.AllBlocks; import com.simibubi.create.AllBlocks;
import com.simibubi.create.config.AllConfigs; import com.simibubi.create.config.AllConfigs;
import com.simibubi.create.foundation.advancement.AllTriggers;
import com.simibubi.create.foundation.item.IAddedByOther; import com.simibubi.create.foundation.item.IAddedByOther;
import com.simibubi.create.modules.contraptions.base.KineticTileEntity; import com.simibubi.create.modules.contraptions.base.KineticTileEntity;
import com.simibubi.create.modules.contraptions.relays.belt.BeltBlock; import com.simibubi.create.modules.contraptions.relays.belt.BeltBlock;
@ -71,9 +72,9 @@ public class BeltConnectorItem extends BlockItem implements IAddedByOther {
if (!canConnect(world, firstPulley, pos)) if (!canConnect(world, firstPulley, pos))
return ActionResultType.FAIL; return ActionResultType.FAIL;
if (firstPulley != null && !firstPulley.equals(pos)) { if (firstPulley != null && !firstPulley.equals(pos) && !world.isRemote) {
createBelts(world, firstPulley, pos); createBelts(world, firstPulley, pos);
AllTriggers.triggerFor(AllTriggers.CONNECT_BELT, context.getPlayer());
if (!context.getPlayer().isCreative()) if (!context.getPlayer().isCreative())
context.getItem().shrink(1); context.getItem().shrink(1);
} }

View file

@ -1,10 +1,13 @@
package com.simibubi.create.modules.contraptions.relays.elementary; package com.simibubi.create.modules.contraptions.relays.elementary;
import com.simibubi.create.AllBlocks; import com.simibubi.create.AllBlocks;
import com.simibubi.create.foundation.advancement.AllTriggers;
import com.simibubi.create.foundation.utility.Iterate;
import com.simibubi.create.foundation.utility.VecHelper; import com.simibubi.create.foundation.utility.VecHelper;
import net.minecraft.block.Block; import net.minecraft.block.Block;
import net.minecraft.block.BlockState; import net.minecraft.block.BlockState;
import net.minecraft.entity.player.PlayerEntity;
import net.minecraft.item.BlockItem; import net.minecraft.item.BlockItem;
import net.minecraft.item.BlockItemUseContext; import net.minecraft.item.BlockItemUseContext;
import net.minecraft.util.ActionResultType; import net.minecraft.util.ActionResultType;
@ -13,6 +16,7 @@ import net.minecraft.util.Direction.Axis;
import net.minecraft.util.Direction.AxisDirection; import net.minecraft.util.Direction.AxisDirection;
import net.minecraft.util.math.BlockPos; import net.minecraft.util.math.BlockPos;
import net.minecraft.util.math.Vec3d; import net.minecraft.util.math.Vec3d;
import net.minecraft.world.World;
public class CogwheelBlockItem extends BlockItem { public class CogwheelBlockItem extends BlockItem {
@ -54,8 +58,8 @@ public class CogwheelBlockItem extends BlockItem {
hitVec = hitVec hitVec = hitVec
.mul(new Vec3d(Direction.getFacingFromAxis(AxisDirection.POSITIVE, offsetAxis).getDirectionVec())); .mul(new Vec3d(Direction.getFacingFromAxis(AxisDirection.POSITIVE, offsetAxis).getDirectionVec()));
BlockPos correctPos = context.getPos().add(Math.signum(hitVec.x), Math.signum(hitVec.y), BlockPos correctPos =
Math.signum(hitVec.z)); context.getPos().add(Math.signum(hitVec.x), Math.signum(hitVec.y), Math.signum(hitVec.z));
if (context.getWorld().getBlockState(correctPos).getMaterial().isReplaceable()) if (context.getWorld().getBlockState(correctPos).getMaterial().isReplaceable())
context = BlockItemUseContext.func_221536_a(context, correctPos, largeOnLarge ? face context = BlockItemUseContext.func_221536_a(context, correctPos, largeOnLarge ? face
@ -67,4 +71,41 @@ public class CogwheelBlockItem extends BlockItem {
return super.tryPlace(context); return super.tryPlace(context);
} }
@Override
// Trigger cogwheel criterion
protected boolean placeBlock(BlockItemUseContext context, BlockState state) {
World world = context.getWorld();
PlayerEntity player = context.getPlayer();
if (!world.isRemote && player != null) {
Axis axis = state.get(CogWheelBlock.AXIS);
for (Axis perpendicular1 : Iterate.axes) {
if (perpendicular1 == axis)
continue;
Direction d1 = Direction.getFacingFromAxis(AxisDirection.POSITIVE, perpendicular1);
for (Axis perpendicular2 : Iterate.axes) {
if (perpendicular1 == perpendicular2)
continue;
if (axis == perpendicular2)
continue;
Direction d2 = Direction.getFacingFromAxis(AxisDirection.POSITIVE, perpendicular2);
for (int offset1 : Iterate.positiveAndNegative) {
for (int offset2 : Iterate.positiveAndNegative) {
BlockPos connectedPos = context.getPos().offset(d1, offset1).offset(d2, offset2);
BlockState blockState = world.getBlockState(connectedPos);
if (!(blockState.getBlock() instanceof CogWheelBlock))
continue;
if (blockState.get(CogWheelBlock.AXIS) != axis)
continue;
if (AllBlocks.LARGE_COGWHEEL.typeOf(blockState) == large)
continue;
AllTriggers.triggerFor(AllTriggers.SHIFTING_GEARS, player);
}
}
}
}
}
return super.placeBlock(context, state);
}
} }

View file

@ -1,10 +1,8 @@
package com.simibubi.create.modules.curiosities.tools; package com.simibubi.create.modules.curiosities.tools;
import com.simibubi.create.foundation.advancement.AllTriggers;
import com.simibubi.create.foundation.block.render.CustomRenderedItemModel; import com.simibubi.create.foundation.block.render.CustomRenderedItemModel;
import com.simibubi.create.foundation.item.IHaveCustomItemModel; import com.simibubi.create.foundation.item.IHaveCustomItemModel;
import com.simibubi.create.foundation.utility.VecHelper; import com.simibubi.create.foundation.utility.VecHelper;
import com.simibubi.create.modules.contraptions.components.deployer.DeployerFakePlayer;
import com.simibubi.create.modules.curiosities.tools.SandPaperItemRenderer.SandPaperModel; import com.simibubi.create.modules.curiosities.tools.SandPaperItemRenderer.SandPaperModel;
import net.minecraft.client.renderer.model.IBakedModel; import net.minecraft.client.renderer.model.IBakedModel;
@ -12,7 +10,6 @@ import net.minecraft.enchantment.Enchantment;
import net.minecraft.entity.LivingEntity; import net.minecraft.entity.LivingEntity;
import net.minecraft.entity.item.ItemEntity; import net.minecraft.entity.item.ItemEntity;
import net.minecraft.entity.player.PlayerEntity; import net.minecraft.entity.player.PlayerEntity;
import net.minecraft.entity.player.ServerPlayerEntity;
import net.minecraft.item.Item; import net.minecraft.item.Item;
import net.minecraft.item.ItemStack; import net.minecraft.item.ItemStack;
import net.minecraft.item.ItemUseContext; import net.minecraft.item.ItemUseContext;
@ -31,6 +28,7 @@ import net.minecraft.util.math.Vec3d;
import net.minecraft.world.World; import net.minecraft.world.World;
import net.minecraftforge.api.distmarker.Dist; import net.minecraftforge.api.distmarker.Dist;
import net.minecraftforge.api.distmarker.OnlyIn; import net.minecraftforge.api.distmarker.OnlyIn;
import net.minecraftforge.common.util.FakePlayer;
public class SandPaperItem extends Item implements IHaveCustomItemModel { public class SandPaperItem extends Item implements IHaveCustomItemModel {
@ -136,11 +134,9 @@ public class SandPaperItem extends Item implements IHaveCustomItemModel {
} }
if (!polished.isEmpty()) { if (!polished.isEmpty()) {
if (player instanceof DeployerFakePlayer) { if (player instanceof FakePlayer) {
player.dropItem(polished, false, false); player.dropItem(polished, false, false);
} else { } else {
AllTriggers.SANDPAPER_USE.trigger((ServerPlayerEntity) player, toPolish, polished);
player.inventory.placeItemBackInInventory(worldIn, polished); player.inventory.placeItemBackInInventory(worldIn, polished);
} }
} }

View file

@ -0,0 +1,81 @@
package com.simibubi.create.modules.logistics.block.inventories;
import com.simibubi.create.foundation.block.ProperDirectionalBlock;
import com.simibubi.create.foundation.utility.AllShapes;
import net.minecraft.block.Block;
import net.minecraft.block.BlockState;
import net.minecraft.item.BlockItemUseContext;
import net.minecraft.state.BooleanProperty;
import net.minecraft.state.StateContainer.Builder;
import net.minecraft.util.Direction;
import net.minecraft.util.math.BlockPos;
import net.minecraft.util.math.shapes.ISelectionContext;
import net.minecraft.util.math.shapes.VoxelShape;
import net.minecraft.world.IBlockReader;
import net.minecraft.world.IWorld;
import net.minecraft.world.World;
public class CrateBlock extends ProperDirectionalBlock {
public static final BooleanProperty DOUBLE = BooleanProperty.create("double");
public CrateBlock(Properties p_i48415_1_) {
super(p_i48415_1_);
setDefaultState(getDefaultState().with(FACING, Direction.UP).with(DOUBLE, false));
}
@Override
public VoxelShape getShape(BlockState state, IBlockReader worldIn, BlockPos pos, ISelectionContext context) {
return AllShapes.CRATE_BLOCK_SHAPE;
}
@Override
public BlockState updatePostPlacement(BlockState stateIn, Direction facing, BlockState facingState, IWorld worldIn,
BlockPos currentPos, BlockPos facingPos) {
boolean isDouble = stateIn.get(DOUBLE);
Direction blockFacing = stateIn.get(FACING);
boolean isFacingOther = facingState.getBlock() == this && facingState.get(DOUBLE)
&& facingState.get(FACING) == facing.getOpposite();
if (!isDouble) {
if (!isFacingOther)
return stateIn;
return stateIn.with(DOUBLE, true).with(FACING, facing);
}
if (facing != blockFacing)
return stateIn;
if (!isFacingOther)
return stateIn.with(DOUBLE, false);
return stateIn;
}
@Override
public BlockState getStateForPlacement(BlockItemUseContext context) {
BlockPos pos = context.getPos();
World world = context.getWorld();
if (!context.isPlacerSneaking()) {
for (Direction d : Direction.values()) {
BlockState state = world.getBlockState(pos.offset(d));
if (state.getBlock() == this && !state.get(DOUBLE))
return getDefaultState().with(FACING, d).with(DOUBLE, true);
}
}
Direction placedOnFace = context.getFace().getOpposite();
BlockState state = world.getBlockState(pos.offset(placedOnFace));
if (state.getBlock() == this && !state.get(DOUBLE))
return getDefaultState().with(FACING, placedOnFace).with(DOUBLE, true);
return getDefaultState();
}
@Override
protected void fillStateContainer(Builder<Block, BlockState> builder) {
super.fillStateContainer(builder.add(DOUBLE));
}
}

View file

@ -1,74 +1,36 @@
package com.simibubi.create.modules.logistics.block.inventories; package com.simibubi.create.modules.logistics.block.inventories;
import com.simibubi.create.AllBlocks; import com.simibubi.create.AllBlocks;
import com.simibubi.create.foundation.block.ProperDirectionalBlock;
import com.simibubi.create.foundation.item.ItemHelper; import com.simibubi.create.foundation.item.ItemHelper;
import com.simibubi.create.foundation.utility.AllShapes;
import net.minecraft.block.Block;
import net.minecraft.block.BlockState; import net.minecraft.block.BlockState;
import net.minecraft.block.Blocks; import net.minecraft.block.Blocks;
import net.minecraft.entity.player.PlayerEntity; import net.minecraft.entity.player.PlayerEntity;
import net.minecraft.entity.player.ServerPlayerEntity; import net.minecraft.entity.player.ServerPlayerEntity;
import net.minecraft.item.BlockItemUseContext;
import net.minecraft.item.ItemStack; import net.minecraft.item.ItemStack;
import net.minecraft.state.BooleanProperty;
import net.minecraft.state.StateContainer.Builder;
import net.minecraft.tileentity.TileEntity; import net.minecraft.tileentity.TileEntity;
import net.minecraft.util.Direction;
import net.minecraft.util.Direction.AxisDirection; import net.minecraft.util.Direction.AxisDirection;
import net.minecraft.util.Hand; import net.minecraft.util.Hand;
import net.minecraft.util.math.BlockPos; import net.minecraft.util.math.BlockPos;
import net.minecraft.util.math.BlockRayTraceResult; import net.minecraft.util.math.BlockRayTraceResult;
import net.minecraft.util.math.shapes.ISelectionContext;
import net.minecraft.util.math.shapes.VoxelShape;
import net.minecraft.world.IBlockReader; import net.minecraft.world.IBlockReader;
import net.minecraft.world.IWorld;
import net.minecraft.world.World; import net.minecraft.world.World;
import net.minecraftforge.fml.network.NetworkHooks; import net.minecraftforge.fml.network.NetworkHooks;
public class FlexcrateBlock extends ProperDirectionalBlock { public class FlexcrateBlock extends CrateBlock {
public static final BooleanProperty DOUBLE = BooleanProperty.create("double");
public FlexcrateBlock() { public FlexcrateBlock() {
super(Properties.from(Blocks.ANDESITE)); super(Properties.from(Blocks.ANDESITE));
setDefaultState(getDefaultState().with(FACING, Direction.UP).with(DOUBLE, false));
}
@Override
public VoxelShape getShape(BlockState state, IBlockReader worldIn, BlockPos pos, ISelectionContext context) {
return AllShapes.CRATE_BLOCK_SHAPE;
}
@Override
protected void fillStateContainer(Builder<Block, BlockState> builder) {
super.fillStateContainer(builder.add(DOUBLE));
} }
@Override @Override
public boolean hasTileEntity(BlockState state) { public boolean hasTileEntity(BlockState state) {
return true; return true;
} }
@Override @Override
public BlockState getStateForPlacement(BlockItemUseContext context) { public TileEntity createTileEntity(BlockState state, IBlockReader world) {
BlockPos pos = context.getPos(); return new FlexcrateTileEntity();
World world = context.getWorld();
if (!context.isPlacerSneaking()) {
for (Direction d : Direction.values()) {
BlockState state = world.getBlockState(pos.offset(d));
if (AllBlocks.FLEXCRATE.typeOf(state) && !state.get(DOUBLE))
return getDefaultState().with(FACING, d).with(DOUBLE, true);
}
}
Direction placedOnFace = context.getFace().getOpposite();
BlockState state = world.getBlockState(pos.offset(placedOnFace));
if (AllBlocks.FLEXCRATE.typeOf(state) && !state.get(DOUBLE))
return getDefaultState().with(FACING, placedOnFace).with(DOUBLE, true);
return getDefaultState();
} }
@Override @Override
@ -93,29 +55,6 @@ public class FlexcrateBlock extends ProperDirectionalBlock {
} }
} }
@Override
public BlockState updatePostPlacement(BlockState stateIn, Direction facing, BlockState facingState, IWorld worldIn,
BlockPos currentPos, BlockPos facingPos) {
boolean isDouble = stateIn.get(DOUBLE);
Direction blockFacing = stateIn.get(FACING);
boolean isFacingOther = AllBlocks.FLEXCRATE.typeOf(facingState) && facingState.get(DOUBLE)
&& facingState.get(FACING) == facing.getOpposite();
if (!isDouble) {
if (!isFacingOther)
return stateIn;
return stateIn.with(DOUBLE, true).with(FACING, facing);
}
if (facing != blockFacing)
return stateIn;
if (!isFacingOther)
return stateIn.with(DOUBLE, false);
return stateIn;
}
@Override @Override
public boolean onBlockActivated(BlockState state, World worldIn, BlockPos pos, PlayerEntity player, Hand handIn, public boolean onBlockActivated(BlockState state, World worldIn, BlockPos pos, PlayerEntity player, Hand handIn,
BlockRayTraceResult hit) { BlockRayTraceResult hit) {
@ -133,11 +72,6 @@ public class FlexcrateBlock extends ProperDirectionalBlock {
} }
} }
@Override
public TileEntity createTileEntity(BlockState state, IBlockReader world) {
return new FlexcrateTileEntity();
}
public static void splitCrate(World world, BlockPos pos) { public static void splitCrate(World world, BlockPos pos) {
BlockState state = world.getBlockState(pos); BlockState state = world.getBlockState(pos);
if (!AllBlocks.FLEXCRATE.typeOf(state)) if (!AllBlocks.FLEXCRATE.typeOf(state))

View file

@ -1,36 +0,0 @@
package com.simibubi.create.modules.schematics.block;
import com.simibubi.create.foundation.utility.AllShapes;
import net.minecraft.block.Block;
import net.minecraft.block.BlockState;
import net.minecraft.block.material.Material;
import net.minecraft.item.ItemGroup;
import net.minecraft.item.ItemStack;
import net.minecraft.util.NonNullList;
import net.minecraft.util.math.BlockPos;
import net.minecraft.util.math.shapes.ISelectionContext;
import net.minecraft.util.math.shapes.VoxelShape;
import net.minecraft.world.IBlockReader;
public class CreativeCrateBlock extends Block {
public CreativeCrateBlock() {
super(Properties.create(Material.WOOD));
}
@Override
public boolean isSolid(BlockState state) {
return false;
}
@Override
public void fillItemGroup(ItemGroup group, NonNullList<ItemStack> items) {
}
@Override
public VoxelShape getShape(BlockState state, IBlockReader worldIn, BlockPos pos, ISelectionContext context) {
return AllShapes.CRATE_BLOCK_SHAPE;
}
}

View file

@ -1,6 +1,17 @@
{ {
"forgemarker": 1,
"variants": { "variants": {
"": { "model": "create:block/creative_crate" } "double=true,facing=up": { "model": "create:block/crate/creative/double_bottom" },
"double=true,facing=down": { "model": "create:block/crate/creative/double_top" },
"double=true,facing=west": { "model": "create:block/crate/creative/double_left", "y": 90 },
"double=true,facing=east": { "model": "create:block/crate/creative/double_right", "y": 90 },
"double=true,facing=north": { "model": "create:block/crate/creative/double_right" },
"double=true,facing=south": { "model": "create:block/crate/creative/double_left" },
"double=false,facing=up": { "model": "create:block/crate/creative/single" },
"double=false,facing=down": { "model": "create:block/crate/creative/single" },
"double=false,facing=west": { "model": "create:block/crate/creative/single" },
"double=false,facing=east": { "model": "create:block/crate/creative/single" },
"double=false,facing=north": { "model": "create:block/crate/creative/single" },
"double=false,facing=south": { "model": "create:block/crate/creative/single" }
} }
} }

View file

@ -0,0 +1,17 @@
{
"variants": {
"double=true,facing=up": { "model": "create:block/crate/copper/double_bottom" },
"double=true,facing=down": { "model": "create:block/crate/copper/double_top" },
"double=true,facing=west": { "model": "create:block/crate/copper/double_left", "y": 90 },
"double=true,facing=east": { "model": "create:block/crate/copper/double_right", "y": 90 },
"double=true,facing=north": { "model": "create:block/crate/copper/double_right" },
"double=true,facing=south": { "model": "create:block/crate/copper/double_left" },
"double=false,facing=up": { "model": "create:block/crate/copper/single" },
"double=false,facing=down": { "model": "create:block/crate/copper/single" },
"double=false,facing=west": { "model": "create:block/crate/copper/single" },
"double=false,facing=east": { "model": "create:block/crate/copper/single" },
"double=false,facing=north": { "model": "create:block/crate/copper/single" },
"double=false,facing=south": { "model": "create:block/crate/copper/single" }
}
}

View file

@ -1,17 +1,17 @@
{ {
"variants": { "variants": {
"double=true,facing=up": { "model": "create:block/flexcrate/double_bottom" }, "double=true,facing=up": { "model": "create:block/crate/brass/double_bottom" },
"double=true,facing=down": { "model": "create:block/flexcrate/double_top" }, "double=true,facing=down": { "model": "create:block/crate/brass/double_top" },
"double=true,facing=west": { "model": "create:block/flexcrate/double_left", "y": 90 }, "double=true,facing=west": { "model": "create:block/crate/brass/double_left", "y": 90 },
"double=true,facing=east": { "model": "create:block/flexcrate/double_right", "y": 90 }, "double=true,facing=east": { "model": "create:block/crate/brass/double_right", "y": 90 },
"double=true,facing=north": { "model": "create:block/flexcrate/double_right" }, "double=true,facing=north": { "model": "create:block/crate/brass/double_right" },
"double=true,facing=south": { "model": "create:block/flexcrate/double_left" }, "double=true,facing=south": { "model": "create:block/crate/brass/double_left" },
"double=false,facing=up": { "model": "create:block/flexcrate/single" }, "double=false,facing=up": { "model": "create:block/crate/brass/single" },
"double=false,facing=down": { "model": "create:block/flexcrate/single" }, "double=false,facing=down": { "model": "create:block/crate/brass/single" },
"double=false,facing=west": { "model": "create:block/flexcrate/single" }, "double=false,facing=west": { "model": "create:block/crate/brass/single" },
"double=false,facing=east": { "model": "create:block/flexcrate/single" }, "double=false,facing=east": { "model": "create:block/crate/brass/single" },
"double=false,facing=north": { "model": "create:block/flexcrate/single" }, "double=false,facing=north": { "model": "create:block/crate/brass/single" },
"double=false,facing=south": { "model": "create:block/flexcrate/single" } "double=false,facing=south": { "model": "create:block/crate/brass/single" }
} }
} }

View file

@ -0,0 +1,17 @@
{
"variants": {
"double=true,facing=up": { "model": "create:block/crate/andesite/double_bottom" },
"double=true,facing=down": { "model": "create:block/crate/andesite/double_top" },
"double=true,facing=west": { "model": "create:block/crate/andesite/double_left", "y": 90 },
"double=true,facing=east": { "model": "create:block/crate/andesite/double_right", "y": 90 },
"double=true,facing=north": { "model": "create:block/crate/andesite/double_right" },
"double=true,facing=south": { "model": "create:block/crate/andesite/double_left" },
"double=false,facing=up": { "model": "create:block/crate/andesite/single" },
"double=false,facing=down": { "model": "create:block/crate/andesite/single" },
"double=false,facing=west": { "model": "create:block/crate/andesite/single" },
"double=false,facing=east": { "model": "create:block/crate/andesite/single" },
"double=false,facing=north": { "model": "create:block/crate/andesite/single" },
"double=false,facing=south": { "model": "create:block/crate/andesite/single" }
}
}

View file

@ -131,7 +131,10 @@
"block.create.contact": "Redstone Contact", "block.create.contact": "Redstone Contact",
"block.create.redstone_bridge": "Redstone Link", "block.create.redstone_bridge": "Redstone Link",
"block.create.stockswitch": "Stockpile Switch", "block.create.stockswitch": "Stockpile Switch",
"block.create.warehouse_crate": "Warehouse Crate",
"block.create.flexcrate": "Adjustable Crate", "block.create.flexcrate": "Adjustable Crate",
"block.create.filtered_crate": "Filtered Crate",
"block.create.creative_crate": "The Endless Crate",
"block.create.extractor": "Extractor", "block.create.extractor": "Extractor",
"block.create.belt_funnel": "Funnel", "block.create.belt_funnel": "Funnel",
"block.create.linked_extractor": "Linked Extractor", "block.create.linked_extractor": "Linked Extractor",
@ -256,7 +259,6 @@
"block.create.schematicannon": "Schematicannon", "block.create.schematicannon": "Schematicannon",
"block.create.schematic_table": "Schematic Table", "block.create.schematic_table": "Schematic Table",
"block.create.creative_crate": "Schematicannon Creatifier",
"block.create.cocoa_log": "Cocoa Jungle Log", "block.create.cocoa_log": "Cocoa Jungle Log",
@ -272,7 +274,6 @@
"death.attack.create.drill": "%1$s was impaled by Mechanical Drill", "death.attack.create.drill": "%1$s was impaled by Mechanical Drill",
"death.attack.create.saw": "%1$s got cut in half by Mechanical Saw", "death.attack.create.saw": "%1$s got cut in half by Mechanical Saw",
"create.block.deployer.damage_source_name": "a rogue Deployer", "create.block.deployer.damage_source_name": "a rogue Deployer",
"death.attack.create.curse_polish": "%1$s tried to polish a cursed item",
"death.attack.create.cuckoo_clock_explosion": "%1$s was blown up by tampered cuckoo clock", "death.attack.create.cuckoo_clock_explosion": "%1$s was blown up by tampered cuckoo clock",
"create.recipe.crushing": "Crushing", "create.recipe.crushing": "Crushing",
@ -628,47 +629,77 @@
"create.command.killTPSCommand.status.usage.1": "[Create]: use /killtps start <tickTime> to artificially slow down the server tick", "create.command.killTPSCommand.status.usage.1": "[Create]: use /killtps start <tickTime> to artificially slow down the server tick",
"create.command.killTPSCommand.argument.tickTime": "tickTime", "create.command.killTPSCommand.argument.tickTime": "tickTime",
"advancement.create:root": "In the beginning, let's Create!", "advancement.create.root": "Welcome to Create",
"advancement.create:root.desc": "It's time to start building some amazing Contraptions!", "advancement.create.root.desc": "It's time to start building some amazing Contraptions!",
"advancement.create:andesite_alloy": "Alliterations Aplenty", "advancement.create.andesite_alloy": "Alliterations Aplenty",
"advancement.create:andesite_alloy.desc": "Create's materials have weird names, Andesite Alloy is one of them.", "advancement.create.andesite_alloy.desc": "Create's materials have weird names, Andesite Alloy is one of them.",
"advancement.create:andesite_casing": "The Andesite Age ",
"advancement.create:andesite_casing.desc": "Use some Andesite, Meta, and Wood to create a basic Casing.",
"advancement.create:crushing_wheel": "A Pair of Giants",
"advancement.create:crushing_wheel.desc": "Create some Crushing Wheels to break down materials.",
"advancement.create:rotation": "It's Alive!",
"advancement.create:rotation.desc": "Watch your first kinetic component spin.",
"advancement.create:overstressed": "Overstressed",
"advancement.create:overstressed.desc": "Experience the laws of physics firsthand.",
"advancement.create:sand_paper": "Power Polish",
"advancement.create:sand_paper.desc": "Create some Sand Paper to make things pretty.",
"advancement.create:polished_rose_quartz": "Pink Diamonds",
"advancement.create:polished_rose_quartz.desc": "Polish Rose Quartz until you can see through it.",
"advancement.create:sand_paper_secret": "9001 Grit Sand Paper",
"advancement.create:sand_paper_secret.desc": "Use your Sand Paper to sand some Sand Paper.",
"advancement.create:press": "'Bonk!'",
"advancement.create:press.desc": "Make a Mechanical Press and use it to create some Plates.",
"advancement.create:mixer": "Mixin' it Up",
"advancement.create:mixer.desc": "Create a Mechanical Mixer.",
"advancement.create:brass": "An Actual Alloy",
"advancement.create:brass.desc": "Use Copper and Zinc to create some Brass.",
"advancement.create:brass_casing": "The Brass Age",
"advancement.create:brass_casing.desc": "Use newly obtained Brass and some Wood to create a more advanced Casing.",
"advancement.create:deployer": "Poke, Place, and Attack",
"advancement.create:deployer.desc": "Create a Deployer, the perfect reflection of yourself.",
"advancement.create:deployer_secret": "Pound It, Bro!",
"advancement.create:deployer_secret.desc": "Make two Deployers fist-bump.",
"advancement.create:chromatic_compound": "Bipolar Materials",
"advancement.create:chromatic_compound.desc": "Craft a Bar of Chromatic Compound.",
"advancement.create:shadow_steel": "Void Returner",
"advancement.create:shadow_steel.desc": "Create Shadow Steel, a metal bar of nothingness.",
"advancement.create:refined_radiance": "Bright and Inspiring",
"advancement.create:refined_radiance.desc": "Create Refined Radiance, a powerful chromatic substance.",
"advancement.create:refined_radiance_secret": "Forged by the Beam of Light",
"advancement.create:refined_radiance_secret.desc": "Find the alternative way to make Refined Radiance.",
"advancement.create:speed_secret": "Nice ",
"advancement.create:speed_secret.desc": "Watch a Speedometer reach exactly 69 rpm.",
"advancement.create.its_alive": "It's Alive!",
"advancement.create.its_alive.desc": "Watch your first kinetic component spin.",
"advancement.create.shifting_gears": "Shifting Gear",
"advancement.create.shifting_gears.desc": "Connect a large to a small cogwheel allowing you to change the speed of your contraption.",
"advancement.create.overstressed": "Overstressed",
"advancement.create.overstressed.desc": "Experience the limits of stress firsthand.",
"advancement.create.belt": "Convey it all",
"advancement.create.belt.desc": "Connect two shafts with a Mechanical Belt.",
"advancement.create.wrench": "Configure Conveniently",
"advancement.create.wrench.desc": "Create a Wrench to aid you in building your contraptions.",
"advancement.create.goggles": "Stress-o-vision",
"advancement.create.goggles.desc": "Create some goggles to aid you in getting more kinetic information for components.",
"advancement.create.speed_gauge": "But how fast exactly?",
"advancement.create.speed_gauge.desc": "Place and power a Speedometer. Look at it through your goggles to read its exact value.",
"advancement.create.stress_gauge": "But how stressed exactly?",
"advancement.create.stress_gauge.desc": "Place and power a Stressometer. Look at it through your goggles to read its exact value.",
"advancement.create.water_wheel": "Harnessing Hydraulics",
"advancement.create.water_wheel.desc": "Place a Water Wheel and try getting it to spin!",
"advancement.create.lava_wheel": "Magma Wheel",
"advancement.create.lava_wheel.desc": "This shouldn't have worked.",
"advancement.create.millstone": "Pocket Crusher",
"advancement.create.millstone.desc": "Place and power a Millstone",
"advancement.create.andesite_casing": "The Andesite Age",
"advancement.create.andesite_casing.desc": "Use some Andesite Alloy and Wood to create a basic Casing.",
"advancement.create.drill": "Stationary breakers",
"advancement.create.drill.desc": "Place and power a Mechanical Drill",
"advancement.create.press": "Press goes 'Bonk!'",
"advancement.create.press.desc": "Power a Mechanical Press and use it to create some Plates.",
"advancement.create.polished_rose_quartz": "Pink Diamonds",
"advancement.create.polished_rose_quartz.desc": "Use a piece of sand paper to polish Rose Quartz until it becomes transparent.",
"advancement.create.electron_tube": "Beep boop",
"advancement.create.electron_tube.desc": "Make some Electron Tubes, useful in crafting less primitive machinery.",
"advancement.create.saw": "Stationary Chopping",
"advancement.create.saw.desc": "Place and power a Mechanical Saw",
"advancement.create.basin": "Basin Operation",
"advancement.create.basin.desc": "Place a basin and try throwing items into it.",
"advancement.create.mixer": "Mixin' it Up",
"advancement.create.mixer.desc": "Place a Mechanical Mixer above the basin, power it, and start mixing some ingredients.",
"advancement.create.compact": "Automated Compacting",
"advancement.create.compact.desc": "Use a press and a basin to compact some items.",
"advancement.create.expert_lane_1": "The Andesite Expert Lane",
"advancement.create.expert_lane_1.desc": "Work in Progress",
"advancement.create.brass": "An Actual Alloy",
"advancement.create.brass.desc": "Use Crushed Copper and Crushed Zinc to create some Brass.",
"advancement.create.brass_casing": "The Brass Age",
"advancement.create.brass_casing.desc": "Use newly obtained Brass and some Wood to create a more advanced Casing.",
"advancement.create.crafter": "Automated Assembly",
"advancement.create.crafter.desc": "Place and power some Mechanical Crafters",
"advancement.create.deployer": "Poke, Place, and Attack",
"advancement.create.deployer.desc": "Place and power a Deployer, the perfect reflection of yourself.",
"advancement.create.fist_bump": "Pound It, Bro!",
"advancement.create.fist_bump.desc": "Make two Deployers fist-bump.",
"advancement.create.crushing_wheel": "A Pair of Giants",
"advancement.create.crushing_wheel.desc": "Create some Crushing Wheels to break down more materials more effectively.",
"advancement.create.chromatic_compound": "Bipolar Minerals",
"advancement.create.chromatic_compound.desc": "Create a Bar of Chromatic Compound.",
"advancement.create.shadow_steel": "Void Returner",
"advancement.create.shadow_steel.desc": "Create Shadow Steel, a metal bar of nothingness.",
"advancement.create.refined_radiance": "Bright and Inspiring",
"advancement.create.refined_radiance.desc": "Create Refined Radiance, a powerful chromatic substance.",
"create.subtitle.schematicannon_launch_block": "Schematicannon shoots", "create.subtitle.schematicannon_launch_block": "Schematicannon shoots",
"create.subtitle.schematicannon_finish": "Schematicannon finishes", "create.subtitle.schematicannon_finish": "Schematicannon finishes",
"create.subtitle.slime_added": "Slime squishes", "create.subtitle.slime_added": "Slime squishes",
@ -769,9 +800,6 @@
"item.create.blueprint_and_quill.tooltip.control3": "R-Click while Sneaking", "item.create.blueprint_and_quill.tooltip.control3": "R-Click while Sneaking",
"item.create.blueprint_and_quill.tooltip.action3": "_Resets_ and removes the selection.", "item.create.blueprint_and_quill.tooltip.action3": "_Resets_ and removes the selection.",
"block.create.creative_crate.tooltip": "CREATIVE CRATE",
"block.create.creative_crate.tooltip.summary": "Provides an endless supply of blocks to adjacent _Schematicannons_.",
"block.create.schematicannon.tooltip": "SCHEMATICANNON", "block.create.schematicannon.tooltip": "SCHEMATICANNON",
"block.create.schematicannon.tooltip.summary": "Shoots blocks to recreate a deployed _Schematic_ in the World. Uses items from adjacent Inventories and _Gunpowder_ as fuel.", "block.create.schematicannon.tooltip.summary": "Shoots blocks to recreate a deployed _Schematic_ in the World. Uses items from adjacent Inventories and _Gunpowder_ as fuel.",
"block.create.schematicannon.tooltip.control1": "When R-Clicked", "block.create.schematicannon.tooltip.control1": "When R-Clicked",
@ -1176,5 +1204,9 @@
"tool.create.rose_quartz.tooltip": "ROSE QUARTZ TOOLS", "tool.create.rose_quartz.tooltip": "ROSE QUARTZ TOOLS",
"tool.create.rose_quartz.tooltip.summary": "This tool grants you a _greater_ _reach_ for _breaking_ _blocks_ or _placing_ _blocks_ from the off-hand.", "tool.create.rose_quartz.tooltip.summary": "This tool grants you a _greater_ _reach_ for _breaking_ _blocks_ or _placing_ _blocks_ from the off-hand.",
"block.create.warehouse_crate.tooltip": "WIP",
"block.create.filtered_crate.tooltip": "WIP",
"block.create.creative_crate.tooltip": "WIP",
"itemGroup.create": "Create" "itemGroup.create": "Create"
} }

View file

@ -0,0 +1,8 @@
{
"parent": "create:block/crate/double_bottom",
"textures": {
"side": "create:block/crate_andesite_side",
"crate": "create:block/crate_andesite",
"casing": "create:block/andesite_casing"
}
}

View file

@ -0,0 +1,8 @@
{
"parent": "create:block/crate/double_left",
"textures": {
"side": "create:block/crate_andesite_side",
"crate": "create:block/crate_andesite",
"casing": "create:block/andesite_casing"
}
}

View file

@ -0,0 +1,8 @@
{
"parent": "create:block/crate/double_right",
"textures": {
"side": "create:block/crate_andesite_side",
"crate": "create:block/crate_andesite",
"casing": "create:block/andesite_casing"
}
}

View file

@ -0,0 +1,8 @@
{
"parent": "create:block/crate/double_top",
"textures": {
"side": "create:block/crate_andesite_side",
"crate": "create:block/crate_andesite",
"casing": "create:block/andesite_casing"
}
}

View file

@ -0,0 +1,8 @@
{
"parent": "create:block/crate/single",
"textures": {
"side": "create:block/crate_andesite_side",
"crate": "create:block/crate_andesite",
"casing": "create:block/andesite_casing"
}
}

View file

@ -0,0 +1,8 @@
{
"parent": "create:block/crate/double_bottom",
"textures": {
"side": "create:block/crate_brass_side",
"crate": "create:block/crate_brass",
"casing": "create:block/brass_casing"
}
}

View file

@ -0,0 +1,8 @@
{
"parent": "create:block/crate/double_left",
"textures": {
"side": "create:block/crate_brass_side",
"crate": "create:block/crate_brass",
"casing": "create:block/brass_casing"
}
}

View file

@ -0,0 +1,8 @@
{
"parent": "create:block/crate/double_right",
"textures": {
"side": "create:block/crate_brass_side",
"crate": "create:block/crate_brass",
"casing": "create:block/brass_casing"
}
}

View file

@ -0,0 +1,8 @@
{
"parent": "create:block/crate/double_top",
"textures": {
"side": "create:block/crate_brass_side",
"crate": "create:block/crate_brass",
"casing": "create:block/brass_casing"
}
}

View file

@ -0,0 +1,8 @@
{
"parent": "create:block/crate/single",
"textures": {
"side": "create:block/crate_brass_side",
"crate": "create:block/crate_brass",
"casing": "create:block/brass_casing"
}
}

View file

@ -0,0 +1,8 @@
{
"parent": "create:block/crate/double_bottom",
"textures": {
"side": "create:block/crate_copper_side",
"crate": "create:block/crate_copper",
"casing": "create:block/copper_casing"
}
}

View file

@ -0,0 +1,8 @@
{
"parent": "create:block/crate/double_left",
"textures": {
"side": "create:block/crate_copper_side",
"crate": "create:block/crate_copper",
"casing": "create:block/copper_casing"
}
}

View file

@ -0,0 +1,8 @@
{
"parent": "create:block/crate/double_right",
"textures": {
"side": "create:block/crate_copper_side",
"crate": "create:block/crate_copper",
"casing": "create:block/copper_casing"
}
}

View file

@ -0,0 +1,8 @@
{
"parent": "create:block/crate/double_top",
"textures": {
"side": "create:block/crate_copper_side",
"crate": "create:block/crate_copper",
"casing": "create:block/copper_casing"
}
}

View file

@ -0,0 +1,8 @@
{
"parent": "create:block/crate/single",
"textures": {
"side": "create:block/crate_copper_side",
"crate": "create:block/crate_copper",
"casing": "create:block/copper_casing"
}
}

View file

@ -0,0 +1,8 @@
{
"parent": "create:block/crate/double_bottom",
"textures": {
"side": "create:block/crate_creative_side",
"crate": "create:block/crate_creative",
"casing": "create:block/chorus_chrome_mesh"
}
}

View file

@ -0,0 +1,8 @@
{
"parent": "create:block/crate/double_left",
"textures": {
"side": "create:block/crate_creative_side",
"crate": "create:block/crate_creative",
"casing": "create:block/chorus_chrome_mesh"
}
}

View file

@ -0,0 +1,8 @@
{
"parent": "create:block/crate/double_right",
"textures": {
"side": "create:block/crate_creative_side",
"crate": "create:block/crate_creative",
"casing": "create:block/chorus_chrome_mesh"
}
}

View file

@ -0,0 +1,8 @@
{
"parent": "create:block/crate/double_top",
"textures": {
"side": "create:block/crate_creative_side",
"crate": "create:block/crate_creative",
"casing": "create:block/chorus_chrome_mesh"
}
}

View file

@ -0,0 +1,8 @@
{
"parent": "create:block/crate/single",
"textures": {
"side": "create:block/crate_creative_side",
"crate": "create:block/crate_creative",
"casing": "create:block/chorus_chrome_mesh"
}
}

View file

@ -2,9 +2,9 @@
"credit": "Made with Blockbench", "credit": "Made with Blockbench",
"parent": "block/block", "parent": "block/block",
"textures": { "textures": {
"0": "create:block/double_flexcrate_side", "0": "#side",
"3": "create:block/brass_casing_14", "4": "#crate",
"particle": "create:block/flex_crate" "particle": "#casing"
}, },
"elements": [ "elements": [
{ {
@ -15,7 +15,7 @@
"east": {"uv": [8.5, 8, 15.5, 16], "texture": "#0"}, "east": {"uv": [8.5, 8, 15.5, 16], "texture": "#0"},
"south": {"uv": [8.5, 8, 15.5, 16], "texture": "#0"}, "south": {"uv": [8.5, 8, 15.5, 16], "texture": "#0"},
"west": {"uv": [8.5, 8, 15.5, 16], "texture": "#0"}, "west": {"uv": [8.5, 8, 15.5, 16], "texture": "#0"},
"down": {"uv": [1, 1, 15, 15], "rotation": 270, "texture": "#3"} "down": {"uv": [8.5, 8.5, 15.5, 15.5], "rotation": 270, "texture": "#4"}
} }
} }
] ]

View file

@ -2,17 +2,16 @@
"credit": "Made with Blockbench", "credit": "Made with Blockbench",
"parent": "block/block", "parent": "block/block",
"textures": { "textures": {
"0": "create:block/double_flexcrate_side", "0": "#side",
"1": "create:block/double_flexcrate_bottom", "1": "#crate",
"2": "create:block/flex_crate", "particle": "#casing"
"particle": "create:block/flex_crate"
}, },
"elements": [ "elements": [
{ {
"from": [1, 0, 1], "from": [1, 0, 1],
"to": [15, 14, 16], "to": [15, 14, 16],
"faces": { "faces": {
"north": {"uv": [1, 1, 15, 15], "texture": "#2"}, "north": {"uv": [0.5, 8.5, 7.5, 15.5], "texture": "#1"},
"east": {"uv": [8, 0.5, 15.5, 7.5], "texture": "#0"}, "east": {"uv": [8, 0.5, 15.5, 7.5], "texture": "#0"},
"west": {"uv": [0.5, 0.5, 8, 7.5], "texture": "#0"}, "west": {"uv": [0.5, 0.5, 8, 7.5], "texture": "#0"},
"up": {"uv": [0.5, 0.5, 8, 7.5], "rotation": 90, "texture": "#1"}, "up": {"uv": [0.5, 0.5, 8, 7.5], "rotation": 90, "texture": "#1"},

View file

@ -2,10 +2,9 @@
"credit": "Made with Blockbench", "credit": "Made with Blockbench",
"parent": "block/block", "parent": "block/block",
"textures": { "textures": {
"0": "create:block/double_flexcrate_side", "0": "#side",
"1": "create:block/double_flexcrate_bottom", "1": "#crate",
"2": "create:block/flex_crate", "particle": "#casing"
"particle": "create:block/flex_crate"
}, },
"elements": [ "elements": [
{ {
@ -13,7 +12,7 @@
"to": [15, 14, 15], "to": [15, 14, 15],
"faces": { "faces": {
"east": {"uv": [0.5, 0.5, 8, 7.5], "texture": "#0"}, "east": {"uv": [0.5, 0.5, 8, 7.5], "texture": "#0"},
"south": {"uv": [1, 1, 15, 15], "texture": "#2"}, "south": {"uv": [0.5, 8.5, 7.5, 15.5], "texture": "#1"},
"west": {"uv": [8, 0.5, 15.5, 7.5], "texture": "#0"}, "west": {"uv": [8, 0.5, 15.5, 7.5], "texture": "#0"},
"up": {"uv": [8, 0.5, 15.5, 7.5], "rotation": 90, "texture": "#1"}, "up": {"uv": [8, 0.5, 15.5, 7.5], "rotation": 90, "texture": "#1"},
"down": {"uv": [8, 0.5, 15.5, 7.5], "rotation": 270, "texture": "#1"} "down": {"uv": [8, 0.5, 15.5, 7.5], "rotation": 270, "texture": "#1"}

View file

@ -2,9 +2,9 @@
"credit": "Made with Blockbench", "credit": "Made with Blockbench",
"parent": "block/block", "parent": "block/block",
"textures": { "textures": {
"0": "create:block/double_flexcrate_side", "0": "#side",
"3": "create:block/brass_casing_14", "2": "#crate",
"particle": "create:block/flex_crate" "particle": "#casing"
}, },
"elements": [ "elements": [
{ {
@ -15,7 +15,7 @@
"east": {"uv": [0.5, 8.5, 7.5, 15.5], "texture": "#0"}, "east": {"uv": [0.5, 8.5, 7.5, 15.5], "texture": "#0"},
"south": {"uv": [0.5, 8.5, 7.5, 15.5], "texture": "#0"}, "south": {"uv": [0.5, 8.5, 7.5, 15.5], "texture": "#0"},
"west": {"uv": [0.5, 8.5, 7.5, 15.5], "texture": "#0"}, "west": {"uv": [0.5, 8.5, 7.5, 15.5], "texture": "#0"},
"up": {"uv": [1, 1, 15, 15], "rotation": 90, "texture": "#3"} "up": {"uv": [8.5, 8.5, 15.5, 15.5], "rotation": 90, "texture": "#2"}
} }
} }
] ]

View file

@ -0,0 +1,23 @@
{
"credit": "Made with Blockbench",
"parent": "block/block",
"textures": {
"2": "#crate",
"particle": "#casing"
},
"elements": [
{
"name": "Crate",
"from": [1, 0, 1],
"to": [15, 14, 15],
"faces": {
"north": {"uv": [0.5, 8.5, 7.5, 15.5], "texture": "#2"},
"east": {"uv": [0.5, 8.5, 7.5, 15.5], "texture": "#2"},
"south": {"uv": [0.5, 8.5, 7.5, 15.5], "texture": "#2"},
"west": {"uv": [0.5, 8.5, 7.5, 15.5], "texture": "#2"},
"up": {"uv": [8.5, 8.5, 15.5, 15.5], "texture": "#2"},
"down": {"uv": [8.5, 8.5, 15.5, 15.5], "texture": "#2"}
}
}
]
}

View file

@ -1,23 +0,0 @@
{
"parent": "block/block",
"textures": {
"particle": "create:block/flex_crate",
"side": "create:block/flex_crate",
"top": "create:block/brass_casing_14"
},
"elements": [
{
"name": "Crate",
"from": [ 1, 0, 1 ],
"to": [ 15, 14, 15 ],
"faces": {
"north": { "texture": "#side", "uv": [ 1, 1, 15, 15 ] },
"east": { "texture": "#side", "uv": [ 1, 1, 15, 15 ] },
"south": { "texture": "#side", "uv": [ 1, 1, 15, 15 ] },
"west": { "texture": "#side", "uv": [ 1, 1, 15, 15 ] },
"up": { "texture": "#top", "uv": [ 1, 1, 15, 15 ] },
"down": { "texture": "#top", "uv": [ 1, 1, 15, 15 ] }
}
}
]
}

View file

@ -1,3 +1,3 @@
{ {
"parent": "create:block/creative_crate" "parent": "create:block/crate/creative/single"
} }

View file

@ -0,0 +1,3 @@
{
"parent": "create:block/crate/copper/single"
}

View file

@ -1,3 +1,3 @@
{ {
"parent": "create:block/flexcrate/single" "parent": "create:block/crate/brass/single"
} }

View file

@ -0,0 +1,3 @@
{
"parent": "create:block/crate/andesite/single"
}

Binary file not shown.

Before

Width:  |  Height:  |  Size: 468 B

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.3 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.3 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.2 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.3 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.4 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 1,004 B

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.2 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 524 B

Binary file not shown.

Before

Width:  |  Height:  |  Size: 316 B

Binary file not shown.

Before

Width:  |  Height:  |  Size: 763 B

Binary file not shown.

Before

Width:  |  Height:  |  Size: 561 B

View file

@ -1,30 +1,35 @@
{ {
"display": { "parent": "create:root",
"title": { "display": {
"translate": "advancement.create:andesite_alloy" "icon": {
}, "item": "create:andesite_alloy"
"description": { },
"translate": "advancement.create:andesite_alloy.desc" "title": {
}, "translate": "advancement.create.andesite_alloy"
"icon": { },
"description": {
"translate": "advancement.create.andesite_alloy.desc"
},
"frame": "task",
"show_toast": true,
"announce_to_chat": false,
"hidden": false
},
"criteria": {
"0": {
"trigger": "minecraft:inventory_changed",
"conditions": {
"items": [
{
"item": "create:andesite_alloy" "item": "create:andesite_alloy"
}, }
"frame": "task", ]
"show_toast": true, }
"announce_to_chat": false, }
"hidden": true },
}, "requirements": [
"criteria": { [
"alloy": { "0"
"trigger": "minecraft:inventory_changed", ]
"conditions": { ]
"items": [
{
"item": "create:andesite_alloy"
}
]
}
}
},
"parent": "create:root"
} }

View file

@ -1,30 +1,35 @@
{ {
"display": { "parent": "create:andesite_alloy",
"title": { "display": {
"translate": "advancement.create:andesite_casing" "icon": {
}, "item": "create:andesite_casing"
"description": { },
"translate": "advancement.create:andesite_casing.desc" "title": {
}, "translate": "advancement.create.andesite_casing"
"icon": { },
"description": {
"translate": "advancement.create.andesite_casing.desc"
},
"frame": "goal",
"show_toast": true,
"announce_to_chat": true,
"hidden": false
},
"criteria": {
"0": {
"trigger": "minecraft:inventory_changed",
"conditions": {
"items": [
{
"item": "create:andesite_casing" "item": "create:andesite_casing"
}, }
"frame": "task", ]
"show_toast": true, }
"announce_to_chat": false, }
"hidden": false },
}, "requirements": [
"criteria": { [
"casing": { "0"
"trigger": "minecraft:inventory_changed", ]
"conditions": { ]
"items": [
{
"item": "create:andesite_casing"
}
]
}
}
},
"parent": "create:andesite_alloy"
} }

View file

@ -0,0 +1,37 @@
{
"parent": "create:press",
"display": {
"icon": {
"item": "create:basin"
},
"title": {
"translate": "advancement.create.basin"
},
"description": {
"translate": "advancement.create.basin.desc"
},
"frame": "task",
"show_toast": true,
"announce_to_chat": false,
"hidden": false
},
"criteria": {
"0": {
"trigger": "minecraft:placed_block",
"conditions": {
"block": "create:basin"
}
},
"1": {
"trigger": "create:basin"
}
},
"requirements": [
[
"0"
],
[
"1"
]
]
}

View file

@ -0,0 +1,28 @@
{
"parent": "create:its_alive",
"display": {
"icon": {
"item": "create:belt_connector"
},
"title": {
"translate": "advancement.create.belt"
},
"description": {
"translate": "advancement.create.belt.desc"
},
"frame": "task",
"show_toast": true,
"announce_to_chat": false,
"hidden": false
},
"criteria": {
"0": {
"trigger": "create:connect_belt"
}
},
"requirements": [
[
"0"
]
]
}

View file

@ -1,31 +1,35 @@
{ {
"display": { "parent": "create:mixer",
"title": { "display": {
"translate": "advancement.create:brass", "icon": {
"color": "gold" "item": "create:brass_ingot"
},
"description": {
"translate": "advancement.create:brass.desc"
},
"icon": {
"item": "create:crushed_brass"
},
"frame": "task",
"show_toast": true,
"announce_to_chat": false,
"hidden": false
}, },
"criteria": { "title": {
"brass": { "translate": "advancement.create.brass"
"trigger": "minecraft:inventory_changed",
"conditions": {
"items": [
{
"item": "create:crushed_brass"
}
]
}
}
}, },
"parent": "create:mechanical_mixer" "description": {
"translate": "advancement.create.brass.desc"
},
"frame": "task",
"show_toast": true,
"announce_to_chat": false,
"hidden": false
},
"criteria": {
"0": {
"trigger": "minecraft:inventory_changed",
"conditions": {
"items": [
{
"item": "create:brass_ingot"
}
]
}
}
},
"requirements": [
[
"0"
]
]
} }

View file

@ -1,30 +1,35 @@
{ {
"display": { "parent": "create:brass",
"title": { "display": {
"translate": "advancement.create:brass_casing" "icon": {
}, "item": "create:brass_casing"
"description": { },
"translate": "advancement.create:brass_casing.desc" "title": {
}, "translate": "advancement.create.brass_casing"
"icon": { },
"description": {
"translate": "advancement.create.brass_casing.desc"
},
"frame": "goal",
"show_toast": true,
"announce_to_chat": true,
"hidden": false
},
"criteria": {
"0": {
"trigger": "minecraft:inventory_changed",
"conditions": {
"items": [
{
"item": "create:brass_casing" "item": "create:brass_casing"
}, }
"frame": "task", ]
"show_toast": true, }
"announce_to_chat": false, }
"hidden": false },
}, "requirements": [
"criteria": { [
"casing": { "0"
"trigger": "minecraft:inventory_changed", ]
"conditions": { ]
"items": [
{
"item": "create:brass_casing"
}
]
}
}
},
"parent": "create:brass"
} }

View file

@ -1,31 +1,35 @@
{ {
"display": { "parent": "create:crushing_wheel",
"title": { "display": {
"translate": "advancement.create:chromatic_compound", "icon": {
"color": "dark_purple" "item": "create:chromatic_compound"
}, },
"description": { "title": {
"translate": "advancement.create:chromatic_compound.desc" "translate": "advancement.create.chromatic_compound"
}, },
"icon": { "description": {
"translate": "advancement.create.chromatic_compound.desc"
},
"frame": "task",
"show_toast": true,
"announce_to_chat": false,
"hidden": false
},
"criteria": {
"0": {
"trigger": "minecraft:inventory_changed",
"conditions": {
"items": [
{
"item": "create:chromatic_compound" "item": "create:chromatic_compound"
}, }
"frame": "task", ]
"show_toast": true, }
"announce_to_chat": false, }
"hidden": false },
}, "requirements": [
"criteria": { [
"alloy": { "0"
"trigger": "minecraft:inventory_changed", ]
"conditions": { ]
"items": [
{
"item": "create:chromatic_compound"
}
]
}
}
},
"parent": "create:mechanical_mixer"
} }

View file

@ -0,0 +1,28 @@
{
"parent": "create:basin",
"display": {
"icon": {
"item": "minecraft:iron_block"
},
"title": {
"translate": "advancement.create.compact"
},
"description": {
"translate": "advancement.create.compact.desc"
},
"frame": "task",
"show_toast": true,
"announce_to_chat": false,
"hidden": false
},
"criteria": {
"0": {
"trigger": "create:compact"
}
},
"requirements": [
[
"0"
]
]
}

View file

@ -0,0 +1,40 @@
{
"parent": "create:brass_casing",
"display": {
"icon": {
"item": "create:mechanical_crafter"
},
"title": {
"translate": "advancement.create.crafter"
},
"description": {
"translate": "advancement.create.crafter.desc"
},
"frame": "task",
"show_toast": true,
"announce_to_chat": true,
"hidden": false
},
"criteria": {
"0": {
"trigger": "minecraft:placed_block",
"conditions": {
"block": "create:mechanical_crafter"
}
},
"1": {
"trigger": "create:kinetic_block",
"conditions": {
"block": "create:mechanical_crafter"
}
}
},
"requirements": [
[
"0"
],
[
"1"
]
]
}

View file

@ -1,34 +1,35 @@
{ {
"display": { "parent": "create:crafter",
"title": { "display": {
"translate": "advancement.create:crushing_wheel" "icon": {
}, "item": "create:crushing_wheel"
"description": { },
"translate": "advancement.create:crushing_wheel.desc" "title": {
}, "translate": "advancement.create.crushing_wheel"
"icon": { },
"description": {
"translate": "advancement.create.crushing_wheel.desc"
},
"frame": "task",
"show_toast": true,
"announce_to_chat": true,
"hidden": false
},
"criteria": {
"0": {
"trigger": "minecraft:inventory_changed",
"conditions": {
"items": [
{
"item": "create:crushing_wheel" "item": "create:crushing_wheel"
}, }
"frame": "task", ]
"show_toast": true, }
"announce_to_chat": false, }
"hidden": false },
}, "requirements": [
"criteria": { [
"crushers": { "0"
"trigger": "minecraft:inventory_changed", ]
"conditions": { ]
"items": [
{
"item": "create:crushing_wheel",
"count": {
"min": 2,
"max": 64
}
}
]
}
}
},
"parent": "create:andesite_alloy"
} }

View file

@ -1,30 +1,40 @@
{ {
"display": { "parent": "create:brass_casing",
"title": { "display": {
"translate": "advancement.create:deployer" "icon": {
}, "item": "create:deployer"
"description": {
"translate": "advancement.create:deployer.desc"
},
"icon": {
"item": "create:deployer"
},
"frame": "task",
"show_toast": true,
"announce_to_chat": false,
"hidden": false
}, },
"criteria": { "title": {
"deployer": { "translate": "advancement.create.deployer"
"trigger": "minecraft:inventory_changed",
"conditions": {
"items": [
{
"item": "create:deployer"
}
]
}
}
}, },
"parent": "create:brass" "description": {
"translate": "advancement.create.deployer.desc"
},
"frame": "goal",
"show_toast": true,
"announce_to_chat": true,
"hidden": false
},
"criteria": {
"0": {
"trigger": "minecraft:placed_block",
"conditions": {
"block": "create:deployer"
}
},
"1": {
"trigger": "create:kinetic_block",
"conditions": {
"block": "create:deployer"
}
}
},
"requirements": [
[
"0"
],
[
"1"
]
]
} }

View file

@ -1,23 +0,0 @@
{
"display": {
"title": {
"translate": "advancement.create:deployer_secret"
},
"description": {
"translate": "advancement.create:deployer_secret.desc"
},
"icon": {
"item": "create:deployer"
},
"frame": "goal",
"show_toast": true,
"announce_to_chat": true,
"hidden": true
},
"criteria": {
"touching": {
"trigger": "create:deployer"
}
},
"parent": "create:deployer"
}

View file

@ -0,0 +1,40 @@
{
"parent": "create:andesite_casing",
"display": {
"icon": {
"item": "create:drill"
},
"title": {
"translate": "advancement.create.drill"
},
"description": {
"translate": "advancement.create.drill.desc"
},
"frame": "task",
"show_toast": true,
"announce_to_chat": false,
"hidden": false
},
"criteria": {
"0": {
"trigger": "minecraft:placed_block",
"conditions": {
"block": "create:drill"
}
},
"1": {
"trigger": "create:kinetic_block",
"conditions": {
"block": "create:drill"
}
}
},
"requirements": [
[
"0"
],
[
"1"
]
]
}

View file

@ -0,0 +1,35 @@
{
"parent": "create:polished_rose_quartz",
"display": {
"icon": {
"item": "create:electron_tube"
},
"title": {
"translate": "advancement.create.electron_tube"
},
"description": {
"translate": "advancement.create.electron_tube.desc"
},
"frame": "task",
"show_toast": true,
"announce_to_chat": false,
"hidden": false
},
"criteria": {
"0": {
"trigger": "minecraft:inventory_changed",
"conditions": {
"items": [
{
"item": "create:electron_tube"
}
]
}
}
},
"requirements": [
[
"0"
]
]
}

View file

@ -0,0 +1,35 @@
{
"parent": "create:andesite_casing",
"display": {
"icon": {
"item": "minecraft:andesite"
},
"title": {
"translate": "advancement.create.expert_lane_1"
},
"description": {
"translate": "advancement.create.expert_lane_1.desc"
},
"frame": "challenge",
"show_toast": false,
"announce_to_chat": false,
"hidden": false
},
"criteria": {
"0": {
"trigger": "minecraft:inventory_changed",
"conditions": {
"items": [
{
"item": "create:andesite_casing"
}
]
}
}
},
"requirements": [
[
"0"
]
]
}

View file

@ -0,0 +1,28 @@
{
"parent": "create:deployer",
"display": {
"icon": {
"item": "create:large_cogwheel"
},
"title": {
"translate": "advancement.create.fist_bump"
},
"description": {
"translate": "advancement.create.fist_bump.desc"
},
"frame": "goal",
"show_toast": true,
"announce_to_chat": true,
"hidden": true
},
"criteria": {
"0": {
"trigger": "create:deployer"
}
},
"requirements": [
[
"0"
]
]
}

View file

@ -0,0 +1,35 @@
{
"parent": "create:its_alive",
"display": {
"icon": {
"item": "create:goggles"
},
"title": {
"translate": "advancement.create.goggles"
},
"description": {
"translate": "advancement.create.goggles.desc"
},
"frame": "task",
"show_toast": true,
"announce_to_chat": false,
"hidden": false
},
"criteria": {
"0": {
"trigger": "minecraft:inventory_changed",
"conditions": {
"items": [
{
"item": "create:goggles"
}
]
}
}
},
"requirements": [
[
"0"
]
]
}

View file

@ -0,0 +1,28 @@
{
"parent": "create:andesite_alloy",
"display": {
"icon": {
"item": "create:cogwheel"
},
"title": {
"translate": "advancement.create.its_alive"
},
"description": {
"translate": "advancement.create.its_alive.desc"
},
"frame": "task",
"show_toast": true,
"announce_to_chat": false,
"hidden": false
},
"criteria": {
"0": {
"trigger": "create:rotation"
}
},
"requirements": [
[
"0"
]
]
}

View file

@ -0,0 +1,28 @@
{
"parent": "create:water_wheel",
"display": {
"icon": {
"item": "minecraft:lava_bucket"
},
"title": {
"translate": "advancement.create.lava_wheel"
},
"description": {
"translate": "advancement.create.lava_wheel.desc"
},
"frame": "goal",
"show_toast": true,
"announce_to_chat": true,
"hidden": true
},
"criteria": {
"0": {
"trigger": "create:lava_wheel"
}
},
"requirements": [
[
"0"
]
]
}

View file

@ -1,30 +0,0 @@
{
"display": {
"title": {
"translate": "advancement.create:mixer"
},
"description": {
"translate": "advancement.create:mixer.desc"
},
"icon": {
"item": "create:mechanical_mixer"
},
"frame": "task",
"show_toast": true,
"announce_to_chat": false,
"hidden": false
},
"criteria": {
"mixer": {
"trigger": "minecraft:inventory_changed",
"conditions": {
"items": [
{
"item": "create:mechanical_mixer"
}
]
}
}
},
"parent": "create:mechanical_press"
}

View file

@ -1,48 +0,0 @@
{
"display": {
"title": {
"translate": "advancement.create:press"
},
"description": {
"translate": "advancement.create:press.desc"
},
"icon": {
"item": "create:mechanical_press"
},
"frame": "goal",
"show_toast": true,
"announce_to_chat": true,
"hidden": false
},
"criteria": {
"press": {
"trigger": "minecraft:inventory_changed",
"conditions": {
"items": [
{
"item": "create:mechanical_press"
}
]
}
},
"plate": {
"trigger": "minecraft:inventory_changed",
"conditions": {
"items": [
{
"tag": "forge:plates"
}
]
}
}
},
"requirements": [
[
"press"
],
[
"plate"
]
],
"parent": "create:andesite_casing"
}

View file

@ -0,0 +1,40 @@
{
"parent": "create:andesite_alloy",
"display": {
"icon": {
"item": "create:millstone"
},
"title": {
"translate": "advancement.create.millstone"
},
"description": {
"translate": "advancement.create.millstone.desc"
},
"frame": "task",
"show_toast": true,
"announce_to_chat": false,
"hidden": false
},
"criteria": {
"0": {
"trigger": "minecraft:placed_block",
"conditions": {
"block": "create:millstone"
}
},
"1": {
"trigger": "create:kinetic_block",
"conditions": {
"block": "create:millstone"
}
}
},
"requirements": [
[
"0"
],
[
"1"
]
]
}

View file

@ -0,0 +1,46 @@
{
"parent": "create:basin",
"display": {
"icon": {
"item": "create:mechanical_mixer"
},
"title": {
"translate": "advancement.create.mixer"
},
"description": {
"translate": "advancement.create.mixer.desc"
},
"frame": "task",
"show_toast": true,
"announce_to_chat": true,
"hidden": false
},
"criteria": {
"0": {
"trigger": "minecraft:placed_block",
"conditions": {
"block": "create:mechanical_mixer"
}
},
"1": {
"trigger": "create:kinetic_block",
"conditions": {
"block": "create:mechanical_mixer"
}
},
"2": {
"trigger": "create:mixer"
}
},
"requirements": [
[
"0"
],
[
"1"
],
[
"2"
]
]
}

View file

@ -1,24 +1,28 @@
{ {
"display": { "parent": "create:its_alive",
"title": { "display": {
"translate": "advancement.create:overstressed", "icon": {
"color": "red" "item": "minecraft:barrier"
},
"description": {
"translate": "advancement.create:overstressed.desc"
},
"icon": {
"item": "minecraft:barrier"
},
"frame": "task",
"show_toast": true,
"announce_to_chat": false,
"hidden": true
}, },
"criteria": { "title": {
"alloy": { "translate": "advancement.create.overstressed"
"trigger": "create:overstressed"
}
}, },
"parent": "create:rotation" "description": {
"translate": "advancement.create.overstressed.desc"
},
"frame": "goal",
"show_toast": true,
"announce_to_chat": true,
"hidden": true
},
"criteria": {
"0": {
"trigger": "create:overstressed"
}
},
"requirements": [
[
"0"
]
]
} }

View file

@ -1,32 +1,35 @@
{ {
"display": { "parent": "create:andesite_casing",
"title": { "display": {
"translate": "advancement.create:polished_rose_quartz", "icon": {
"color": "red" "item": "create:polished_rose_quartz"
}, },
"description": { "title": {
"translate": "advancement.create:polished_rose_quartz.desc" "translate": "advancement.create.polished_rose_quartz"
}, },
"icon": { "description": {
"translate": "advancement.create.polished_rose_quartz.desc"
},
"frame": "task",
"show_toast": true,
"announce_to_chat": false,
"hidden": false
},
"criteria": {
"0": {
"trigger": "minecraft:inventory_changed",
"conditions": {
"items": [
{
"item": "create:polished_rose_quartz" "item": "create:polished_rose_quartz"
}, }
"frame": "task", ]
"show_toast": true, }
"announce_to_chat": false, }
"hidden": true },
}, "requirements": [
"criteria": { [
"quartz": { "0"
"trigger": "create:sandpaper_use", ]
"conditions": { ]
"target": {
"item": "create:rose_quartz"
},
"result": {
"item": "create:polished_rose_quartz"
}
}
}
},
"parent": "create:sand_paper"
} }

View file

@ -0,0 +1,28 @@
{
"parent": "create:andesite_casing",
"display": {
"icon": {
"item": "create:mechanical_press"
},
"title": {
"translate": "advancement.create.press"
},
"description": {
"translate": "advancement.create.press.desc"
},
"frame": "task",
"show_toast": true,
"announce_to_chat": true,
"hidden": false
},
"criteria": {
"0": {
"trigger": "create:bonk"
}
},
"requirements": [
[
"0"
]
]
}

View file

@ -1,31 +1,35 @@
{ {
"display": { "parent": "create:chromatic_compound",
"title": { "display": {
"translate": "advancement.create:refined_radiance", "icon": {
"color": "white" "item": "create:refined_radiance"
}, },
"description": { "title": {
"translate": "advancement.create:refined_radiance.desc" "translate": "advancement.create.refined_radiance"
}, },
"icon": { "description": {
"translate": "advancement.create.refined_radiance.desc"
},
"frame": "goal",
"show_toast": true,
"announce_to_chat": true,
"hidden": false
},
"criteria": {
"0": {
"trigger": "minecraft:inventory_changed",
"conditions": {
"items": [
{
"item": "create:refined_radiance" "item": "create:refined_radiance"
}, }
"frame": "goal", ]
"show_toast": true, }
"announce_to_chat": true, }
"hidden": false },
}, "requirements": [
"criteria": { [
"radiance": { "0"
"trigger": "minecraft:inventory_changed", ]
"conditions": { ]
"items": [
{
"item": "create:refined_radiance"
}
]
}
}
},
"parent": "create:chromatic_compound"
} }

View file

@ -1,24 +0,0 @@
{
"display": {
"title": {
"translate": "advancement.create:refined_radiance_secret",
"color": "white"
},
"description": {
"translate": "advancement.create:refined_radiance_secret.desc"
},
"icon": {
"item": "create:refined_radiance"
},
"frame": "challenge",
"show_toast": true,
"announce_to_chat": true,
"hidden": true
},
"criteria": {
"ritual": {
"trigger": "create:light_absorbed"
}
},
"parent": "create:chromatic_compound"
}

View file

@ -1,21 +1,29 @@
{ {
"display": { "display": {
"icon": { "icon": {
"item": "create:brass_ingot" "item": "create:brass_hand"
}, },
"title": { "title": {
"translate": "advancement.create:root" "translate": "advancement.create.root"
}, },
"description": { "description": {
"translate": "advancement.create:root.desc" "translate": "advancement.create.root.desc"
}, },
"background": "create:textures/block/scoria_bricks.png", "frame": "task",
"show_toast": false, "show_toast": false,
"announce_to_chat": false "announce_to_chat": false,
"hidden": false,
"background": "create:textures/block/scoria_bricks.png"
}, },
"criteria": { "criteria": {
"flower": { "0": {
"trigger": "minecraft:inventory_changed" "trigger": "minecraft:inventory_changed",
"conditions": {}
} }
} },
"requirements": [
[
"0"
]
]
} }

View file

@ -1,23 +0,0 @@
{
"display": {
"title": {
"translate": "advancement.create:rotation"
},
"description": {
"translate": "advancement.create:rotation.desc"
},
"icon": {
"item": "create:cogwheel"
},
"frame": "task",
"show_toast": true,
"announce_to_chat": true,
"hidden": true
},
"criteria": {
"alloy": {
"trigger": "create:rotation"
}
},
"parent": "create:andesite_alloy"
}

View file

@ -1,47 +0,0 @@
{
"display": {
"title": {
"translate": "advancement.create:sand_paper",
"color": "yellow"
},
"description": {
"translate": "advancement.create:sand_paper.desc"
},
"icon": {
"item": "create:sand_paper"
},
"frame": "task",
"show_toast": true,
"announce_to_chat": false,
"hidden": true
},
"criteria": {
"paperNormal": {
"trigger": "minecraft:inventory_changed",
"conditions": {
"items": [
{
"item": "create:sand_paper"
}
]
}
},
"paperRed": {
"trigger": "minecraft:inventory_changed",
"conditions": {
"items": [
{
"item": "create:red_sand_paper"
}
]
}
}
},
"requirements": [
[
"paperNormal",
"paperRed"
]
],
"parent": "create:root"
}

View file

@ -1,43 +0,0 @@
{
"display": {
"title": {
"translate": "advancement.create:sand_paper_secret",
"color": "yellow"
},
"description": {
"translate": "advancement.create:sand_paper_secret.desc"
},
"icon": {
"item": "create:red_sand_paper"
},
"frame": "goal",
"show_toast": true,
"announce_to_chat": true,
"hidden": true
},
"criteria": {
"normal": {
"trigger": "create:sandpaper_use",
"conditions": {
"result": {
"item": "create:sand_paper"
}
}
},
"red": {
"trigger": "create:sandpaper_use",
"conditions": {
"result": {
"item": "create:red_sand_paper"
}
}
}
},
"requirements": [
[
"normal",
"red"
]
],
"parent": "create:sand_paper"
}

View file

@ -0,0 +1,40 @@
{
"parent": "create:press",
"display": {
"icon": {
"item": "create:saw"
},
"title": {
"translate": "advancement.create.saw"
},
"description": {
"translate": "advancement.create.saw.desc"
},
"frame": "task",
"show_toast": true,
"announce_to_chat": false,
"hidden": false
},
"criteria": {
"0": {
"trigger": "minecraft:placed_block",
"conditions": {
"block": "create:saw"
}
},
"1": {
"trigger": "create:kinetic_block",
"conditions": {
"block": "create:saw"
}
}
},
"requirements": [
[
"0"
],
[
"1"
]
]
}

Some files were not shown because too many files have changed in this diff Show more