More sync fixes with regards to prev commit + Fixed the Fluid Grid not having a View type setting

This commit is contained in:
raoulvdberge
2019-11-01 22:55:27 +01:00
parent 3f8556e8b0
commit 3af161c649
4 changed files with 13 additions and 6 deletions

View File

@@ -115,7 +115,7 @@ public class GridScreen extends BaseScreen<GridContainer> implements IScreenInfo
addButton(searchField);
if (grid.getGridType() != GridType.FLUID && grid.getViewType() != -1) {
if (grid.getViewType() != -1) {
addSideButton(new GridViewTypeSideButton(this, grid));
}

View File

@@ -1,7 +1,6 @@
package com.raoulvdberge.refinedstorage.screen.grid.filtering;
import com.raoulvdberge.refinedstorage.screen.grid.stack.IGridStack;
import com.raoulvdberge.refinedstorage.screen.grid.stack.ItemGridStack;
import java.util.function.Predicate;
@@ -14,7 +13,10 @@ public class CraftableGridFilter implements Predicate<IGridStack> {
@Override
public boolean test(IGridStack stack) {
// TODO Make working with fluids.
return stack instanceof ItemGridStack && stack.isCraftable() == craftable;
if (craftable) {
return stack.isCraftable();
} else {
return !stack.isCraftable() && stack.getOtherId() == null;
}
}
}

View File

@@ -58,8 +58,12 @@ public abstract class BaseGridView implements IGridView {
while (it.hasNext()) {
IGridStack stack = it.next();
// TODO Make working with grid sorting mode.
if (stack.isCraftable() &&
// If this is a crafting stack,
// and there is a regular matching stack in the view too,
// and we aren't in "view only craftables" mode,
// we don't want the duplicate stacks and we will remove this stack.
if (screen.getGrid().getViewType() != IGrid.VIEW_TYPE_CRAFTABLES &&
stack.isCraftable() &&
stack.getOtherId() != null &&
map.containsKey(stack.getOtherId())) {
it.remove();