diff --git a/src/Compiler/ComponentTagCompiler.php b/src/Compiler/ComponentTagCompiler.php index 4cf62f2..97e3c14 100644 --- a/src/Compiler/ComponentTagCompiler.php +++ b/src/Compiler/ComponentTagCompiler.php @@ -83,7 +83,13 @@ function (array $matches) { protected function componentStartString(string $component, string $attributes): string { - return "{% embed \"@" . $this->twigPathAlias . "/" . lcfirst($component) . ".twig\" with { props: $attributes } %}"; + return sprintf( + // another `%` is used for escaping the `%`, e. g. `%%` -> `%` + "{%% embed \"@%s/%s.twig\" with { props: %s } %%}", + $this->twigPathAlias, + $this->normalizeComponentPathName($component), + $attributes + ); } /** @@ -146,6 +152,13 @@ function (array $matches) { ); } + private function normalizeComponentPathName(string $name): string + { + return preg_replace_callback('/^[A-Z]+_?/', function ($matches) { + return strtolower($matches[0]); + }, $name) ?: $name; + } + private function valueParser(?string $value, string $attribute): string { if ($value === null) { diff --git a/tests/Compiler/ComponentTagCompilerTest.php b/tests/Compiler/ComponentTagCompilerTest.php index 346e459..bb86fa3 100644 --- a/tests/Compiler/ComponentTagCompilerTest.php +++ b/tests/Compiler/ComponentTagCompilerTest.php @@ -15,6 +15,13 @@ public function testShouldCompile(): void $this->assertSame('{% embed "@alias/alert.twig" with { props: {\'color\': "primary"} } %}{% endembed %}', $compiler->compile()); } + public function testShouldCompileUnstable(): void + { + $compiler = new ComponentTagCompiler('', 'alias'); + + $this->assertSame('{% embed "@alias/unstable_Alert.twig" with { props: {\'color\': "primary"} } %}{% endembed %}', $compiler->compile()); + } + public function testShouldCompileClosingTag(): void { $compiler = new ComponentTagCompiler('test', 'alias');