From e802d5204b96d645ec3d40b81b4a8bdc6e0ee675 Mon Sep 17 00:00:00 2001 From: n-peugnet Date: Mon, 4 Nov 2019 23:31:31 +0100 Subject: refactor: switch to psr-4 autoloading --- app/class/Element.php | 204 ++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 204 insertions(+) create mode 100644 app/class/Element.php (limited to 'app/class/Element.php') diff --git a/app/class/Element.php b/app/class/Element.php new file mode 100644 index 0000000..09f4e35 --- /dev/null +++ b/app/class/Element.php @@ -0,0 +1,204 @@ +hydrate($datas); + $this->analyse($pageid); + } + + public function hydrate($datas) + { + foreach ($datas as $key => $value) { + $method = 'set' . $key; + + if (method_exists($this, $method)) { + $this->$method($value); + } + } + } + + private function analyse(string $pageid) + { + if(!empty($this->options)) { + + // Replace "!" by the real page name + $this->options = str_replace('!', $pageid, $this->options); + + preg_match('~(:([a-z0-9-_+!]+))?(\/([a-z0-9-,_+=]+))?~', $this->options, $matches); + if(isset($matches[2]) && !empty($matches[2])) { + $this->sources = explode('+', $matches[2]); + } else { + $this->sources[] = $pageid; + } + if(isset($matches[4])) { + $this->params = explode(',', $matches[4]); + } + + $this->readoptions(); + + } else { + $this->sources[] = $pageid; + } + } + + private function readoptions() + { + if(!empty($this->params)) { + foreach ($this->params as $param ) { + preg_match('~([a-z0-9-_]+)(=(-?[0-9]+))?~', $param, $optionmatch); + if(isset($optionmatch[1])) { + $key = $optionmatch[1]; + } + if(isset($optionmatch[3])) { + $value = $optionmatch[3]; + } else { + $read = '

Rendering error :

Paramaters must have a value like : /' . $key . '=__value__ for parameter : ' . $key . '

'; + //throw new Exception($read); + } + $method = 'set' . $key; + if (in_array($key, self::OPTIONS)) { + if (!$this->$method($value)) { + $read = '

Rendering error :

Invalid value input : ' . $value . ' for parameter : ' . $key . '

'; + //throw new Exception($read); + + } + } else { + $read = '

Rendering error :

Parameter name : ' . $optionmatch[1] . ' does not exist

'; + //throw new Exception($read); + } + } + } + } + + public function addtags() + { + $this->content = PHP_EOL . '<' . $this->type() . '>' . PHP_EOL . $this->content() . PHP_EOL . 'type() . '>' . PHP_EOL; + } + + + + + + // __________________________________________________ G E T ____________________________________________________________ + + + public function fullmatch() + { + return $this->fullmatch; + } + + public function type() + { + return $this->type; + } + + public function options() + { + return $this->options; + } + + public function params() + { + return $this->params; + } + + public function sources() + { + return $this->sources; + } + + public function autolink() + { + return $this->autolink; + } + + public function markdown() + { + return $this->markdown; + } + + public function content() + { + return $this->content; + } + + + + + + + // __________________________________________________ S E T ____________________________________________________________ + + + public function setfullmatch(string $fullmatch) + { + $this->fullmatch = $fullmatch; + } + + public function settype(string $type) + { + $type = strtolower($type); + if(in_array($type, Model::TEXT_ELEMENTS)) { + $this->type = $type; + } + } + + public function setoptions(string $options) + { + if(!empty($options)) { + $this->options = $options; + } + } + + public function setautolink(int $level) + { + if($level >= 0 && $level <= 16) { + $this->autolink = $level; + return true; + } else { + return false; + } + } + + public function setmarkdown(int $level) + { + if($level >= 0 && $level <= 1) { + $this->markdown = $level; + return true; + } else { + return false; + } + } + + public function setcontent(string $content) + { + $this->content = $content; + } + +} + + + + +?> \ No newline at end of file -- cgit v1.2.3