Initialize the library

This page describes how to initialize the library.

To use the library and create custom inventories, it first must be initialized by defining a set of reusable Java objects. This is done by using the CraftVentoryLibrary class that provides several methods to use the default behaviors implemented in the library.

Create an InventoryService

An InventoryService is a class with two purposes:

  • Register, store and retrieve inventory providers

  • Store information about players with an opened inventory and manage inventories' life cycle

An instance of this class with the default behavior provided by the library can be created by using the following code:

InventoryService service = CraftVentoryLibrary.createInventoryService(Plugin plugin);

Note: We recommand to store this object as an instance variable in the main class of your plugin (eq. the class that extends JavaPlugin).

Create an InventoryConfigDAO

An InventoryConfigDAO is a class used to load an inventory from a configuration file. By default, the library provides an instance of this class to load inventories from YAML files. The following code uses the library built-in methods to create a new instance of InventoryConfigDAO:

// Factory used to load item click actions.
ClickActionLoaderFactory<ConfigurationSection> factory =
        FastInventoryLibrary.createDefaultClickActionLoaderFactory();

InventoryConfigDAO dao = FastInventoryLibrary.createDefaultConfigDAO(factory);

Note: ClickActionLoaderFactory is a class that is used to load item actions from the configuration file.

Example

Here is a complete example:

public class CraftVentoryPlugin extends JavaPlugin {

    private InventoryService inventoryService;

    @Override
    public void onEnable() {
        this.inventoryService = CraftVentoryLibrary.createInventoryService(this);
        this.loadInventoryProviders();
    }

    private void loadInventoryProviders() {

        ClickActionLoaderFactory<ConfigurationSection> factory =
                FastInventoryLibrary.createDefaultClickActionLoaderFactory();

        InventoryConfigDAO dao = FastInventoryLibrary.createDefaultConfigDAO(factory);

        // Register inventory providers here.
    }
}

Last updated