commit
7c35c54e4a
20
config.yml
20
config.yml
@ -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)}
|
||||||
|
@ -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);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user