CraftVentory
  • Welcome
  • get started
    • Inventory configuration
      • Item actions
    • Initialize the library
    • Declare an inventory
    • Open a inventory
  • Advanced concepts
    • Placeholders
    • Pagination
    • Data storage
    • Enhancements
    • Hooks
    • Custom item actions
    • Context
    • I18n
Powered by GitBook
On this page
  • Create an InventoryService
  • Create an InventoryConfigDAO
  • Example
Export as PDF
  1. get started

Initialize the library

This page describes how to initialize the library.

PreviousItem actionsNextDeclare an inventory

Last updated 6 months ago

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

  • 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.
    }
}
inventory providers