123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534 |
- package me.shedaniel.rei.gui;
- import com.google.common.collect.Lists;
- import com.mojang.blaze3d.platform.GlStateManager;
- import me.shedaniel.cloth.api.ClientUtils;
- import me.shedaniel.rei.RoughlyEnoughItemsCore;
- import me.shedaniel.rei.api.DisplayHelper;
- import me.shedaniel.rei.client.ClientHelper;
- import me.shedaniel.rei.client.ScreenHelper;
- import me.shedaniel.rei.client.Weather;
- import me.shedaniel.rei.gui.widget.*;
- import net.minecraft.client.MinecraftClient;
- import net.minecraft.client.audio.PositionedSoundInstance;
- import net.minecraft.client.font.TextRenderer;
- import net.minecraft.client.gui.*;
- import net.minecraft.client.render.GuiLighting;
- import net.minecraft.client.resource.language.I18n;
- import net.minecraft.client.util.Window;
- import net.minecraft.client.world.ClientWorld;
- import net.minecraft.item.ItemStack;
- import net.minecraft.sound.SoundEvents;
- import net.minecraft.text.TranslatableTextComponent;
- import net.minecraft.util.Identifier;
- import net.minecraft.util.math.MathHelper;
- import net.minecraft.world.GameMode;
- import java.awt.*;
- import java.util.*;
- import java.util.List;
- import java.util.stream.Collectors;
- public class ContainerScreenOverlay extends AbstractParentElement implements Drawable {
-
- private static final Identifier CHEST_GUI_TEXTURE = new Identifier("roughlyenoughitems", "textures/gui/recipecontainer.png");
- private static final List<QueuedTooltip> QUEUED_TOOLTIPS = Lists.newArrayList();
- public static String searchTerm = "";
- private static int page = 0;
- private static ItemListOverlay itemListOverlay;
- private final List<Widget> widgets = Lists.newLinkedList();
- private Rectangle rectangle;
- private Window window;
- private ButtonWidget buttonLeft, buttonRight;
- private int lastLeft;
-
- public static ItemListOverlay getItemListOverlay() {
- return itemListOverlay;
- }
-
- public void init() {
- init(false);
- }
-
- public void init(boolean setPage) {
- //Update Variables
- this.children().clear();
- this.window = MinecraftClient.getInstance().window;
- DisplayHelper.DisplayBoundsHandler boundsHandler = RoughlyEnoughItemsCore.getDisplayHelper().getResponsibleBoundsHandler(MinecraftClient.getInstance().currentScreen.getClass());
- this.rectangle = RoughlyEnoughItemsCore.getConfigManager().getConfig().mirrorItemPanel ? boundsHandler.getLeftBounds(MinecraftClient.getInstance().currentScreen) : boundsHandler.getRightBounds(MinecraftClient.getInstance().currentScreen);
- this.lastLeft = getLeft();
- widgets.add(this.itemListOverlay = new ItemListOverlay(page));
- itemListOverlay.updateList(boundsHandler, boundsHandler.getItemListArea(rectangle), page, searchTerm);
-
- widgets.add(buttonLeft = new ButtonWidget(rectangle.x, rectangle.y + 5, 16, 16, new TranslatableTextComponent("text.rei.left_arrow")) {
- @Override
- public void onPressed() {
- page--;
- if (page < 0)
- page = getTotalPage();
- itemListOverlay.updateList(boundsHandler, boundsHandler.getItemListArea(rectangle), page, searchTerm);
- }
-
- @Override
- public Optional<String> getTooltips() {
- return Optional.ofNullable(I18n.translate("text.rei.previous_page"));
- }
-
- @Override
- public boolean changeFocus(boolean boolean_1) {
- return false;
- }
- });
- widgets.add(buttonRight = new ButtonWidget(rectangle.x + rectangle.width - 18, rectangle.y + 5, 16, 16, new TranslatableTextComponent("text.rei.right_arrow")) {
- @Override
- public void onPressed() {
- page++;
- if (page > getTotalPage())
- page = 0;
- itemListOverlay.updateList(boundsHandler, boundsHandler.getItemListArea(rectangle), page, searchTerm);
- }
-
- @Override
- public Optional<String> getTooltips() {
- return Optional.ofNullable(I18n.translate("text.rei.next_page"));
- }
-
- @Override
- public boolean changeFocus(boolean boolean_1) {
- return false;
- }
- });
- if (setPage)
- page = MathHelper.clamp(page, 0, getTotalPage());
- widgets.add(new ButtonWidget(RoughlyEnoughItemsCore.getConfigManager().getConfig().mirrorItemPanel ? window.getScaledWidth() - 30 : 10, 10, 20, 20, "") {
- @Override
- public void onPressed() {
- if (Screen.hasShiftDown()) {
- ClientHelper.setCheating(!ClientHelper.isCheating());
- return;
- }
- RoughlyEnoughItemsCore.getConfigManager().openConfigScreen(ScreenHelper.getLastContainerScreen());
- }
-
- @Override
- public void render(int mouseX, int mouseY, float delta) {
- super.render(mouseX, mouseY, delta);
- GuiLighting.disable();
- if (ClientHelper.isCheating())
- fill(getBounds().x, getBounds().y, getBounds().x + 20, getBounds().y + 20, new Color(255, 0, 0, 42).getRGB());
- MinecraftClient.getInstance().getTextureManager().bindTexture(CHEST_GUI_TEXTURE);
- GlStateManager.color4f(1.0F, 1.0F, 1.0F, 1.0F);
- blit(getBounds().x + 3, getBounds().y + 3, 0, 0, 14, 14);
- }
-
- @Override
- public Optional<String> getTooltips() {
- String tooltips = I18n.translate("text.rei.config_tooltip");
- tooltips += "\n ";
- if (!ClientHelper.isCheating())
- tooltips += "\n§c§m" + I18n.translate("text.rei.cheating");
- else
- tooltips += "\n§a" + I18n.translate("text.rei.cheating");
- return Optional.ofNullable(tooltips);
- }
-
- @Override
- public boolean changeFocus(boolean boolean_1) {
- return false;
- }
- });
- if (RoughlyEnoughItemsCore.getConfigManager().getConfig().showUtilsButtons) {
- widgets.add(new ButtonWidget(RoughlyEnoughItemsCore.getConfigManager().getConfig().mirrorItemPanel ? window.getScaledWidth() - 55 : 35, 10, 20, 20, "") {
- @Override
- public void onPressed() {
- MinecraftClient.getInstance().player.sendChatMessage(RoughlyEnoughItemsCore.getConfigManager().getConfig().gamemodeCommand.replaceAll("\\{gamemode}", getNextGameMode().getName()));
- }
-
- @Override
- public void render(int mouseX, int mouseY, float delta) {
- text = getGameModeShortText(getCurrentGameMode());
- super.render(mouseX, mouseY, delta);
- }
-
- @Override
- public Optional<String> getTooltips() {
- return Optional.ofNullable(I18n.translate("text.rei.gamemode_button.tooltip", getGameModeText(getNextGameMode())));
- }
-
- @Override
- public boolean changeFocus(boolean boolean_1) {
- return false;
- }
- });
- widgets.add(new ButtonWidget(RoughlyEnoughItemsCore.getConfigManager().getConfig().mirrorItemPanel ? window.getScaledWidth() - 80 : 60, 10, 20, 20, "") {
- @Override
- public void onPressed() {
- MinecraftClient.getInstance().player.sendChatMessage(RoughlyEnoughItemsCore.getConfigManager().getConfig().weatherCommand.replaceAll("\\{weather}", getNextWeather().name().toLowerCase()));
- }
-
- @Override
- public void render(int mouseX, int mouseY, float delta) {
- super.render(mouseX, mouseY, delta);
- GuiLighting.disable();
- MinecraftClient.getInstance().getTextureManager().bindTexture(CHEST_GUI_TEXTURE);
- GlStateManager.color4f(1.0F, 1.0F, 1.0F, 1.0F);
- blit(getBounds().x + 3, getBounds().y + 3, getCurrentWeather().getId() * 14, 14, 14, 14);
- }
-
- @Override
- public Optional<String> getTooltips() {
- return Optional.ofNullable(I18n.translate("text.rei.weather_button.tooltip", I18n.translate(getNextWeather().getTranslateKey())));
- }
-
- @Override
- public boolean changeFocus(boolean boolean_1) {
- return false;
- }
- });
- }
- widgets.add(new ClickableLabelWidget(rectangle.x + (rectangle.width / 2), rectangle.y + 10, "") {
- @Override
- public void render(int mouseX, int mouseY, float delta) {
- page = MathHelper.clamp(page, 0, getTotalPage());
- this.text = String.format("%s/%s", page + 1, getTotalPage() + 1);
- super.render(mouseX, mouseY, delta);
- }
-
- @Override
- public Optional<String> getTooltips() {
- return Optional.ofNullable(I18n.translate("text.rei.go_back_first_page"));
- }
-
- @Override
- public void onLabelClicked() {
- MinecraftClient.getInstance().getSoundManager().play(PositionedSoundInstance.master(SoundEvents.UI_BUTTON_CLICK, 1.0F));
- page = 0;
- itemListOverlay.updateList(boundsHandler, boundsHandler.getItemListArea(rectangle), page, searchTerm);
- }
-
- @Override
- public boolean changeFocus(boolean boolean_1) {
- return false;
- }
- });
- if (ScreenHelper.searchField == null)
- ScreenHelper.searchField = new SearchFieldWidget(0, 0, 0, 0);
- ScreenHelper.searchField.setChangedListener(s -> {
- searchTerm = s;
- itemListOverlay.updateList(boundsHandler, boundsHandler.getItemListArea(rectangle), page, searchTerm);
- });
- ScreenHelper.searchField.getBounds().setBounds(getTextFieldArea());
- this.widgets.add(ScreenHelper.searchField);
- ScreenHelper.searchField.setText(searchTerm);
- if (RoughlyEnoughItemsCore.getConfigManager().getConfig().enableCraftableOnlyButton)
- this.widgets.add(new CraftableToggleButtonWidget(getCraftableToggleArea()) {
- @Override
- public void onPressed() {
- RoughlyEnoughItemsCore.getConfigManager().toggleCraftableOnly();
- itemListOverlay.updateList(boundsHandler, boundsHandler.getItemListArea(rectangle), page, searchTerm);
- }
-
- @Override
- public void render(int mouseX, int mouseY, float delta) {
- blitOffset = 600;
- super.render(mouseX, mouseY, delta);
- }
- });
-
- this.itemListOverlay.updateList(boundsHandler, boundsHandler.getItemListArea(rectangle), page, searchTerm);
- }
-
- private Weather getNextWeather() {
- try {
- Weather current = getCurrentWeather();
- int next = current.getId() + 1;
- if (next >= 3)
- next = 0;
- return Weather.byId(next);
- } catch (Exception e) {
- return Weather.CLEAR;
- }
- }
-
- private Weather getCurrentWeather() {
- ClientWorld world = MinecraftClient.getInstance().world;
- if (world.isThundering())
- return Weather.THUNDER;
- if (world.getLevelProperties().isRaining())
- return Weather.RAIN;
- return Weather.CLEAR;
- }
-
- private String getGameModeShortText(GameMode gameMode) {
- return I18n.translate("text.rei.short_gamemode." + gameMode.getName());
- }
-
- private String getGameModeText(GameMode gameMode) {
- return I18n.translate("selectWorld.gameMode." + gameMode.getName());
- }
-
- private GameMode getNextGameMode() {
- try {
- GameMode current = getCurrentGameMode();
- int next = current.getId() + 1;
- if (next > 3)
- next = 0;
- return GameMode.byId(next);
- } catch (Exception e) {
- return GameMode.INVALID;
- }
- }
-
- private GameMode getCurrentGameMode() {
- return MinecraftClient.getInstance().getNetworkHandler().getScoreboardEntry(MinecraftClient.getInstance().player.getGameProfile().getId()).getGameMode();
- }
-
- private Rectangle getTextFieldArea() {
- int widthRemoved = RoughlyEnoughItemsCore.getConfigManager().getConfig().enableCraftableOnlyButton ? 22 : 2;
- if (RoughlyEnoughItemsCore.getConfigManager().getConfig().sideSearchField)
- return new Rectangle(rectangle.x + 2, window.getScaledHeight() - 22, rectangle.width - 6 - widthRemoved, 18);
- if (MinecraftClient.getInstance().currentScreen instanceof RecipeViewingScreen) {
- RecipeViewingScreen widget = (RecipeViewingScreen) MinecraftClient.getInstance().currentScreen;
- return new Rectangle(widget.getBounds().x, window.getScaledHeight() - 22, widget.getBounds().width - widthRemoved, 18);
- }
- return new Rectangle(ScreenHelper.getLastContainerScreenHooks().rei_getContainerLeft(), window.getScaledHeight() - 22, ScreenHelper.getLastContainerScreenHooks().rei_getContainerWidth() - widthRemoved, 18);
- }
-
- private Rectangle getCraftableToggleArea() {
- Rectangle searchBoxArea = getTextFieldArea();
- searchBoxArea.setLocation(searchBoxArea.x + searchBoxArea.width + 4, searchBoxArea.y - 1);
- searchBoxArea.setSize(20, 20);
- return searchBoxArea;
- }
-
- private String getCheatModeText() {
- return I18n.translate(String.format("%s%s", "text.rei.", ClientHelper.isCheating() ? "cheat" : "nocheat"));
- }
-
- public Rectangle getRectangle() {
- return rectangle;
- }
-
- @Override
- public void render(int mouseX, int mouseY, float delta) {
- List<ItemStack> currentStacks = ClientHelper.getInventoryItemsTypes();
- if (getLeft() != lastLeft)
- init(true);
- else if (RoughlyEnoughItemsCore.getConfigManager().isCraftableOnlyEnabled() && (!hasSameListContent(new LinkedList<>(ScreenHelper.inventoryStacks), currentStacks) || (currentStacks.size() != ScreenHelper.inventoryStacks.size()))) {
- ScreenHelper.inventoryStacks = ClientHelper.getInventoryItemsTypes();
- DisplayHelper.DisplayBoundsHandler boundsHandler = RoughlyEnoughItemsCore.getDisplayHelper().getResponsibleBoundsHandler(MinecraftClient.getInstance().currentScreen.getClass());
- itemListOverlay.updateList(boundsHandler, boundsHandler.getItemListArea(rectangle), page, searchTerm);
- }
- GlStateManager.color4f(1.0F, 1.0F, 1.0F, 1.0F);
- GuiLighting.disable();
- this.renderWidgets(mouseX, mouseY, delta);
- }
-
- public void lateRender(int mouseX, int mouseY, float delta) {
- ScreenHelper.searchField.laterRender(mouseX, mouseY, delta);
- Screen currentScreen = MinecraftClient.getInstance().currentScreen;
- if (!(currentScreen instanceof RecipeViewingScreen) || !((RecipeViewingScreen) currentScreen).choosePageActivated)
- QUEUED_TOOLTIPS.stream().filter(queuedTooltip -> queuedTooltip != null).forEach(queuedTooltip -> renderTooltip(queuedTooltip.getText(), queuedTooltip.getLocation().x, queuedTooltip.getLocation().y));
- QUEUED_TOOLTIPS.clear();
- }
-
- public void renderTooltip(List<String> list_1, int int_1, int int_2) {
- TextRenderer font = MinecraftClient.getInstance().textRenderer;
- Window window = MinecraftClient.getInstance().window;
- if (!list_1.isEmpty()) {
- GlStateManager.disableRescaleNormal();
- GuiLighting.disable();
- GlStateManager.disableLighting();
- int int_3 = 0;
- Iterator var5 = list_1.iterator();
- while (var5.hasNext()) {
- String string_1 = (String) var5.next();
- int int_4 = font.getStringWidth(string_1);
- if (int_4 > int_3)
- int_3 = int_4;
- }
- int int_5 = int_1 + 12;
- int int_6 = int_2 - 12;
- int int_8 = 8;
- if (list_1.size() > 1)
- int_8 += 2 + (list_1.size() - 1) * 10;
- if (int_5 + int_3 > window.getScaledWidth())
- int_5 -= 28 + int_3;
- if (int_6 + int_8 + 6 > window.getScaledHeight())
- int_6 = window.getScaledHeight() - int_8 - 6;
-
- this.blitOffset = 1000;
- this.fillGradient(int_5 - 3, int_6 - 4, int_5 + int_3 + 3, int_6 - 3, -267386864, -267386864);
- this.fillGradient(int_5 - 3, int_6 + int_8 + 3, int_5 + int_3 + 3, int_6 + int_8 + 4, -267386864, -267386864);
- this.fillGradient(int_5 - 3, int_6 - 3, int_5 + int_3 + 3, int_6 + int_8 + 3, -267386864, -267386864);
- this.fillGradient(int_5 - 4, int_6 - 3, int_5 - 3, int_6 + int_8 + 3, -267386864, -267386864);
- this.fillGradient(int_5 + int_3 + 3, int_6 - 3, int_5 + int_3 + 4, int_6 + int_8 + 3, -267386864, -267386864);
- this.fillGradient(int_5 - 3, int_6 - 3 + 1, int_5 - 3 + 1, int_6 + int_8 + 3 - 1, 1347420415, 1344798847);
- this.fillGradient(int_5 + int_3 + 2, int_6 - 3 + 1, int_5 + int_3 + 3, int_6 + int_8 + 3 - 1, 1347420415, 1344798847);
- this.fillGradient(int_5 - 3, int_6 - 3, int_5 + int_3 + 3, int_6 - 3 + 1, 1347420415, 1347420415);
- this.fillGradient(int_5 - 3, int_6 + int_8 + 2, int_5 + int_3 + 3, int_6 + int_8 + 3, 1344798847, 1344798847);
-
- for(int int_12 = 0; int_12 < list_1.size(); ++int_12) {
- GlStateManager.disableDepthTest();
- font.drawWithShadow(list_1.get(int_12), (float) int_5, (float) int_6, -1);
- GlStateManager.enableDepthTest();
- if (int_12 == 0)
- int_6 += 2;
- int_6 += 10;
- }
- this.blitOffset = 0;
- GlStateManager.enableLighting();
- GuiLighting.enable();
- GlStateManager.enableRescaleNormal();
- }
- }
-
- private boolean hasSameListContent(List<ItemStack> list1, List<ItemStack> list2) {
- Collections.sort(list1, (itemStack, t1) -> {
- return ItemListOverlay.tryGetItemStackName(itemStack).compareToIgnoreCase(ItemListOverlay.tryGetItemStackName(t1));
- });
- Collections.sort(list2, (itemStack, t1) -> {
- return ItemListOverlay.tryGetItemStackName(itemStack).compareToIgnoreCase(ItemListOverlay.tryGetItemStackName(t1));
- });
- String lastString = String.join("", list1.stream().map(itemStack -> {
- return ItemListOverlay.tryGetItemStackName(itemStack);
- }).collect(Collectors.toList())), currentString = String.join("", list2.stream().map(itemStack -> {
- return ItemListOverlay.tryGetItemStackName(itemStack);
- }).collect(Collectors.toList()));
- return lastString.equals(currentString);
- }
-
- public void addTooltip(QueuedTooltip queuedTooltip) {
- QUEUED_TOOLTIPS.add(queuedTooltip);
- }
-
- public void renderWidgets(int int_1, int int_2, float float_1) {
- if (!ScreenHelper.isOverlayVisible())
- return;
- buttonLeft.enabled = itemListOverlay.children().size() > 0;
- buttonRight.enabled = itemListOverlay.children().size() > 0;
- widgets.forEach(widget -> {
- GuiLighting.disable();
- widget.render(int_1, int_2, float_1);
- });
- GuiLighting.disable();
- }
-
- private int getLeft() {
- if (MinecraftClient.getInstance().currentScreen instanceof RecipeViewingScreen) {
- RecipeViewingScreen widget = (RecipeViewingScreen) MinecraftClient.getInstance().currentScreen;
- return widget.getBounds().x;
- }
- if (MinecraftClient.getInstance().player.getRecipeBook().isGuiOpen())
- return ScreenHelper.getLastContainerScreenHooks().rei_getContainerLeft() - 147 - 30;
- return ScreenHelper.getLastContainerScreenHooks().rei_getContainerLeft();
- }
-
- private int getTotalPage() {
- if (itemListOverlay.getTotalSlotsPerPage() > 0)
- return MathHelper.ceil(itemListOverlay.getCurrentDisplayed().size() / itemListOverlay.getTotalSlotsPerPage());
- return 0;
- }
-
- @Override
- public boolean mouseScrolled(double i, double j, double amount) {
- if (!ScreenHelper.isOverlayVisible())
- return false;
- if (rectangle.contains(ClientUtils.getMouseLocation())) {
- if (amount > 0 && buttonLeft.enabled)
- buttonLeft.onPressed();
- else if (amount < 0 && buttonRight.enabled)
- buttonRight.onPressed();
- else
- return false;
- return true;
- }
- for(Widget widget : widgets)
- if (widget.mouseScrolled(i, j, amount))
- return true;
- return false;
- }
-
- @Override
- public boolean keyPressed(int int_1, int int_2, int int_3) {
- if (ScreenHelper.isOverlayVisible())
- for(Element listener : widgets)
- if (listener.keyPressed(int_1, int_2, int_3))
- return true;
- if (ClientHelper.HIDE.matchesKey(int_1, int_2)) {
- ScreenHelper.toggleOverlayVisible();
- return true;
- }
- if (!ScreenHelper.isOverlayVisible())
- return false;
- Point point = ClientUtils.getMouseLocation();
- ItemStack itemStack = null;
- if (MinecraftClient.getInstance().currentScreen instanceof ContainerScreen)
- if (ScreenHelper.getLastContainerScreenHooks().rei_getHoveredSlot() != null && !ScreenHelper.getLastContainerScreenHooks().rei_getHoveredSlot().getStack().isEmpty())
- itemStack = ScreenHelper.getLastContainerScreenHooks().rei_getHoveredSlot().getStack();
- if (itemStack != null && !itemStack.isEmpty()) {
- if (ClientHelper.RECIPE.matchesKey(int_1, int_2))
- return ClientHelper.executeRecipeKeyBind(itemStack);
- else if (ClientHelper.USAGE.matchesKey(int_1, int_2))
- return ClientHelper.executeUsageKeyBind(itemStack);
- }
- return false;
- }
-
- @Override
- public boolean charTyped(char char_1, int int_1) {
- if (!ScreenHelper.isOverlayVisible())
- return false;
- for(Element listener : widgets)
- if (listener.charTyped(char_1, int_1))
- return true;
- return false;
- }
-
- @Override
- public List<? extends Element> children() {
- return widgets;
- }
-
- @Override
- public boolean mouseClicked(double double_1, double double_2, int int_1) {
- if (!ScreenHelper.isOverlayVisible())
- return false;
- for(Element element : widgets) {
- if (element.mouseClicked(double_1, double_2, int_1)) {
- this.setFocused(element);
- if (int_1 == 0)
- this.setDragging(true);
- return true;
- }
- }
- return false;
- }
-
- public static class SearchFieldWidget extends TextFieldWidget {
- public SearchFieldWidget(int x, int y, int width, int height) {
- super(x, y, width, height);
- }
-
- public void laterRender(int int_1, int int_2, float float_1) {
- GuiLighting.disable();
- GlStateManager.disableDepthTest();
- super.render(int_1, int_2, float_1);
- GlStateManager.enableDepthTest();
- }
-
- @Override
- public boolean mouseClicked(double double_1, double double_2, int int_1) {
- if (isVisible() && getBounds().contains(double_1, double_2) && int_1 == 1) {
- setText("");
- return true;
- }
- return super.mouseClicked(double_1, double_2, int_1);
- }
-
- @Override
- public void render(int int_1, int int_2, float float_1) {
- }
- }
-
- }
|