use of com.minecolonies.coremod.colony.interactionhandling.StandardInteraction in project minecolonies by ldtteam.
the class EntityAIWorkPupil method decide.
/**
* Decide between recess and studying.
*
* @return next state to go to.
*/
private IAIState decide() {
if (worker.getRandom().nextInt(STUDY_TO_RECESS_RATIO) < 1) {
recessPos = getOwnBuilding().getPosition();
return RECESS;
}
final BuildingSchool school = getOwnBuilding();
final BlockPos pos = school.getRandomPlaceToSit();
if (pos == null) {
worker.getCitizenData().triggerInteraction(new StandardInteraction(new TranslationTextComponent(PUPIL_NO_CARPET), ChatPriority.BLOCKING));
return DECIDE;
}
studyPos = pos;
return STUDY;
}
use of com.minecolonies.coremod.colony.interactionhandling.StandardInteraction in project minecolonies by ldtteam.
the class AbstractEntityAIBasic method dumpInventory.
/**
* Walk to building and dump inventory. If inventory is dumped, continue execution so that the state can be resolved.
*
* @return INVENTORY_FULL | IDLE
*/
@NotNull
private IAIState dumpInventory() {
final IBuilding building = getBuildingToDump();
if (building == null) {
// Uh oh, that shouldn't happen. Restart AI.
return afterDump();
}
if (!worker.isWorkerAtSiteWithMove(building.getPosition(), DEFAULT_RANGE_FOR_DELAY)) {
setDelay(WALK_DELAY);
return INVENTORY_FULL;
}
if (InventoryUtils.isProviderFull(building)) {
final ICitizenData citizenData = worker.getCitizenData();
if (citizenData != null) {
citizenData.triggerInteraction(new StandardInteraction(new TranslationTextComponent(COM_MINECOLONIES_COREMOD_ENTITY_WORKER_INVENTORYFULLCHEST), ChatPriority.IMPORTANT));
}
// Note that this will not create a pickup request when another request is already in progress.
if (building.getPickUpPriority() > 0) {
building.createPickupRequest(getMaxBuildingPriority(true));
hasDumpedItems = false;
}
alreadyKept.clear();
slotAt = 0;
this.clearActionsDone();
return afterDump();
} else if (dumpOneMoreSlot()) {
return INVENTORY_FULL;
}
alreadyKept.clear();
slotAt = 0;
this.clearActionsDone();
if (isAfterDumpPickupAllowed() && building.getPickUpPriority() > 0 && hasDumpedItems) {
// Worker is not currently crafting, pickup is allowed.
// Note that this will not create a pickup request when another request is already in progress.
building.createPickupRequest(scaledPriority(building.getPickUpPriority()));
hasDumpedItems = false;
}
return afterDump();
}
use of com.minecolonies.coremod.colony.interactionhandling.StandardInteraction in project minecolonies by ldtteam.
the class AbstractEntityAIRequestSmelter method craft.
@Override
protected IAIState craft() {
final FurnaceUserModule module = getOwnBuilding().getFirstModuleOccurance(FurnaceUserModule.class);
final List<ItemStack> possibleFuels = getAllowedFuel();
if (possibleFuels.isEmpty()) {
if (worker.getCitizenData() != null) {
worker.getCitizenData().triggerInteraction(new StandardInteraction(new TranslationTextComponent(FURNACE_USER_NO_FUEL), ChatPriority.BLOCKING));
}
return getState();
}
if (currentRecipeStorage != null) {
possibleFuels.removeIf(stack -> ItemStackUtils.compareItemStacksIgnoreStackSize(stack, currentRecipeStorage.getPrimaryOutput()));
// There is always only one input.
possibleFuels.removeIf(stack -> ItemStackUtils.compareItemStacksIgnoreStackSize(stack, currentRecipeStorage.getCleanedInput().get(0).getItemStack()));
}
if (walkToBuilding()) {
setDelay(STANDARD_DELAY);
return getState();
}
if (currentRecipeStorage != null && currentRequest == null) {
currentRequest = job.getCurrentTask();
}
if (currentRecipeStorage != null && currentRecipeStorage.getIntermediate() != Blocks.FURNACE) {
return super.craft();
}
if (module.getFurnaces().isEmpty()) {
if (worker.getCitizenData() != null) {
worker.getCitizenData().triggerInteraction(new StandardInteraction(new TranslationTextComponent(BAKER_HAS_NO_FURNACES_MESSAGE), ChatPriority.BLOCKING));
}
setDelay(STANDARD_DELAY);
return START_WORKING;
}
final BlockPos furnacePosWithUsedFuel = getPositionOfOvenToRetrieveFuelFrom();
if (furnacePosWithUsedFuel != null) {
walkTo = furnacePosWithUsedFuel;
worker.getCitizenStatusHandler().setLatestStatus(new TranslationTextComponent("com.minecolonies.coremod.status.retrieving"));
return RETRIEVING_USED_FUEL_FROM_FURNACE;
}
final BlockPos posOfOven = getPositionOfOvenToRetrieveFrom();
if (posOfOven != null) {
walkTo = posOfOven;
worker.getCitizenStatusHandler().setLatestStatus(new TranslationTextComponent("com.minecolonies.coremod.status.retrieving"));
return RETRIEVING_END_PRODUCT_FROM_FURNACE;
}
// Safety net, should get caught removing things from the furnace.
if (currentRequest != null && job.getMaxCraftingCount() > 0 && job.getCraftCounter() >= job.getMaxCraftingCount()) {
job.finishRequest(true);
currentRecipeStorage = null;
currentRequest = null;
resetValues();
return INVENTORY_FULL;
}
if (currentRequest != null && (currentRequest.getState() == RequestState.CANCELLED || currentRequest.getState() == RequestState.FAILED)) {
incrementActionsDone(getActionRewardForCraftingSuccess());
currentRecipeStorage = null;
currentRequest = null;
resetValues();
return START_WORKING;
}
return checkIfAbleToSmelt();
}
use of com.minecolonies.coremod.colony.interactionhandling.StandardInteraction in project minecolonies by ldtteam.
the class AbstractEntityAIRequestSmelter method getActivePossibleFuels.
/**
* Get the list of possible fuels, adjusted for any inputs/outputs of the current recipe to avoid interference
*/
private List<ItemStack> getActivePossibleFuels() {
final List<ItemStack> possibleFuels = getAllowedFuel();
if (possibleFuels.isEmpty()) {
if (worker.getCitizenData() != null) {
worker.getCitizenData().triggerInteraction(new StandardInteraction(new TranslationTextComponent(FURNACE_USER_NO_FUEL), ChatPriority.IMPORTANT));
}
return ImmutableList.of();
}
if (currentRecipeStorage != null) {
possibleFuels.removeIf(stack -> ItemStackUtils.compareItemStacksIgnoreStackSize(stack, currentRecipeStorage.getPrimaryOutput()));
// There is always only one input.
possibleFuels.removeIf(stack -> ItemStackUtils.compareItemStacksIgnoreStackSize(stack, currentRecipeStorage.getCleanedInput().get(0).getItemStack()));
}
return possibleFuels;
}
use of com.minecolonies.coremod.colony.interactionhandling.StandardInteraction in project minecolonies by ldtteam.
the class AbstractEntityAIUsesFurnace method startWorking.
/**
* Central method of the furnace user, he decides about what to do next from here. First check if any of the workers has important tasks to handle first. If not check if there
* is an oven with an item which has to be retrieved. If not check if fuel and smeltable are available and request if necessary and get into inventory. Then check if able to
* smelt already.
*
* @return the next state to go to.
*/
public IAIState startWorking() {
if (walkToBuilding()) {
return getState();
}
final FurnaceUserModule furnaceModule = getOwnBuilding().getFirstModuleOccurance(FurnaceUserModule.class);
final ItemListModule itemListModule = getOwnBuilding().getModuleMatching(ItemListModule.class, m -> m.getId().equals(FUEL_LIST));
worker.getCitizenData().setVisibleStatus(VisibleCitizenStatus.WORKING);
if (itemListModule.getList().isEmpty()) {
if (worker.getCitizenData() != null) {
worker.getCitizenData().triggerInteraction(new StandardInteraction(new TranslationTextComponent(FURNACE_USER_NO_FUEL), ChatPriority.BLOCKING));
}
return getState();
}
if (furnaceModule.getFurnaces().isEmpty()) {
if (worker.getCitizenData() != null) {
worker.getCitizenData().triggerInteraction(new StandardInteraction(new TranslationTextComponent(BAKER_HAS_NO_FURNACES_MESSAGE), ChatPriority.BLOCKING));
}
return getState();
}
worker.getCitizenStatusHandler().setLatestStatus(new TranslationTextComponent(COM_MINECOLONIES_COREMOD_STATUS_DECIDING));
final IAIState nextState = checkForImportantJobs();
if (nextState != START_WORKING) {
return nextState;
}
final BlockPos posOfUsedFuelOven = getPositionOfOvenToRetrieveFuelFrom();
if (posOfUsedFuelOven != null) {
walkTo = posOfUsedFuelOven;
worker.getCitizenStatusHandler().setLatestStatus(new TranslationTextComponent("com.minecolonies.coremod.status.retrieving"));
return RETRIEVING_USED_FUEL_FROM_FURNACE;
}
final BlockPos posOfOven = getPositionOfOvenToRetrieveFrom();
if (posOfOven != null) {
walkTo = posOfOven;
worker.getCitizenStatusHandler().setLatestStatus(new TranslationTextComponent("com.minecolonies.coremod.status.retrieving"));
return RETRIEVING_END_PRODUCT_FROM_FURNACE;
}
final int amountOfSmeltableInBuilding = InventoryUtils.getCountFromBuilding(getOwnBuilding(), this::isSmeltable);
final int amountOfSmeltableInInv = InventoryUtils.getItemCountInItemHandler((worker.getInventoryCitizen()), this::isSmeltable);
final int amountOfFuelInBuilding = InventoryUtils.getCountFromBuilding(getOwnBuilding(), itemListModule.getList());
final int amountOfFuelInInv = InventoryUtils.getItemCountInItemHandler((worker.getInventoryCitizen()), stack -> itemListModule.isItemInList(new ItemStorage(stack)));
if (amountOfSmeltableInBuilding + amountOfSmeltableInInv <= 0 && !reachedMaxToKeep()) {
requestSmeltable();
}
if (amountOfFuelInBuilding + amountOfFuelInInv <= 0 && !getOwnBuilding().hasWorkerOpenRequestsFiltered(worker.getCitizenData().getId(), req -> req.getShortDisplayString().getSiblings().contains(new TranslationTextComponent(COM_MINECOLONIES_REQUESTS_BURNABLE)))) {
worker.getCitizenData().createRequestAsync(new StackList(getAllowedFuel(), COM_MINECOLONIES_REQUESTS_BURNABLE, STACKSIZE * furnaceModule.getFurnaces().size(), 1));
}
if (amountOfSmeltableInBuilding > 0 && amountOfSmeltableInInv == 0) {
needsCurrently = new Tuple<>(this::isSmeltable, STACKSIZE);
return GATHERING_REQUIRED_MATERIALS;
} else if (amountOfFuelInBuilding > 0 && amountOfFuelInInv == 0) {
needsCurrently = new Tuple<>(stack -> itemListModule.isItemInList(new ItemStorage(stack)), STACKSIZE);
return GATHERING_REQUIRED_MATERIALS;
}
return checkIfAbleToSmelt(amountOfFuelInBuilding + amountOfFuelInInv, amountOfSmeltableInBuilding + amountOfSmeltableInInv);
}
Aggregations