From bb8743ae8f306c3099c78ce1e018d227df3935d0 Mon Sep 17 00:00:00 2001 From: elaps Date: Mon, 8 Jul 2024 15:09:29 +0500 Subject: [PATCH] basic x-component support --- lib/BladeOne.php | 60 ++++++++++++++++++++++++++++++++++++++++++++---- 1 file changed, 55 insertions(+), 5 deletions(-) diff --git a/lib/BladeOne.php b/lib/BladeOne.php index bd57139..98bf1ea 100644 --- a/lib/BladeOne.php +++ b/lib/BladeOne.php @@ -139,6 +139,7 @@ class BladeOne /** @var array All the available compiler functions. */ protected array $compilers = [ 'Extensions', + 'Components', 'Statements', 'Comments', 'Echos', @@ -2894,6 +2895,55 @@ protected function getEchoMethods(): array }); return $methods; } + /** + * Compile Blade components that start with "x-". + * + * @param string $value + * + * @return array|string|string[]|null + */ + protected function compileComponents($value) + { + /** + * @param array $match + * [0]=full expression with @ and parenthesis + * [1]=Component name + * [2]=parameters + * [3]=... + * [4]=content + * + * @return mixed|string + */ + + $callback = function($match) { + + if(static::contains($match[0], 'x-')) { + $match[4] = $this->compileComponents( $match[4]); + } + $paramsCompiled = $this->parseParams($match[2]); + $str = "('components.".$match[1]."',".$paramsCompiled.")"; + + return self::compileComponent($str).$match[4].self::compileEndComponent(); + }; + return preg_replace_callback('/]*)?(>((?:(?!<\/x-\1>).)*)<\/x-\1>|\/>)/ms', $callback, $value); + + } + + protected function parseParams($params) { + preg_match_all('/([a-z-0-9:]*?)\s*?=\s*?(.+?)(\s|$)/ms', $params, $matches); + $paramsCompiled = []; + foreach ($matches[1] as $i => $key) { + $value = str_replace('"','',$matches[2][$i]); + //its php code + if(self::startsWith($key, ':')) { + $key = substr($key, 1); + $paramsCompiled[] = '"'.$key. '"' . '=>' . $value; + continue; + } + $paramsCompiled[] = '"'.$key. '"' . '=>' .'"'. $value. '"'; + } + return '['.implode(',',$paramsCompiled).']'; + } /** * Compile Blade statements that start with "@". @@ -4191,12 +4241,12 @@ protected function runtimeStyle($expression=null,$separator=' '): string * @param string $expression * @return string */ - protected function compileSelected($expression): string - { - return $this->phpTag . "if$expression echo 'selected'; ?>"; - } + protected function compileSelected($expression): string + { + return $this->phpTag . "if$expression echo 'selected'; ?>"; + } - /** + /** * Compile the disabled statements into valid PHP. * * @param string $expression