Skip to content

Commit

Permalink
Update block description (#262)
Browse files Browse the repository at this point in the history
  • Loading branch information
QuazChick authored Apr 1, 2024
1 parent 096ddac commit b1db14d
Show file tree
Hide file tree
Showing 3 changed files with 94 additions and 62 deletions.
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
}
}
}
}
}

0 comments on commit b1db14d

Please sign in to comment.