Compare commits
30 Commits
1.20.1-v1.
...
1.21.1-v1.
| Author | SHA1 | Date | |
|---|---|---|---|
| c79812feae | |||
| 2839700e78 | |||
| 5c34debd58 | |||
| f1c5fc9524 | |||
| 2bf45b16fe | |||
| 52421933ee | |||
| 6aa4b1ac9c | |||
| 957e092b15 | |||
| 6e8c7bec2c | |||
| 0f5c0e3618 | |||
| c11b90bdc0 | |||
| ef77df4196 | |||
| 8207e7c82c | |||
| 6edf2728b1 | |||
| 11c9325a4e | |||
| bb6b90b092 | |||
| ef7fbe84c2 | |||
| ef81343057 | |||
| 33569a5070 | |||
| 9090c9655d | |||
| 889af04867 | |||
| 4668456cc5 | |||
| 2d49d2ffb3 | |||
| 52cfd8a781 | |||
| f85204ef4b | |||
| 83a6acc443 | |||
| 95b22ce721 | |||
| 89ef123213 | |||
| c75998037c | |||
| 745c57500e |
BIN
assets/images/web/logo.png
(Stored with Git LFS)
Normal file
BIN
assets/images/web/logo.png
(Stored with Git LFS)
Normal file
Binary file not shown.
221
build.gradle
221
build.gradle
@ -1,134 +1,191 @@
|
|||||||
buildscript {
|
|
||||||
repositories {
|
|
||||||
// These repositories are only for Gradle plugins, put any other repositories in the repository block further below
|
|
||||||
maven { url = 'https://repo.spongepowered.org/repository/maven-public/' }
|
|
||||||
mavenCentral()
|
|
||||||
}
|
|
||||||
dependencies {
|
|
||||||
classpath 'org.spongepowered:mixingradle:0.7-SNAPSHOT'
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
plugins {
|
plugins {
|
||||||
id 'eclipse'
|
id 'java-library'
|
||||||
|
id 'maven-publish'
|
||||||
|
id 'net.neoforged.moddev' version '2.0.137'
|
||||||
id 'idea'
|
id 'idea'
|
||||||
id 'net.minecraftforge.gradle' version '[6.0.16,6.2)'
|
|
||||||
id 'org.parchmentmc.librarian.forgegradle' version '1.+'
|
|
||||||
}
|
}
|
||||||
|
|
||||||
apply plugin: 'org.spongepowered.mixin'
|
tasks.named('wrapper', Wrapper).configure {
|
||||||
|
// Define wrapper values here so as to not have to always do so when updating gradlew.properties.
|
||||||
|
// Switching this to Wrapper.DistributionType.ALL will download the full gradle sources that comes with
|
||||||
|
// documentation attached on cursor hover of gradle classes and methods. However, this comes with increased
|
||||||
|
// file size for Gradle. If you do switch this to ALL, run the Gradle wrapper task twice afterwards.
|
||||||
|
// (Verify by checking gradle/wrapper/gradle-wrapper.properties to see if distributionUrl now points to `-all`)
|
||||||
|
distributionType = Wrapper.DistributionType.BIN
|
||||||
|
}
|
||||||
|
|
||||||
group = mod_group_id
|
group = mod_group_id
|
||||||
version = mod_version
|
version = mod_version
|
||||||
|
|
||||||
|
repositories {
|
||||||
|
// Add here additional repositories if required by some of the dependencies below.
|
||||||
|
}
|
||||||
|
|
||||||
base {
|
base {
|
||||||
archivesName = "${mod_id}-${minecraft_version}"
|
archivesName = "${mod_id}-${minecraft_version}"
|
||||||
}
|
}
|
||||||
|
|
||||||
java {
|
java {
|
||||||
toolchain.languageVersion = JavaLanguageVersion.of(17)
|
toolchain.languageVersion = JavaLanguageVersion.of(21)
|
||||||
}
|
}
|
||||||
|
|
||||||
minecraft {
|
neoForge {
|
||||||
mappings channel: mapping_channel, version: "$mapping_version-$minecraft_version"
|
// Specify the version of NeoForge to use.
|
||||||
|
version = project.neo_version
|
||||||
|
|
||||||
copyIdeResources = true
|
parchment {
|
||||||
// generateRunFolders = true
|
mappingsVersion = project.parchment_mappings_version
|
||||||
// accessTransformer = file('src/main/resources/META-INF/accesstransformer.cfg') // https://docs.minecraftforge.net/en/latest/advanced/accesstransformers/
|
minecraftVersion = project.parchment_minecraft_version
|
||||||
|
}
|
||||||
|
|
||||||
|
// This line is optional. Access Transformers are automatically detected
|
||||||
|
// accessTransformers = project.files('src/main/resources/META-INF/accesstransformer.cfg')
|
||||||
|
|
||||||
|
// Default run configurations.
|
||||||
|
// These can be tweaked, removed, or duplicated as needed.
|
||||||
runs {
|
runs {
|
||||||
// applies to all the run configs below
|
|
||||||
configureEach {
|
|
||||||
workingDirectory project.file('run')
|
|
||||||
|
|
||||||
property 'forge.logging.markers', 'REGISTRIES'
|
|
||||||
property 'forge.logging.console.level', 'debug'
|
|
||||||
|
|
||||||
mods {
|
|
||||||
"${mod_id}" {
|
|
||||||
source sourceSets.main
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
client {
|
client {
|
||||||
property 'forge.enabledGameTestNamespaces', mod_id
|
client()
|
||||||
|
|
||||||
|
// Comma-separated list of namespaces to load gametests from. Empty = all namespaces.
|
||||||
|
systemProperty 'neoforge.enabledGameTestNamespaces', project.mod_id
|
||||||
}
|
}
|
||||||
|
|
||||||
server {
|
server {
|
||||||
property 'forge.enabledGameTestNamespaces', mod_id
|
server()
|
||||||
args '--nogui'
|
programArgument '--nogui'
|
||||||
|
systemProperty 'neoforge.enabledGameTestNamespaces', project.mod_id
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// This run config launches GameTestServer and runs all registered gametests, then exits.
|
||||||
|
// By default, the server will crash when no gametests are provided.
|
||||||
|
// The gametest system is also enabled by default for other run configs under the /test command.
|
||||||
gameTestServer {
|
gameTestServer {
|
||||||
property 'forge.enabledGameTestNamespaces', mod_id
|
type = "gameTestServer"
|
||||||
|
systemProperty 'neoforge.enabledGameTestNamespaces', project.mod_id
|
||||||
}
|
}
|
||||||
|
|
||||||
data {
|
data {
|
||||||
workingDirectory project.file('run-data')
|
data()
|
||||||
args '--mod', mod_id, '--all', '--output', file('src/generated/resources/'), '--existing', file('src/main/resources/')
|
|
||||||
|
// example of overriding the workingDirectory set in configureEach above, uncomment if you want to use it
|
||||||
|
// gameDirectory = project.file('run-data')
|
||||||
|
|
||||||
|
// Specify the modid for data generation, where to output the resulting resource, and where to look for existing resources.
|
||||||
|
programArguments.addAll '--mod', project.mod_id, '--all', '--output', file('src/generated/resources/').getAbsolutePath(), '--existing', file('src/main/resources/').getAbsolutePath()
|
||||||
|
}
|
||||||
|
|
||||||
|
// applies to all the run configs above
|
||||||
|
configureEach {
|
||||||
|
// Recommended logging data for a userdev environment
|
||||||
|
// The markers can be added/remove as needed separated by commas.
|
||||||
|
// "SCAN": For mods scan.
|
||||||
|
// "REGISTRIES": For firing of registry events.
|
||||||
|
// "REGISTRYDUMP": For getting the contents of all registries.
|
||||||
|
systemProperty 'forge.logging.markers', 'REGISTRIES'
|
||||||
|
|
||||||
|
// Recommended logging level for the console
|
||||||
|
// You can set various levels here.
|
||||||
|
// Please read: https://stackoverflow.com/questions/2031163/when-to-use-the-different-log-levels
|
||||||
|
logLevel = org.slf4j.event.Level.DEBUG
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
mods {
|
||||||
|
// define mod <-> source bindings
|
||||||
|
// these are used to tell the game which sources are for which mod
|
||||||
|
// multi mod projects should define one per mod
|
||||||
|
"${mod_id}" {
|
||||||
|
sourceSet(sourceSets.main)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
mixin {
|
// Include resources generated by data generators.
|
||||||
add sourceSets.main, "${mod_id}.refmap.json"
|
|
||||||
|
|
||||||
config "${mod_id}.mixins.json"
|
|
||||||
}
|
|
||||||
|
|
||||||
sourceSets.main.resources {
|
sourceSets.main.resources {
|
||||||
srcDir 'src/generated/resources'
|
srcDir 'src/generated/resources'
|
||||||
}
|
}
|
||||||
|
|
||||||
repositories {
|
// Sets up a dependency configuration called 'localRuntime'.
|
||||||
exclusiveContent {
|
// This configuration should be used instead of 'runtimeOnly' to declare
|
||||||
forRepository {
|
// a dependency that will be present for runtime testing but that is
|
||||||
maven {
|
// "optional", meaning it will not be pulled by dependents of this mod.
|
||||||
name = "Modrinth"
|
configurations {
|
||||||
url = "https://api.modrinth.com/maven"
|
runtimeClasspath.extendsFrom localRuntime
|
||||||
}
|
|
||||||
}
|
|
||||||
forRepositories(fg.repository) // Only add this if you're using ForgeGradle, otherwise remove this line
|
|
||||||
filter {
|
|
||||||
includeGroup "maven.modrinth"
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
dependencies {
|
dependencies {
|
||||||
minecraft "net.minecraftforge:forge:${minecraft_version}-${forge_version}"
|
// Example optional mod dependency with JEI
|
||||||
annotationProcessor 'org.spongepowered:mixin:0.8.5:processor'
|
// The JEI API is declared for compile time use, while the full JEI artifact is used at runtime
|
||||||
|
// compileOnly "mezz.jei:jei-${mc_version}-common-api:${jei_version}"
|
||||||
|
// compileOnly "mezz.jei:jei-${mc_version}-neoforge-api:${jei_version}"
|
||||||
|
// We add the full version to localRuntime, not runtimeOnly, so that we do not publish a dependency on it
|
||||||
|
// localRuntime "mezz.jei:jei-${mc_version}-neoforge:${jei_version}"
|
||||||
|
|
||||||
|
// Example mod dependency using a mod jar from ./libs with a flat dir repository
|
||||||
|
// This maps to ./libs/coolmod-${mc_version}-${coolmod_version}.jar
|
||||||
|
// The group id is ignored when searching -- in this case, it is "blank"
|
||||||
|
// implementation "blank:coolmod-${mc_version}:${coolmod_version}"
|
||||||
|
|
||||||
|
// Example mod dependency using a file as dependency
|
||||||
|
// implementation files("libs/coolmod-${mc_version}-${coolmod_version}.jar")
|
||||||
|
|
||||||
|
// Example project dependency using a sister or child project:
|
||||||
|
// implementation project(":myproject")
|
||||||
|
|
||||||
|
// For more info:
|
||||||
|
// http://www.gradle.org/docs/current/userguide/artifact_dependencies_tutorial.html
|
||||||
|
// http://www.gradle.org/docs/current/userguide/dependency_management.html
|
||||||
}
|
}
|
||||||
|
|
||||||
tasks.named('processResources', ProcessResources).configure {
|
|
||||||
var replaceProperties = [minecraft_version : minecraft_version, minecraft_version_range: minecraft_version_range,
|
|
||||||
forge_version : forge_version, forge_version_range: forge_version_range,
|
|
||||||
loader_version_range: loader_version_range,
|
|
||||||
mod_id : mod_id, mod_name: mod_name, mod_license: mod_license, mod_version: mod_version,
|
|
||||||
mod_authors : mod_authors, mod_description: mod_description]
|
|
||||||
|
|
||||||
|
// This block of code expands all declared replace properties in the specified resource targets.
|
||||||
|
// A missing property will result in an error. Properties are expanded using ${} Groovy notation.
|
||||||
|
// When "copyIdeResources" is enabled, this will also run before the game launches in IDE environments.
|
||||||
|
// See https://docs.gradle.org/current/dsl/org.gradle.language.jvm.tasks.ProcessResources.html
|
||||||
|
tasks.withType(ProcessResources).configureEach {
|
||||||
|
var replaceProperties = [
|
||||||
|
minecraft_version : minecraft_version,
|
||||||
|
minecraft_version_range: minecraft_version_range,
|
||||||
|
neo_version : neo_version,
|
||||||
|
neo_version_range : neo_version_range,
|
||||||
|
loader_version_range : loader_version_range,
|
||||||
|
mod_id : mod_id,
|
||||||
|
mod_name : mod_name,
|
||||||
|
mod_license : mod_license,
|
||||||
|
mod_version : mod_version,
|
||||||
|
mod_authors : mod_authors,
|
||||||
|
mod_description : mod_description
|
||||||
|
]
|
||||||
inputs.properties replaceProperties
|
inputs.properties replaceProperties
|
||||||
|
|
||||||
filesMatching(['META-INF/mods.toml', 'pack.mcmeta']) {
|
filesMatching(['META-INF/neoforge.mods.toml']) {
|
||||||
expand replaceProperties + [project: project]
|
expand replaceProperties
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
tasks.named('jar', Jar).configure {
|
// Example configuration to allow publishing using the maven-publish plugin
|
||||||
manifest {
|
publishing {
|
||||||
attributes(["Specification-Title" : mod_id,
|
publications {
|
||||||
"Specification-Vendor" : mod_authors,
|
register('mavenJava', MavenPublication) {
|
||||||
"Specification-Version" : "1",
|
from components.java
|
||||||
"Implementation-Title" : project.name,
|
}
|
||||||
"Implementation-Version" : project.jar.archiveVersion,
|
}
|
||||||
"Implementation-Vendor" : mod_authors,
|
repositories {
|
||||||
"Implementation-Timestamp": new Date().format("yyyy-MM-dd'T'HH:mm:ssZ")])
|
maven {
|
||||||
|
url "file://${project.projectDir}/repo"
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
finalizedBy 'reobfJar'
|
|
||||||
}
|
}
|
||||||
|
|
||||||
tasks.withType(JavaCompile).configureEach {
|
tasks.withType(JavaCompile).configureEach {
|
||||||
options.encoding = 'UTF-8'
|
options.encoding = 'UTF-8' // Use the UTF-8 charset for Java compilation
|
||||||
|
}
|
||||||
|
|
||||||
|
// IDEA no longer automatically downloads sources/javadoc jars for dependencies, so we need to explicitly enable the behavior.
|
||||||
|
idea {
|
||||||
|
module {
|
||||||
|
downloadSources = true
|
||||||
|
downloadJavadoc = true
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@ -1,5 +1,8 @@
|
|||||||
org.gradle.jvmargs=-Xmx3G
|
org.gradle.jvmargs=-Xmx3G
|
||||||
org.gradle.daemon=false
|
org.gradle.daemon=true
|
||||||
|
org.gradle.parallel=true
|
||||||
|
org.gradle.caching=true
|
||||||
|
org.gradle.configuration-cache=true
|
||||||
|
|
||||||
mod_id=firefly_bush_backport
|
mod_id=firefly_bush_backport
|
||||||
mod_name=Firefly Bush Backport
|
mod_name=Firefly Bush Backport
|
||||||
@ -9,12 +12,12 @@ mod_group_id=dev.micle
|
|||||||
mod_authors=Micle
|
mod_authors=Micle
|
||||||
mod_description=Firefly bush backport from 1.21.5.
|
mod_description=Firefly bush backport from 1.21.5.
|
||||||
|
|
||||||
minecraft_version=1.20.1
|
minecraft_version=1.21.1
|
||||||
minecraft_version_range=[1.20.1,1.21)
|
minecraft_version_range=[1.21.1,1.22)
|
||||||
|
|
||||||
forge_version=47.4.0
|
neo_version=21.1.228
|
||||||
forge_version_range=[47,)
|
neo_version_range=[21.1.228,21.2)
|
||||||
loader_version_range=[47,)
|
loader_version_range=[1,)
|
||||||
|
|
||||||
mapping_channel=parchment
|
parchment_minecraft_version=1.21.1
|
||||||
mapping_version=2023.09.03
|
parchment_mappings_version=2024.11.17
|
||||||
|
|||||||
8
gradle/wrapper/gradle-wrapper.properties
vendored
8
gradle/wrapper/gradle-wrapper.properties
vendored
@ -1 +1,7 @@
|
|||||||
distributionUrl=https\://services.gradle.org/distributions/gradle-8.8-bin.zip
|
distributionBase=GRADLE_USER_HOME
|
||||||
|
distributionPath=wrapper/dists
|
||||||
|
distributionUrl=https\://services.gradle.org/distributions/gradle-9.2.1-bin.zip
|
||||||
|
networkTimeout=10000
|
||||||
|
validateDistributionUrl=true
|
||||||
|
zipStoreBase=GRADLE_USER_HOME
|
||||||
|
zipStorePath=wrapper/dists
|
||||||
@ -10,7 +10,7 @@ pluginManagement {
|
|||||||
}
|
}
|
||||||
|
|
||||||
plugins {
|
plugins {
|
||||||
id 'org.gradle.toolchains.foojay-resolver-convention' version '0.7.0'
|
id 'org.gradle.toolchains.foojay-resolver-convention' version '1.0.0'
|
||||||
}
|
}
|
||||||
|
|
||||||
rootProject.name = "${mod_id}-${minecraft_version}"
|
rootProject.name = "${mod_id}-${minecraft_version}"
|
||||||
|
|||||||
@ -1,5 +1,5 @@
|
|||||||
{
|
{
|
||||||
"type": "forge:add_features",
|
"type": "neoforge:add_features",
|
||||||
"biomes": "#minecraft:is_overworld",
|
"biomes": "#minecraft:is_overworld",
|
||||||
"features": "firefly_bush_backport:patch_firefly_bush_near_water",
|
"features": "firefly_bush_backport:patch_firefly_bush_near_water",
|
||||||
"step": "vegetal_decoration"
|
"step": "vegetal_decoration"
|
||||||
@ -1,6 +1,6 @@
|
|||||||
{
|
{
|
||||||
"type": "forge:add_features",
|
"type": "neoforge:add_features",
|
||||||
"biomes": "#forge:is_swamp",
|
"biomes": "#c:is_swamp",
|
||||||
"features": "firefly_bush_backport:patch_firefly_bush_near_water_swamp",
|
"features": "firefly_bush_backport:patch_firefly_bush_near_water_swamp",
|
||||||
"step": "vegetal_decoration"
|
"step": "vegetal_decoration"
|
||||||
}
|
}
|
||||||
@ -1,6 +1,6 @@
|
|||||||
{
|
{
|
||||||
"type": "forge:add_features",
|
"type": "neoforge:add_features",
|
||||||
"biomes": "#forge:is_swamp",
|
"biomes": "#c:is_swamp",
|
||||||
"features": "firefly_bush_backport:patch_firefly_bush_swamp",
|
"features": "firefly_bush_backport:patch_firefly_bush_swamp",
|
||||||
"step": "vegetal_decoration"
|
"step": "vegetal_decoration"
|
||||||
}
|
}
|
||||||
@ -1,6 +1,6 @@
|
|||||||
{
|
{
|
||||||
"type": "forge:remove_features",
|
"type": "neoforge:remove_features",
|
||||||
"biomes": "#forge:is_swamp",
|
"biomes": "#c:is_swamp",
|
||||||
"features": "firefly_bush_backport:patch_firefly_bush_near_water",
|
"features": "firefly_bush_backport:patch_firefly_bush_near_water",
|
||||||
"steps": "vegetal_decoration"
|
"steps": "vegetal_decoration"
|
||||||
}
|
}
|
||||||
@ -0,0 +1,7 @@
|
|||||||
|
{
|
||||||
|
"values": {
|
||||||
|
"firefly_bush_backport:firefly_bush": {
|
||||||
|
"chance": 0.3
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
@ -3,28 +3,46 @@ package dev.micle.firefly_bush_backport;
|
|||||||
import com.mojang.logging.LogUtils;
|
import com.mojang.logging.LogUtils;
|
||||||
import dev.micle.firefly_bush_backport.proxy.IProxy;
|
import dev.micle.firefly_bush_backport.proxy.IProxy;
|
||||||
import dev.micle.firefly_bush_backport.proxy.Proxy;
|
import dev.micle.firefly_bush_backport.proxy.Proxy;
|
||||||
import net.minecraftforge.fml.DistExecutor;
|
import net.minecraft.resources.ResourceLocation;
|
||||||
import net.minecraftforge.fml.common.Mod;
|
import net.neoforged.api.distmarker.Dist;
|
||||||
import net.minecraftforge.fml.javafmlmod.FMLJavaModLoadingContext;
|
import net.neoforged.bus.api.IEventBus;
|
||||||
|
import net.neoforged.fml.ModContainer;
|
||||||
|
import net.neoforged.fml.ModList;
|
||||||
|
import net.neoforged.fml.common.Mod;
|
||||||
|
import net.neoforged.fml.loading.FMLEnvironment;
|
||||||
import org.slf4j.Logger;
|
import org.slf4j.Logger;
|
||||||
|
|
||||||
|
import java.util.Optional;
|
||||||
|
|
||||||
@Mod(FireflyBushBackport.MOD_ID)
|
@Mod(FireflyBushBackport.MOD_ID)
|
||||||
public class FireflyBushBackport {
|
public class FireflyBushBackport {
|
||||||
public static final String MOD_ID = "firefly_bush_backport";
|
public static final String MOD_ID = "firefly_bush_backport";
|
||||||
public static final Logger LOGGER = LogUtils.getLogger();
|
public static final Logger LOGGER = LogUtils.getLogger();
|
||||||
private static FMLJavaModLoadingContext fmlJavaModLoadingContext;
|
|
||||||
private static IProxy proxy;
|
private static IProxy proxy;
|
||||||
|
|
||||||
public FireflyBushBackport(FMLJavaModLoadingContext context) {
|
public FireflyBushBackport(IEventBus modEventBus, ModContainer modContainer) {
|
||||||
fmlJavaModLoadingContext = context;
|
proxy = FMLEnvironment.dist == Dist.CLIENT
|
||||||
|
? new Proxy.Client(modEventBus, modContainer)
|
||||||
proxy = DistExecutor.safeRunForDist(
|
: new Proxy.Server(modEventBus, modContainer);
|
||||||
() -> Proxy.Client::new,
|
|
||||||
() -> Proxy.Server::new
|
|
||||||
);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public static FMLJavaModLoadingContext getFMLJavaModLoadingContext() {
|
public static ResourceLocation createResourceLocation(String name) {
|
||||||
return fmlJavaModLoadingContext;
|
if (name.contains(":")) {
|
||||||
|
throw new IllegalArgumentException("Name contains namespace");
|
||||||
|
}
|
||||||
|
return ResourceLocation.fromNamespaceAndPath(MOD_ID, name);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static String getVersion() {
|
||||||
|
Optional<? extends ModContainer> optional = ModList.get().getModContainerById(MOD_ID);
|
||||||
|
if (optional.isPresent()) {
|
||||||
|
return optional.get().getModInfo().getVersion().toString();
|
||||||
|
}
|
||||||
|
return "0.0.0";
|
||||||
|
}
|
||||||
|
|
||||||
|
public static IProxy getProxy() {
|
||||||
|
return proxy;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@ -1,5 +1,6 @@
|
|||||||
package dev.micle.firefly_bush_backport.block;
|
package dev.micle.firefly_bush_backport.block;
|
||||||
|
|
||||||
|
import com.mojang.serialization.MapCodec;
|
||||||
import dev.micle.firefly_bush_backport.config.Config;
|
import dev.micle.firefly_bush_backport.config.Config;
|
||||||
import dev.micle.firefly_bush_backport.particle.ModParticles;
|
import dev.micle.firefly_bush_backport.particle.ModParticles;
|
||||||
import dev.micle.firefly_bush_backport.sound.ModSounds;
|
import dev.micle.firefly_bush_backport.sound.ModSounds;
|
||||||
@ -14,16 +15,25 @@ import net.minecraft.world.level.block.BonemealableBlock;
|
|||||||
import net.minecraft.world.level.block.BushBlock;
|
import net.minecraft.world.level.block.BushBlock;
|
||||||
import net.minecraft.world.level.block.state.BlockState;
|
import net.minecraft.world.level.block.state.BlockState;
|
||||||
import net.minecraft.world.level.levelgen.Heightmap;
|
import net.minecraft.world.level.levelgen.Heightmap;
|
||||||
|
import org.jetbrains.annotations.NotNull;
|
||||||
|
|
||||||
import javax.annotation.ParametersAreNonnullByDefault;
|
import javax.annotation.ParametersAreNonnullByDefault;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Optional;
|
import java.util.Optional;
|
||||||
|
|
||||||
public class FireflyBushBlock extends BushBlock implements BonemealableBlock {
|
public class FireflyBushBlock extends BushBlock implements BonemealableBlock {
|
||||||
|
public static final MapCodec<FireflyBushBlock> CODEC = simpleCodec(FireflyBushBlock::new);
|
||||||
|
|
||||||
public FireflyBushBlock(Properties properties) {
|
public FireflyBushBlock(Properties properties) {
|
||||||
super(properties);
|
super(properties);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
@NotNull
|
||||||
|
protected MapCodec<? extends BushBlock> codec() {
|
||||||
|
return CODEC;
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@ParametersAreNonnullByDefault
|
@ParametersAreNonnullByDefault
|
||||||
public void animateTick(BlockState blockState, Level level, BlockPos blockPos, RandomSource randomSource) {
|
public void animateTick(BlockState blockState, Level level, BlockPos blockPos, RandomSource randomSource) {
|
||||||
@ -58,7 +68,7 @@ public class FireflyBushBlock extends BushBlock implements BonemealableBlock {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
@ParametersAreNonnullByDefault
|
@ParametersAreNonnullByDefault
|
||||||
public boolean isValidBonemealTarget(LevelReader level, BlockPos blockPos, BlockState blockState, boolean isClient) {
|
public boolean isValidBonemealTarget(LevelReader level, BlockPos blockPos, BlockState blockState) {
|
||||||
return hasSpreadableNeighbourPos(level, blockPos, blockState);
|
return hasSpreadableNeighbourPos(level, blockPos, blockState);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@ -6,15 +6,14 @@ import net.minecraft.world.level.block.SoundType;
|
|||||||
import net.minecraft.world.level.block.state.BlockBehaviour;
|
import net.minecraft.world.level.block.state.BlockBehaviour;
|
||||||
import net.minecraft.world.level.material.MapColor;
|
import net.minecraft.world.level.material.MapColor;
|
||||||
import net.minecraft.world.level.material.PushReaction;
|
import net.minecraft.world.level.material.PushReaction;
|
||||||
import net.minecraftforge.eventbus.api.IEventBus;
|
import net.neoforged.bus.api.IEventBus;
|
||||||
import net.minecraftforge.registries.DeferredRegister;
|
import net.neoforged.neoforge.registries.DeferredHolder;
|
||||||
import net.minecraftforge.registries.ForgeRegistries;
|
import net.neoforged.neoforge.registries.DeferredRegister;
|
||||||
import net.minecraftforge.registries.RegistryObject;
|
|
||||||
|
|
||||||
public class ModBlocks {
|
public class ModBlocks {
|
||||||
public static final DeferredRegister<Block> BLOCKS = DeferredRegister.create(ForgeRegistries.BLOCKS, FireflyBushBackport.MOD_ID);
|
public static final DeferredRegister<Block> BLOCKS = DeferredRegister.createBlocks(FireflyBushBackport.MOD_ID);
|
||||||
|
|
||||||
public static RegistryObject<Block> FIREFLY_BUSH = BLOCKS.register("firefly_bush",
|
public static DeferredHolder<Block, FireflyBushBlock> FIREFLY_BUSH = BLOCKS.register("firefly_bush",
|
||||||
() -> new FireflyBushBlock(BlockBehaviour.Properties.of()
|
() -> new FireflyBushBlock(BlockBehaviour.Properties.of()
|
||||||
.mapColor(MapColor.PLANT)
|
.mapColor(MapColor.PLANT)
|
||||||
.ignitedByLava()
|
.ignitedByLava()
|
||||||
|
|||||||
@ -1,45 +1,46 @@
|
|||||||
package dev.micle.firefly_bush_backport.config;
|
package dev.micle.firefly_bush_backport.config;
|
||||||
|
|
||||||
import dev.micle.firefly_bush_backport.FireflyBushBackport;
|
|
||||||
import net.minecraft.util.random.SimpleWeightedRandomList;
|
import net.minecraft.util.random.SimpleWeightedRandomList;
|
||||||
import net.minecraft.world.level.Level;
|
import net.minecraft.world.level.Level;
|
||||||
import net.minecraftforge.common.ForgeConfigSpec;
|
import net.neoforged.bus.api.IEventBus;
|
||||||
import net.minecraftforge.eventbus.api.SubscribeEvent;
|
import net.neoforged.bus.api.SubscribeEvent;
|
||||||
import net.minecraftforge.fml.common.Mod;
|
import net.neoforged.fml.ModContainer;
|
||||||
import net.minecraftforge.fml.config.ModConfig;
|
import net.neoforged.fml.config.ModConfig;
|
||||||
import net.minecraftforge.fml.event.config.ModConfigEvent;
|
import net.neoforged.fml.event.config.ModConfigEvent;
|
||||||
|
import net.neoforged.neoforge.common.ModConfigSpec;
|
||||||
import org.apache.commons.lang3.tuple.Pair;
|
import org.apache.commons.lang3.tuple.Pair;
|
||||||
|
|
||||||
import java.awt.*;
|
import java.awt.*;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
@Mod.EventBusSubscriber(modid = FireflyBushBackport.MOD_ID, bus = Mod.EventBusSubscriber.Bus.MOD)
|
|
||||||
public final class Config {
|
public final class Config {
|
||||||
public static final Client CLIENT;
|
public static final Client CLIENT;
|
||||||
public static final ForgeConfigSpec CLIENT_SPEC;
|
public static final ModConfigSpec CLIENT_SPEC;
|
||||||
public static final Common COMMON;
|
public static final Common COMMON;
|
||||||
public static final ForgeConfigSpec COMMON_SPEC;
|
public static final ModConfigSpec COMMON_SPEC;
|
||||||
public static final Server SERVER;
|
public static final Server SERVER;
|
||||||
public static final ForgeConfigSpec SERVER_SPEC;
|
public static final ModConfigSpec SERVER_SPEC;
|
||||||
|
|
||||||
static {
|
static {
|
||||||
Pair<Client, ForgeConfigSpec> clientSpecPair = new ForgeConfigSpec.Builder().configure(Client::new);
|
Pair<Client, ModConfigSpec> clientSpecPair = new ModConfigSpec.Builder().configure(Client::new);
|
||||||
CLIENT = clientSpecPair.getLeft();
|
CLIENT = clientSpecPair.getLeft();
|
||||||
CLIENT_SPEC = clientSpecPair.getRight();
|
CLIENT_SPEC = clientSpecPair.getRight();
|
||||||
|
|
||||||
Pair<Common, ForgeConfigSpec> commonSpecPair = new ForgeConfigSpec.Builder().configure(Common::new);
|
Pair<Common, ModConfigSpec> commonSpecPair = new ModConfigSpec.Builder().configure(Common::new);
|
||||||
COMMON = commonSpecPair.getLeft();
|
COMMON = commonSpecPair.getLeft();
|
||||||
COMMON_SPEC = commonSpecPair.getRight();
|
COMMON_SPEC = commonSpecPair.getRight();
|
||||||
|
|
||||||
Pair<Server, ForgeConfigSpec> serverSpecPair = new ForgeConfigSpec.Builder().configure(Server::new);
|
Pair<Server, ModConfigSpec> serverSpecPair = new ModConfigSpec.Builder().configure(Server::new);
|
||||||
SERVER = serverSpecPair.getLeft();
|
SERVER = serverSpecPair.getLeft();
|
||||||
SERVER_SPEC = serverSpecPair.getRight();
|
SERVER_SPEC = serverSpecPair.getRight();
|
||||||
}
|
}
|
||||||
|
|
||||||
public static void register() {
|
public static void register(IEventBus modEventBus, ModContainer modContainer) {
|
||||||
FireflyBushBackport.getFMLJavaModLoadingContext().registerConfig(ModConfig.Type.CLIENT, CLIENT_SPEC);
|
modContainer.registerConfig(ModConfig.Type.CLIENT, CLIENT_SPEC);
|
||||||
FireflyBushBackport.getFMLJavaModLoadingContext().registerConfig(ModConfig.Type.COMMON, COMMON_SPEC);
|
modContainer.registerConfig(ModConfig.Type.COMMON, COMMON_SPEC);
|
||||||
FireflyBushBackport.getFMLJavaModLoadingContext().registerConfig(ModConfig.Type.SERVER, SERVER_SPEC);
|
modContainer.registerConfig(ModConfig.Type.SERVER, SERVER_SPEC);
|
||||||
|
|
||||||
|
modEventBus.addListener(Config::onConfigReloadEvent);
|
||||||
}
|
}
|
||||||
|
|
||||||
@SubscribeEvent
|
@SubscribeEvent
|
||||||
@ -54,29 +55,29 @@ public final class Config {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public static class Client {
|
public static class Client {
|
||||||
public static ForgeConfigSpec.DoubleValue bushFireflyChancePerTick;
|
public static ModConfigSpec.DoubleValue bushFireflyChancePerTick;
|
||||||
public static ForgeConfigSpec.DoubleValue bushFireflyHorizontalRange;
|
public static ModConfigSpec.DoubleValue bushFireflyHorizontalRange;
|
||||||
public static ForgeConfigSpec.DoubleValue bushFireflyVerticalRange;
|
public static ModConfigSpec.DoubleValue bushFireflyVerticalRange;
|
||||||
public static ForgeConfigSpec.IntValue bushFireflySpawnMaxBrightnessLevel;
|
public static ModConfigSpec.IntValue bushFireflySpawnMaxBrightnessLevel;
|
||||||
public static ForgeConfigSpec.IntValue bushFireflyAmbientSoundChanceOneIn;
|
public static ModConfigSpec.IntValue bushFireflyAmbientSoundChanceOneIn;
|
||||||
|
|
||||||
public static ForgeConfigSpec.BooleanValue bushExtraAlwaysPlayAmbientSound;
|
public static ModConfigSpec.BooleanValue bushExtraAlwaysPlayAmbientSound;
|
||||||
public static ForgeConfigSpec.BooleanValue bushExtraAlwaysSpawnParticles;
|
public static ModConfigSpec.BooleanValue bushExtraAlwaysSpawnParticles;
|
||||||
|
|
||||||
public static ForgeConfigSpec.DoubleValue particleFadeOutLightTime;
|
public static ModConfigSpec.DoubleValue particleFadeOutLightTime;
|
||||||
public static ForgeConfigSpec.DoubleValue particleFadeInLightTime;
|
public static ModConfigSpec.DoubleValue particleFadeInLightTime;
|
||||||
public static ForgeConfigSpec.DoubleValue particleFadeOutAlphaTime;
|
public static ModConfigSpec.DoubleValue particleFadeOutAlphaTime;
|
||||||
public static ForgeConfigSpec.DoubleValue particleFadeInAlphaTime;
|
public static ModConfigSpec.DoubleValue particleFadeInAlphaTime;
|
||||||
public static ForgeConfigSpec.IntValue particleMinLifetime;
|
public static ModConfigSpec.IntValue particleMinLifetime;
|
||||||
public static ForgeConfigSpec.IntValue particleMaxLifetime;
|
public static ModConfigSpec.IntValue particleMaxLifetime;
|
||||||
|
|
||||||
public static ForgeConfigSpec.DoubleValue particleExtraFriction;
|
public static ModConfigSpec.DoubleValue particleExtraFriction;
|
||||||
public static ForgeConfigSpec.DoubleValue particleExtraScale;
|
public static ModConfigSpec.DoubleValue particleExtraScale;
|
||||||
public static ForgeConfigSpec.DoubleValue particleExtraBrightness;
|
public static ModConfigSpec.DoubleValue particleExtraBrightness;
|
||||||
private static ForgeConfigSpec.ConfigValue<List<? extends String>> particleExtraColors;
|
private static ModConfigSpec.ConfigValue<List<? extends String>> particleExtraColors;
|
||||||
public static SimpleWeightedRandomList<Color> particleExtraColorsWeightedList;
|
public static SimpleWeightedRandomList<Color> particleExtraColorsWeightedList;
|
||||||
|
|
||||||
Client(ForgeConfigSpec.Builder builder) {
|
Client(ModConfigSpec.Builder builder) {
|
||||||
builder.comment("Settings for the firefly bush.").push("bush");
|
builder.comment("Settings for the firefly bush.").push("bush");
|
||||||
bushFireflyChancePerTick = builder
|
bushFireflyChancePerTick = builder
|
||||||
.defineInRange("bushFireflyChancePerTick", 0.7, 0, 1);
|
.defineInRange("bushFireflyChancePerTick", 0.7, 0, 1);
|
||||||
@ -120,7 +121,7 @@ public final class Config {
|
|||||||
.defineInRange("particleExtraBrightness", 255.0, 0, 255);
|
.defineInRange("particleExtraBrightness", 255.0, 0, 255);
|
||||||
particleExtraColors = builder
|
particleExtraColors = builder
|
||||||
.comment("List of color hex values and their weight. Format: '<color_hex>,<weight>'")
|
.comment("List of color hex values and their weight. Format: '<color_hex>,<weight>'")
|
||||||
.defineList("particleExtraColors", List.of("#ffffff,1"), Client::isValidColorEntry);
|
.defineList("particleExtraColors", List.of(getDefaultColorEntry()), Client::getDefaultColorEntry, Client::isValidColorEntry);
|
||||||
builder.pop();
|
builder.pop();
|
||||||
builder.pop();
|
builder.pop();
|
||||||
}
|
}
|
||||||
@ -137,16 +138,20 @@ public final class Config {
|
|||||||
private static boolean isValidColorEntry(Object entry) {
|
private static boolean isValidColorEntry(Object entry) {
|
||||||
return entry instanceof String && ((String) entry).matches("#\\w{6},\\d+$");
|
return entry instanceof String && ((String) entry).matches("#\\w{6},\\d+$");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private static String getDefaultColorEntry() {
|
||||||
|
return "#ffffff,1";
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public static class Common {
|
public static class Common {
|
||||||
Common(ForgeConfigSpec.Builder builder) {}
|
Common(ModConfigSpec.Builder builder) {}
|
||||||
|
|
||||||
private static void onConfigReload() {}
|
private static void onConfigReload() {}
|
||||||
}
|
}
|
||||||
|
|
||||||
public static class Server {
|
public static class Server {
|
||||||
Server(ForgeConfigSpec.Builder builder) {}
|
Server(ModConfigSpec.Builder builder) {}
|
||||||
|
|
||||||
private static void onConfigReload() {}
|
private static void onConfigReload() {}
|
||||||
}
|
}
|
||||||
|
|||||||
@ -1,21 +1,21 @@
|
|||||||
package dev.micle.firefly_bush_backport.data;
|
package dev.micle.firefly_bush_backport.data;
|
||||||
|
|
||||||
import dev.micle.firefly_bush_backport.FireflyBushBackport;
|
|
||||||
import dev.micle.firefly_bush_backport.data.client.ModBlockStateProvider;
|
import dev.micle.firefly_bush_backport.data.client.ModBlockStateProvider;
|
||||||
|
import dev.micle.firefly_bush_backport.data.client.ModDataMapProvider;
|
||||||
import dev.micle.firefly_bush_backport.data.client.ModItemModelProvider;
|
import dev.micle.firefly_bush_backport.data.client.ModItemModelProvider;
|
||||||
import dev.micle.firefly_bush_backport.data.client.ModSoundDefinitionsProvider;
|
import dev.micle.firefly_bush_backport.data.client.ModSoundDefinitionsProvider;
|
||||||
import dev.micle.firefly_bush_backport.data.server.ModLootTableProvider;
|
import dev.micle.firefly_bush_backport.data.server.ModLootTableProvider;
|
||||||
import dev.micle.firefly_bush_backport.data.server.ModWorldGenProvider;
|
import dev.micle.firefly_bush_backport.data.server.ModWorldGenProvider;
|
||||||
import net.minecraft.core.HolderLookup;
|
import net.minecraft.core.HolderLookup;
|
||||||
import net.minecraft.data.DataGenerator;
|
import net.minecraft.data.DataGenerator;
|
||||||
import net.minecraftforge.common.data.ExistingFileHelper;
|
import net.neoforged.bus.api.SubscribeEvent;
|
||||||
import net.minecraftforge.data.event.GatherDataEvent;
|
import net.neoforged.fml.common.EventBusSubscriber;
|
||||||
import net.minecraftforge.eventbus.api.SubscribeEvent;
|
import net.neoforged.neoforge.common.data.ExistingFileHelper;
|
||||||
import net.minecraftforge.fml.common.Mod;
|
import net.neoforged.neoforge.data.event.GatherDataEvent;
|
||||||
|
|
||||||
import java.util.concurrent.CompletableFuture;
|
import java.util.concurrent.CompletableFuture;
|
||||||
|
|
||||||
@Mod.EventBusSubscriber(modid = FireflyBushBackport.MOD_ID, bus = Mod.EventBusSubscriber.Bus.MOD)
|
@EventBusSubscriber
|
||||||
public class DataGenerators {
|
public class DataGenerators {
|
||||||
@SubscribeEvent
|
@SubscribeEvent
|
||||||
public static void gatherData(GatherDataEvent event) {
|
public static void gatherData(GatherDataEvent event) {
|
||||||
@ -26,8 +26,9 @@ public class DataGenerators {
|
|||||||
generator.addProvider(event.includeClient(), new ModBlockStateProvider(generator, existingFileHelper));
|
generator.addProvider(event.includeClient(), new ModBlockStateProvider(generator, existingFileHelper));
|
||||||
generator.addProvider(event.includeClient(), new ModItemModelProvider(generator, existingFileHelper));
|
generator.addProvider(event.includeClient(), new ModItemModelProvider(generator, existingFileHelper));
|
||||||
generator.addProvider(event.includeClient(), new ModSoundDefinitionsProvider(generator, existingFileHelper));
|
generator.addProvider(event.includeClient(), new ModSoundDefinitionsProvider(generator, existingFileHelper));
|
||||||
|
generator.addProvider(event.includeClient(), new ModDataMapProvider(generator, lookupProvider));
|
||||||
|
|
||||||
generator.addProvider(event.includeServer(), new ModLootTableProvider(generator));
|
generator.addProvider(event.includeServer(), new ModLootTableProvider(generator, lookupProvider));
|
||||||
generator.addProvider(event.includeServer(), new ModWorldGenProvider(generator, lookupProvider));
|
generator.addProvider(event.includeServer(), new ModWorldGenProvider(generator, lookupProvider));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@ -5,9 +5,9 @@ import dev.micle.firefly_bush_backport.block.ModBlocks;
|
|||||||
import net.minecraft.data.DataGenerator;
|
import net.minecraft.data.DataGenerator;
|
||||||
import net.minecraft.resources.ResourceLocation;
|
import net.minecraft.resources.ResourceLocation;
|
||||||
import net.minecraft.world.level.block.Block;
|
import net.minecraft.world.level.block.Block;
|
||||||
import net.minecraftforge.client.model.generators.BlockStateProvider;
|
import net.neoforged.neoforge.client.model.generators.BlockStateProvider;
|
||||||
import net.minecraftforge.common.data.ExistingFileHelper;
|
import net.neoforged.neoforge.common.data.ExistingFileHelper;
|
||||||
import net.minecraftforge.registries.RegistryObject;
|
import net.neoforged.neoforge.registries.DeferredHolder;
|
||||||
|
|
||||||
import java.util.Objects;
|
import java.util.Objects;
|
||||||
|
|
||||||
@ -21,7 +21,7 @@ public class ModBlockStateProvider extends BlockStateProvider {
|
|||||||
crossEmissiveBlock(ModBlocks.FIREFLY_BUSH);
|
crossEmissiveBlock(ModBlocks.FIREFLY_BUSH);
|
||||||
}
|
}
|
||||||
|
|
||||||
private void crossEmissiveBlock(RegistryObject<Block> block) {
|
private void crossEmissiveBlock(DeferredHolder<Block, ? extends Block> block) {
|
||||||
String name = Objects.requireNonNull(block.getId()).getPath();
|
String name = Objects.requireNonNull(block.getId()).getPath();
|
||||||
simpleBlock(block.get(), models()
|
simpleBlock(block.get(), models()
|
||||||
.withExistingParent(name, ResourceLocation.fromNamespaceAndPath(FireflyBushBackport.MOD_ID, "block/cross_emissive"))
|
.withExistingParent(name, ResourceLocation.fromNamespaceAndPath(FireflyBushBackport.MOD_ID, "block/cross_emissive"))
|
||||||
|
|||||||
@ -0,0 +1,24 @@
|
|||||||
|
package dev.micle.firefly_bush_backport.data.client;
|
||||||
|
|
||||||
|
import dev.micle.firefly_bush_backport.item.ModItems;
|
||||||
|
import net.minecraft.core.HolderLookup;
|
||||||
|
import net.minecraft.data.DataGenerator;
|
||||||
|
import net.neoforged.neoforge.common.data.DataMapProvider;
|
||||||
|
import net.neoforged.neoforge.registries.datamaps.builtin.Compostable;
|
||||||
|
import net.neoforged.neoforge.registries.datamaps.builtin.NeoForgeDataMaps;
|
||||||
|
|
||||||
|
import javax.annotation.ParametersAreNonnullByDefault;
|
||||||
|
import java.util.concurrent.CompletableFuture;
|
||||||
|
|
||||||
|
public class ModDataMapProvider extends DataMapProvider {
|
||||||
|
public ModDataMapProvider(DataGenerator generator, CompletableFuture<HolderLookup.Provider> lookupProvider) {
|
||||||
|
super(generator.getPackOutput(), lookupProvider);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
@ParametersAreNonnullByDefault
|
||||||
|
protected void gather(HolderLookup.Provider provider) {
|
||||||
|
this.builder(NeoForgeDataMaps.COMPOSTABLES)
|
||||||
|
.add(ModItems.FIREFLY_BUSH, new Compostable(0.3F), false);
|
||||||
|
}
|
||||||
|
}
|
||||||
@ -2,15 +2,15 @@ package dev.micle.firefly_bush_backport.data.client;
|
|||||||
|
|
||||||
import dev.micle.firefly_bush_backport.FireflyBushBackport;
|
import dev.micle.firefly_bush_backport.FireflyBushBackport;
|
||||||
import dev.micle.firefly_bush_backport.block.ModBlocks;
|
import dev.micle.firefly_bush_backport.block.ModBlocks;
|
||||||
|
import net.minecraft.core.registries.BuiltInRegistries;
|
||||||
import net.minecraft.data.DataGenerator;
|
import net.minecraft.data.DataGenerator;
|
||||||
import net.minecraft.world.item.Items;
|
import net.minecraft.world.item.Items;
|
||||||
import net.minecraft.world.level.block.Block;
|
import net.minecraft.world.level.block.Block;
|
||||||
import net.minecraftforge.client.model.generators.ItemModelBuilder;
|
import net.neoforged.neoforge.client.model.generators.ItemModelBuilder;
|
||||||
import net.minecraftforge.client.model.generators.ItemModelProvider;
|
import net.neoforged.neoforge.client.model.generators.ItemModelProvider;
|
||||||
import net.minecraftforge.client.model.generators.ModelFile;
|
import net.neoforged.neoforge.client.model.generators.ModelFile;
|
||||||
import net.minecraftforge.common.data.ExistingFileHelper;
|
import net.neoforged.neoforge.common.data.ExistingFileHelper;
|
||||||
import net.minecraftforge.registries.ForgeRegistries;
|
import net.neoforged.neoforge.registries.DeferredHolder;
|
||||||
import net.minecraftforge.registries.RegistryObject;
|
|
||||||
|
|
||||||
import java.util.Objects;
|
import java.util.Objects;
|
||||||
|
|
||||||
@ -21,11 +21,11 @@ public class ModItemModelProvider extends ItemModelProvider {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected void registerModels() {
|
protected void registerModels() {
|
||||||
ModBlocks.BLOCKS.getEntries().stream().map(RegistryObject::get).forEach(this::blockItemModel);
|
ModBlocks.BLOCKS.getEntries().stream().map(DeferredHolder::get).forEach(this::blockItemModel);
|
||||||
}
|
}
|
||||||
|
|
||||||
private void blockItemModel(Block block) {
|
private void blockItemModel(Block block) {
|
||||||
String name = Objects.requireNonNull(ForgeRegistries.BLOCKS.getKey(block)).getPath();
|
String name = Objects.requireNonNull(BuiltInRegistries.BLOCK.getKey(block)).getPath();
|
||||||
|
|
||||||
if (block == ModBlocks.FIREFLY_BUSH.get()) {
|
if (block == ModBlocks.FIREFLY_BUSH.get()) {
|
||||||
builder(getExistingFile(mcLoc("item/generated")), name);
|
builder(getExistingFile(mcLoc("item/generated")), name);
|
||||||
|
|||||||
@ -4,8 +4,8 @@ import dev.micle.firefly_bush_backport.FireflyBushBackport;
|
|||||||
import dev.micle.firefly_bush_backport.sound.ModSounds;
|
import dev.micle.firefly_bush_backport.sound.ModSounds;
|
||||||
import net.minecraft.data.DataGenerator;
|
import net.minecraft.data.DataGenerator;
|
||||||
import net.minecraft.resources.ResourceLocation;
|
import net.minecraft.resources.ResourceLocation;
|
||||||
import net.minecraftforge.common.data.ExistingFileHelper;
|
import net.neoforged.neoforge.common.data.ExistingFileHelper;
|
||||||
import net.minecraftforge.common.data.SoundDefinitionsProvider;
|
import net.neoforged.neoforge.common.data.SoundDefinitionsProvider;
|
||||||
|
|
||||||
public class ModSoundDefinitionsProvider extends SoundDefinitionsProvider {
|
public class ModSoundDefinitionsProvider extends SoundDefinitionsProvider {
|
||||||
public ModSoundDefinitionsProvider(DataGenerator generator, ExistingFileHelper existingFileHelper) {
|
public ModSoundDefinitionsProvider(DataGenerator generator, ExistingFileHelper existingFileHelper) {
|
||||||
|
|||||||
@ -1,17 +1,17 @@
|
|||||||
package dev.micle.firefly_bush_backport.data.loot;
|
package dev.micle.firefly_bush_backport.data.loot;
|
||||||
|
|
||||||
import dev.micle.firefly_bush_backport.block.ModBlocks;
|
import dev.micle.firefly_bush_backport.block.ModBlocks;
|
||||||
|
import net.minecraft.core.HolderLookup;
|
||||||
import net.minecraft.data.loot.BlockLootSubProvider;
|
import net.minecraft.data.loot.BlockLootSubProvider;
|
||||||
import net.minecraft.world.flag.FeatureFlags;
|
import net.minecraft.world.flag.FeatureFlags;
|
||||||
import net.minecraft.world.level.block.Block;
|
import net.minecraft.world.level.block.Block;
|
||||||
import net.minecraftforge.registries.RegistryObject;
|
|
||||||
import org.jetbrains.annotations.NotNull;
|
import org.jetbrains.annotations.NotNull;
|
||||||
|
|
||||||
import java.util.Set;
|
import java.util.Set;
|
||||||
|
|
||||||
public class ModBlockLootTableProvider extends BlockLootSubProvider {
|
public class ModBlockLootTableProvider extends BlockLootSubProvider {
|
||||||
public ModBlockLootTableProvider() {
|
public ModBlockLootTableProvider(HolderLookup.Provider provider) {
|
||||||
super(Set.of(), FeatureFlags.REGISTRY.allFlags());
|
super(Set.of(), FeatureFlags.REGISTRY.allFlags(), provider);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@ -21,6 +21,6 @@ public class ModBlockLootTableProvider extends BlockLootSubProvider {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected @NotNull Iterable<Block> getKnownBlocks() {
|
protected @NotNull Iterable<Block> getKnownBlocks() {
|
||||||
return ModBlocks.BLOCKS.getEntries().stream().map(RegistryObject::get)::iterator;
|
return ModBlocks.BLOCKS.getEntries().stream().map(x -> (Block)x.value())::iterator;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@ -1,17 +1,19 @@
|
|||||||
package dev.micle.firefly_bush_backport.data.server;
|
package dev.micle.firefly_bush_backport.data.server;
|
||||||
|
|
||||||
import dev.micle.firefly_bush_backport.data.loot.ModBlockLootTableProvider;
|
import dev.micle.firefly_bush_backport.data.loot.ModBlockLootTableProvider;
|
||||||
|
import net.minecraft.core.HolderLookup;
|
||||||
import net.minecraft.data.DataGenerator;
|
import net.minecraft.data.DataGenerator;
|
||||||
import net.minecraft.data.loot.LootTableProvider;
|
import net.minecraft.data.loot.LootTableProvider;
|
||||||
import net.minecraft.world.level.storage.loot.parameters.LootContextParamSets;
|
import net.minecraft.world.level.storage.loot.parameters.LootContextParamSets;
|
||||||
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Set;
|
import java.util.Set;
|
||||||
|
import java.util.concurrent.CompletableFuture;
|
||||||
|
|
||||||
public class ModLootTableProvider extends LootTableProvider {
|
public class ModLootTableProvider extends LootTableProvider {
|
||||||
public ModLootTableProvider(DataGenerator generator) {
|
public ModLootTableProvider(DataGenerator generator, CompletableFuture<HolderLookup.Provider> registries) {
|
||||||
super(generator.getPackOutput(), Set.of(), List.of(
|
super(generator.getPackOutput(), Set.of(), List.of(
|
||||||
new LootTableProvider.SubProviderEntry(ModBlockLootTableProvider::new, LootContextParamSets.BLOCK)
|
new LootTableProvider.SubProviderEntry(ModBlockLootTableProvider::new, LootContextParamSets.BLOCK)
|
||||||
));
|
), registries);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@ -8,8 +8,8 @@ import net.minecraft.core.HolderLookup;
|
|||||||
import net.minecraft.core.RegistrySetBuilder;
|
import net.minecraft.core.RegistrySetBuilder;
|
||||||
import net.minecraft.core.registries.Registries;
|
import net.minecraft.core.registries.Registries;
|
||||||
import net.minecraft.data.DataGenerator;
|
import net.minecraft.data.DataGenerator;
|
||||||
import net.minecraftforge.common.data.DatapackBuiltinEntriesProvider;
|
import net.neoforged.neoforge.common.data.DatapackBuiltinEntriesProvider;
|
||||||
import net.minecraftforge.registries.ForgeRegistries;
|
import net.neoforged.neoforge.registries.NeoForgeRegistries;
|
||||||
|
|
||||||
import java.util.Set;
|
import java.util.Set;
|
||||||
import java.util.concurrent.CompletableFuture;
|
import java.util.concurrent.CompletableFuture;
|
||||||
@ -18,7 +18,7 @@ public class ModWorldGenProvider extends DatapackBuiltinEntriesProvider {
|
|||||||
public static final RegistrySetBuilder BUILDER = new RegistrySetBuilder()
|
public static final RegistrySetBuilder BUILDER = new RegistrySetBuilder()
|
||||||
.add(Registries.CONFIGURED_FEATURE, ModConfiguredFeatures::bootstrap)
|
.add(Registries.CONFIGURED_FEATURE, ModConfiguredFeatures::bootstrap)
|
||||||
.add(Registries.PLACED_FEATURE, ModPlacedFeatures::bootstrap)
|
.add(Registries.PLACED_FEATURE, ModPlacedFeatures::bootstrap)
|
||||||
.add(ForgeRegistries.Keys.BIOME_MODIFIERS, ModBiomeModifiers::bootstrap);
|
.add(NeoForgeRegistries.Keys.BIOME_MODIFIERS, ModBiomeModifiers::bootstrap);
|
||||||
|
|
||||||
public ModWorldGenProvider(DataGenerator generator, CompletableFuture<HolderLookup.Provider> registries) {
|
public ModWorldGenProvider(DataGenerator generator, CompletableFuture<HolderLookup.Provider> registries) {
|
||||||
super(generator.getPackOutput(), registries, BUILDER, Set.of(FireflyBushBackport.MOD_ID));
|
super(generator.getPackOutput(), registries, BUILDER, Set.of(FireflyBushBackport.MOD_ID));
|
||||||
|
|||||||
@ -2,13 +2,13 @@ package dev.micle.firefly_bush_backport.event;
|
|||||||
|
|
||||||
import dev.micle.firefly_bush_backport.item.ModItems;
|
import dev.micle.firefly_bush_backport.item.ModItems;
|
||||||
import net.minecraft.world.item.ItemStack;
|
import net.minecraft.world.item.ItemStack;
|
||||||
import net.minecraftforge.common.BasicItemListing;
|
import net.neoforged.bus.api.SubscribeEvent;
|
||||||
import net.minecraftforge.event.village.WandererTradesEvent;
|
import net.neoforged.neoforge.common.BasicItemListing;
|
||||||
import net.minecraftforge.eventbus.api.SubscribeEvent;
|
import net.neoforged.neoforge.event.village.WandererTradesEvent;
|
||||||
|
|
||||||
public class OnWandererTradesEventHandler {
|
public class OnWandererTradesEventHandler {
|
||||||
@SubscribeEvent
|
@SubscribeEvent
|
||||||
public void onWandererTradesEvent(WandererTradesEvent event) {
|
public void onWandererTradesEvent(WandererTradesEvent event) {
|
||||||
event.getGenericTrades().add(new BasicItemListing(3, new ItemStack(ModItems.FIREFLY_BUSH.get(), 1), 12, 1));
|
event.getGenericTrades().add(new BasicItemListing(3, new ItemStack(ModItems.FIREFLY_BUSH, 1), 12, 1));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@ -5,23 +5,22 @@ import dev.micle.firefly_bush_backport.block.ModBlocks;
|
|||||||
import net.minecraft.world.item.BlockItem;
|
import net.minecraft.world.item.BlockItem;
|
||||||
import net.minecraft.world.item.Item;
|
import net.minecraft.world.item.Item;
|
||||||
import net.minecraft.world.level.block.Block;
|
import net.minecraft.world.level.block.Block;
|
||||||
import net.minecraftforge.eventbus.api.IEventBus;
|
import net.neoforged.bus.api.IEventBus;
|
||||||
import net.minecraftforge.registries.DeferredRegister;
|
import net.neoforged.neoforge.registries.DeferredHolder;
|
||||||
import net.minecraftforge.registries.ForgeRegistries;
|
import net.neoforged.neoforge.registries.DeferredRegister;
|
||||||
import net.minecraftforge.registries.RegistryObject;
|
|
||||||
|
|
||||||
import java.util.Objects;
|
import java.util.Objects;
|
||||||
|
|
||||||
public class ModItems {
|
public class ModItems {
|
||||||
public static final DeferredRegister<Item> ITEMS = DeferredRegister.create(ForgeRegistries.ITEMS, FireflyBushBackport.MOD_ID);
|
public static final DeferredRegister<Item> ITEMS = DeferredRegister.createItems(FireflyBushBackport.MOD_ID);
|
||||||
|
|
||||||
public static final RegistryObject<BlockItem> FIREFLY_BUSH = registerBlock(ModBlocks.FIREFLY_BUSH);
|
public static final DeferredHolder<Item, BlockItem> FIREFLY_BUSH = registerBlock(ModBlocks.FIREFLY_BUSH);
|
||||||
|
|
||||||
public static void register(IEventBus modEventBus) {
|
public static void register(IEventBus modEventBus) {
|
||||||
ITEMS.register(modEventBus);
|
ITEMS.register(modEventBus);
|
||||||
}
|
}
|
||||||
|
|
||||||
private static RegistryObject<BlockItem> registerBlock(RegistryObject<Block> block) {
|
private static <T extends Block> DeferredHolder<Item, BlockItem> registerBlock(DeferredHolder<Block, T> block) {
|
||||||
return ITEMS.register(Objects.requireNonNull(block.getId()).getPath(), () -> new BlockItem(block.get(), new Item.Properties()));
|
return ITEMS.register(Objects.requireNonNull(block.getId()).getPath(), () -> new BlockItem(block.get(), new Item.Properties()));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@ -6,8 +6,8 @@ import net.minecraft.client.particle.*;
|
|||||||
import net.minecraft.core.BlockPos;
|
import net.minecraft.core.BlockPos;
|
||||||
import net.minecraft.core.particles.SimpleParticleType;
|
import net.minecraft.core.particles.SimpleParticleType;
|
||||||
import net.minecraft.util.Mth;
|
import net.minecraft.util.Mth;
|
||||||
import net.minecraftforge.api.distmarker.Dist;
|
import net.neoforged.api.distmarker.Dist;
|
||||||
import net.minecraftforge.api.distmarker.OnlyIn;
|
import net.neoforged.api.distmarker.OnlyIn;
|
||||||
import org.jetbrains.annotations.NotNull;
|
import org.jetbrains.annotations.NotNull;
|
||||||
|
|
||||||
import javax.annotation.ParametersAreNonnullByDefault;
|
import javax.annotation.ParametersAreNonnullByDefault;
|
||||||
|
|||||||
@ -3,15 +3,15 @@ package dev.micle.firefly_bush_backport.particle;
|
|||||||
import dev.micle.firefly_bush_backport.FireflyBushBackport;
|
import dev.micle.firefly_bush_backport.FireflyBushBackport;
|
||||||
import net.minecraft.core.particles.ParticleType;
|
import net.minecraft.core.particles.ParticleType;
|
||||||
import net.minecraft.core.particles.SimpleParticleType;
|
import net.minecraft.core.particles.SimpleParticleType;
|
||||||
import net.minecraftforge.eventbus.api.IEventBus;
|
import net.minecraft.core.registries.BuiltInRegistries;
|
||||||
import net.minecraftforge.registries.DeferredRegister;
|
import net.neoforged.bus.api.IEventBus;
|
||||||
import net.minecraftforge.registries.ForgeRegistries;
|
import net.neoforged.neoforge.registries.DeferredHolder;
|
||||||
import net.minecraftforge.registries.RegistryObject;
|
import net.neoforged.neoforge.registries.DeferredRegister;
|
||||||
|
|
||||||
public class ModParticles {
|
public class ModParticles {
|
||||||
public static final DeferredRegister<ParticleType<?>> PARTICLE_TYPES = DeferredRegister.create(ForgeRegistries.PARTICLE_TYPES, FireflyBushBackport.MOD_ID);
|
public static final DeferredRegister<ParticleType<?>> PARTICLE_TYPES = DeferredRegister.create(BuiltInRegistries.PARTICLE_TYPE, FireflyBushBackport.MOD_ID);
|
||||||
|
|
||||||
public static final RegistryObject<SimpleParticleType> FIREFLY = PARTICLE_TYPES.register("firefly",
|
public static final DeferredHolder<ParticleType<?>, SimpleParticleType> FIREFLY = PARTICLE_TYPES.register("firefly",
|
||||||
() -> new SimpleParticleType(false));
|
() -> new SimpleParticleType(false));
|
||||||
|
|
||||||
public static void register(IEventBus modEventBus) {
|
public static void register(IEventBus modEventBus) {
|
||||||
|
|||||||
@ -4,8 +4,15 @@ import net.minecraft.server.MinecraftServer;
|
|||||||
import net.minecraft.world.entity.player.Player;
|
import net.minecraft.world.entity.player.Player;
|
||||||
import net.minecraft.world.level.Level;
|
import net.minecraft.world.level.Level;
|
||||||
|
|
||||||
|
import javax.annotation.Nullable;
|
||||||
|
|
||||||
public interface IProxy {
|
public interface IProxy {
|
||||||
|
@Nullable
|
||||||
MinecraftServer getServer();
|
MinecraftServer getServer();
|
||||||
|
|
||||||
|
@Nullable
|
||||||
Player getClientPlayer();
|
Player getClientPlayer();
|
||||||
|
|
||||||
|
@Nullable
|
||||||
Level getClientLevel();
|
Level getClientLevel();
|
||||||
}
|
}
|
||||||
|
|||||||
@ -1,6 +1,5 @@
|
|||||||
package dev.micle.firefly_bush_backport.proxy;
|
package dev.micle.firefly_bush_backport.proxy;
|
||||||
|
|
||||||
import dev.micle.firefly_bush_backport.FireflyBushBackport;
|
|
||||||
import dev.micle.firefly_bush_backport.block.ModBlocks;
|
import dev.micle.firefly_bush_backport.block.ModBlocks;
|
||||||
import dev.micle.firefly_bush_backport.config.Config;
|
import dev.micle.firefly_bush_backport.config.Config;
|
||||||
import dev.micle.firefly_bush_backport.event.OnWandererTradesEventHandler;
|
import dev.micle.firefly_bush_backport.event.OnWandererTradesEventHandler;
|
||||||
@ -13,25 +12,23 @@ import net.minecraft.client.Minecraft;
|
|||||||
import net.minecraft.server.MinecraftServer;
|
import net.minecraft.server.MinecraftServer;
|
||||||
import net.minecraft.world.entity.player.Player;
|
import net.minecraft.world.entity.player.Player;
|
||||||
import net.minecraft.world.level.Level;
|
import net.minecraft.world.level.Level;
|
||||||
import net.minecraft.world.level.block.ComposterBlock;
|
import net.neoforged.api.distmarker.Dist;
|
||||||
import net.minecraftforge.api.distmarker.Dist;
|
import net.neoforged.api.distmarker.OnlyIn;
|
||||||
import net.minecraftforge.api.distmarker.OnlyIn;
|
import net.neoforged.bus.api.IEventBus;
|
||||||
import net.minecraftforge.client.event.RegisterParticleProvidersEvent;
|
import net.neoforged.fml.ModContainer;
|
||||||
import net.minecraftforge.common.MinecraftForge;
|
import net.neoforged.fml.event.lifecycle.*;
|
||||||
import net.minecraftforge.event.AddReloadListenerEvent;
|
import net.neoforged.neoforge.client.event.RegisterParticleProvidersEvent;
|
||||||
import net.minecraftforge.event.server.ServerStartedEvent;
|
import net.neoforged.neoforge.common.NeoForge;
|
||||||
import net.minecraftforge.event.server.ServerStoppingEvent;
|
import net.neoforged.neoforge.event.AddReloadListenerEvent;
|
||||||
import net.minecraftforge.eventbus.api.IEventBus;
|
import net.neoforged.neoforge.event.server.ServerStartedEvent;
|
||||||
import net.minecraftforge.fml.event.lifecycle.*;
|
import net.neoforged.neoforge.event.server.ServerStoppingEvent;
|
||||||
|
|
||||||
public class Proxy implements IProxy {
|
public class Proxy implements IProxy {
|
||||||
private static MinecraftServer server = null;
|
private static MinecraftServer server = null;
|
||||||
|
|
||||||
// Common setup
|
// Common setup
|
||||||
public Proxy() {
|
public Proxy(IEventBus modEventBus, ModContainer modContainer) {
|
||||||
IEventBus modEventBus = FireflyBushBackport.getFMLJavaModLoadingContext().getModEventBus();
|
Config.register(modEventBus, modContainer);
|
||||||
|
|
||||||
Config.register();
|
|
||||||
ModBlocks.register(modEventBus);
|
ModBlocks.register(modEventBus);
|
||||||
ModItems.register(modEventBus);
|
ModItems.register(modEventBus);
|
||||||
ModCreativeModeTabs.register(modEventBus);
|
ModCreativeModeTabs.register(modEventBus);
|
||||||
@ -44,17 +41,15 @@ public class Proxy implements IProxy {
|
|||||||
modEventBus.addListener(Proxy::imcProcess);
|
modEventBus.addListener(Proxy::imcProcess);
|
||||||
|
|
||||||
// Register event bus listeners
|
// Register event bus listeners
|
||||||
MinecraftForge.EVENT_BUS.addListener(Proxy::onAddReloadListeners);
|
NeoForge.EVENT_BUS.addListener(Proxy::onAddReloadListeners);
|
||||||
MinecraftForge.EVENT_BUS.addListener(Proxy::serverStarted);
|
NeoForge.EVENT_BUS.addListener(Proxy::serverStarted);
|
||||||
MinecraftForge.EVENT_BUS.addListener(Proxy::serverStopping);
|
NeoForge.EVENT_BUS.addListener(Proxy::serverStopping);
|
||||||
|
|
||||||
// Register event handlers
|
// Register event handlers
|
||||||
MinecraftForge.EVENT_BUS.register(new OnWandererTradesEventHandler());
|
NeoForge.EVENT_BUS.register(new OnWandererTradesEventHandler());
|
||||||
}
|
}
|
||||||
|
|
||||||
private static void setup(FMLCommonSetupEvent event) {
|
private static void setup(FMLCommonSetupEvent event) {}
|
||||||
ComposterBlock.COMPOSTABLES.put(ModItems.FIREFLY_BUSH.get().asItem(), 0.3F);
|
|
||||||
}
|
|
||||||
|
|
||||||
private static void imcEnqueue(InterModEnqueueEvent event) {}
|
private static void imcEnqueue(InterModEnqueueEvent event) {}
|
||||||
|
|
||||||
@ -87,8 +82,8 @@ public class Proxy implements IProxy {
|
|||||||
|
|
||||||
// Client setup
|
// Client setup
|
||||||
public static class Client extends Proxy {
|
public static class Client extends Proxy {
|
||||||
public Client() {
|
public Client(IEventBus modEventBus, ModContainer modContainer) {
|
||||||
IEventBus modEventBus = FireflyBushBackport.getFMLJavaModLoadingContext().getModEventBus();
|
super(modEventBus, modContainer);
|
||||||
|
|
||||||
// Register mod event bus listeners
|
// Register mod event bus listeners
|
||||||
modEventBus.addListener(Client::setup);
|
modEventBus.addListener(Client::setup);
|
||||||
@ -119,9 +114,10 @@ public class Proxy implements IProxy {
|
|||||||
|
|
||||||
// Server setup
|
// Server setup
|
||||||
public static class Server extends Proxy {
|
public static class Server extends Proxy {
|
||||||
public Server() {
|
public Server(IEventBus modEventBus, ModContainer modContainer) {
|
||||||
|
super(modEventBus, modContainer);
|
||||||
|
|
||||||
// Register mod event bus listeners
|
// Register mod event bus listeners
|
||||||
IEventBus modEventBus = FireflyBushBackport.getFMLJavaModLoadingContext().getModEventBus();
|
|
||||||
modEventBus.addListener(Server::setup);
|
modEventBus.addListener(Server::setup);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@ -1,23 +1,23 @@
|
|||||||
package dev.micle.firefly_bush_backport.sound;
|
package dev.micle.firefly_bush_backport.sound;
|
||||||
|
|
||||||
import dev.micle.firefly_bush_backport.FireflyBushBackport;
|
import dev.micle.firefly_bush_backport.FireflyBushBackport;
|
||||||
|
import net.minecraft.core.registries.BuiltInRegistries;
|
||||||
import net.minecraft.resources.ResourceLocation;
|
import net.minecraft.resources.ResourceLocation;
|
||||||
import net.minecraft.sounds.SoundEvent;
|
import net.minecraft.sounds.SoundEvent;
|
||||||
import net.minecraftforge.eventbus.api.IEventBus;
|
import net.neoforged.bus.api.IEventBus;
|
||||||
import net.minecraftforge.registries.DeferredRegister;
|
import net.neoforged.neoforge.registries.DeferredHolder;
|
||||||
import net.minecraftforge.registries.ForgeRegistries;
|
import net.neoforged.neoforge.registries.DeferredRegister;
|
||||||
import net.minecraftforge.registries.RegistryObject;
|
|
||||||
|
|
||||||
public class ModSounds {
|
public class ModSounds {
|
||||||
public static final DeferredRegister<SoundEvent> SOUND_EVENTS = DeferredRegister.create(ForgeRegistries.SOUND_EVENTS, FireflyBushBackport.MOD_ID);
|
public static final DeferredRegister<SoundEvent> SOUND_EVENTS = DeferredRegister.create(BuiltInRegistries.SOUND_EVENT, FireflyBushBackport.MOD_ID);
|
||||||
|
|
||||||
public static final RegistryObject<SoundEvent> FIREFLY_BUSH_IDLE = registerSoundEvent("block.firefly_bush.idle");
|
public static final DeferredHolder<SoundEvent, SoundEvent> FIREFLY_BUSH_IDLE = registerSoundEvent("block.firefly_bush.idle");
|
||||||
|
|
||||||
public static void register(IEventBus modEventBus) {
|
public static void register(IEventBus modEventBus) {
|
||||||
SOUND_EVENTS.register(modEventBus);
|
SOUND_EVENTS.register(modEventBus);
|
||||||
}
|
}
|
||||||
|
|
||||||
private static RegistryObject<SoundEvent> registerSoundEvent(String name) {
|
private static DeferredHolder<SoundEvent, SoundEvent> registerSoundEvent(String name) {
|
||||||
return SOUND_EVENTS.register(name, () -> SoundEvent.createVariableRangeEvent(ResourceLocation.fromNamespaceAndPath(FireflyBushBackport.MOD_ID, name)));
|
return SOUND_EVENTS.register(name, () -> SoundEvent.createVariableRangeEvent(ResourceLocation.fromNamespaceAndPath(FireflyBushBackport.MOD_ID, name)));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@ -2,17 +2,17 @@ package dev.micle.firefly_bush_backport.tab;
|
|||||||
|
|
||||||
import dev.micle.firefly_bush_backport.FireflyBushBackport;
|
import dev.micle.firefly_bush_backport.FireflyBushBackport;
|
||||||
import dev.micle.firefly_bush_backport.block.ModBlocks;
|
import dev.micle.firefly_bush_backport.block.ModBlocks;
|
||||||
import net.minecraft.core.registries.Registries;
|
import net.minecraft.core.registries.BuiltInRegistries;
|
||||||
import net.minecraft.network.chat.Component;
|
import net.minecraft.network.chat.Component;
|
||||||
import net.minecraft.world.item.CreativeModeTab;
|
import net.minecraft.world.item.CreativeModeTab;
|
||||||
import net.minecraftforge.eventbus.api.IEventBus;
|
import net.neoforged.bus.api.IEventBus;
|
||||||
import net.minecraftforge.registries.DeferredRegister;
|
import net.neoforged.neoforge.registries.DeferredHolder;
|
||||||
import net.minecraftforge.registries.RegistryObject;
|
import net.neoforged.neoforge.registries.DeferredRegister;
|
||||||
|
|
||||||
public class ModCreativeModeTabs {
|
public class ModCreativeModeTabs {
|
||||||
public static final DeferredRegister<CreativeModeTab> CREATIVE_MODE_TABS = DeferredRegister.create(Registries.CREATIVE_MODE_TAB, FireflyBushBackport.MOD_ID);
|
public static final DeferredRegister<CreativeModeTab> CREATIVE_MODE_TABS = DeferredRegister.create(BuiltInRegistries.CREATIVE_MODE_TAB, FireflyBushBackport.MOD_ID);
|
||||||
|
|
||||||
public static final RegistryObject<CreativeModeTab> MAIN_TAB = CREATIVE_MODE_TABS.register( "main",
|
public static final DeferredHolder<CreativeModeTab, CreativeModeTab> MAIN_TAB = CREATIVE_MODE_TABS.register( "main",
|
||||||
() -> CreativeModeTab.builder()
|
() -> CreativeModeTab.builder()
|
||||||
.title(Component.translatable(String.format("itemGroup.%s.main", FireflyBushBackport.MOD_ID)))
|
.title(Component.translatable(String.format("itemGroup.%s.main", FireflyBushBackport.MOD_ID)))
|
||||||
.icon(ModBlocks.FIREFLY_BUSH.get().asItem()::getDefaultInstance)
|
.icon(ModBlocks.FIREFLY_BUSH.get().asItem()::getDefaultInstance)
|
||||||
|
|||||||
@ -4,17 +4,17 @@ import dev.micle.firefly_bush_backport.FireflyBushBackport;
|
|||||||
import net.minecraft.core.HolderGetter;
|
import net.minecraft.core.HolderGetter;
|
||||||
import net.minecraft.core.HolderSet;
|
import net.minecraft.core.HolderSet;
|
||||||
import net.minecraft.core.registries.Registries;
|
import net.minecraft.core.registries.Registries;
|
||||||
import net.minecraft.data.worldgen.BootstapContext;
|
import net.minecraft.data.worldgen.BootstrapContext;
|
||||||
import net.minecraft.resources.ResourceKey;
|
import net.minecraft.resources.ResourceKey;
|
||||||
import net.minecraft.resources.ResourceLocation;
|
import net.minecraft.resources.ResourceLocation;
|
||||||
import net.minecraft.tags.BiomeTags;
|
import net.minecraft.tags.BiomeTags;
|
||||||
import net.minecraft.world.level.biome.Biome;
|
import net.minecraft.world.level.biome.Biome;
|
||||||
import net.minecraft.world.level.levelgen.GenerationStep;
|
import net.minecraft.world.level.levelgen.GenerationStep;
|
||||||
import net.minecraft.world.level.levelgen.placement.PlacedFeature;
|
import net.minecraft.world.level.levelgen.placement.PlacedFeature;
|
||||||
import net.minecraftforge.common.Tags;
|
import net.neoforged.neoforge.common.Tags;
|
||||||
import net.minecraftforge.common.world.BiomeModifier;
|
import net.neoforged.neoforge.common.world.BiomeModifier;
|
||||||
import net.minecraftforge.common.world.ForgeBiomeModifiers;
|
import net.neoforged.neoforge.common.world.BiomeModifiers;
|
||||||
import net.minecraftforge.registries.ForgeRegistries;
|
import net.neoforged.neoforge.registries.NeoForgeRegistries;
|
||||||
|
|
||||||
import java.util.Set;
|
import java.util.Set;
|
||||||
|
|
||||||
@ -24,29 +24,29 @@ public class ModBiomeModifiers {
|
|||||||
public static final ResourceKey<BiomeModifier> ADD_PATCH_FIREFLY_BUSH_NEAR_WATER = registerKey("add_patch_firefly_bush_near_water");
|
public static final ResourceKey<BiomeModifier> ADD_PATCH_FIREFLY_BUSH_NEAR_WATER = registerKey("add_patch_firefly_bush_near_water");
|
||||||
public static final ResourceKey<BiomeModifier> REMOVE_PATCH_FIREFLY_BUSH_NEAR_WATER = registerKey("remove_patch_firefly_bush_near_water");
|
public static final ResourceKey<BiomeModifier> REMOVE_PATCH_FIREFLY_BUSH_NEAR_WATER = registerKey("remove_patch_firefly_bush_near_water");
|
||||||
|
|
||||||
public static void bootstrap(BootstapContext<BiomeModifier> context) {
|
public static void bootstrap(BootstrapContext<BiomeModifier> context) {
|
||||||
HolderGetter<PlacedFeature> placedFeatures = context.lookup(Registries.PLACED_FEATURE);
|
HolderGetter<PlacedFeature> placedFeatures = context.lookup(Registries.PLACED_FEATURE);
|
||||||
HolderGetter<Biome> biomes = context.lookup(Registries.BIOME);
|
HolderGetter<Biome> biomes = context.lookup(Registries.BIOME);
|
||||||
|
|
||||||
context.register(ADD_PATCH_FIREFLY_BUSH_SWAMP, new ForgeBiomeModifiers.AddFeaturesBiomeModifier(
|
context.register(ADD_PATCH_FIREFLY_BUSH_SWAMP, new BiomeModifiers.AddFeaturesBiomeModifier(
|
||||||
biomes.getOrThrow(Tags.Biomes.IS_SWAMP),
|
biomes.getOrThrow(Tags.Biomes.IS_SWAMP),
|
||||||
HolderSet.direct(placedFeatures.getOrThrow(ModPlacedFeatures.PATCH_FIREFLY_BUSH_SWAMP_PLACED_KEY)),
|
HolderSet.direct(placedFeatures.getOrThrow(ModPlacedFeatures.PATCH_FIREFLY_BUSH_SWAMP_PLACED_KEY)),
|
||||||
GenerationStep.Decoration.VEGETAL_DECORATION
|
GenerationStep.Decoration.VEGETAL_DECORATION
|
||||||
));
|
));
|
||||||
|
|
||||||
context.register(ADD_PATCH_FIREFLY_BUSH_NEAR_WATER_SWAMP, new ForgeBiomeModifiers.AddFeaturesBiomeModifier(
|
context.register(ADD_PATCH_FIREFLY_BUSH_NEAR_WATER_SWAMP, new BiomeModifiers.AddFeaturesBiomeModifier(
|
||||||
biomes.getOrThrow(Tags.Biomes.IS_SWAMP),
|
biomes.getOrThrow(Tags.Biomes.IS_SWAMP),
|
||||||
HolderSet.direct(placedFeatures.getOrThrow(ModPlacedFeatures.PATCH_FIREFLY_BUSH_NEAR_WATER_SWAMP_PLACED_KEY)),
|
HolderSet.direct(placedFeatures.getOrThrow(ModPlacedFeatures.PATCH_FIREFLY_BUSH_NEAR_WATER_SWAMP_PLACED_KEY)),
|
||||||
GenerationStep.Decoration.VEGETAL_DECORATION
|
GenerationStep.Decoration.VEGETAL_DECORATION
|
||||||
));
|
));
|
||||||
|
|
||||||
context.register(ADD_PATCH_FIREFLY_BUSH_NEAR_WATER, new ForgeBiomeModifiers.AddFeaturesBiomeModifier(
|
context.register(ADD_PATCH_FIREFLY_BUSH_NEAR_WATER, new BiomeModifiers.AddFeaturesBiomeModifier(
|
||||||
biomes.getOrThrow(BiomeTags.IS_OVERWORLD),
|
biomes.getOrThrow(BiomeTags.IS_OVERWORLD),
|
||||||
HolderSet.direct(placedFeatures.getOrThrow(ModPlacedFeatures.PATCH_FIREFLY_BUSH_NEAR_WATER_PLACED_KEY)),
|
HolderSet.direct(placedFeatures.getOrThrow(ModPlacedFeatures.PATCH_FIREFLY_BUSH_NEAR_WATER_PLACED_KEY)),
|
||||||
GenerationStep.Decoration.VEGETAL_DECORATION
|
GenerationStep.Decoration.VEGETAL_DECORATION
|
||||||
));
|
));
|
||||||
|
|
||||||
context.register(REMOVE_PATCH_FIREFLY_BUSH_NEAR_WATER, new ForgeBiomeModifiers.RemoveFeaturesBiomeModifier(
|
context.register(REMOVE_PATCH_FIREFLY_BUSH_NEAR_WATER, new BiomeModifiers.RemoveFeaturesBiomeModifier(
|
||||||
biomes.getOrThrow(Tags.Biomes.IS_SWAMP),
|
biomes.getOrThrow(Tags.Biomes.IS_SWAMP),
|
||||||
HolderSet.direct(placedFeatures.getOrThrow(ModPlacedFeatures.PATCH_FIREFLY_BUSH_NEAR_WATER_PLACED_KEY)),
|
HolderSet.direct(placedFeatures.getOrThrow(ModPlacedFeatures.PATCH_FIREFLY_BUSH_NEAR_WATER_PLACED_KEY)),
|
||||||
Set.of(GenerationStep.Decoration.VEGETAL_DECORATION)
|
Set.of(GenerationStep.Decoration.VEGETAL_DECORATION)
|
||||||
@ -54,6 +54,6 @@ public class ModBiomeModifiers {
|
|||||||
}
|
}
|
||||||
|
|
||||||
private static ResourceKey<BiomeModifier> registerKey(String name) {
|
private static ResourceKey<BiomeModifier> registerKey(String name) {
|
||||||
return ResourceKey.create(ForgeRegistries.Keys.BIOME_MODIFIERS, ResourceLocation.fromNamespaceAndPath(FireflyBushBackport.MOD_ID, name));
|
return ResourceKey.create(NeoForgeRegistries.Keys.BIOME_MODIFIERS, ResourceLocation.fromNamespaceAndPath(FireflyBushBackport.MOD_ID, name));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@ -3,7 +3,7 @@ package dev.micle.firefly_bush_backport.worldgen;
|
|||||||
import dev.micle.firefly_bush_backport.FireflyBushBackport;
|
import dev.micle.firefly_bush_backport.FireflyBushBackport;
|
||||||
import dev.micle.firefly_bush_backport.block.ModBlocks;
|
import dev.micle.firefly_bush_backport.block.ModBlocks;
|
||||||
import net.minecraft.core.registries.Registries;
|
import net.minecraft.core.registries.Registries;
|
||||||
import net.minecraft.data.worldgen.BootstapContext;
|
import net.minecraft.data.worldgen.BootstrapContext;
|
||||||
import net.minecraft.data.worldgen.placement.PlacementUtils;
|
import net.minecraft.data.worldgen.placement.PlacementUtils;
|
||||||
import net.minecraft.resources.ResourceKey;
|
import net.minecraft.resources.ResourceKey;
|
||||||
import net.minecraft.resources.ResourceLocation;
|
import net.minecraft.resources.ResourceLocation;
|
||||||
@ -17,7 +17,7 @@ import net.minecraft.world.level.levelgen.feature.stateproviders.SimpleStateProv
|
|||||||
public class ModConfiguredFeatures {
|
public class ModConfiguredFeatures {
|
||||||
public static final ResourceKey<ConfiguredFeature<?, ?>> PATCH_FIREFLY_BUSH_KEY = registerKey("patch_firefly_bush");
|
public static final ResourceKey<ConfiguredFeature<?, ?>> PATCH_FIREFLY_BUSH_KEY = registerKey("patch_firefly_bush");
|
||||||
|
|
||||||
public static void bootstrap(BootstapContext<ConfiguredFeature<?, ?>> context) {
|
public static void bootstrap(BootstrapContext<ConfiguredFeature<?, ?>> context) {
|
||||||
register(context, PATCH_FIREFLY_BUSH_KEY, Feature.RANDOM_PATCH, new RandomPatchConfiguration(
|
register(context, PATCH_FIREFLY_BUSH_KEY, Feature.RANDOM_PATCH, new RandomPatchConfiguration(
|
||||||
20,
|
20,
|
||||||
4,
|
4,
|
||||||
@ -36,7 +36,7 @@ public class ModConfiguredFeatures {
|
|||||||
}
|
}
|
||||||
|
|
||||||
private static <FC extends FeatureConfiguration, F extends Feature<FC>> void register(
|
private static <FC extends FeatureConfiguration, F extends Feature<FC>> void register(
|
||||||
BootstapContext<ConfiguredFeature<?, ?>> context,
|
BootstrapContext<ConfiguredFeature<?, ?>> context,
|
||||||
ResourceKey<ConfiguredFeature<?, ?>> key, F feature, FC configuration
|
ResourceKey<ConfiguredFeature<?, ?>> key, F feature, FC configuration
|
||||||
) {
|
) {
|
||||||
context.register(key, new ConfiguredFeature<>(feature, configuration));
|
context.register(key, new ConfiguredFeature<>(feature, configuration));
|
||||||
|
|||||||
@ -6,7 +6,7 @@ import net.minecraft.core.Holder;
|
|||||||
import net.minecraft.core.HolderGetter;
|
import net.minecraft.core.HolderGetter;
|
||||||
import net.minecraft.core.Vec3i;
|
import net.minecraft.core.Vec3i;
|
||||||
import net.minecraft.core.registries.Registries;
|
import net.minecraft.core.registries.Registries;
|
||||||
import net.minecraft.data.worldgen.BootstapContext;
|
import net.minecraft.data.worldgen.BootstrapContext;
|
||||||
import net.minecraft.data.worldgen.placement.PlacementUtils;
|
import net.minecraft.data.worldgen.placement.PlacementUtils;
|
||||||
import net.minecraft.resources.ResourceKey;
|
import net.minecraft.resources.ResourceKey;
|
||||||
import net.minecraft.resources.ResourceLocation;
|
import net.minecraft.resources.ResourceLocation;
|
||||||
@ -24,7 +24,7 @@ public class ModPlacedFeatures {
|
|||||||
public static final ResourceKey<PlacedFeature> PATCH_FIREFLY_BUSH_NEAR_WATER_SWAMP_PLACED_KEY = registerKey("patch_firefly_bush_near_water_swamp");
|
public static final ResourceKey<PlacedFeature> PATCH_FIREFLY_BUSH_NEAR_WATER_SWAMP_PLACED_KEY = registerKey("patch_firefly_bush_near_water_swamp");
|
||||||
public static final ResourceKey<PlacedFeature> PATCH_FIREFLY_BUSH_NEAR_WATER_PLACED_KEY = registerKey("patch_firefly_bush_near_water");
|
public static final ResourceKey<PlacedFeature> PATCH_FIREFLY_BUSH_NEAR_WATER_PLACED_KEY = registerKey("patch_firefly_bush_near_water");
|
||||||
|
|
||||||
public static void bootstrap(BootstapContext<PlacedFeature> context) {
|
public static void bootstrap(BootstrapContext<PlacedFeature> context) {
|
||||||
HolderGetter<ConfiguredFeature<?, ?>> configuredFeatures = context.lookup(Registries.CONFIGURED_FEATURE);
|
HolderGetter<ConfiguredFeature<?, ?>> configuredFeatures = context.lookup(Registries.CONFIGURED_FEATURE);
|
||||||
|
|
||||||
register(context, PATCH_FIREFLY_BUSH_SWAMP_PLACED_KEY, configuredFeatures.getOrThrow(ModConfiguredFeatures.PATCH_FIREFLY_BUSH_KEY), List.of(
|
register(context, PATCH_FIREFLY_BUSH_SWAMP_PLACED_KEY, configuredFeatures.getOrThrow(ModConfiguredFeatures.PATCH_FIREFLY_BUSH_KEY), List.of(
|
||||||
@ -73,7 +73,7 @@ public class ModPlacedFeatures {
|
|||||||
return ResourceKey.create(Registries.PLACED_FEATURE, ResourceLocation.fromNamespaceAndPath(FireflyBushBackport.MOD_ID, name));
|
return ResourceKey.create(Registries.PLACED_FEATURE, ResourceLocation.fromNamespaceAndPath(FireflyBushBackport.MOD_ID, name));
|
||||||
}
|
}
|
||||||
|
|
||||||
private static void register(BootstapContext<PlacedFeature> context, ResourceKey<PlacedFeature> key, Holder<ConfiguredFeature<?, ?>> configuration, List<PlacementModifier> modifiers) {
|
private static void register(BootstrapContext<PlacedFeature> context, ResourceKey<PlacedFeature> key, Holder<ConfiguredFeature<?, ?>> configuration, List<PlacementModifier> modifiers) {
|
||||||
context.register(key, new PlacedFeature(configuration, List.copyOf(modifiers)));
|
context.register(key, new PlacedFeature(configuration, List.copyOf(modifiers)));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@ -1,30 +0,0 @@
|
|||||||
modLoader = "javafml"
|
|
||||||
loaderVersion = "${loader_version_range}"
|
|
||||||
license = "${mod_license}"
|
|
||||||
issueTrackerURL="https://gitea.micle.dev/minecraft-mods/firefly_bush_backport/issues"
|
|
||||||
|
|
||||||
[[mods]]
|
|
||||||
modId = "${mod_id}"
|
|
||||||
version = "${mod_version}"
|
|
||||||
displayName = "${mod_name}"
|
|
||||||
#updateJSONURL="https://change.me.example.invalid/updates.json" # https://docs.minecraftforge.net/en/latest/misc/updatechecker/
|
|
||||||
#displayURL="https://change.me.to.your.mods.homepage.example.invalid/"
|
|
||||||
logoFile="logo.jpg"
|
|
||||||
#credits=""
|
|
||||||
authors = "${mod_authors}"
|
|
||||||
displayTest="MATCH_VERSION" # MATCH_VERSION, IGNORE_SERVER_VERSION (server only), IGNORE_ALL_VERSION (client only), NONE (IExtensionPoint.DisplayTest)
|
|
||||||
description = '''${mod_description}'''
|
|
||||||
|
|
||||||
[[dependencies."${mod_id}"]]
|
|
||||||
modId = "forge"
|
|
||||||
mandatory = true
|
|
||||||
versionRange = "${forge_version_range}"
|
|
||||||
ordering = "NONE" # BEFORE, AFTER, NONE
|
|
||||||
side = "BOTH" # BOTH, CLIENT, SERVER
|
|
||||||
|
|
||||||
[[dependencies."${mod_id}"]]
|
|
||||||
modId = "minecraft"
|
|
||||||
mandatory = true
|
|
||||||
versionRange = "${minecraft_version_range}"
|
|
||||||
ordering = "NONE"
|
|
||||||
side = "BOTH"
|
|
||||||
44
src/main/resources/META-INF/neoforge.mods.toml
Normal file
44
src/main/resources/META-INF/neoforge.mods.toml
Normal file
@ -0,0 +1,44 @@
|
|||||||
|
modLoader = "javafml"
|
||||||
|
loaderVersion = "${loader_version_range}"
|
||||||
|
license = "${mod_license}"
|
||||||
|
issueTrackerURL="https://gitea.micle.dev/minecraft-mods/firefly_bush_backport/issues"
|
||||||
|
|
||||||
|
[[mods]]
|
||||||
|
modId = "${mod_id}"
|
||||||
|
version = "${mod_version}"
|
||||||
|
displayName = "${mod_name}"
|
||||||
|
#updateJSONURL="https://change.me.example.invalid/updates.json" # https://docs.minecraftforge.net/en/latest/misc/updatechecker/
|
||||||
|
#displayURL="https://change.me.to.your.mods.homepage.example.invalid/"
|
||||||
|
logoFile="logo.png"
|
||||||
|
#credits=""
|
||||||
|
authors = "${mod_authors}"
|
||||||
|
description = '''${mod_description}'''
|
||||||
|
|
||||||
|
#[[mixins]]
|
||||||
|
#config = "${mod_id}.mixins.json"
|
||||||
|
|
||||||
|
#[[accessTransformers]]
|
||||||
|
#file = "META-INF/accesstransformer.cfg"
|
||||||
|
|
||||||
|
[[dependencies."${mod_id}"]]
|
||||||
|
modId = "neoforge"
|
||||||
|
# The type of the dependency. Can be one of "required", "optional", "incompatible" or "discouraged" (case insensitive).
|
||||||
|
# 'required' requires the mod to exist, 'optional' does not
|
||||||
|
# 'incompatible' will prevent the game from loading when the mod exists, and 'discouraged' will show a warning"
|
||||||
|
type = "required"
|
||||||
|
versionRange = "${neo_version_range}"
|
||||||
|
ordering = "NONE" # BEFORE, AFTER, NONE
|
||||||
|
side = "BOTH" # BOTH, CLIENT, SERVER
|
||||||
|
|
||||||
|
[[dependencies."${mod_id}"]]
|
||||||
|
modId = "minecraft"
|
||||||
|
type = "required"
|
||||||
|
versionRange = "${minecraft_version_range}"
|
||||||
|
ordering = "NONE"
|
||||||
|
side = "BOTH"
|
||||||
|
|
||||||
|
# Features are specific properties of the game environment, that you may want to declare you require. This example declares
|
||||||
|
# that your mod requires GL version 3.2 or higher. Other features will be added. They are side aware so declaring this won't
|
||||||
|
# stop your mod loading on the server for example.
|
||||||
|
#[features.${mod_id}]
|
||||||
|
#openGLVersion = "[3.2,)"
|
||||||
BIN
src/main/resources/logo.jpg
(Stored with Git LFS)
BIN
src/main/resources/logo.jpg
(Stored with Git LFS)
Binary file not shown.
BIN
src/main/resources/logo.png
(Stored with Git LFS)
Normal file
BIN
src/main/resources/logo.png
(Stored with Git LFS)
Normal file
Binary file not shown.
Reference in New Issue
Block a user