8 Commits
1.0 ... 2.1

Author SHA1 Message Date
User
cf3a11cb62 20231008#3 2023-10-08 20:06:59 +03:00
User
7b3228d14e 20231008#2 2023-10-08 19:12:28 +03:00
User
5b967d6439 20231008#1 2023-10-08 18:57:09 +03:00
User
37d3884205 20231007#3 2023-10-07 17:55:16 +03:00
User
93246556e0 20231007#2 2023-10-07 16:52:39 +03:00
User
1f77fe9ee9 20230926#3 2023-09-26 21:31:56 +03:00
User
eaa314786c 20230626#2 2023-06-26 20:12:23 +03:00
User
c9913b99a4 20230626#1 2023-06-26 19:58:03 +03:00
3 changed files with 28 additions and 55 deletions

View File

@@ -10,12 +10,12 @@ Stable version
composer require rmphp/content
```
```bash
composer require rmphp/content:"^1.0"
composer require rmphp/content:"^2.0"
```
Dev version contains the latest changes
```bash
composer require rmphp/content:"1.0.x-dev"
composer require rmphp/content:"2.x-dev"
```

View File

@@ -2,18 +2,12 @@
namespace Rmphp\Content;
use Rmphp\Foundation\Exceptions\AppError;
use Rmphp\Foundation\Exceptions\AppException;
use Rmphp\Foundation\TemplateInterface;
class Content implements TemplateInterface {
private array $content = [];
private ContentData $data;
private ContentData $dataGlobal;
private string $basePath = "";
private string $template;
private string $subtemplatePath;
/**
* Content constructor.
* @param string $template
@@ -28,12 +22,11 @@ class Content implements TemplateInterface {
* @return TemplateInterface
*/
public function setTemplate(string $template, array $resource = []) : TemplateInterface {
if(empty($this->data)) $this->data = new ContentData();
foreach ($resource as $resKey => $resVal){
$this->data->{$resKey} = $resVal;
$this->{$resKey} = $resVal;
}
$this->basePath = dirname(__DIR__, 4);
$this->template = $this->basePath.'/'.$template;
ContentData::$basePath = dirname(__DIR__, 4);
ContentData::$template = ContentData::$basePath.'/'.$template;
return $this;
}
@@ -42,7 +35,7 @@ class Content implements TemplateInterface {
* @return TemplateInterface
*/
public function setSubtemplePath(string $subtemplatePath) : TemplateInterface {
$this->subtemplatePath = $this->basePath.'/'.$subtemplatePath;
ContentData::$subtemplatePath = ContentData::$basePath.'/'.$subtemplatePath;
return $this;
}
@@ -50,10 +43,9 @@ class Content implements TemplateInterface {
* @return string
*/
public function getSubtemplePath(): string {
return $this->subtemplatePath;
return ContentData::$subtemplatePath;
}
/**
* @param string $point
* @param string $string
@@ -61,8 +53,8 @@ class Content implements TemplateInterface {
*/
public function addValue(string $point, string $string) : void {
if (empty($point)) throw new AppException("Empty point");
if (empty($this->subtemplatePath))throw new AppException("SubtemplatePath is not defined");
$this->content[$point][] = $string;
if (empty(ContentData::$subtemplatePath))throw new AppException("SubtemplatePath is not defined");
ContentData::$content[$point][] = $string;
}
/**
@@ -71,7 +63,7 @@ class Content implements TemplateInterface {
* @throws AppException
*/
public function setValue(string $point, string $string) : void {
unset($this->content[$point]);
unset(ContentData::$content[$point]);
$this->addValue($point, $string);
}
@@ -82,14 +74,13 @@ class Content implements TemplateInterface {
* @throws AppException
*/
public function addSubtemple(string $point, string $subTempl, array $resource = []) : void {
if (empty($this->subtemplatePath))throw new AppException("SubtemplatePath is not defined");
if (empty(ContentData::$subtemplatePath))throw new AppException("SubtemplatePath is not defined");
if (empty($point)) throw new AppException("Empty point");
if (empty($subTempl) || !file_exists($this->subtemplatePath."/".$subTempl)) throw new AppException($this->subtemplatePath."/".$subTempl. " is not found");
if(empty($this->data)) $this->data = new ContentData();
if (empty($subTempl) || !file_exists(ContentData::$subtemplatePath."/".$subTempl)) throw new AppException(ContentData::$subtemplatePath."/".$subTempl. " is not found");
foreach ($resource as $resKey => $resVal){
$this->data->{$resKey} = $resVal;
$this->{$resKey} = $resVal;
}
ob_start(); include $this->subtemplatePath."/".$subTempl; $this->content[$point][] = ob_get_contents(); ob_end_clean();
ob_start(); include ContentData::$subtemplatePath."/".$subTempl; ContentData::$content[$point][] = ob_get_contents(); ob_end_clean();
}
/**
@@ -99,20 +90,10 @@ class Content implements TemplateInterface {
* @throws AppException
*/
public function setSubtemple(string $point, string $subTempl, array $resource = []) : void {
unset($this->content[$point]);
unset(ContentData::$content[$point]);
$this->addSubtemple($point, $subTempl, $resource);
}
/**
* @param array $globals
*/
public function setGlobals(array $globals = []) : void {
$this->dataGlobal = new ContentData();
foreach ($globals as $resKey => $resVal){
$this->dataGlobal->{$resKey} = $resVal;
}
}
/**
* @param string $incFile
* @param array $resource
@@ -120,12 +101,11 @@ class Content implements TemplateInterface {
* @throws AppException
*/
public function inc(string $incFile, array $resource = []) : string {
if(empty($this->data)) $this->data = new ContentData();
foreach ($resource as $resKey => $resVal){
$this->data->{$resKey} = $resVal;
$this->{$resKey} = $resVal;
}
if(empty($incFile) || !file_exists($this->subtemplatePath."/".$incFile)) throw new AppException("Empty inc file");
ob_start(); include $this->subtemplatePath."/".$incFile; $out = ob_get_contents(); ob_end_clean();
if(empty($incFile) || !file_exists(ContentData::$subtemplatePath."/".$incFile)) throw new AppException("Empty inc file");
ob_start(); include ContentData::$subtemplatePath."/".$incFile; $out = ob_get_contents(); ob_end_clean();
return $out;
}
@@ -134,16 +114,17 @@ class Content implements TemplateInterface {
* @return string
*/
public function getPoint(string $point) : string {
if (empty($point) || empty($this->content[$point])) return "";
return implode("", $this->content[$point]);
if (empty($point) || empty(ContentData::$content[$point])) return "";
return implode("", ContentData::$content[$point]);
}
/**
* @return string
* @throws AppException
*/
public function getResponse(): string {
if (empty($this->template) || !file_exists($this->template)) return '';
ob_start(); include $this->template; $out = ob_get_contents(); ob_end_clean();
if (empty(ContentData::$template) || !file_exists(ContentData::$template)) throw new AppError("Invalid template file");
ob_start(); include ContentData::$template; $out = ob_get_contents(); ob_end_clean();
return $out;
}
}

View File

@@ -5,17 +5,9 @@ namespace Rmphp\Content;
class ContentData {
private array $data;
public static string $basePath = "";
public static string $template;
public static string $subtemplatePath;
public static array $content = [];
public function __set($name, $value) {
$this->data[$name] = $value;
}
public function __isset($name) {
return isset($this->data[$name]);
}
public function __get($name) {
return $this->data[$name] ?? null;
}
}