diff --git a/dd.html b/dd.html new file mode 100644 index 0000000..00c18f1 --- /dev/null +++ b/dd.html @@ -0,0 +1 @@ +sdfsdfsdfsdfsdfff \ No newline at end of file diff --git a/src/autoload.php b/src/autoload.php index 6a2c473..005c0ef 100644 --- a/src/autoload.php +++ b/src/autoload.php @@ -1,5 +1,6 @@ $value) + if(substr($name, 0, 5) == 'HTTP_') + $headers[str_replace(' ', '-', ucwords(strtolower(str_replace('_', ' ', substr($name, 5)))))] = $value; + + return $headers; + } +} +?> \ No newline at end of file diff --git a/src/initialize.php b/src/initialize.php deleted file mode 100644 index b39472f..0000000 --- a/src/initialize.php +++ /dev/null @@ -1,8 +0,0 @@ - \ No newline at end of file diff --git a/src/main.php b/src/main.php index 596e2fb..11c2255 100644 --- a/src/main.php +++ b/src/main.php @@ -3,8 +3,11 @@ class Main { + private $outputBuffer = []; + function __construct($path) { + $this->startTime = microtime(true); $this->templateEngine = new \Tale\Jade\Renderer(); $path = rtrim($path, '/') . '/'; @@ -13,6 +16,12 @@ function __construct($path) $this->initialize() ->compileSass() ->compileCoffee(); + + if(is_array(getallheaders())) + $this->isPJAX = array_key_exists(strtolower($this->pjaxHeader), getallheaders()) ? getallheaders()[strtolower($this->pjaxHeader)] + : false; + else + $this->isPJAX = false; } @@ -27,7 +36,7 @@ function __construct($path) * @return Main */ - function setSetting($name, $value) + public function setSetting($name, $value) { switch($name) { @@ -45,6 +54,8 @@ function setSetting($name, $value) case 'sasscPath' : $this->sasscPath = $value; break; case 'coffeeExtension': $this->coffeeExtension = $value; break; case 'sassExtension' : $this->sassExtension = $value; break; + case 'pjaxHeader' : $this->pjaxHeader = $value; break; + case 'titleVariable' : $this->titleVariable = $value; break; } return $this; @@ -59,7 +70,7 @@ function setSetting($name, $value) * @return Main */ - function initialize() + private function initialize() { $this->setSetting('compiled' , $this->mainPath . 'compiled/') ->setSetting('script' , $this->mainPath . 'scripts/') @@ -70,7 +81,9 @@ function initialize() ->setSetting('config' , $this->mainPath . 'config.yml') ->setSetting('coffeeExtension', '.coffee') ->setSetting('sassExtension' , '.sass') - ->setSetting('extension' , '.jade'); + ->setSetting('extension' , '.jade') + ->setSetting('titleVariable' , 'title') + ->setSetting('pjaxHeader' , 'HTTP_X_PJAX'); /** Load the configures and store to the variable */ $this->config = yaml_parse(file_get_contents($this->configPath)); @@ -105,6 +118,12 @@ function initialize() + //*********************************************** + //*********************************************** + //*************** C O M P I L E R *************** + //*********************************************** + //*********************************************** + /** * Compile the coffees. * @@ -128,7 +147,6 @@ public function compileCoffee() $this->scriptPath, $this->coffeeExtension, $this->compiledPath); - return $this; } @@ -164,13 +182,181 @@ public function compileSass() $this->sassExtension, $this->sasscPath, $this->compiledPath); + return $this; + } + + + + + //*********************************************** + //*********************************************** + //**************** C A P T U R E **************** + //*********************************************** + //*********************************************** + + /** + * Capture the rendered content after this function. + * + * @param bool $force Force capture. + * + * @return Main + */ + + public function capture($force = false) + { + if(!$this->isPJAX && !$force) + return $this; + + ob_start(); + + return $this; + } + + + + + /** + * Stop capturing, and store the captured content to the specified array. + * + * @param string $position The place to store the captured content. + * + * @return Main + */ + + public function endCapture($position = null) + { + if(!$this->isPJAX && $position) + return $this; + + switch($position) + { + case 'header': + $this->outputBuffer['header'] = ob_get_clean(); + break; + case 'content': + $this->outputBuffer['content'] = ob_get_clean(); + break; + case 'footer': + $this->outputBuffer['footer'] = ob_get_clean(); + break; + case null: + return ob_get_clean(); + break; + } + + return $this; + } + + + + + //*********************************************** + //*********************************************** + //****************** P J A X ******************** + //*********************************************** + //*********************************************** + + /** + * + */ + + public function header($templateFile, $variables = null) + { + /** Set the json header if it's a PJAX request */ + if($this->isPJAX) + header('Content-Type: application/json; charset=utf-8'); + + /** Set the title */ + $this->title = isset($variables[$this->titleVariable]) ? $variables[$this->titleVariable] + : null; + /** Capture the rendered content from now on */ + $this->capture() + /** Load the header and require it */ + ->render($templateFile, $variables) + /** Stop capturing, and store the captured content to the output buffer array */ + ->endCapture('header') + /** Start another capture action for the content part */ + ->capture(); + + return $this; + } + + /** + * + * + */ + + public function footer($templateFile, $variables = null) + { + /** Stop capturing, what we got here is a content-only part, store it either */ + $this->endCapture('content') + /** Now capture the footer part */ + ->capture() + /** Require the footer template */ + ->render($templateFile, $variables) + /** And stop capturing, you know what's next right? */ + ->endCapture('footer'); + + $this->endTime = microtime(true); + $this->totalTime = $this->endTime - $this->startTime; + + /** Return the rendered content if it's a PJAX request */ + if($this->isPJAX) + echo json_encode($this->returnPJAX()); + return $this; } + /** + * Combine the different informations based on the PJAX header content. + * + * @return array The datas. + */ + + function returnPJAX() + { + if(!$this->isPJAX) + return false; + + $types = explode(', ', $this->isPJAX); + $data = []; + + if(strpos($this->isPJAX, 'title') !== false) + $data['title'] = $this->title; + + if(strpos($this->isPJAX, 'html') !== false) + $data['html'] = $this->outputBuffer['header'] . + $this->outputBuffer['content'] . + $this->outputBuffer['footer']; + + if(strpos($this->isPJAX, 'header') !== false) + $data['header'] = $this->outputBuffer['header']; + + if(strpos($this->isPJAX, 'content') !== false) + $data['content'] = $this->outputBuffer['content']; + + if(strpos($this->isPJAX, 'footer') !== false) + $data['footer'] = $this->outputBuffer['footer']; + + if(strpos($this->isPJAX, 'wasted') !== false) + $data['wasted'] = $this->totalTime; + + return $data; + } + + + + + //*********************************************** + //*********************************************** + //****************** B A S I C ****************** + //*********************************************** + //*********************************************** + /** * Render the template files and output. * @@ -207,6 +393,12 @@ public function fetch($templateFile, $variables = null) + //*********************************************** + //*********************************************** + //**************** H E L P E R S **************** + //*********************************************** + //*********************************************** + /** * Get the path of the shortname, * returns the original path if there's no shortname for the path. diff --git a/test/cache/views/default/tpls/test.phtml b/test/cache/views/default/tpls/test.phtml deleted file mode 100644 index 0a2d951..0000000 --- a/test/cache/views/default/tpls/test.phtml +++ /dev/null @@ -1 +0,0 @@ -
\ No newline at end of file diff --git a/test/cache/views/home/ubuntu/workspace/test/default/tpls/test.phtml b/test/cache/views/home/ubuntu/workspace/test/default/tpls/test.phtml index 2ba6cf7..1fa74bc 100644 --- a/test/cache/views/home/ubuntu/workspace/test/default/tpls/test.phtml +++ b/test/cache/views/home/ubuntu/workspace/test/default/tpls/test.phtml @@ -1 +1 @@ -