Rebooting Advancements
- Reworked basic advancement tree, to be continued - Removed unused trigger and damage source for sandpaper - Added some new crate assets
|
@ -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()),
|
||||||
|
|
314
src/main/java/com/simibubi/create/data/CreateAdvancements.java
Normal 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()));
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -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;
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -0,0 +1,9 @@
|
||||||
|
package com.simibubi.create.foundation.advancement;
|
||||||
|
|
||||||
|
import net.minecraft.entity.player.ServerPlayerEntity;
|
||||||
|
|
||||||
|
public interface ITriggerable {
|
||||||
|
|
||||||
|
public void trigger(ServerPlayerEntity player);
|
||||||
|
|
||||||
|
}
|
|
@ -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;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
}
|
|
@ -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());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -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 {
|
||||||
|
|
||||||
|
|
|
@ -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));
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
|
@ -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);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -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);
|
||||||
}
|
}
|
||||||
|
|
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -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));
|
||||||
|
|
|
@ -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);
|
||||||
}
|
}
|
||||||
|
|
|
@ -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);
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -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);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -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));
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -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))
|
||||||
|
|
|
@ -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;
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
|
@ -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" }
|
||||||
}
|
}
|
||||||
}
|
}
|
|
@ -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" }
|
||||||
|
}
|
||||||
|
}
|
|
@ -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" }
|
||||||
}
|
}
|
||||||
}
|
}
|
|
@ -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" }
|
||||||
|
}
|
||||||
|
}
|
|
@ -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"
|
||||||
}
|
}
|
||||||
|
|
|
@ -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"
|
||||||
|
}
|
||||||
|
}
|
|
@ -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"
|
||||||
|
}
|
||||||
|
}
|
|
@ -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"
|
||||||
|
}
|
||||||
|
}
|
|
@ -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"
|
||||||
|
}
|
||||||
|
}
|
|
@ -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"
|
||||||
|
}
|
||||||
|
}
|
|
@ -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"
|
||||||
|
}
|
||||||
|
}
|
|
@ -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"
|
||||||
|
}
|
||||||
|
}
|
|
@ -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"
|
||||||
|
}
|
||||||
|
}
|
|
@ -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"
|
||||||
|
}
|
||||||
|
}
|
|
@ -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"
|
||||||
|
}
|
||||||
|
}
|
|
@ -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"
|
||||||
|
}
|
||||||
|
}
|
|
@ -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"
|
||||||
|
}
|
||||||
|
}
|
|
@ -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"
|
||||||
|
}
|
||||||
|
}
|
|
@ -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"
|
||||||
|
}
|
||||||
|
}
|
|
@ -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"
|
||||||
|
}
|
||||||
|
}
|
|
@ -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"
|
||||||
|
}
|
||||||
|
}
|
|
@ -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"
|
||||||
|
}
|
||||||
|
}
|
|
@ -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"
|
||||||
|
}
|
||||||
|
}
|
|
@ -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"
|
||||||
|
}
|
||||||
|
}
|
|
@ -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"
|
||||||
|
}
|
||||||
|
}
|
|
@ -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"}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
]
|
]
|
|
@ -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"},
|
|
@ -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"}
|
|
@ -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"}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
]
|
]
|
|
@ -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"}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
|
@ -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 ] }
|
|
||||||
}
|
|
||||||
}
|
|
||||||
]
|
|
||||||
}
|
|
|
@ -1,3 +1,3 @@
|
||||||
{
|
{
|
||||||
"parent": "create:block/creative_crate"
|
"parent": "create:block/crate/creative/single"
|
||||||
}
|
}
|
|
@ -0,0 +1,3 @@
|
||||||
|
{
|
||||||
|
"parent": "create:block/crate/copper/single"
|
||||||
|
}
|
|
@ -1,3 +1,3 @@
|
||||||
{
|
{
|
||||||
"parent": "create:block/flexcrate/single"
|
"parent": "create:block/crate/brass/single"
|
||||||
}
|
}
|
|
@ -0,0 +1,3 @@
|
||||||
|
{
|
||||||
|
"parent": "create:block/crate/andesite/single"
|
||||||
|
}
|
Before Width: | Height: | Size: 468 B |
After Width: | Height: | Size: 1.3 KiB |
After Width: | Height: | Size: 1.3 KiB |
BIN
src/main/resources/assets/create/textures/block/crate_brass.png
Normal file
After Width: | Height: | Size: 1.2 KiB |
Before Width: | Height: | Size: 1.5 KiB After Width: | Height: | Size: 1.5 KiB |
BIN
src/main/resources/assets/create/textures/block/crate_copper.png
Normal file
After Width: | Height: | Size: 1.3 KiB |
After Width: | Height: | Size: 1.4 KiB |
After Width: | Height: | Size: 1,004 B |
After Width: | Height: | Size: 1.2 KiB |
Before Width: | Height: | Size: 524 B |
Before Width: | Height: | Size: 316 B |
Before Width: | Height: | Size: 763 B |
Before Width: | Height: | Size: 561 B |
|
@ -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"
|
|
||||||
}
|
}
|
|
@ -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"
|
|
||||||
}
|
}
|
37
src/main/resources/data/create/advancements/basin.json
Normal 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"
|
||||||
|
]
|
||||||
|
]
|
||||||
|
}
|
28
src/main/resources/data/create/advancements/belt.json
Normal 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"
|
||||||
|
]
|
||||||
|
]
|
||||||
|
}
|
|
@ -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"
|
||||||
|
]
|
||||||
|
]
|
||||||
}
|
}
|
|
@ -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"
|
|
||||||
}
|
}
|
|
@ -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"
|
|
||||||
}
|
}
|
28
src/main/resources/data/create/advancements/compact.json
Normal 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"
|
||||||
|
]
|
||||||
|
]
|
||||||
|
}
|
40
src/main/resources/data/create/advancements/crafter.json
Normal 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"
|
||||||
|
]
|
||||||
|
]
|
||||||
|
}
|
|
@ -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"
|
|
||||||
}
|
}
|
|
@ -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"
|
||||||
|
]
|
||||||
|
]
|
||||||
}
|
}
|
|
@ -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"
|
|
||||||
}
|
|
40
src/main/resources/data/create/advancements/drill.json
Normal 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"
|
||||||
|
]
|
||||||
|
]
|
||||||
|
}
|
|
@ -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"
|
||||||
|
]
|
||||||
|
]
|
||||||
|
}
|
|
@ -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"
|
||||||
|
]
|
||||||
|
]
|
||||||
|
}
|
28
src/main/resources/data/create/advancements/fist_bump.json
Normal 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"
|
||||||
|
]
|
||||||
|
]
|
||||||
|
}
|
35
src/main/resources/data/create/advancements/goggles.json
Normal 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"
|
||||||
|
]
|
||||||
|
]
|
||||||
|
}
|
28
src/main/resources/data/create/advancements/its_alive.json
Normal 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"
|
||||||
|
]
|
||||||
|
]
|
||||||
|
}
|
28
src/main/resources/data/create/advancements/lava_wheel.json
Normal 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"
|
||||||
|
]
|
||||||
|
]
|
||||||
|
}
|
|
@ -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"
|
|
||||||
}
|
|
|
@ -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"
|
|
||||||
}
|
|
40
src/main/resources/data/create/advancements/millstone.json
Normal 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"
|
||||||
|
]
|
||||||
|
]
|
||||||
|
}
|
46
src/main/resources/data/create/advancements/mixer.json
Normal 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"
|
||||||
|
]
|
||||||
|
]
|
||||||
|
}
|
|
@ -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"
|
||||||
|
]
|
||||||
|
]
|
||||||
}
|
}
|
|
@ -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"
|
|
||||||
}
|
}
|
28
src/main/resources/data/create/advancements/press.json
Normal 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"
|
||||||
|
]
|
||||||
|
]
|
||||||
|
}
|
|
@ -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"
|
|
||||||
}
|
}
|
|
@ -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"
|
|
||||||
}
|
|
|
@ -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"
|
||||||
|
]
|
||||||
|
]
|
||||||
}
|
}
|
|
@ -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"
|
|
||||||
}
|
|
|
@ -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"
|
|
||||||
}
|
|
|
@ -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"
|
|
||||||
}
|
|
40
src/main/resources/data/create/advancements/saw.json
Normal 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"
|
||||||
|
]
|
||||||
|
]
|
||||||
|
}
|