Private constructorReadonly typeThe BlockType that the permutation has.
The type of liquid this function should be called for.
Whether this block is removed when touched by liquid.
Returns whether this block is removed when touched by liquid.
This function can throw errors.
Error
The type of liquid this function should be called for.
Whether this block can have a liquid placed over it.
Returns whether this block can have a liquid placed over it, i.e. be waterlogged.
This function can throw errors.
Error
Optional amount: numberNumber of instances of this block to place in the prototype item stack.
Retrieves a prototype item stack based on this block permutation that can be used with item Container/ContainerSlot APIs.
Name of the block state who's value is to be returned.
Returns the state if the permutation has it, else
undefined.
Gets a state for the permutation.
Returns true if the permutation has the tag, else false.
Checks to see if the permutation has a specific tag.
checkBlockTags.ts
import { DimensionLocation } from "@minecraft/server";
function checkBlockTags(log: (message: string, status?: number) => void, targetLocation: DimensionLocation) {
  // Fetch the block
  const block = targetLocation.dimension.getBlock(targetLocation);
  // check that the block is loaded
  if (block) {
    log(`Block is dirt: ${block.hasTag("dirt")}`);
    log(`Block is wood: ${block.hasTag("wood")}`);
    log(`Block is stone: ${block.hasTag("stone")}`);
  }
}
The type of liquid this function should be called for.
Whether this block stops liquid from flowing.
Returns whether this block stops liquid from flowing.
This function can throw errors.
Error
The type of liquid this function should be called for.
Whether this block is removed and spawns its item when touched by liquid.
Returns whether this block is removed and spawns its item when touched by liquid.
This function can throw errors.
Error
An optional set of states to compare against.
Optional states: BlockStateArg<T>Returns a boolean whether a specified permutation matches this permutation. If states is not specified, matches checks against the set of types more broadly.
Identifier of the block property.
Value of the block property.
Returns a derived BlockPermutation with a specific property set.
This function can throw errors.
Static resolveIdentifier of the block to check.
Optional states: BlockStateArg<T>Given a type identifier and an optional set of properties, will return a BlockPermutation object that is usable in other block APIs (e.g., block.setPermutation)
This function can throw errors.
addBlockColorCube.ts
import { BlockPermutation, DimensionLocation } from "@minecraft/server";
import { Vector3Utils } from "@minecraft/math";
import { MinecraftBlockTypes } from "@minecraft/vanilla-data";
function addBlockColorCube(targetLocation: DimensionLocation) {
  const allWoolBlocks: string[] = [
    MinecraftBlockTypes.WhiteWool,
    MinecraftBlockTypes.OrangeWool,
    MinecraftBlockTypes.MagentaWool,
    MinecraftBlockTypes.LightBlueWool,
    MinecraftBlockTypes.YellowWool,
    MinecraftBlockTypes.LimeWool,
    MinecraftBlockTypes.PinkWool,
    MinecraftBlockTypes.GrayWool,
    MinecraftBlockTypes.LightGrayWool,
    MinecraftBlockTypes.CyanWool,
    MinecraftBlockTypes.PurpleWool,
    MinecraftBlockTypes.BlueWool,
    MinecraftBlockTypes.BrownWool,
    MinecraftBlockTypes.GreenWool,
    MinecraftBlockTypes.RedWool,
    MinecraftBlockTypes.BlackWool,
  ];
  const cubeDim = 7;
  let colorIndex = 0;
  for (let x = 0; x <= cubeDim; x++) {
    for (let y = 0; y <= cubeDim; y++) {
      for (let z = 0; z <= cubeDim; z++) {
        colorIndex++;
        targetLocation.dimension
          .getBlock(Vector3Utils.add(targetLocation, { x, y, z }))
          ?.setPermutation(BlockPermutation.resolve(allWoolBlocks[colorIndex % allWoolBlocks.length]));
      }
    }
  }
}
Contains the combination of type BlockType and properties (also sometimes called block state) which describe a block (but does not belong to a specific Block).
Example
addTranslatedSign.ts