Merge pull request #1 from FarmAndFight/secondary

Secondary -> master
This commit is contained in:
Quentin Legot 2020-06-10 18:52:57 +02:00 committed by GitHub
commit 7c35c54e4a
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 71 additions and 6 deletions

View File

@ -2,8 +2,18 @@ book:
title: "Un magnifique titre" title: "Un magnifique titre"
author: "Auteur du livre" author: "Auteur du livre"
pages: pages:
#You can add clickable text by writing it like the following example
#random_text {your_text_with_abilities,hover_message,click_event<true or false>(action,argument)} other_random_text
# ACTION_LIST: CHANGE_PAGE, COPY_TO_CLIPBOARD, OPEN_URL, RUN_COMMAND, SUGGEST_COMMAND
#examples:
# - This is an example
# if a player click {here,he would see this message by hovering,true(CHANGE_PAGE.4)}
# he would open page 4
# if she exist
#note that if you want to write an { or } in your text put a \ before
#colors are also supported with & and §, help available on https://minecraft.tools/en/color-code.php
- | - |
Premier page Premiere page
C'est beau tu trouve pas ? C'est beau tu trouve pas ?
- | - |
ça c'est Seconde page. ça c'est Seconde page.
@ -12,3 +22,11 @@ book:
Et cette troisème alors ? Et cette troisème alors ?
la meilleure de toutes ! la meilleure de toutes !
Tu trouves pas ? Tu trouves pas ?
- |
This is an example
if a player click {here,he would see this message by hovering,true(CHANGE_PAGE.1)}
he would open page 1
if she exist
{Link,he would see this message by hovering,true(OPEN_URL.https://spigotmc.org)}
{Command,he would see this message by hovering,true(RUN_COMMAND./say salut)}
{Suggest,he would see this message by hovering,true(SUGGEST_COMMAND./say salut)}

View File

@ -7,6 +7,11 @@ import org.bukkit.entity.Player;
import org.bukkit.inventory.ItemStack; import org.bukkit.inventory.ItemStack;
import org.bukkit.inventory.meta.BookMeta; import org.bukkit.inventory.meta.BookMeta;
import net.md_5.bungee.api.chat.ClickEvent;
import net.md_5.bungee.api.chat.ComponentBuilder;
import net.md_5.bungee.api.chat.HoverEvent;
import net.md_5.bungee.api.chat.TextComponent;
public class Book { public class Book {
private ItemStack book; private ItemStack book;
@ -23,10 +28,53 @@ public class Book {
BookMeta meta = (BookMeta) book.getItemMeta(); BookMeta meta = (BookMeta) book.getItemMeta();
meta.setTitle(_title); meta.setTitle(_title);
meta.setAuthor(_author); meta.setAuthor(_author);
for(int i=0;i<_pages.size();i++) for (String rawPage: _pages){
meta.addPage(_pages.get(i).replace("&", "§")); ComponentBuilder page = new ComponentBuilder("");
if(book.setItemMeta(meta)) rawPage = rawPage.replace("&", "§");
if (rawPage.contains("{") && rawPage.contains("}")) {
String[] sections = rawPage.split("\\{|\\}");
boolean edit = false;
TextComponent message = new TextComponent();
for(String section : sections) {
if(!edit) {
message.addExtra(section);
}else {
String[] elements = section.split(",");
TextComponent eventBuilder = new TextComponent(elements[0]);
if(!elements[1].equals("")) {
eventBuilder.setHoverEvent(new HoverEvent(HoverEvent.Action.SHOW_TEXT, new ComponentBuilder(elements[1]).create()));
}
if(elements[2].startsWith("true")) {
// System.out.println(elements[2].substring(5, elements[2].length() - 1));
if(elements[2].startsWith("OPEN_URL", 5)) {
eventBuilder.setClickEvent(new ClickEvent(ClickEvent.Action.OPEN_URL, elements[2].substring(elements[2].indexOf(".") + 1, elements[2].length() - 1)));
}
if(elements[2].startsWith("RUN_COMMAND", 5)) {
eventBuilder.setClickEvent(new ClickEvent(ClickEvent.Action.RUN_COMMAND, elements[2].substring(elements[2].indexOf(".") + 1, elements[2].length() - 1)));
}
if(elements[2].startsWith("SUGGEST_COMMAND", 5)) {
eventBuilder.setClickEvent(new ClickEvent(ClickEvent.Action.SUGGEST_COMMAND, elements[2].substring(elements[2].indexOf(".") + 1, elements[2].length() - 1)));
}
if(elements[2].startsWith("CHANGE_PAGE", 5)) {
eventBuilder.setClickEvent(new ClickEvent(ClickEvent.Action.CHANGE_PAGE, elements[2].substring(elements[2].indexOf(".") + 1, elements[2].length() - 1)));
}
}
message.addExtra(eventBuilder);
}
edit = !edit;
}
page.append(message);
}else {
page.append(rawPage);
}
meta.spigot().addPage(page.create());
}
if(book.setItemMeta(meta)) {
return true; return true;
}
return false; return false;
} }
@ -39,5 +87,4 @@ public class Book {
public void openBook(Player player) { public void openBook(Player player) {
player.openBook(book); player.openBook(book);
} }
} }