Skip to content
Daniel V edited this page Dec 23, 2023 · 10 revisions

The New Menu Library

Welcome to the documentation for The New Menu Library! This library provides a powerful and flexible framework for creating graphical user interfaces (GUIs) in Minecraft plugins. Whether you want to create custom menus for Folia, Spigot, Paper or Sponge, this library is for you!

Table of Contents

  1. Overview
  2. Getting Started
  3. Features
  4. Documentation
  5. Contributing
  6. License

Overview

The New Menu Library is designed to simplify the process of creating interactive menus and UIs in Minecraft plugins. It provides a clean and intuitive API for constructing menus, defining icons, and handling player interactions. Whether you're a seasoned developer or new to plugin development, this library aims to enhance the user experience by making menu creation easy and enjoyable.

Features

  • Easy menu and icon creation with a builder pattern.
  • Support for various player interactions, such as clicks and chat input.
  • Flexible constraint system for defining conditions and behaviors.
  • Stateful icons for dynamic menu elements.
  • Integration with multiple platforms, whether on Sponge, Folia, or Spigot/Paper.

Documentation

Menu

The Menu class represents a menu in the library. It provides methods for adding pages, handling player interactions, and more.

Icon

The Icon class represents an icon in a menu. Icons can have actions, constraints, and dynamic item providers.

MenuBuilder

The MenuBuilder class is a builder for creating instances of the Menu class. It provides methods for setting menu properties and adding pages.

IconBuilder

The IconBuilder class is a builder for creating instances of the Icon class. It provides methods for setting icon properties, adding actions, and applying constraints.

For detailed documentation and usage examples, refer to the specific class documentation.

Contributing

We welcome contributions from the community! Whether it's bug fixes, feature enhancements, or documentation improvements, feel free to submit pull requests.

  1. Fork the repository.
  2. Create a branch for your changes.
  3. Make your changes and commit them with clear messages.
  4. Make sure your code follows the TNE Java Style guidelines.
  5. Push your branch to your fork.
  6. Submit a pull request.
  7. Agree to the CLA in your Pull Request

License

This library is licensed under the GNU Affero General Public License (AGPL-3.0). See the LICENSE file for details.

Clone this wiki locally