Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Update block description #262

Merged
merged 1 commit into from
Apr 1, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
98 changes: 36 additions & 62 deletions source/behavior/blocks/format/minecraft.block.json
Original file line number Diff line number Diff line change
Expand Up @@ -44,14 +44,30 @@
"minecraft:random_ticking": { "$ref": "./triggers/random_ticking.json" }
}
},
"traits_ref": {
"states_ref": {
"title": "States",
"description": "Block states are variables that can be set to different values in order to change how your block looks or behaves.",
"type": "object",
"title": "Trait",
"propertyNames": { "pattern": "^([a-zA-Z0-9_]+:[a-zA-Z0-9_\\-]+)$" },
"additionalProperties": {
"title": "State",
"description": "The key defines the name of a state, which must be properly namespaced. Each value is an array that contains all of the possible values of that state or an object defining a range of integers.",
"oneOf": [
// "my:state": [false, true]
{ "$ref": "./states/enum.json" },
// "my:state": { "values": { "min": 0, "max": 15 } }
{ "$ref": "./states/integer_range.json" }
]
}
},
"traits_ref": {
"title": "Traits",
"description": "A shortcut for creators to use Vanilla block states without needing to define and manage a series of events or triggers on custom blocks",
"type": "object",
"additionalProperties": false,
"properties": {
"minecraft:placement_position": { "$ref": "./traits/placement_position.json" },
"minecraft:placement_direction": { "$ref": "./traits/placement_direction.json" }
"minecraft:placement_direction": { "$ref": "./traits/placement_direction.json" },
"minecraft:placement_position": { "$ref": "./traits/placement_position.json" }
}
}
},
Expand All @@ -63,12 +79,17 @@
"additionalProperties": false,
"required": ["identifier"],
"properties": {
"identifier": {
"title": "Identifier",
"description": "The identifier for this block. The name must include a namespace and must not use the Minecraft namespace unless overriding a Vanilla block.",
"type": "string",
"$ref": "../../../general/block/identifier.json"
},
"menu_category": {
"title": "Menu Category",
"$comment": "UNDOCUMENTED",
"description": "The category this block will be placed in the menu.",
"description": "Specifies the menu category and group for the block, which determine where this block is placed in the inventory and crafting table container screens. If this field is omitted, the block will not appear in the inventory or crafting table container screens.",
"type": "object",
"default": "misc",
"examples": [{ "category": "construction" }],
"additionalProperties": false,
"required": ["category"],
"properties": {
Expand All @@ -80,65 +101,18 @@
},
"is_hidden_in_commands": {
"title": "Is Hidden In Commands",
"$comment": "UNDOCUMENTED",
"description": "If true, this item will not be shown in the /give command autocomplete list.",
"type": "boolean"
"description": "Determines whether or not this item can be used with commands such as /give and /setblock. Commands can use blocks by default",
"type": "boolean",
"default": false
}
}
},
"identifier": {
"type": "string",
"description": "The identifier for this block. The name must include a namespace and must not use the Minecraft namespace unless overriding a Vanilla block.",
"title": "Identifier",
"$ref": "../../../general/block/identifier.json"
},
"is_experimental": {
"type": "boolean",
"default": false,
"description": "If this block is experimental, it will only be registered if the world is marked as experimantal.",
"title": "Is Experimental"
},
"register_to_creative_menu": {
"type": "boolean",
"default": false,
"description": "Whether or not to register this block to the creative inventory menu.",
"title": "Register To Creative Menu"
},
"states": {
"title": "States",
"description": "[HOLIDAY EXPERIMENTAL] UNDOCUMENTED.",
"$comment": "UNDOCUMENTED",
"propertyNames": { "pattern": "^([a-zA-Z0-9_]+:[a-zA-Z0-9_\\-]+)$" },
"type": "object",
"additionalProperties": {
"title": "State",
"description": "A block property. The name should be specified as `<namespace>:<block property>`",
"oneOf": [
{
"type": "array",
"items": {
"title": "Property Value",
"description": "The value of this property.",
"anyOf": [{ "type": "boolean" }, { "type": "number" }, { "type": "integer" }, { "type": "string" }]
}
},
{ "type": "object" }
]
}
},
"traits": {
"type": "object",
"title": "Trait",
"$ref": "#/definitions/traits_ref"
}
"states": { "$ref": "#/definitions/states_ref" },
"traits": { "$ref": "#/definitions/traits_ref" }
}
},
"events": { "$ref": "./events.json" },
"components": {
"type": "object",
"title": "Component",
"$ref": "#/definitions/components_ref"
},
"components": { "$ref": "#/definitions/components_ref" },
"permutations": {
"type": "array",
"title": "Permutations",
Expand All @@ -153,8 +127,8 @@
"properties": {
"condition": {
"title": "Condition",
"description": "A Molang expression that evaluates to true or false to determine if this permutation should be used. For permutation conditions you are limited to using one Molang query: \"query.block_property()\"",
"$ref": "../../../molang/string.json"
"description": "A Molang expression that evaluates to true or false to determine if this permutation should be used. For permutation conditions you are limited to using one Molang query: \"query.block_state()\"",
"$ref": "../../../molang/boolean.json"
},
"components": {
"type": "object",
Expand Down
30 changes: 30 additions & 0 deletions source/behavior/blocks/format/states/enum.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,30 @@
{
"$id": "blockception.minecraft.behavior.block.states.enum",
"type": "array",
"minItems": 1,
"maxItems": 16,
"uniqueItems": true,
"items": {
"description": "A valid value of this state. All valid values must be of the same type (boolean, integer or string)."
},
"oneOf": [
{
"items": {
"title": "Boolean State Value",
"type": "boolean"
}
},
{
"items": {
"title": "Integer State Value",
"type": "integer"
}
},
{
"items": {
"title": "String State Value",
"type": "string"
}
}
]
}
28 changes: 28 additions & 0 deletions source/behavior/blocks/format/states/integer_range.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,28 @@
{
"$id": "blockception.minecraft.behavior.block.states.integer_range",
"type": "object",
"required": ["values"],
"additionalProperties": false,
"properties": {
"values": {
"title": "State Integer Value Range",
"type": "object",
"required": ["min", "max"],
"additionalProperties": false,
"properties": {
"min": {
"title": "Minimum",
"description": "The lowest integer this state supports. This is also used as the default state value.",
"type": "integer",
"default": 0
},
"max": {
"title": "Maximum",
"description": "The highest integer this state supports. This cannot be more than 15 above the minimum.",
"type": "integer",
"default": 15
}
}
}
}
}
Loading