/* * This file is part of NucleusFramework for Bukkit, licensed under the MIT License (MIT). * * Copyright (c) JCThePants (www.jcwhatever.com) * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal * in the Software without restriction, including without limitation the rights * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell * copies of the Software, and to permit persons to whom the Software is * furnished to do so, subject to the following conditions: * * The above copyright notice and this permission notice shall be included in * all copies or substantial portions of the Software. * * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN * THE SOFTWARE. */ package com.jcwhatever.nucleus.internal.managed.scripting.api.views; import com.jcwhatever.nucleus.collections.WeakHashSet; import com.jcwhatever.nucleus.mixins.IDisposable; import com.jcwhatever.nucleus.utils.PreCon; import com.jcwhatever.nucleus.utils.items.ItemFilter; import com.jcwhatever.nucleus.utils.items.ItemStackUtils; import com.jcwhatever.nucleus.utils.player.PlayerUtils; import com.jcwhatever.nucleus.views.ViewSession; import com.jcwhatever.nucleus.views.menu.MenuItemBuilder; import org.bukkit.entity.Player; import org.bukkit.inventory.ItemStack; import org.bukkit.plugin.Plugin; import java.util.Set; public class SAPI_Views implements IDisposable { private final Plugin _plugin; private final Set<IDisposable> _views = new WeakHashSet<>(10); private boolean _isDisposed; public SAPI_Views(Plugin plugin) { PreCon.notNull(plugin); _plugin = plugin; } @Override public boolean isDisposed() { return _isDisposed; } @Override public void dispose() { for (IDisposable view : _views) { view.dispose(); } _views.clear(); _isDisposed = true; } /** * Create a new {@link MenuItemBuilder}. * * @param itemStack The {@link ItemStack} that will be used to represent the item in a menu inventory. * The argument can be an {@link org.bukkit.inventory.ItemStack}, * {@link org.bukkit.Material}, {@link org.bukkit.material.MaterialData}, the name or * alternate of the material or a serialized item stack string. */ public MenuItemBuilder menuItemBuilder(Object itemStack) { PreCon.notNull(itemStack); ItemStack stack = ItemStackUtils.getItemStack(itemStack); PreCon.isValid(stack != null, "Invalid itemStack. Must be an ItemStack, " + "material name, serializable item stack string, Material, or MaterialData."); return new MenuItemBuilder(stack); } /** * Create a new menu view. * * @param player The {@link org.bukkit.entity.Player} the view is for. Argument can also be * the player name, the players UUID or an * {@link com.jcwhatever.nucleus.mixins.IPlayerReference} instance. * @param title The views title. */ public ScriptMenuView createMenu(Object player, String title) { PreCon.notNull(player); PreCon.notNull(title); Player p = PlayerUtils.getPlayer(player); PreCon.isValid(p != null, "Invalid player object."); ScriptMenuView menuView = new ScriptMenuView(_plugin, p, title); _views.add(menuView); return menuView; } /** * Create a new workbench view. * * @param player The {@link org.bukkit.entity.Player} the view is for. Argument can also be * the player name, the players UUID or an * {@link com.jcwhatever.nucleus.mixins.IPlayerReference} instance. */ public ScriptWorkbenchView createWorkbench(Object player) { PreCon.notNull(player); Player p = PlayerUtils.getPlayer(player); PreCon.isValid(p != null, "Invalid player object."); ScriptWorkbenchView view = new ScriptWorkbenchView(_plugin, p, new ItemFilter(_plugin, null)); _views.add(view); return view; } /** * Create a new anvil view. * * @param player The {@link org.bukkit.entity.Player} the view is for. Argument can also be * the player name, the players UUID or an * {@link com.jcwhatever.nucleus.mixins.IPlayerReference} instance. */ public ScriptAnvilView createAnvil(Object player) { PreCon.notNull(player); Player p = PlayerUtils.getPlayer(player); PreCon.isValid(p != null, "Invalid player object."); ScriptAnvilView view = new ScriptAnvilView(_plugin, p, new ItemFilter(_plugin, null)); _views.add(view); return view; } /** * Determine if a player is currently viewing an artificial inventory view. * * @param player The {@link org.bukkit.entity.Player} to check. Argument can also be * the player name, the players UUID or an * {@link com.jcwhatever.nucleus.mixins.IPlayerReference} instance. */ public boolean isViewing(Object player) { PreCon.notNull(player); Player p = PlayerUtils.getPlayer(player); PreCon.isValid(p != null, "Invalid player object."); ViewSession session = ViewSession.getCurrent(p); return session != null && session.getCurrent() != null; } }