Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/devsrsouza/kotlinbukkitapi
KotlinBukkitAPI is an API for Bukkit/SpigotAPI using the cool and nifty features Kotlin has to make your life more easier.
https://github.com/devsrsouza/kotlinbukkitapi
bukkit dsl kotlin minecraft spigot
Last synced: 28 days ago
JSON representation
KotlinBukkitAPI is an API for Bukkit/SpigotAPI using the cool and nifty features Kotlin has to make your life more easier.
- Host: GitHub
- URL: https://github.com/devsrsouza/kotlinbukkitapi
- Owner: DevSrSouza
- License: mit
- Created: 2018-03-03T08:25:34.000Z (over 6 years ago)
- Default Branch: master
- Last Pushed: 2023-06-25T13:41:41.000Z (over 1 year ago)
- Last Synced: 2024-10-11T03:40:29.494Z (28 days ago)
- Topics: bukkit, dsl, kotlin, minecraft, spigot
- Language: Kotlin
- Homepage:
- Size: 875 KB
- Stars: 156
- Watchers: 11
- Forks: 20
- Open Issues: 11
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
## KotlinBukkitAPI
![Kotlin version](https://img.shields.io/static/v1?label=Kotlin&message=1.5.0&color=Orange&style=for-the-badge)
[![GitHub stars](https://img.shields.io/github/stars/DevSrSouza/KotlinBukkitAPI.svg?style=for-the-badge&color=orange&logo=)](https://github.com/DevSrSouza/KotlinBukkitAPI/stargazers)
[![Github Issues](https://img.shields.io/github/issues-raw/DevSrSouza/KotlinBukkitAPI.svg?style=for-the-badge&color=orange&logo=)](https://github.com/DevSrSouza/KotlinBukkitAPI/issues)
[![GitHub last commit](https://img.shields.io/github/last-commit/DevSrSouza/KotlinBukkitAPI/master.svg?style=for-the-badge&color=orange&logo=)](https://github.com/DevSrSouza/KotlinBukkitAPI/commit)
[![Discord](https://img.shields.io/discord/597530273009106975?style=for-the-badge&color=ORANGE&label=Discord)](https://discord.gg/HhucBqk)
[![Minecraft Server Running with KotlinBukkitAPI](https://img.shields.io/bstats/servers/6356?color=ORANGE&style=for-the-badge)](https://bstats.org/plugin/bukkit/KotlinBukkitAPI/6356)
[![MIT License](https://img.shields.io/badge/license-MIT-blue.svg?color=ORANGE&style=for-the-badge)](https://choosealicense.com/licenses/mit)
[![Build Status](https://img.shields.io/jenkins/build?jobUrl=http%3A%2F%2Fjenkins.devsrsouza.com.br%2Fjob%2FKotlinBukkitAPI%2F&style=for-the-badge)](http://jenkins.devsrsouza.com.br/job/KotlinBukkitAPI/)KotlinBukkitAPI is an API for Bukkit/SpigotAPI using the cool and nifty features Kotlin has to make your life more easier.
* Need help? contact me on [Twitter](https://twitter.com/DevSrSouza) or join the [Discord](https://discord.gg/HhucBqk)
## ANNOUNCEMENT
**Developer returns to the project! You can find a lot more information at [Discord](https://discord.gg/HhucBqk), join and chat with me!**
### Contents:
* [Documentation](https://github.com/DevSrSouza/KotlinBukkitAPI/wiki/)
* [Issue reporting](https://github.com/DevSrSouza/KotlinBukkitAPI/issues)
* [Dev builds (download)](http://jenkins.devsrsouza.com.br/job/KotlinBukkitAPI/)
* [Starter project](https://github.com/KotlinMinecraft/KBAPI-StarterProject/)
* [Setup for development](https://github.com/DevSrSouza/KotlinBukkitAPI/wiki/Getting-Started)
* [Example plugins](https://github.com/KotlinMinecraft)# Samples
## [We have more Samples in the Documentation](https://github.com/DevSrSouza/KotlinBukkitAPI/wiki/)
KotlinBukkitAPI goes beyond this samples, and you can find all of it in the [wiki/documentation](https://github.com/DevSrSouza/KotlinBukkitAPI/wiki/).
Event DSL sample
```kotlin
plugin.events {
event {
player.msg("&3Welcome ${player.name}".translateColor())
}
event {
broadcast("&eThe player &c${player.name} &eleft :(".translateColor())
}
}
```Simple Command DSL example
```kotlin
plugin.simpleCommand("twitter") {
sender.msg("&eFollow me on Twitter :D &ahttps://twitter.com/DevSrSouza".translateColor())
}
```Item meta DSL and other stuff
```kotlin
val gem = item(Material.DIAMOND).apply {
amount = 5
meta {
displayName = "&bGem".translateColor()
}
}
val encbook = item(Material.ENCHANTED_BOOK).meta {
displayName = "&4&lThe powerful BOOK".translateColor()
addStoredEnchant(Enchantment.DAMAGE_ALL, 10, true) // putting sharpness 10 to the book
}
```Another approach:
```
val gem = item(Material.DIAMOND, amount = 5).displayName("&bGem".translateColor())val encbook = metadataItem(Material.ENCHANTED_BOOK) {
displayName = "&4&lThe powerful BOOK".translateColor()
addStoredEnchant(Enchantment.DAMAGE_ALL, 10, true) // putting sharpness 10 to the book
}
```Menu creator DSL
```kotlin
val myMenu = menu(+"&cWarps", 3, true) {val arenaPvP = item(Material.DIAMOND_SWORD) {
addEnchant(Enchantment.DAMAGE_ALL, 5, true)
displayName = "&4Arena PvP".translateColor()
}slot(2, 4, arenaPvP) { // Line, Slot
onClick {
player.teleport(Location(player.world, 250, 70, -355))
close() // close the menu
}
}slot(2, 6, item(Material.GOLD).displayName("&6Shop".translateColor())) {
onClick {
player.teleport(Location(player.world, 2399, 70, -1234))
close() // close the menu
}
}// when the menu renders to a player, will show the Paper item with their name.
slot(3, 9, item(Material.PAPER).displayName("Hello {player}")) {
onRender {
showingItem?.meta {
displayName = displayName.replace("{player}", player.name)
}
}
}
}// open to player
myMenu.openToPlayer(player)
```You can find more examples in the [Documentation](https://github.com/DevSrSouza/KotlinBukkitAPI/wiki/)
# Project
## Modules
![](.github/images/module-graph.svg)
| Module | Description |
|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Architecture | KotlinPlugin and Lifecycle aware APIs, inspired in Android Lifecycle Components |
| Extensions | Extensions for bunch of Bukkit types like block, player, inventory, text, permissions, etc |
| Utility | Utility types and APIs for Kotlin and Bukkit development, for example, ExpiratioList, OnlinePlayerCollections, Kotlin Duration tick support. |
| Coroutines | Adds Kotlin Coroutines Dispatcher for Bukkit Scheduler API as well as adding Flow APIs and Structured Concurrency (CoroutineScope bounded to Lifecycle of the plugin or Manager class). |
| Exposed | Extensions for SQL framework [Exposed](https://github.com/JetBrains/Exposed/) |
| Serialization | Extensions for [Kotlinx.serialization](https://github.com/Kotlin/kotlinx.serialization) |
| Menu | DSL to create Menus easy and support for Preview in IntelliJ by using the [Plugin](https://github.com/DevSrSouza/KotlinBukkitAPI-Tooling#menu-preview) |
| Command Legacy | DSL to create Commands and Sub Commands with Parameter type safe, auto registering and support for Coroutines |
| Scoreboard Legacy | DSL to create Scoreboard with support for handling updates easily |## Consider donate
![logo](logo.png)