mirror of
https://github.com/Rogiel/l2jserver2
synced 2025-12-11 09:42:54 +00:00
Gatekeeper complete implementation
Signed-off-by: Rogiel <rogiel@rogiel.com>
This commit is contained in:
@@ -16,20 +16,14 @@
|
||||
*/
|
||||
package com.l2jserver.model.world.npc.controller;
|
||||
|
||||
import java.util.List;
|
||||
|
||||
import com.google.inject.Inject;
|
||||
import com.l2jserver.game.net.Lineage2Connection;
|
||||
import com.l2jserver.game.net.packet.server.NPCHtmlMessagePacket;
|
||||
import com.l2jserver.model.id.template.provider.TeleportationTemplateIDProvider;
|
||||
import com.l2jserver.model.template.NPCTemplate.TeleportRegion;
|
||||
import com.l2jserver.model.template.TeleportationTemplate;
|
||||
import com.l2jserver.model.world.L2Character;
|
||||
import com.l2jserver.model.world.NPC;
|
||||
import com.l2jserver.service.game.spawn.SpawnService;
|
||||
import com.l2jserver.util.exception.L2Exception;
|
||||
import com.l2jserver.util.html.markup.HtmlTemplate;
|
||||
import com.l2jserver.util.html.markup.MarkupTag;
|
||||
|
||||
/**
|
||||
* This controller is used to control teleporters (e.g. gatekeepers)
|
||||
@@ -49,29 +43,9 @@ public class TeleporterController extends AbstractNPCController {
|
||||
public void action(NPC npc, Lineage2Connection conn, L2Character character,
|
||||
String... args) throws L2Exception {
|
||||
if (args.length >= 2) {
|
||||
if (args[0].equals("TeleportList")) {
|
||||
final List<TeleportRegion> regions = getTeleportRegions(npc,
|
||||
args[1]);
|
||||
final HtmlTemplate template = new HtmlTemplate() {
|
||||
@Override
|
||||
protected void build(MarkupTag body) {
|
||||
body.textcode(556);
|
||||
for (final TeleportRegion region : regions) {
|
||||
body.addLink(
|
||||
region.getID().getTemplate().getName()
|
||||
+ " - "
|
||||
+ region.getPrice()
|
||||
+ " "
|
||||
+ region.getItem().getTemplate()
|
||||
.getName(),
|
||||
"Teleport " + region.getID().getID()).br();
|
||||
}
|
||||
}
|
||||
};
|
||||
conn.write(new NPCHtmlMessagePacket(npc, template));
|
||||
} else if (args[0].equals("Teleport")) {
|
||||
if (args[0].equals("goto")) {
|
||||
final TeleportationTemplate tele = teleportationIdProvider
|
||||
.createID(args[1]).getTemplate();
|
||||
.createID(Integer.parseInt(args[1])).getTemplate();
|
||||
if (tele == null) {
|
||||
// TODO chat
|
||||
conn.sendActionFailed();
|
||||
@@ -83,8 +57,4 @@ public class TeleporterController extends AbstractNPCController {
|
||||
}
|
||||
super.action(npc, conn, character, args);
|
||||
}
|
||||
|
||||
protected List<TeleportRegion> getTeleportRegions(NPC npc, String id) {
|
||||
return npc.getTemplate().getTeleportRegions(id);
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user