Getting Started
Formatting Blade
Parsing Templates
Blade Documents
Compilation
Validation
Workspaces
The default behavior of the compiler is to treat all custom component tags as if they were "normal" Blade component tags. However, we can provide custom compilers for our specific component tag prefixes and return custom-compiled output.
We create custom component tag compilers by implementing the Stillat\BladeParser\Contracts\CustomComponentTagCompiler
interface. Each custom compiler implementation must implement the following method:
1<?php2 3public function compile(ComponentNode $component): ?string;
This method's return type can be a string
, which should contain the custom compiled output. If the method returns null
, the default component tag compiler will be utilized. If you wish to return no output, return an empty string.
The following example implements a custom component tag compiler. In addition, it disables the compilation of core components:
1<?php 2 3use Stillat\BladeParser\Contracts\CustomComponentTagCompiler; 4use Stillat\BladeParser\Document\Document; 5use Stillat\BladeParser\Document\DocumentCompilerOptions; 6use Stillat\BladeParser\Nodes\Components\ComponentNode; 7 8 9class CustomCompiler implements CustomComponentTagCompiler10{11 public function compile(ComponentNode $component): ?string12 {13 return 'My custom compilation result!';14 }15}16 17$template = <<<'BLADE'18<a-custom />19<x-profile />20BLADE;21 22$doc = Document::fromText(23 $template,24 customComponentTags: ['a']25);26 27$result = $doc->compile(new DocumentCompilerOptions(28 customTagCompilers: ['a' => new CustomCompiler],29 compileCoreComponentTags: false30));
Custom Component Names
You may have noticed that we supplied our custom component prefix to both our call to Document::fromText
, and have specified it again as part of our DocumentCompilerOptions
. This is because parsing and compilation are two distinct steps, and compilation of a Document
instance is always optional.
Our example would produce the following results:
1My custom compilation result!2<x-profile />