aboutsummaryrefslogtreecommitdiff
path: root/src/main/java/gregtech/api/gui/widgets/CoverTickRateButton.java
blob: ab05a989257e42a12702ad258bf81fd51be6821c (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
package gregtech.api.gui.widgets;

import static gregtech.api.gui.modularui.GTUITextures.OVERLAY_BUTTON_HOURGLASS;
import static gregtech.common.covers.CoverInfo.MAX_TICK_RATE_ADDITION;

import java.util.List;

import net.minecraft.util.StatCollector;

import org.jetbrains.annotations.NotNull;

import com.google.common.collect.ImmutableList;
import com.gtnewhorizons.modularui.api.drawable.UITexture;
import com.gtnewhorizons.modularui.api.widget.IWidgetBuilder;
import com.gtnewhorizons.modularui.api.widget.Widget;
import com.gtnewhorizons.modularui.common.widget.ButtonWidget;
import com.gtnewhorizons.modularui.common.widget.FakeSyncWidget;

import gregtech.api.gui.modularui.GTUITextures;
import gregtech.common.covers.CoverInfo;

public class CoverTickRateButton extends ButtonWidget {

    private static final UITexture BACKGROUND = GTUITextures.BUTTON_COVER_NORMAL.getSubArea(0, 0, 1, 0.5f);

    private final CoverInfo coverInfo;
    private int clientTickRate;
    private int tickRateAddition;

    public CoverTickRateButton(@NotNull CoverInfo coverInfo, @NotNull IWidgetBuilder<?> builder) {
        this.coverInfo = coverInfo;
        this.clientTickRate = coverInfo.getTickRate();
        this.tickRateAddition = coverInfo.getTickRateAddition();

        super.setBackground(BACKGROUND, OVERLAY_BUTTON_HOURGLASS);
        super.setOnClick(this::onClick);
        super.dynamicTooltip(this::dynamicTooltip);
        super.attachSyncer(
            new FakeSyncWidget.IntegerSyncer(this.coverInfo::getTickRate, integer -> clientTickRate = integer),
            builder,
            (widget, aInt) -> notifyTooltipChange())
                .attachSyncer(
                    new FakeSyncWidget.IntegerSyncer(
                        this.coverInfo::getTickRateAddition,
                        integer -> tickRateAddition = integer),
                    builder);

    }

    private void onClick(@NotNull ClickData clickData, @NotNull Widget widget) {
        final int iterations = clickData.ctrl ? 5 : 1;
        final boolean isDecreasing = clickData.mouseButton == 1;

        // Do five operations at once if Ctrl is held down. Since the actual increase granted by each invocation can be
        // different on each call, just call the method several times rather than trying to do a bunch of weird math.
        for (int i = 0; i < iterations; i++) {
            coverInfo.adjustTickRateMultiplier(isDecreasing);
        }
    }

    private List<String> dynamicTooltip() {
        final String boundsNotification;

        if (tickRateAddition == 0) {
            boundsNotification = StatCollector.translateToLocal("gt.cover.info.button.bounds_notification.minimum");
        } else if (tickRateAddition >= MAX_TICK_RATE_ADDITION - 1) {
            // Clamping can make tickRateAddition approach but never actually equal MAX_ADDITION, so we need this
            // adjustment.
            boundsNotification = StatCollector.translateToLocal("gt.cover.info.button.bounds_notification.maximum");
        } else {
            boundsNotification = "";
        }

        return ImmutableList.of(
            StatCollector.translateToLocalFormatted(
                "gt.cover.info.button.tick_rate.1",
                new CoverInfo.ClientTickRateFormatter(clientTickRate),
                boundsNotification),
            StatCollector.translateToLocal("gt.cover.info.button.tick_rate.2"),
            StatCollector.translateToLocal("gt.cover.info.button.tick_rate.3"));
    }
}