001/*
002 * Trident - A Multithreaded Server Alternative
003 * Copyright 2014 The TridentSDK Team
004 *
005 * Licensed under the Apache License, Version 2.0 (the "License");
006 * you may not use this file except in compliance with the License.
007 * You may obtain a copy of the License at
008 *
009 *    http://www.apache.org/licenses/LICENSE-2.0
010 *
011 * Unless required by applicable law or agreed to in writing, software
012 * distributed under the License is distributed on an "AS IS" BASIS,
013 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
014 * See the License for the specific language governing permissions and
015 * limitations under the License.
016 */
017
018package net.tridentsdk.event.player;
019
020import net.tridentsdk.entity.living.Player;
021import net.tridentsdk.event.Cancellable;
022import net.tridentsdk.inventory.Item;
023
024/**
025 * Occurs when a player drops an item out of their inventory, usually by default pressing 'q'
026 *
027 * @author The TridentSDK Team
028 * @since 0.3-alpha-DP
029 */
030public class PlayerDropItemEvent extends PlayerEvent implements Cancellable {
031    private final Item item;
032    private boolean cancelled;
033
034    public PlayerDropItemEvent(Player player, Item item) {
035        super(player);
036        this.item = item;
037    }
038
039    /**
040     * @return return the dropped item
041     */
042    public Item item() {
043        return this.item;
044    }
045
046    @Override
047    public boolean isIgnored() {
048        return cancelled;
049    }
050
051    @Override
052    public void cancel(boolean cancelled) {
053        this.cancelled = cancelled;
054    }
055}