ShopChest - Spigot/Bukkit Plugin
Go to file
2023-08-17 13:09:07 +02:00
lib Restore IslandWorld-8.5.jar 2023-03-25 17:38:51 +01:00
nms Use Spigot 1.20.1 dependency in nms module 2023-06-13 17:18:55 +02:00
plugin Quick fix for #19 2023-08-17 13:09:07 +02:00
.gitignore Change to relative path for target folders 2021-12-27 17:21:36 +01:00
LICENSE.txt LICENSE should be a .txt file 2016-07-19 17:49:26 +02:00
pom.xml Add LocalizedItemManager 2023-07-20 01:24:03 +02:00
README.md Add instruction sections 2023-07-20 01:55:58 +02:00

ShopChest

ShopChest - Spigot/Bukkit Plugin

General information

This fork of ShopChest intend to be updatable easily. It also adds some common features like barrel or shulker shops. It's still in progress and therefore, this repository has many branches. Most of them have very explicit name, but there is two things to know:

  • The 'master' branch is the original plugin, with no major changes. It supports the most recent version of Minecraft.
  • The 'feature/clean-project' branch is a 'work-in-progress' branch. It contains bug fixes and adds new features. However, as the structure change, some plugin that were previously using ShopChest can break. If it's the case, just use the original version (in 'master' branch).

Usage

To download the plugin, see the Download section below.

Why

Since 1.20.1, ShopChest use a new language system in order to avoid major changes at each minecraft release.
Note that it can break support for older version. Although it uses a minecraft chat mechanic added in 1.8, it's part of the Bukkit API since February 13 of 2023. Backward compatibility is possible but requires more work and will be provided only if requested in the issues section.
Previously, all messages were store in a single file called <locale>.lang. Now each language is made of two files:

  • messages-<locale>.lang which contains ShopChest internal messages and which will likely never change
  • items-<locale>.lang which contains item translations used by holograms.

The second one differs a bit from previously. As minecraft is constantly updated with new items, there is no point to provide it, it would be constantly outdated.

Instructions

  • Install the plugin in your plugin folder.
  • Run the server a first time to generate each configuration files
  • Set the desired locale in the configuration
  • Restart the server (or process the command /shop reload) to generate local-specifics language files.
  • Copy the output of LangGenerator into the used items language file.
  • Restart the server (or process the command /shop reload) to load the correct translations.

You may have some warnings if shops are loaded while the items file is empty. (For example during the reload process). It's perfectly fine, even if it says that you should report them, you can ignore it as long as the file is empty.
You may need to repeat this process at each minecraft update in order to be able to have the translations for the new items.

API

To use the API, you need to add the following repository and dependency in your maven project:

<repositories>
  <repository>
    <id>shopchest-repo</id>
    <url>https://epicericee.github.io/ShopChest/maven/</url>
  </repository>
</repositories>

<dependencies>
  <dependency>
    <groupId>de.epiceric</groupId>
    <artifactId>ShopChest</artifactId>
    <version>1.11.1</version>
    <scope>provided</scope>
  </dependency>
</dependencies>

You can find the javadoc here: https://epicericee.github.io/ShopChest/javadoc/

Build

You need Maven with Github access and a jdk. If you don't know how to give Github access to maven, check this . If you don't know how to create a personal token, check this .

  • Use sh lib/install_local_depedencies.sh to import local dependencies.
  • Use mvn clean install at the root of the project to build ShopChest artifact.

After the build succeeded, the ShopChest.jar is found in the /plugin/target/ folder.

Issues

If you find any issues, please provide them in the Issues Section with a good description of how to reproduce it. If you get any error messages in the console, please also provide them.

Download

You can download the recent builds in the release section. This resource/plugin can also be found on the official spigot page here, but as I don't own it, the most recent build there only supports Minecraft up to 1.16.