phpOMS/DataStorage/Web/Builder.php

104 lines
2.4 KiB
PHP

<?php
/**
* Orange Management
*
* PHP Version 7.2
*
* @package phpOMS\DataStorage\Web
* @copyright Dennis Eichhorn
* @license OMS License 1.0
* @version 1.0.0
* @link http://website.orange-management.de
*/
declare(strict_types=1);
namespace phpOMS\DataStorage\Web;
use phpOMs\DataStorage\Database\Query\Builder as DatabaseQueryBuilder;
use phpOMS\Localization\Localization;
use phpOMS\Message\Http\Rest;
use phpOMS\Uri\Http;
/**
* Array utils.
*
* @package phpOMS\DataStorage\Web
* @license OMS License 1.0
* @link http://website.orange-management.de
* @since 1.0.0
*/
class Builder
{
private function download($uri)
{
$finder = [];
$l11n = new Localization();
foreach ($this->from as $from) {
$doc = new \DOMDocument();
$doc->loadHTML(Rest::request($l11n, new Http($from)));
$finder[$from] = new \DomXPath($doc);
}
return $finder;
}
public function get(string $xpath)
{
$nodes = $finder->query($xpath);
}
public function execute()
{
$finder = $this->download();
$result = [];
$table = null;
foreach ($this->wheres as $column => $where) {
if ($column === 'xpath') {
$table = $this->createTable($finder->query($where['value']));
}
}
foreach ($this->columns as $column) {
}
}
private function createTable($node) : array
{
if (\strtolower($node->tagName) === 'table') {
return $this->createTableFromTable();
} elseif (\strtolower($node->tagName) === 'li') {
return $this->createTableFromList();
} else {
return $this->createTableFromContent();
}
}
private function createTableFromTable($node) : array
{
// todo: get header either thead or <th> (either first row or first column)
// todo: get rest except tfoot
// find first unique column and define as additional id (in addition to row number)
}
private function createTableFromList($node) : array
{
$table = [];
$children = $node->childNodes;
foreach ($children as $child) {
$table[] = $child->asXML();
}
return $table;
}
private function createTableFromContent($node) : array
{
return [$node->asXML()];
}
}