diff --git a/assets/Module_PCB.aseprite b/assets/Module_PCB.aseprite index be01039..f465138 100644 Binary files a/assets/Module_PCB.aseprite and b/assets/Module_PCB.aseprite differ diff --git a/src/main/java/systems/brn/serverstorage/ServerStorage.java b/src/main/java/systems/brn/serverstorage/ServerStorage.java index 13721a1..833068c 100644 --- a/src/main/java/systems/brn/serverstorage/ServerStorage.java +++ b/src/main/java/systems/brn/serverstorage/ServerStorage.java @@ -28,7 +28,7 @@ import java.util.HashMap; import java.util.List; public class ServerStorage implements ModInitializer { - public static final List moduleList = Arrays.asList("bus", "configuration", "container", "display", "drive", "filtering", "inventory", "pagination", "pcb", "transport", "netherite_upgrade"); + public static final List moduleList = Arrays.asList("bus", "configuration", "container", "display", "drive", "filtering", "inventory", "pagination", "pcb", "transport", "antenna", "radio", "antenna_connector", "modem", "netherite_upgrade"); public static final List tiers = Arrays.asList("iron", "golden", "diamond", "netherite"); public static final List materialList = Arrays.asList("pcb", "pcb_substrate", "cpu", "cpu_substrate", "drive_controller", "drive_casing"); diff --git a/src/main/java/systems/brn/serverstorage/blocks/ConnectedBlock.java b/src/main/java/systems/brn/serverstorage/blocks/ConnectedBlock.java index ced3d9e..be3d562 100644 --- a/src/main/java/systems/brn/serverstorage/blocks/ConnectedBlock.java +++ b/src/main/java/systems/brn/serverstorage/blocks/ConnectedBlock.java @@ -1,5 +1,8 @@ package systems.brn.serverstorage.blocks; +import eu.pb4.polymer.blocks.api.BlockModelType; +import eu.pb4.polymer.blocks.api.PolymerBlockModel; +import eu.pb4.polymer.blocks.api.PolymerBlockResourceUtils; import eu.pb4.polymer.core.api.block.SimplePolymerBlock; import net.minecraft.block.Block; import net.minecraft.block.BlockState; @@ -9,11 +12,14 @@ import net.minecraft.inventory.Inventory; import net.minecraft.item.ItemStack; import net.minecraft.state.StateManager; import net.minecraft.state.property.EnumProperty; +import net.minecraft.util.Identifier; import net.minecraft.util.math.BlockPos; import net.minecraft.util.math.Direction; import net.minecraft.world.World; import systems.brn.serverstorage.lib.ConnectionType; +import java.util.HashMap; + public class ConnectedBlock extends SimplePolymerBlock { public static final EnumProperty NORTH = EnumProperty.of("north", ConnectionType.class); @@ -23,6 +29,39 @@ public class ConnectedBlock extends SimplePolymerBlock { public static final EnumProperty UP = EnumProperty.of("up", ConnectionType.class); public static final EnumProperty DOWN = EnumProperty.of("down", ConnectionType.class); + // Function to get Y-axis rotation for North, South, East, and West directions + public static int getRotationFromDirection(Direction direction) { + if (direction == Direction.EAST) { + return 90; + } else if (direction == Direction.SOUTH) { + return 180; + } else if (direction == Direction.WEST) { + return 270; + } else { + return 0; + } + } + + // Function to get X-axis rotation for Up and Down directions + public static int getXRotationFromDirection(Direction direction) { + if (direction == Direction.UP) { + return 270; + } else if (direction == Direction.DOWN) { + return 90; + } else { + return 0; + } + } + + public static HashMap generateRotations(Identifier identifier) { + Identifier modelIdentifier = identifier.withPath("block/" + identifier.getPath()); + HashMap rotations = new HashMap<>(); + for (Direction direction : Direction.values()) { + rotations.put(direction, PolymerBlockResourceUtils.requestBlock(BlockModelType.FULL_BLOCK, PolymerBlockModel.of(modelIdentifier, getXRotationFromDirection(direction), getRotationFromDirection(direction)))); + } + return rotations; + } + public void setDefaultState() { setDefaultState(getStateManager().getDefaultState() .with(NORTH, ConnectionType.NONE) @@ -66,9 +105,9 @@ public class ConnectedBlock extends SimplePolymerBlock { BlockEntity blockEntity = world.getBlockEntity(neighborPos); boolean isConnectedToInventory = blockEntity instanceof Inventory; ConnectionType connectionType = ConnectionType.NONE; - if (isConnectedToBus){ + if (isConnectedToBus) { connectionType = ConnectionType.BUS; - } else if (isConnectedToInventory){ + } else if (isConnectedToInventory) { connectionType = ConnectionType.INVENTORY; } diff --git a/src/main/java/systems/brn/serverstorage/blocks/HardDriveContainerBlock.java b/src/main/java/systems/brn/serverstorage/blocks/HardDriveContainerBlock.java index d76c7bf..a74e8a2 100644 --- a/src/main/java/systems/brn/serverstorage/blocks/HardDriveContainerBlock.java +++ b/src/main/java/systems/brn/serverstorage/blocks/HardDriveContainerBlock.java @@ -1,8 +1,5 @@ package systems.brn.serverstorage.blocks; -import eu.pb4.polymer.blocks.api.BlockModelType; -import eu.pb4.polymer.blocks.api.PolymerBlockModel; -import eu.pb4.polymer.blocks.api.PolymerBlockResourceUtils; import eu.pb4.polymer.blocks.api.PolymerTexturedBlock; import eu.pb4.polymer.core.api.block.PolymerBlockUtils; import net.fabricmc.fabric.api.event.player.UseBlockCallback; @@ -27,24 +24,26 @@ import org.jetbrains.annotations.Nullable; import systems.brn.serverstorage.blockentities.HardDriveContainerBlockEntity; import systems.brn.serverstorage.lib.StorageNetwork; +import java.util.HashMap; + import static systems.brn.serverstorage.ServerStorage.*; public class HardDriveContainerBlock extends ConnectedBlock implements PolymerTexturedBlock, BlockEntityProvider { final Identifier identifier; public static final DirectionProperty FACING = FacingBlock.FACING; - private final BlockState polymerBlockState; + private final HashMap rotations; public HardDriveContainerBlock(AbstractBlock.Settings settings, Identifier identifier) { super(settings, Blocks.NOTE_BLOCK); this.identifier = identifier; this.setDefaultState(this.stateManager.getDefaultState().with(FACING, Direction.NORTH)); - this.polymerBlockState = PolymerBlockResourceUtils.requestBlock(BlockModelType.FULL_BLOCK, PolymerBlockModel.of(identifier.withPath("block/" + identifier.getPath()))); + this.rotations = generateRotations(identifier); } @Override public BlockState getPlacementState(ItemPlacementContext ctx) { - return this.getDefaultState().with(FACING, ctx.getHorizontalPlayerFacing().getOpposite()); + return this.getDefaultState().with(FACING, ctx.getPlayerLookDirection().getOpposite()); } @Override @@ -55,7 +54,8 @@ public class HardDriveContainerBlock extends ConnectedBlock implements PolymerTe @Override public BlockState getPolymerBlockState(BlockState state) { - return this.polymerBlockState; + Direction direction = state.get(FACING); + return rotations.get(direction); } public static void register() { diff --git a/src/main/java/systems/brn/serverstorage/blocks/InventoryInterfaceBlock.java b/src/main/java/systems/brn/serverstorage/blocks/InventoryInterfaceBlock.java index 6f1672c..62eac80 100644 --- a/src/main/java/systems/brn/serverstorage/blocks/InventoryInterfaceBlock.java +++ b/src/main/java/systems/brn/serverstorage/blocks/InventoryInterfaceBlock.java @@ -1,8 +1,5 @@ package systems.brn.serverstorage.blocks; -import eu.pb4.polymer.blocks.api.BlockModelType; -import eu.pb4.polymer.blocks.api.PolymerBlockModel; -import eu.pb4.polymer.blocks.api.PolymerBlockResourceUtils; import eu.pb4.polymer.blocks.api.PolymerTexturedBlock; import eu.pb4.polymer.core.api.block.PolymerBlockUtils; import eu.pb4.sgui.api.elements.GuiElementBuilder; @@ -35,24 +32,26 @@ import systems.brn.serverstorage.lib.PagedGui; import systems.brn.serverstorage.screens.SearchScreen; import systems.brn.serverstorage.screens.SettingsScreen; +import java.util.HashMap; + import static systems.brn.serverstorage.ServerStorage.*; import static systems.brn.serverstorage.lib.PagedGui.*; public class InventoryInterfaceBlock extends ConnectedBlock implements PolymerTexturedBlock, BlockEntityProvider { final Identifier identifier; public static final DirectionProperty FACING = FacingBlock.FACING; - private final BlockState polymerBlockState; + private final HashMap rotations; public InventoryInterfaceBlock(Settings settings, Identifier identifier) { super(settings, Blocks.NOTE_BLOCK); this.identifier = identifier; this.setDefaultState(this.stateManager.getDefaultState().with(FACING, Direction.NORTH)); - this.polymerBlockState = PolymerBlockResourceUtils.requestBlock(BlockModelType.FULL_BLOCK, PolymerBlockModel.of(identifier.withPath("block/" + identifier.getPath()))); + this.rotations = generateRotations(identifier); } @Override public BlockState getPlacementState(ItemPlacementContext ctx) { - return this.getDefaultState().with(FACING, ctx.getHorizontalPlayerFacing().getOpposite()); + return this.getDefaultState().with(FACING, ctx.getPlayerLookDirection().getOpposite()); } @Override @@ -63,7 +62,8 @@ public class InventoryInterfaceBlock extends ConnectedBlock implements PolymerTe @Override public BlockState getPolymerBlockState(BlockState state) { - return this.polymerBlockState; + Direction direction = state.get(FACING); + return rotations.get(direction); } public static void register() { @@ -150,7 +150,7 @@ public class InventoryInterfaceBlock extends ConnectedBlock implements PolymerTe Block block = state.getBlock(); if (block instanceof InventoryInterfaceBlock) { - if (!world.getGameRules().getBoolean(ServerStorage_Interface_Enable)){ + if (!world.getGameRules().getBoolean(ServerStorage_Interface_Enable)) { playerEntity.sendMessage(Text.translatable("message.serverstorage.block_disabled"), true); return ActionResult.PASS; } diff --git a/src/main/java/systems/brn/serverstorage/blocks/RadioInterfaceBlock.java b/src/main/java/systems/brn/serverstorage/blocks/RadioInterfaceBlock.java index f9fbfab..5ee39da 100644 --- a/src/main/java/systems/brn/serverstorage/blocks/RadioInterfaceBlock.java +++ b/src/main/java/systems/brn/serverstorage/blocks/RadioInterfaceBlock.java @@ -1,8 +1,5 @@ package systems.brn.serverstorage.blocks; -import eu.pb4.polymer.blocks.api.BlockModelType; -import eu.pb4.polymer.blocks.api.PolymerBlockModel; -import eu.pb4.polymer.blocks.api.PolymerBlockResourceUtils; import eu.pb4.polymer.blocks.api.PolymerTexturedBlock; import eu.pb4.polymer.core.api.block.PolymerBlockUtils; import net.fabricmc.fabric.api.event.player.UseBlockCallback; @@ -34,6 +31,7 @@ import systems.brn.serverstorage.lib.WirelessTerminalComponents; import systems.brn.serverstorage.screens.RadioBlockPlayerMangementScreen; import java.util.ArrayList; +import java.util.HashMap; import java.util.List; import java.util.UUID; @@ -43,18 +41,19 @@ import static systems.brn.serverstorage.lib.Util.removePosition; public class RadioInterfaceBlock extends ConnectedBlock implements PolymerTexturedBlock, BlockEntityProvider { final Identifier identifier; public static final DirectionProperty FACING = FacingBlock.FACING; - private final BlockState polymerBlockState; + private final HashMap rotations; public RadioInterfaceBlock(Settings settings, Identifier identifier) { super(settings, Blocks.NOTE_BLOCK); this.identifier = identifier; this.setDefaultState(this.stateManager.getDefaultState().with(FACING, Direction.NORTH)); - this.polymerBlockState = PolymerBlockResourceUtils.requestBlock(BlockModelType.FULL_BLOCK, PolymerBlockModel.of(identifier.withPath("block/" + identifier.getPath()))); + this.rotations = generateRotations(identifier); + } @Override public BlockState getPlacementState(ItemPlacementContext ctx) { - return this.getDefaultState().with(FACING, ctx.getHorizontalPlayerFacing().getOpposite()); + return this.getDefaultState().with(FACING, ctx.getPlayerLookDirection().getOpposite()); } @Override @@ -65,7 +64,8 @@ public class RadioInterfaceBlock extends ConnectedBlock implements PolymerTextur @Override public BlockState getPolymerBlockState(BlockState state) { - return this.polymerBlockState; + Direction direction = state.get(FACING); + return rotations.get(direction); } public static void register() { diff --git a/src/main/java/systems/brn/serverstorage/blocks/StorageInterfaceBlock.java b/src/main/java/systems/brn/serverstorage/blocks/StorageInterfaceBlock.java index d537b7e..c0353af 100644 --- a/src/main/java/systems/brn/serverstorage/blocks/StorageInterfaceBlock.java +++ b/src/main/java/systems/brn/serverstorage/blocks/StorageInterfaceBlock.java @@ -1,8 +1,5 @@ package systems.brn.serverstorage.blocks; -import eu.pb4.polymer.blocks.api.BlockModelType; -import eu.pb4.polymer.blocks.api.PolymerBlockModel; -import eu.pb4.polymer.blocks.api.PolymerBlockResourceUtils; import eu.pb4.polymer.blocks.api.PolymerTexturedBlock; import eu.pb4.polymer.core.api.block.PolymerBlockUtils; import net.fabricmc.fabric.api.event.player.UseBlockCallback; @@ -33,6 +30,7 @@ import org.jetbrains.annotations.Nullable; import systems.brn.serverstorage.blockentities.StorageInterfaceBlockEntity; import systems.brn.serverstorage.screens.StorageScreen; +import java.util.HashMap; import java.util.List; import static systems.brn.serverstorage.ServerStorage.*; @@ -41,18 +39,18 @@ import static systems.brn.serverstorage.lib.Util.generateBookContent; public class StorageInterfaceBlock extends ConnectedBlock implements PolymerTexturedBlock, BlockEntityProvider { final Identifier identifier; public static final DirectionProperty FACING = FacingBlock.FACING; - private final BlockState polymerBlockState; + private final HashMap rotations; public StorageInterfaceBlock(Settings settings, Identifier identifier) { super(settings, Blocks.NOTE_BLOCK); this.identifier = identifier; this.setDefaultState(this.stateManager.getDefaultState().with(FACING, Direction.NORTH)); - this.polymerBlockState = PolymerBlockResourceUtils.requestBlock(BlockModelType.FULL_BLOCK, PolymerBlockModel.of(identifier.withPath("block/" + identifier.getPath()))); + this.rotations = generateRotations(identifier); } @Override public BlockState getPlacementState(ItemPlacementContext ctx) { - return this.getDefaultState().with(FACING, ctx.getHorizontalPlayerFacing().getOpposite()); + return this.getDefaultState().with(FACING, ctx.getPlayerLookDirection().getOpposite()); } @Override @@ -63,7 +61,8 @@ public class StorageInterfaceBlock extends ConnectedBlock implements PolymerText @Override public BlockState getPolymerBlockState(BlockState state) { - return this.polymerBlockState; + Direction direction = state.get(FACING); + return rotations.get(direction); } public static void register() { diff --git a/src/main/resources/assets/serverstorage/blockstates/bus_connector.json b/src/main/resources/assets/serverstorage/blockstates/bus_connector.json deleted file mode 100644 index 52ea263..0000000 --- a/src/main/resources/assets/serverstorage/blockstates/bus_connector.json +++ /dev/null @@ -1,32 +0,0 @@ -{ - "multipart": [ - { - "when": { "north": "none", "south": "none", "west": "none", "east": "none", "up": "none", "down": "none" }, - "apply": { "model": "serverstorage:block/bus_connector_blank" } - }, - { - "when": { "north": "bus" }, - "apply": { "model": "serverstorage:block/bus_connector_bus_north" } - }, - { - "when": { "south": "bus" }, - "apply": { "model": "serverstorage:block/bus_connector_bus_south" } - }, - { - "when": { "west": "bus" }, - "apply": { "model": "serverstorage:block/bus_connector_bus_west" } - }, - { - "when": { "east": "bus" }, - "apply": { "model": "serverstorage:block/bus_connector_bus_east" } - }, - { - "when": { "up": "bus" }, - "apply": { "model": "serverstorage:block/bus_connector_bus_up" } - }, - { - "when": { "down": "bus" }, - "apply": { "model": "serverstorage:block/bus_connector_bus_down" } - } - ] -} diff --git a/src/main/resources/assets/serverstorage/blockstates/drive_container.json b/src/main/resources/assets/serverstorage/blockstates/drive_container.json deleted file mode 100644 index b7cc7ad..0000000 --- a/src/main/resources/assets/serverstorage/blockstates/drive_container.json +++ /dev/null @@ -1,27 +0,0 @@ -{ - "variants": { - "facing=down": { - "model": "serverstorage:block/drive_container", - "x": 180 - }, - "facing=east": { - "model": "serverstorage:block/drive_container", - "y": 90 - }, - "facing=north": { - "model": "serverstorage:block/drive_container" - }, - "facing=south": { - "model": "serverstorage:block/drive_container", - "y": 180 - }, - "facing=up": { - "model": "serverstorage:block/drive_container", - "x": 90 - }, - "facing=west": { - "model": "serverstorage:block/drive_container", - "y": 270 - } - } -} \ No newline at end of file diff --git a/src/main/resources/assets/serverstorage/blockstates/inventory_interface.json b/src/main/resources/assets/serverstorage/blockstates/inventory_interface.json deleted file mode 100644 index d0cded5..0000000 --- a/src/main/resources/assets/serverstorage/blockstates/inventory_interface.json +++ /dev/null @@ -1,32 +0,0 @@ -{ - "multipart": [ - { - "when": { "north": "none", "south": "none", "west": "none", "east": "none", "up": "none", "down": "none" }, - "apply": { "model": "serverstorage:block/inventory_interface_blank" } - }, - { - "when": { "north": "inventory" }, - "apply": { "model": "serverstorage:block/inventory_interface_inventory_north" } - }, - { - "when": { "south": "inventory" }, - "apply": { "model": "serverstorage:block/inventory_interface_inventory_south" } - }, - { - "when": { "west": "inventory" }, - "apply": { "model": "serverstorage:block/inventory_interface_inventory_west" } - }, - { - "when": { "east": "inventory" }, - "apply": { "model": "serverstorage:block/inventory_interface_inventory_east" } - }, - { - "when": { "up": "inventory" }, - "apply": { "model": "serverstorage:block/inventory_interface_inventory_up" } - }, - { - "when": { "down": "inventory" }, - "apply": { "model": "serverstorage:block/inventory_interface_inventory_down" } - } - ] -} diff --git a/src/main/resources/assets/serverstorage/blockstates/storage.json b/src/main/resources/assets/serverstorage/blockstates/storage.json deleted file mode 100644 index 671916b..0000000 --- a/src/main/resources/assets/serverstorage/blockstates/storage.json +++ /dev/null @@ -1,26 +0,0 @@ -{ - "variants": { - "facing=down": { - "model": "serverstorage:block/storage", - "x": 180 - }, - "facing=east": { - "model": "serverstorage:block/storage", - "y": 90 - }, - "facing=north": { - "model": "serverstorage:block/storage" - }, - "facing=south": { - "model": "serverstorage:block/storage", - "y": 180 - }, - "facing=up": { - "model": "serverstorage:block/storage" - }, - "facing=west": { - "model": "serverstorage:block/storage", - "y": 270 - } - } -} \ No newline at end of file diff --git a/src/main/resources/assets/serverstorage/lang/en_us.json b/src/main/resources/assets/serverstorage/lang/en_us.json index be1c13a..69263c5 100644 --- a/src/main/resources/assets/serverstorage/lang/en_us.json +++ b/src/main/resources/assets/serverstorage/lang/en_us.json @@ -34,6 +34,10 @@ "item.serverstorage.module_inventory": "Inventory Module", "item.serverstorage.module_pagination": "Pagination Module", "item.serverstorage.module_transport": "Transport Module", + "item.serverstorage.module_antenna": "Antenna Module", + "item.serverstorage.module_radio": "Radio Module", + "item.serverstorage.module_antenna_connector": "Antenna Connector Module", + "item.serverstorage.module_modem": "MoDem Module", "item.serverstorage.module_netherite_upgrade": "Netherite Upgrade Module", diff --git a/src/main/resources/assets/serverstorage/models/block/bus_connector_blank.json b/src/main/resources/assets/serverstorage/models/block/bus_connector_blank.json deleted file mode 100644 index ef03a84..0000000 --- a/src/main/resources/assets/serverstorage/models/block/bus_connector_blank.json +++ /dev/null @@ -1,6 +0,0 @@ -{ - "parent": "block/cube_all", - "textures": { - "all": "serverstorage:block/bus_connector_blank" - } -} diff --git a/src/main/resources/assets/serverstorage/models/block/bus_connector_bus_blank.json b/src/main/resources/assets/serverstorage/models/block/bus_connector_bus_blank.json deleted file mode 100644 index ef03a84..0000000 --- a/src/main/resources/assets/serverstorage/models/block/bus_connector_bus_blank.json +++ /dev/null @@ -1,6 +0,0 @@ -{ - "parent": "block/cube_all", - "textures": { - "all": "serverstorage:block/bus_connector_blank" - } -} diff --git a/src/main/resources/assets/serverstorage/models/block/bus_connector_bus_down.json b/src/main/resources/assets/serverstorage/models/block/bus_connector_bus_down.json deleted file mode 100644 index b457aa3..0000000 --- a/src/main/resources/assets/serverstorage/models/block/bus_connector_bus_down.json +++ /dev/null @@ -1,11 +0,0 @@ -{ - "parent": "block/cube", - "textures": { - "down": "serverstorage:block/bus_connector_bus", - "up": "serverstorage:block/bus_connector_blank", - "north": "serverstorage:block/bus_connector_blank", - "south": "serverstorage:block/bus_connector_blank", - "west": "serverstorage:block/bus_connector_blank", - "east": "serverstorage:block/bus_connector_blank" - } -} diff --git a/src/main/resources/assets/serverstorage/models/block/bus_connector_bus_east.json b/src/main/resources/assets/serverstorage/models/block/bus_connector_bus_east.json deleted file mode 100644 index 6df909b..0000000 --- a/src/main/resources/assets/serverstorage/models/block/bus_connector_bus_east.json +++ /dev/null @@ -1,11 +0,0 @@ -{ - "parent": "block/cube", - "textures": { - "down": "serverstorage:block/bus_connector_blank", - "up": "serverstorage:block/bus_connector_blank", - "north": "serverstorage:block/bus_connector_blank", - "south": "serverstorage:block/bus_connector_blank", - "west": "serverstorage:block/bus_connector_blank", - "east": "serverstorage:block/bus_connector_bus" - } -} diff --git a/src/main/resources/assets/serverstorage/models/block/bus_connector_bus_north.json b/src/main/resources/assets/serverstorage/models/block/bus_connector_bus_north.json deleted file mode 100644 index 5a72c76..0000000 --- a/src/main/resources/assets/serverstorage/models/block/bus_connector_bus_north.json +++ /dev/null @@ -1,11 +0,0 @@ -{ - "parent": "block/cube", - "textures": { - "down": "serverstorage:block/bus_connector_blank", - "up": "serverstorage:block/bus_connector_blank", - "north": "serverstorage:block/bus_connector_bus", - "south": "serverstorage:block/bus_connector_blank", - "west": "serverstorage:block/bus_connector_blank", - "east": "serverstorage:block/bus_connector_blank" - } -} diff --git a/src/main/resources/assets/serverstorage/models/block/bus_connector_bus_south.json b/src/main/resources/assets/serverstorage/models/block/bus_connector_bus_south.json deleted file mode 100644 index e99a59c..0000000 --- a/src/main/resources/assets/serverstorage/models/block/bus_connector_bus_south.json +++ /dev/null @@ -1,11 +0,0 @@ -{ - "parent": "block/cube", - "textures": { - "down": "serverstorage:block/bus_connector_blank", - "up": "serverstorage:block/bus_connector_blank", - "north": "serverstorage:block/bus_connector_blank", - "south": "serverstorage:block/bus_connector_bus", - "west": "serverstorage:block/bus_connector_blank", - "east": "serverstorage:block/bus_connector_blank" - } -} diff --git a/src/main/resources/assets/serverstorage/models/block/bus_connector_bus_up.json b/src/main/resources/assets/serverstorage/models/block/bus_connector_bus_up.json deleted file mode 100644 index 09434d2..0000000 --- a/src/main/resources/assets/serverstorage/models/block/bus_connector_bus_up.json +++ /dev/null @@ -1,11 +0,0 @@ -{ - "parent": "block/cube", - "textures": { - "down": "serverstorage:block/bus_connector_blank", - "up": "serverstorage:block/bus_connector_bus", - "north": "serverstorage:block/bus_connector_blank", - "south": "serverstorage:block/bus_connector_blank", - "west": "serverstorage:block/bus_connector_blank", - "east": "serverstorage:block/bus_connector_blank" - } -} diff --git a/src/main/resources/assets/serverstorage/models/block/bus_connector_bus_west.json b/src/main/resources/assets/serverstorage/models/block/bus_connector_bus_west.json deleted file mode 100644 index 028dc60..0000000 --- a/src/main/resources/assets/serverstorage/models/block/bus_connector_bus_west.json +++ /dev/null @@ -1,11 +0,0 @@ -{ - "parent": "block/cube", - "textures": { - "down": "serverstorage:block/bus_connector_blank", - "up": "serverstorage:block/bus_connector_blank", - "north": "serverstorage:block/bus_connector_blank", - "south": "serverstorage:block/bus_connector_blank", - "west": "serverstorage:block/bus_connector_bus", - "east": "serverstorage:block/bus_connector_blank" - } -} diff --git a/src/main/resources/assets/serverstorage/models/block/bus_connector_inventory_blank.json b/src/main/resources/assets/serverstorage/models/block/bus_connector_inventory_blank.json deleted file mode 100644 index ef03a84..0000000 --- a/src/main/resources/assets/serverstorage/models/block/bus_connector_inventory_blank.json +++ /dev/null @@ -1,6 +0,0 @@ -{ - "parent": "block/cube_all", - "textures": { - "all": "serverstorage:block/bus_connector_blank" - } -} diff --git a/src/main/resources/assets/serverstorage/models/block/drive_container.json b/src/main/resources/assets/serverstorage/models/block/drive_container.json index 4492d8b..fd6789f 100644 --- a/src/main/resources/assets/serverstorage/models/block/drive_container.json +++ b/src/main/resources/assets/serverstorage/models/block/drive_container.json @@ -1,7 +1,11 @@ { - "parent": "block/orientable_vertical", + "parent": "block/orientable", "textures": { "front": "serverstorage:block/drive_container_front", - "side": "serverstorage:block/drive_container_side" + "side": "serverstorage:block/drive_container_side", + "top": "serverstorage:block/drive_container_side", + "east": "serverstorage:block/drive_container_side", + "south": "serverstorage:block/drive_container_side", + "west": "serverstorage:block/drive_container_side" } } \ No newline at end of file diff --git a/src/main/resources/assets/serverstorage/models/block/inventory_interface_blank.json b/src/main/resources/assets/serverstorage/models/block/inventory_interface_blank.json deleted file mode 100644 index 30ac750..0000000 --- a/src/main/resources/assets/serverstorage/models/block/inventory_interface_blank.json +++ /dev/null @@ -1,6 +0,0 @@ -{ - "parent": "block/cube_all", - "textures": { - "all": "serverstorage:block/inventory_interface_blank" - } -} diff --git a/src/main/resources/assets/serverstorage/models/block/inventory_interface_inventory_down.json b/src/main/resources/assets/serverstorage/models/block/inventory_interface_inventory_down.json deleted file mode 100644 index 46090d1..0000000 --- a/src/main/resources/assets/serverstorage/models/block/inventory_interface_inventory_down.json +++ /dev/null @@ -1,11 +0,0 @@ -{ - "parent": "block/cube", - "textures": { - "down": "serverstorage:block/inventory_interface_inventory", - "up": "serverstorage:block/inventory_interface_blank", - "north": "serverstorage:block/inventory_interface_blank", - "south": "serverstorage:block/inventory_interface_blank", - "west": "serverstorage:block/inventory_interface_blank", - "east": "serverstorage:block/inventory_interface_blank" - } -} diff --git a/src/main/resources/assets/serverstorage/models/block/inventory_interface_inventory_east.json b/src/main/resources/assets/serverstorage/models/block/inventory_interface_inventory_east.json deleted file mode 100644 index 01b8957..0000000 --- a/src/main/resources/assets/serverstorage/models/block/inventory_interface_inventory_east.json +++ /dev/null @@ -1,11 +0,0 @@ -{ - "parent": "block/cube", - "textures": { - "down": "serverstorage:block/inventory_interface_blank", - "up": "serverstorage:block/inventory_interface_blank", - "north": "serverstorage:block/inventory_interface_blank", - "south": "serverstorage:block/inventory_interface_blank", - "west": "serverstorage:block/inventory_interface_blank", - "east": "serverstorage:block/inventory_interface_inventory" - } -} diff --git a/src/main/resources/assets/serverstorage/models/block/inventory_interface_inventory_north.json b/src/main/resources/assets/serverstorage/models/block/inventory_interface_inventory_north.json deleted file mode 100644 index 55ecafd..0000000 --- a/src/main/resources/assets/serverstorage/models/block/inventory_interface_inventory_north.json +++ /dev/null @@ -1,11 +0,0 @@ -{ - "parent": "block/cube", - "textures": { - "down": "serverstorage:block/inventory_interface_blank", - "up": "serverstorage:block/inventory_interface_blank", - "north": "serverstorage:block/inventory_interface_inventory", - "south": "serverstorage:block/inventory_interface_blank", - "west": "serverstorage:block/inventory_interface_blank", - "east": "serverstorage:block/inventory_interface_blank" - } -} diff --git a/src/main/resources/assets/serverstorage/models/block/inventory_interface_inventory_south.json b/src/main/resources/assets/serverstorage/models/block/inventory_interface_inventory_south.json deleted file mode 100644 index b5eb707..0000000 --- a/src/main/resources/assets/serverstorage/models/block/inventory_interface_inventory_south.json +++ /dev/null @@ -1,11 +0,0 @@ -{ - "parent": "block/cube", - "textures": { - "down": "serverstorage:block/inventory_interface_blank", - "up": "serverstorage:block/inventory_interface_blank", - "north": "serverstorage:block/inventory_interface_blank", - "south": "serverstorage:block/inventory_interface_inventory", - "west": "serverstorage:block/inventory_interface_blank", - "east": "serverstorage:block/inventory_interface_blank" - } -} diff --git a/src/main/resources/assets/serverstorage/models/block/inventory_interface_inventory_up.json b/src/main/resources/assets/serverstorage/models/block/inventory_interface_inventory_up.json deleted file mode 100644 index a06da33..0000000 --- a/src/main/resources/assets/serverstorage/models/block/inventory_interface_inventory_up.json +++ /dev/null @@ -1,11 +0,0 @@ -{ - "parent": "block/cube", - "textures": { - "down": "serverstorage:block/inventory_interface_blank", - "up": "serverstorage:block/inventory_interface_inventory", - "north": "serverstorage:block/inventory_interface_blank", - "south": "serverstorage:block/inventory_interface_blank", - "west": "serverstorage:block/inventory_interface_blank", - "east": "serverstorage:block/inventory_interface_blank" - } -} diff --git a/src/main/resources/assets/serverstorage/models/block/inventory_interface_inventory_west.json b/src/main/resources/assets/serverstorage/models/block/inventory_interface_inventory_west.json deleted file mode 100644 index 9f3d17b..0000000 --- a/src/main/resources/assets/serverstorage/models/block/inventory_interface_inventory_west.json +++ /dev/null @@ -1,11 +0,0 @@ -{ - "parent": "block/cube", - "textures": { - "down": "serverstorage:block/inventory_interface_blank", - "up": "serverstorage:block/inventory_interface_blank", - "north": "serverstorage:block/inventory_interface_blank", - "south": "serverstorage:block/inventory_interface_blank", - "west": "serverstorage:block/inventory_interface_inventory", - "east": "serverstorage:block/inventory_interface_blank" - } -} diff --git a/src/main/resources/assets/serverstorage/models/block/radio_interface.json b/src/main/resources/assets/serverstorage/models/block/radio_interface.json new file mode 100644 index 0000000..662bd66 --- /dev/null +++ b/src/main/resources/assets/serverstorage/models/block/radio_interface.json @@ -0,0 +1,11 @@ +{ + "parent": "block/orientable", + "textures": { + "front": "serverstorage:block/radio_interface_front", + "side": "serverstorage:block/radio_interface_side", + "top": "serverstorage:block/radio_interface_side", + "east": "serverstorage:block/radio_interface_side", + "south": "serverstorage:block/radio_interface_side", + "west": "serverstorage:block/radio_interface_side" + } +} \ No newline at end of file diff --git a/src/main/resources/assets/serverstorage/models/item/bus_connector.json b/src/main/resources/assets/serverstorage/models/item/bus_connector.json index edfa5df..2ce4e99 100644 --- a/src/main/resources/assets/serverstorage/models/item/bus_connector.json +++ b/src/main/resources/assets/serverstorage/models/item/bus_connector.json @@ -1,3 +1,3 @@ { - "parent": "serverstorage:block/bus_connector_blank" + "parent": "serverstorage:block/bus_connector" } \ No newline at end of file diff --git a/src/main/resources/assets/serverstorage/models/item/diamond_antenna.json b/src/main/resources/assets/serverstorage/models/item/diamond_antenna.json new file mode 100644 index 0000000..3241f80 --- /dev/null +++ b/src/main/resources/assets/serverstorage/models/item/diamond_antenna.json @@ -0,0 +1,6 @@ +{ + "parent": "minecraft:item/handheld", + "textures": { + "layer0": "serverstorage:item/diamond_antenna" + } +} \ No newline at end of file diff --git a/src/main/resources/assets/serverstorage/models/item/golden_antenna.json b/src/main/resources/assets/serverstorage/models/item/golden_antenna.json new file mode 100644 index 0000000..8d64f01 --- /dev/null +++ b/src/main/resources/assets/serverstorage/models/item/golden_antenna.json @@ -0,0 +1,6 @@ +{ + "parent": "minecraft:item/handheld", + "textures": { + "layer0": "serverstorage:item/golden_antenna" + } +} \ No newline at end of file diff --git a/src/main/resources/assets/serverstorage/models/item/iron_antenna.json b/src/main/resources/assets/serverstorage/models/item/iron_antenna.json new file mode 100644 index 0000000..2c028aa --- /dev/null +++ b/src/main/resources/assets/serverstorage/models/item/iron_antenna.json @@ -0,0 +1,6 @@ +{ + "parent": "minecraft:item/handheld", + "textures": { + "layer0": "serverstorage:item/iron_antenna" + } +} \ No newline at end of file diff --git a/src/main/resources/assets/serverstorage/models/item/module_antenna.json b/src/main/resources/assets/serverstorage/models/item/module_antenna.json new file mode 100644 index 0000000..f6a70c4 --- /dev/null +++ b/src/main/resources/assets/serverstorage/models/item/module_antenna.json @@ -0,0 +1,6 @@ +{ + "parent": "minecraft:item/handheld", + "textures": { + "layer0": "serverstorage:item/module_antenna" + } +} \ No newline at end of file diff --git a/src/main/resources/assets/serverstorage/models/item/module_antenna_connector.json b/src/main/resources/assets/serverstorage/models/item/module_antenna_connector.json new file mode 100644 index 0000000..6e203db --- /dev/null +++ b/src/main/resources/assets/serverstorage/models/item/module_antenna_connector.json @@ -0,0 +1,6 @@ +{ + "parent": "minecraft:item/handheld", + "textures": { + "layer0": "serverstorage:item/module_antenna_connector" + } +} \ No newline at end of file diff --git a/src/main/resources/assets/serverstorage/models/item/module_modem.json b/src/main/resources/assets/serverstorage/models/item/module_modem.json new file mode 100644 index 0000000..d1793a7 --- /dev/null +++ b/src/main/resources/assets/serverstorage/models/item/module_modem.json @@ -0,0 +1,6 @@ +{ + "parent": "minecraft:item/handheld", + "textures": { + "layer0": "serverstorage:item/module_modem" + } +} \ No newline at end of file diff --git a/src/main/resources/assets/serverstorage/models/item/module_radio.json b/src/main/resources/assets/serverstorage/models/item/module_radio.json new file mode 100644 index 0000000..f0be149 --- /dev/null +++ b/src/main/resources/assets/serverstorage/models/item/module_radio.json @@ -0,0 +1,6 @@ +{ + "parent": "minecraft:item/handheld", + "textures": { + "layer0": "serverstorage:item/module_radio" + } +} \ No newline at end of file diff --git a/src/main/resources/assets/serverstorage/models/item/netherite_antenna.json b/src/main/resources/assets/serverstorage/models/item/netherite_antenna.json new file mode 100644 index 0000000..e20cb6c --- /dev/null +++ b/src/main/resources/assets/serverstorage/models/item/netherite_antenna.json @@ -0,0 +1,6 @@ +{ + "parent": "minecraft:item/handheld", + "textures": { + "layer0": "serverstorage:item/netherite_antenna" + } +} \ No newline at end of file diff --git a/src/main/resources/assets/serverstorage/models/item/radio_interface.json b/src/main/resources/assets/serverstorage/models/item/radio_interface.json new file mode 100644 index 0000000..fc05c3a --- /dev/null +++ b/src/main/resources/assets/serverstorage/models/item/radio_interface.json @@ -0,0 +1,3 @@ +{ + "parent": "serverstorage:block/radio_interface" +} \ No newline at end of file diff --git a/src/main/resources/assets/serverstorage/models/item/wireless_terminal.json b/src/main/resources/assets/serverstorage/models/item/wireless_terminal.json new file mode 100644 index 0000000..83a3bf0 --- /dev/null +++ b/src/main/resources/assets/serverstorage/models/item/wireless_terminal.json @@ -0,0 +1,6 @@ +{ + "parent": "minecraft:item/handheld", + "textures": { + "layer0": "serverstorage:item/wireless_terminal" + } +} \ No newline at end of file diff --git a/src/main/resources/assets/serverstorage/textures/block/radio_interface_front.png b/src/main/resources/assets/serverstorage/textures/block/radio_interface_front.png new file mode 100644 index 0000000..14f4122 Binary files /dev/null and b/src/main/resources/assets/serverstorage/textures/block/radio_interface_front.png differ diff --git a/src/main/resources/assets/serverstorage/textures/block/radio_interface_side.png b/src/main/resources/assets/serverstorage/textures/block/radio_interface_side.png new file mode 100644 index 0000000..f641dd8 Binary files /dev/null and b/src/main/resources/assets/serverstorage/textures/block/radio_interface_side.png differ diff --git a/src/main/resources/assets/serverstorage/textures/item/diamond_antenna.png b/src/main/resources/assets/serverstorage/textures/item/diamond_antenna.png new file mode 100644 index 0000000..c8f3e4d Binary files /dev/null and b/src/main/resources/assets/serverstorage/textures/item/diamond_antenna.png differ diff --git a/src/main/resources/assets/serverstorage/textures/item/golden_antenna.png b/src/main/resources/assets/serverstorage/textures/item/golden_antenna.png new file mode 100644 index 0000000..49e477e Binary files /dev/null and b/src/main/resources/assets/serverstorage/textures/item/golden_antenna.png differ diff --git a/src/main/resources/assets/serverstorage/textures/item/iron_antenna.png b/src/main/resources/assets/serverstorage/textures/item/iron_antenna.png new file mode 100644 index 0000000..81c4a10 Binary files /dev/null and b/src/main/resources/assets/serverstorage/textures/item/iron_antenna.png differ diff --git a/src/main/resources/assets/serverstorage/textures/item/module_antenna.png b/src/main/resources/assets/serverstorage/textures/item/module_antenna.png new file mode 100644 index 0000000..282d795 Binary files /dev/null and b/src/main/resources/assets/serverstorage/textures/item/module_antenna.png differ diff --git a/src/main/resources/assets/serverstorage/textures/item/module_antenna_connector.png b/src/main/resources/assets/serverstorage/textures/item/module_antenna_connector.png new file mode 100644 index 0000000..bc79a10 Binary files /dev/null and b/src/main/resources/assets/serverstorage/textures/item/module_antenna_connector.png differ diff --git a/src/main/resources/assets/serverstorage/textures/item/module_modem.png b/src/main/resources/assets/serverstorage/textures/item/module_modem.png new file mode 100644 index 0000000..294f584 Binary files /dev/null and b/src/main/resources/assets/serverstorage/textures/item/module_modem.png differ diff --git a/src/main/resources/assets/serverstorage/textures/item/module_radio.png b/src/main/resources/assets/serverstorage/textures/item/module_radio.png new file mode 100644 index 0000000..c756271 Binary files /dev/null and b/src/main/resources/assets/serverstorage/textures/item/module_radio.png differ diff --git a/src/main/resources/assets/serverstorage/textures/item/netherite_antenna.png b/src/main/resources/assets/serverstorage/textures/item/netherite_antenna.png new file mode 100644 index 0000000..5c2c1f1 Binary files /dev/null and b/src/main/resources/assets/serverstorage/textures/item/netherite_antenna.png differ diff --git a/src/main/resources/assets/serverstorage/textures/item/wireless_terminal.png b/src/main/resources/assets/serverstorage/textures/item/wireless_terminal.png new file mode 100644 index 0000000..55e0fa7 Binary files /dev/null and b/src/main/resources/assets/serverstorage/textures/item/wireless_terminal.png differ diff --git a/src/main/resources/data/serverstorage/recipe/diamond_antenna.json b/src/main/resources/data/serverstorage/recipe/diamond_antenna.json new file mode 100644 index 0000000..e87582e --- /dev/null +++ b/src/main/resources/data/serverstorage/recipe/diamond_antenna.json @@ -0,0 +1,18 @@ +{ + "type": "minecraft:crafting_shaped", + "category": "misc", + "pattern": [ + " ##", + "## ", + "# " + ], + "key": { + "#": { + "item": "minecraft:diamond" + } + }, + "result": { + "id": "serverstorage:diamond_antenna", + "count": 1 + } +} \ No newline at end of file diff --git a/src/main/resources/data/serverstorage/recipe/golden_antenna.json b/src/main/resources/data/serverstorage/recipe/golden_antenna.json new file mode 100644 index 0000000..c4746b4 --- /dev/null +++ b/src/main/resources/data/serverstorage/recipe/golden_antenna.json @@ -0,0 +1,18 @@ +{ + "type": "minecraft:crafting_shaped", + "category": "misc", + "pattern": [ + " ##", + "## ", + "# " + ], + "key": { + "#": { + "item": "minecraft:gold_ingot" + } + }, + "result": { + "id": "serverstorage:golden_antenna", + "count": 1 + } +} \ No newline at end of file diff --git a/src/main/resources/data/serverstorage/recipe/iron_antenna.json b/src/main/resources/data/serverstorage/recipe/iron_antenna.json new file mode 100644 index 0000000..b8b5951 --- /dev/null +++ b/src/main/resources/data/serverstorage/recipe/iron_antenna.json @@ -0,0 +1,18 @@ +{ + "type": "minecraft:crafting_shaped", + "category": "misc", + "pattern": [ + " ##", + "## ", + "# " + ], + "key": { + "#": { + "item": "minecraft:iron_ingot" + } + }, + "result": { + "id": "serverstorage:iron_antenna", + "count": 1 + } +} \ No newline at end of file diff --git a/src/main/resources/data/serverstorage/recipe/module_antenna.json b/src/main/resources/data/serverstorage/recipe/module_antenna.json new file mode 100644 index 0000000..2366a0d --- /dev/null +++ b/src/main/resources/data/serverstorage/recipe/module_antenna.json @@ -0,0 +1,30 @@ +{ + "type": "minecraft:crafting_shaped", + "category": "misc", + "pattern": [ + "RIR", + "SCS", + "GGG" + ], + "key": { + "G": { + "item": "minecraft:gold_nugget" + }, + "R": { + "item": "minecraft:iron_ingot" + }, + "I": { + "item": "minecraft:gold_ingot" + }, + "C": { + "item": "serverstorage:material_cpu" + }, + "S": { + "item": "serverstorage:material_pcb_substrate" + } + }, + "result": { + "id": "serverstorage:module_antenna", + "count": 1 + } +} \ No newline at end of file diff --git a/src/main/resources/data/serverstorage/recipe/module_antenna_connector.json b/src/main/resources/data/serverstorage/recipe/module_antenna_connector.json new file mode 100644 index 0000000..7215754 --- /dev/null +++ b/src/main/resources/data/serverstorage/recipe/module_antenna_connector.json @@ -0,0 +1,27 @@ +{ + "type": "minecraft:crafting_shaped", + "category": "misc", + "pattern": [ + "RGR", + "SCS", + "GGG" + ], + "key": { + "G": { + "item": "minecraft:gold_nugget" + }, + "R": { + "item": "minecraft:iron_ingot" + }, + "C": { + "item": "serverstorage:material_cpu" + }, + "S": { + "item": "serverstorage:material_pcb_substrate" + } + }, + "result": { + "id": "serverstorage:module_antenna_connector", + "count": 1 + } +} \ No newline at end of file diff --git a/src/main/resources/data/serverstorage/recipe/module_modem.json b/src/main/resources/data/serverstorage/recipe/module_modem.json new file mode 100644 index 0000000..429c856 --- /dev/null +++ b/src/main/resources/data/serverstorage/recipe/module_modem.json @@ -0,0 +1,27 @@ +{ + "type": "minecraft:crafting_shaped", + "category": "misc", + "pattern": [ + "ICI", + "SCS", + "GGG" + ], + "key": { + "G": { + "item": "minecraft:gold_nugget" + }, + "I": { + "item": "minecraft:gold_ingot" + }, + "C": { + "item": "serverstorage:material_cpu" + }, + "S": { + "item": "serverstorage:material_pcb_substrate" + } + }, + "result": { + "id": "serverstorage:module_modem", + "count": 1 + } +} \ No newline at end of file diff --git a/src/main/resources/data/serverstorage/recipe/module_radio.json b/src/main/resources/data/serverstorage/recipe/module_radio.json new file mode 100644 index 0000000..d510a1b --- /dev/null +++ b/src/main/resources/data/serverstorage/recipe/module_radio.json @@ -0,0 +1,27 @@ +{ + "type": "minecraft:crafting_shaped", + "category": "misc", + "pattern": [ + "CIC", + "SCS", + "GGG" + ], + "key": { + "G": { + "item": "minecraft:gold_nugget" + }, + "I": { + "item": "minecraft:gold_ingot" + }, + "C": { + "item": "serverstorage:material_cpu" + }, + "S": { + "item": "serverstorage:material_pcb_substrate" + } + }, + "result": { + "id": "serverstorage:module_radio", + "count": 1 + } +} \ No newline at end of file diff --git a/src/main/resources/data/serverstorage/recipe/netherite_antenna.json b/src/main/resources/data/serverstorage/recipe/netherite_antenna.json new file mode 100644 index 0000000..2d0687a --- /dev/null +++ b/src/main/resources/data/serverstorage/recipe/netherite_antenna.json @@ -0,0 +1,16 @@ +{ + "type": "minecraft:smithing_transform", + "addition": { + "item": "minecraft:netherite_ingot" + }, + "base": { + "item": "serverstorage:diamond_antenna" + }, + "result": { + "count": 1, + "id": "serverstorage:netherite_antenna" + }, + "template": { + "item": "serverstorage:module_netherite_upgrade" + } +} \ No newline at end of file diff --git a/src/main/resources/data/serverstorage/recipe/radio_interface.json b/src/main/resources/data/serverstorage/recipe/radio_interface.json new file mode 100644 index 0000000..a647549 --- /dev/null +++ b/src/main/resources/data/serverstorage/recipe/radio_interface.json @@ -0,0 +1,39 @@ +{ + "type": "minecraft:crafting_shaped", + "category": "misc", + "pattern": [ + "CBH", + "MUG", + "MPF" + ], + "key": { + "P": { + "item": "serverstorage:material_pcb" + }, + "U": { + "item": "serverstorage:material_cpu" + }, + "C": { + "item": "serverstorage:module_radio" + }, + "B": { + "item": "serverstorage:module_bus" + }, + "H": { + "item": "serverstorage:module_antenna_connector" + }, + "M": { + "item": "serverstorage:module_modem" + }, + "G": { + "item": "serverstorage:module_configuration" + }, + "F": { + "item": "serverstorage:module_pagination" + } + }, + "result": { + "id": "serverstorage:radio_interface", + "count": 1 + } +} \ No newline at end of file diff --git a/src/main/resources/data/serverstorage/recipe/wireless_terminal.json b/src/main/resources/data/serverstorage/recipe/wireless_terminal.json new file mode 100644 index 0000000..28f2d89 --- /dev/null +++ b/src/main/resources/data/serverstorage/recipe/wireless_terminal.json @@ -0,0 +1,39 @@ +{ + "type": "minecraft:crafting_shaped", + "category": "misc", + "pattern": [ + "AHM", + "CGF", + "UMP" + ], + "key": { + "P": { + "item": "serverstorage:material_pcb" + }, + "U": { + "item": "serverstorage:material_cpu" + }, + "A": { + "item": "serverstorage:module_antenna" + }, + "C": { + "item": "serverstorage:module_radio" + }, + "H": { + "item": "serverstorage:module_antenna_connector" + }, + "M": { + "item": "serverstorage:module_modem" + }, + "G": { + "item": "serverstorage:module_configuration" + }, + "F": { + "item": "serverstorage:module_pagination" + } + }, + "result": { + "id": "serverstorage:wireless_terminal", + "count": 1 + } +} \ No newline at end of file