Skip to content

Commit

Permalink
Initial Fabric-only alpha version
Browse files Browse the repository at this point in the history
  • Loading branch information
NotRyken committed Jun 19, 2024
1 parent b8c3942 commit a5f8945
Show file tree
Hide file tree
Showing 36 changed files with 146 additions and 111 deletions.
2 changes: 1 addition & 1 deletion .github/workflows/release.yml
Original file line number Diff line number Diff line change
Expand Up @@ -31,7 +31,7 @@ jobs:
if: ${{ runner.os != 'Windows' }}
run: chmod +x ./gradlew
- name: Build
run: ./gradlew build neoforge:githubRelease neoforge:modrinth fabric:githubRelease fabric:modrinth --stacktrace
run: ./gradlew build neoforge:githubRelease fabric:githubRelease --stacktrace
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
MODRINTH_TOKEN: ${{ secrets.MODRINTH_TOKEN }}
Expand Down
14 changes: 14 additions & 0 deletions NOTICE
Original file line number Diff line number Diff line change
@@ -0,0 +1,14 @@
Copyright 2020-2022 Siphalor
Copyright 2024 NotRyken

Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at

http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
22 changes: 17 additions & 5 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -4,23 +4,35 @@

## ClientSort

Provides client-side inventory sorting utilities.
Standalone implementation of Siphalor's [Mouse Wheelie](https://github.com/Siphalor/mouse-wheelie) sorting algorithm.

[![Environment](https://img.shields.io/badge/Environment-Client-blue?logo=)]()
[![Latest Minecraft](https://img.shields.io/modrinth/game-versions/raDGbHBr?label=Latest%20Minecraft&color=%2300AF5C&logo=)](https://modrinth.com/mod/raDGbHBr/versions)

[![Loader](https://img.shields.io/badge/Available%20for-Fabric-dbd0b4?logo=)](https://fabricmc.net/)
[![Loader](https://img.shields.io/badge/Available%20for-Quilt-9115ff?logo=)](https://quiltmc.org/)
[![Loader](https://img.shields.io/badge/Available%20for-NeoForge-f16436?logo=)](https://neoforged.net/)

[![Download on Modrinth](https://img.shields.io/modrinth/dt/raDGbHBr?label=Download%20on%20Modrinth&logo=modrinth&logoColor=%2300AF5C)](https://modrinth.com/mod/raDGbHBr)
[![Download on GitHub](https://img.shields.io/github/downloads/TerminalMC/ClientSort/total?label=Download%20on%20GitHub&logo=github&logoColor=white)](https://github.com/TerminalMC/ClientSort)

</center></div>

### About

Currently only an experimental project.
To sort an inventory, simply hover over it with your mouse and press the keybind (default: middle mouse button).

You can hold `Shift` or `Control` when pressing the sort button to use a different sorting order.

### Dependencies

- [Fabric API](https://modrinth.com/mod/P7dR8mSH) (required)
- [ModMenu](https://modrinth.com/mod/mOgUt4GM) (required for configuration)
- [Cloth Config API](https://modrinth.com/mod/9s6osm5g) (required for configuration)

### Credits

ClientSort uses Siphalor's sorting algorithm from Mouse Wheelie, under license.

Mouse Wheelie is available on [Modrinth](https://modrinth.com/mod/u5Ic2U1u) and
[GitHub](https://github.com/Siphalor/mouse-wheelie/releases)

### License

Expand Down
Binary file removed assets/images/banner.png
Binary file not shown.
Binary file removed assets/images/showcase/command_01.png
Binary file not shown.
Binary file removed assets/images/showcase/config_01.png
Binary file not shown.
Binary file removed assets/images/showcase/config_02.png
Binary file not shown.
41 changes: 18 additions & 23 deletions common/src/main/java/dev/terminalmc/clientsort/ClientSort.java
Original file line number Diff line number Diff line change
@@ -1,31 +1,19 @@
/*
* Copyright 2020-2022 Siphalor
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing,
* software distributed under the License is distributed on an
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND,
* either express or implied.
* See the License for the specific language governing
* permissions and limitations under the License.
* Copyright 2024 NotRyken
* SPDX-License-Identifier: Apache-2.0
*/

package dev.terminalmc.clientsort;

import com.mojang.blaze3d.platform.InputConstants;
import com.mojang.logging.LogUtils;
import dev.terminalmc.clientsort.config.Config;
import dev.terminalmc.clientsort.mixin.KeyMappingAccessor;
import dev.terminalmc.clientsort.network.InteractionManager;
import dev.terminalmc.clientsort.util.inject.IContainerScreen;
import dev.terminalmc.clientsort.util.mod.ModLogger;
import net.minecraft.client.KeyMapping;
import net.minecraft.client.Minecraft;
import org.lwjgl.glfw.GLFW;

import static dev.terminalmc.clientsort.util.mod.Localization.translationKey;

Expand All @@ -47,14 +35,21 @@ public static void init() {

public static void onEndTick(Minecraft mc) {
if (cooldown == 0) {
if (InputConstants.isKeyDown(mc.getWindow().getWindow(),
((KeyMappingAccessor) SORT_KEY).getKey().getValue())) {
if (mc.screen instanceof IContainerScreen screen) {
LogUtils.getLogger().info("good screen");
screen.mouseWheelie_triggerSort();
cooldown = 11;
}
}
int key = ((KeyMappingAccessor) SORT_KEY).getKey().getValue();
if (key != GLFW.GLFW_KEY_UNKNOWN) {
boolean down;
if (key <= 7) {
down = GLFW.glfwGetMouseButton(mc.getWindow().getWindow(), key) == GLFW.GLFW_PRESS;
} else {
down = GLFW.glfwGetKey(mc.getWindow().getWindow(), key) == GLFW.GLFW_PRESS;
}
if (down) {
if (mc.screen instanceof IContainerScreen screen) {
screen.mouseWheelie_triggerSort();
cooldown = 11;
}
}
}
}
if (cooldown > 0) cooldown--;
}
Expand Down
Original file line number Diff line number Diff line change
@@ -1,3 +1,8 @@
/*
* Copyright 2024 NotRyken
* SPDX-License-Identifier: Apache-2.0
*/

package dev.terminalmc.clientsort.config;

import com.google.gson.Gson;
Expand Down
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
/*
* Copyright 2020-2022 Siphalor
* Copyright 2024 NotRyken
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
Expand Down
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
/*
* Copyright 2020-2022 Siphalor
* Copyright 2024 NotRyken
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
Expand Down
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
/*
* Copyright 2020-2022 Siphalor
* Copyright 2024 NotRyken
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
Expand Down
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
/*
* Copyright 2020-2022 Siphalor
* Copyright 2024 NotRyken
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
Expand Down Expand Up @@ -35,7 +36,7 @@ public class SortContext {
AbstractContainerScreen<?> screen;
/**
* The slots that are the target of the current sort action.
* These slots are usually in the same scope (see {@link de.siphalor.mousewheelie.client.inventory.ContainerScreenHelper#getScope(Slot)}).
* These slots are usually in the same scope (see {@link dev.terminalmc.clientsort.inventory.ContainerScreenHelper.getScope(Slot)}).
*/
List<Slot> relevantSlots;

Expand Down
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
/*
* Copyright 2020-2022 Siphalor
* Copyright 2024 NotRyken
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
Expand Down Expand Up @@ -34,7 +35,7 @@

public abstract class SortMode {
public static final Map<String, SortMode> SORT_MODES = new HashMap<>();
private final String name;
public final String name;

public static final SortMode NONE;
public static final SortMode ALPHABET;
Expand Down
Original file line number Diff line number Diff line change
@@ -1,18 +1,6 @@
/*
* Copyright 2020-2022 Siphalor
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing,
* software distributed under the License is distributed on an
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND,
* either express or implied.
* See the License for the specific language governing
* permissions and limitations under the License.
* Copyright 2024 NotRyken
* SPDX-License-Identifier: Apache-2.0
*/

package dev.terminalmc.clientsort.mixin;
Expand Down
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
/*
* Copyright 2020-2022 Siphalor
* Copyright 2024 NotRyken
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
Expand All @@ -26,7 +27,6 @@
import dev.terminalmc.clientsort.util.inject.IContainerScreen;
import dev.terminalmc.clientsort.util.inject.ISlot;
import net.minecraft.client.Minecraft;
import net.minecraft.client.Options;
import net.minecraft.client.gui.screens.Screen;
import net.minecraft.client.gui.screens.inventory.AbstractContainerScreen;
import net.minecraft.network.chat.Component;
Expand All @@ -42,7 +42,6 @@

import java.util.function.Supplier;

@SuppressWarnings("WeakerAccess")
@Mixin(AbstractContainerScreen.class)
public abstract class MixinAbstractContainerScreen extends Screen implements IContainerScreen {
protected MixinAbstractContainerScreen(Component textComponent_1) {
Expand All @@ -61,7 +60,7 @@ protected MixinAbstractContainerScreen(Component textComponent_1) {

@SuppressWarnings({"ConstantConditions", "unchecked"})
@Unique
private final Supplier<ContainerScreenHelper<AbstractContainerScreen<AbstractContainerMenu>>> screenHelper = Suppliers.memoize(
private final Supplier<ContainerScreenHelper<AbstractContainerScreen<AbstractContainerMenu>>> clientSort$screenHelper = Suppliers.memoize(
() -> ContainerScreenHelper.of((AbstractContainerScreen<AbstractContainerMenu>) (Object) this, (slot, data, slotActionType) -> new InteractionManager.CallbackEvent(() -> {
slotClicked(slot, ((ISlot) slot).mouseWheelie_getIdInContainer(), data, slotActionType);
return InteractionManager.TICK_WAITER;
Expand All @@ -78,7 +77,7 @@ public boolean mouseWheelie_triggerSort() {
&& GLFW.glfwGetMouseButton(minecraft.getWindow().getWindow(), GLFW.GLFW_MOUSE_BUTTON_MIDDLE) != 0
&& (!hoveredSlot.getItem().isEmpty() == menu.getCarried().isEmpty()))
return false;
InventorySorter sorter = new InventorySorter(screenHelper.get(), (AbstractContainerScreen<?>) (Object) this, hoveredSlot);
InventorySorter sorter = new InventorySorter(clientSort$screenHelper.get(), (AbstractContainerScreen<?>) (Object) this, hoveredSlot);
Config.Options options = Config.get().options;
SortMode sortMode;
if (hasShiftDown()) {
Expand Down
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
/*
* Copyright 2020-2022 Siphalor
* Copyright 2024 NotRyken
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
Expand Down
Loading

0 comments on commit a5f8945

Please sign in to comment.