Skip to content
This repository has been archived by the owner on Aug 9, 2021. It is now read-only.

Commit

Permalink
Version 1.0
Browse files Browse the repository at this point in the history
  • Loading branch information
Pequla committed Mar 30, 2021
1 parent b46929e commit c706174
Show file tree
Hide file tree
Showing 6 changed files with 308 additions and 0 deletions.
113 changes: 113 additions & 0 deletions .gitignore
Original file line number Diff line number Diff line change
@@ -0,0 +1,113 @@
# User-specific stuff
.idea/

*.iml
*.ipr
*.iws

# IntelliJ
out/

# Compiled class file
*.class

# Log file
*.log

# BlueJ files
*.ctxt

# Package Files #
*.jar
*.war
*.nar
*.ear
*.zip
*.tar.gz
*.rar

# virtual machine crash logs, see http://www.java.com/en/download/help/error_hotspot.xml
hs_err_pid*

*~

# temporary files which can be created if a process still has a handle open of a deleted file
.fuse_hidden*

# KDE directory preferences
.directory

# Linux trash folder which might appear on any partition or disk
.Trash-*

# .nfs files are created when an open file is removed but is still being accessed
.nfs*

# General
.DS_Store
.AppleDouble
.LSOverride

# Icon must end with two \r
Icon

# Thumbnails
._*

# Files that might appear in the root of a volume
.DocumentRevisions-V100
.fseventsd
.Spotlight-V100
.TemporaryItems
.Trashes
.VolumeIcon.icns
.com.apple.timemachine.donotpresent

# Directories potentially created on remote AFP share
.AppleDB
.AppleDesktop
Network Trash Folder
Temporary Items
.apdisk

# Windows thumbnail cache files
Thumbs.db
Thumbs.db:encryptable
ehthumbs.db
ehthumbs_vista.db

# Dump file
*.stackdump

# Folder config file
[Dd]esktop.ini

# Recycle Bin used on file shares
$RECYCLE.BIN/

# Windows Installer files
*.cab
*.msi
*.msix
*.msm
*.msp

# Windows shortcuts
*.lnk

target/

pom.xml.tag
pom.xml.releaseBackup
pom.xml.versionsBackup
pom.xml.next

release.properties
dependency-reduced-pom.xml
buildNumber.properties
.mvn/timing.properties
.mvn/wrapper/maven-wrapper.jar
.flattened-pom.xml

# Common working directory
run/
76 changes: 76 additions & 0 deletions pom.xml
Original file line number Diff line number Diff line change
@@ -0,0 +1,76 @@
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>

<groupId>com.samifying.mobs</groupId>
<artifactId>sami-mobs</artifactId>
<version>1.0</version>
<packaging>jar</packaging>

<name>SamiMobs</name>

<description>Custom mob modification plugin</description>
<properties>
<java.version>1.8</java.version>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
</properties>
<url>https://samifying.com/</url>

<build>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<version>3.8.1</version>
<configuration>
<source>${java.version}</source>
<target>${java.version}</target>
</configuration>
</plugin>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-shade-plugin</artifactId>
<version>3.2.4</version>
<executions>
<execution>
<phase>package</phase>
<goals>
<goal>shade</goal>
</goals>
<configuration>
<createDependencyReducedPom>false</createDependencyReducedPom>
</configuration>
</execution>
</executions>
</plugin>
</plugins>
<resources>
<resource>
<directory>src/main/resources</directory>
<filtering>true</filtering>
</resource>
</resources>
</build>

<repositories>
<repository>
<id>spigotmc-repo</id>
<url>https://hub.spigotmc.org/nexus/content/repositories/snapshots/</url>
</repository>
<repository>
<id>sonatype</id>
<url>https://oss.sonatype.org/content/groups/public/</url>
</repository>
</repositories>

<dependencies>
<dependency>
<groupId>org.spigotmc</groupId>
<artifactId>spigot-api</artifactId>
<version>1.16.4-R0.1-SNAPSHOT</version>
<scope>provided</scope>
</dependency>
</dependencies>
</project>
29 changes: 29 additions & 0 deletions src/main/java/com/samifying/mobs/EventListener.java
Original file line number Diff line number Diff line change
@@ -0,0 +1,29 @@
package com.samifying.mobs;

import org.bukkit.Material;
import org.bukkit.entity.Entity;
import org.bukkit.entity.EntityType;
import org.bukkit.event.EventHandler;
import org.bukkit.event.Listener;
import org.bukkit.event.entity.EntityDeathEvent;
import org.bukkit.inventory.ItemStack;

public class EventListener implements Listener {

@EventHandler
public void onEntityDeathEvent(EntityDeathEvent event) {
Entity entity = event.getEntity();
EntityType type = entity.getType();
if (type == EntityType.SHULKER) {
event.getDrops().clear();
ItemStack stack = new ItemStack(Material.SHULKER_SHELL, 2);
entity.getWorld().dropItemNaturally(entity.getLocation(), stack);
return;
}
if (type == EntityType.ENDER_DRAGON) {
event.getDrops().clear();
ItemStack stack = new ItemStack(Material.ELYTRA, 1);
entity.getWorld().dropItemNaturally(entity.getLocation(), stack);
}
}
}
15 changes: 15 additions & 0 deletions src/main/java/com/samifying/mobs/SamiMobs.java
Original file line number Diff line number Diff line change
@@ -0,0 +1,15 @@
package com.samifying.mobs;

import org.bukkit.plugin.PluginManager;
import org.bukkit.plugin.java.JavaPlugin;

public final class SamiMobs extends JavaPlugin {

@Override
public void onEnable() {
getLogger().info("Loading data");
PluginManager manager = getServer().getPluginManager();
manager.registerEvents(new EventListener(), this);
manager.registerEvents(new ZombieVillagerCure(this), this);
}
}
67 changes: 67 additions & 0 deletions src/main/java/com/samifying/mobs/ZombieVillagerCure.java
Original file line number Diff line number Diff line change
@@ -0,0 +1,67 @@
package com.samifying.mobs;

import org.bukkit.Location;
import org.bukkit.World;
import org.bukkit.entity.Entity;
import org.bukkit.entity.EntityType;
import org.bukkit.entity.LivingEntity;
import org.bukkit.event.EventHandler;
import org.bukkit.event.Listener;
import org.bukkit.event.entity.EntityDamageByEntityEvent;
import org.bukkit.event.entity.EntitySpawnEvent;
import org.bukkit.scheduler.BukkitRunnable;

import java.util.ArrayList;

public class ZombieVillagerCure implements Listener {

private final SamiMobs plugin;
private final ArrayList<LivingEntity> list;

public ZombieVillagerCure(SamiMobs plugin) {
this.plugin = plugin;
this.list = new ArrayList<>();
}

@EventHandler
public void onEntityDamageByEntityEvent(EntityDamageByEntityEvent event) {
Entity entity = event.getEntity();
if (entity.getType() == EntityType.VILLAGER) {
LivingEntity villager = (LivingEntity) entity;
EntityType type = event.getDamager().getType();
if (type == EntityType.ZOMBIE || type == EntityType.ZOMBIE_VILLAGER || type == EntityType.HUSK) {
if (villager.getHealth() <= event.getDamage()) {
Location location = entity.getLocation();
World world = location.getWorld();
if (world != null) {
LivingEntity zombie = (LivingEntity) location.getWorld().spawnEntity(location, EntityType.ZOMBIE_VILLAGER);
list.add(zombie);
}
}
}
}
}

@EventHandler
public void onEntitySpawnEvent(EntitySpawnEvent event) {
Entity entity = event.getEntity();
if (entity.getType() == EntityType.ZOMBIE_VILLAGER) {
LivingEntity zombie = (LivingEntity) entity;
runLater(zombie);
}
}

private void runLater(LivingEntity entity) {
(new BukkitRunnable() {
@Override
public void run() {
if (list.contains(entity)) {
list.remove(entity);
} else {
entity.remove();
}
cancel();
}
}).runTaskLater(plugin, 1L);
}
}
8 changes: 8 additions & 0 deletions src/main/resources/plugin.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
name: SamiMobs
version: ${project.version}
main: com.samifying.mobs.SamiMobs
api-version: 1.16
prefix: SamiMobs
authors: [ Pequla ]
description: Custom mob modification plugin
website: https://samifying.com/

0 comments on commit c706174

Please sign in to comment.