mirror of
https://github.com/cytopia/devilbox.git
synced 2024-12-25 23:41:04 +00:00
111 lines
4.7 KiB
PHP
111 lines
4.7 KiB
PHP
<?php
|
|
page_header(lang('Database schema'), "", array(), h(DB . ($_GET["ns"] ? ".$_GET[ns]" : "")));
|
|
|
|
$table_pos = array();
|
|
$table_pos_js = array();
|
|
$SCHEMA = ($_GET["schema"] ? $_GET["schema"] : $_COOKIE["adminer_schema-" . str_replace(".", "_", DB)]); // $_COOKIE["adminer_schema"] was used before 3.2.0 //! ':' in table name
|
|
preg_match_all('~([^:]+):([-0-9.]+)x([-0-9.]+)(_|$)~', $SCHEMA, $matches, PREG_SET_ORDER);
|
|
foreach ($matches as $i => $match) {
|
|
$table_pos[$match[1]] = array($match[2], $match[3]);
|
|
$table_pos_js[] = "\n\t'" . js_escape($match[1]) . "': [ $match[2], $match[3] ]";
|
|
}
|
|
|
|
$top = 0;
|
|
$base_left = -1;
|
|
$schema = array(); // table => array("fields" => array(name => field), "pos" => array(top, left), "references" => array(table => array(left => array(source, target))))
|
|
$referenced = array(); // target_table => array(table => array(left => target_column))
|
|
$lefts = array(); // float => bool
|
|
foreach (table_status('', true) as $table => $table_status) {
|
|
if (is_view($table_status)) {
|
|
continue;
|
|
}
|
|
$pos = 0;
|
|
$schema[$table]["fields"] = array();
|
|
foreach (fields($table) as $name => $field) {
|
|
$pos += 1.25;
|
|
$field["pos"] = $pos;
|
|
$schema[$table]["fields"][$name] = $field;
|
|
}
|
|
$schema[$table]["pos"] = ($table_pos[$table] ? $table_pos[$table] : array($top, 0));
|
|
foreach ($adminer->foreignKeys($table) as $val) {
|
|
if (!$val["db"]) {
|
|
$left = $base_left;
|
|
if ($table_pos[$table][1] || $table_pos[$val["table"]][1]) {
|
|
$left = min(floatval($table_pos[$table][1]), floatval($table_pos[$val["table"]][1])) - 1;
|
|
} else {
|
|
$base_left -= .1;
|
|
}
|
|
while ($lefts[(string) $left]) {
|
|
// find free $left
|
|
$left -= .0001;
|
|
}
|
|
$schema[$table]["references"][$val["table"]][(string) $left] = array($val["source"], $val["target"]);
|
|
$referenced[$val["table"]][$table][(string) $left] = $val["target"];
|
|
$lefts[(string) $left] = true;
|
|
}
|
|
}
|
|
$top = max($top, $schema[$table]["pos"][0] + 2.5 + $pos);
|
|
}
|
|
|
|
?>
|
|
<div id="schema" style="height: <?php echo $top; ?>em;" onselectstart="return false;">
|
|
<script type="text/javascript">
|
|
var tablePos = {<?php echo implode(",", $table_pos_js) . "\n"; ?>};
|
|
var em = document.getElementById('schema').offsetHeight / <?php echo $top; ?>;
|
|
document.onmousemove = schemaMousemove;
|
|
document.onmouseup = function (ev) {
|
|
schemaMouseup(ev, '<?php echo js_escape(DB); ?>');
|
|
};
|
|
</script>
|
|
<?php
|
|
foreach ($schema as $name => $table) {
|
|
echo "<div class='table' style='top: " . $table["pos"][0] . "em; left: " . $table["pos"][1] . "em;' onmousedown='schemaMousedown(this, event);'>";
|
|
echo '<a href="' . h(ME) . 'table=' . urlencode($name) . '"><b>' . h($name) . "</b></a>";
|
|
|
|
foreach ($table["fields"] as $field) {
|
|
$val = '<span' . type_class($field["type"]) . ' title="' . h($field["full_type"] . ($field["null"] ? " NULL" : '')) . '">' . h($field["field"]) . '</span>';
|
|
echo "<br>" . ($field["primary"] ? "<i>$val</i>" : $val);
|
|
}
|
|
|
|
foreach ((array) $table["references"] as $target_name => $refs) {
|
|
foreach ($refs as $left => $ref) {
|
|
$left1 = $left - $table_pos[$name][1];
|
|
$i = 0;
|
|
foreach ($ref[0] as $source) {
|
|
echo "\n<div class='references' title='" . h($target_name) . "' id='refs$left-" . ($i++) . "' style='left: $left1" . "em; top: " . $table["fields"][$source]["pos"] . "em; padding-top: .5em;'><div style='border-top: 1px solid Gray; width: " . (-$left1) . "em;'></div></div>";
|
|
}
|
|
}
|
|
}
|
|
|
|
foreach ((array) $referenced[$name] as $target_name => $refs) {
|
|
foreach ($refs as $left => $columns) {
|
|
$left1 = $left - $table_pos[$name][1];
|
|
$i = 0;
|
|
foreach ($columns as $target) {
|
|
echo "\n<div class='references' title='" . h($target_name) . "' id='refd$left-" . ($i++) . "' style='left: $left1" . "em; top: " . $table["fields"][$target]["pos"] . "em; height: 1.25em; background: url(../adminer/static/arrow.gif) no-repeat right center;'><div style='height: .5em; border-bottom: 1px solid Gray; width: " . (-$left1) . "em;'></div></div>";
|
|
}
|
|
}
|
|
}
|
|
|
|
echo "\n</div>\n";
|
|
}
|
|
|
|
foreach ($schema as $name => $table) {
|
|
foreach ((array) $table["references"] as $target_name => $refs) {
|
|
foreach ($refs as $left => $ref) {
|
|
$min_pos = $top;
|
|
$max_pos = -10;
|
|
foreach ($ref[0] as $key => $source) {
|
|
$pos1 = $table["pos"][0] + $table["fields"][$source]["pos"];
|
|
$pos2 = $schema[$target_name]["pos"][0] + $schema[$target_name]["fields"][$ref[1][$key]]["pos"];
|
|
$min_pos = min($min_pos, $pos1, $pos2);
|
|
$max_pos = max($max_pos, $pos1, $pos2);
|
|
}
|
|
echo "<div class='references' id='refl$left' style='left: $left" . "em; top: $min_pos" . "em; padding: .5em 0;'><div style='border-right: 1px solid Gray; margin-top: 1px; height: " . ($max_pos - $min_pos) . "em;'></div></div>\n";
|
|
}
|
|
}
|
|
}
|
|
?>
|
|
</div>
|
|
<p class="links"><a href="<?php echo h(ME . "schema=" . urlencode($SCHEMA)); ?>" id="schema-link"><?php echo lang('Permanent link'); ?></a>
|