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');