| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115 |
- <?php
- /* vim: set expandtab sw=4 ts=4 sts=4: */
- /**
- * Contains Relation_Stats_Svg class
- *
- * @package PhpMyAdmin
- */
- if (! defined('PHPMYADMIN')) {
- exit;
- }
- require_once 'libraries/plugins/schema/RelationStats.class.php';
- /**
- * Relation preferences/statistics
- *
- * This class fetches the table master and foreign fields positions
- * and helps in generating the Table references and then connects
- * master table's master field to foreign table's foreign key
- * in SVG XML document.
- *
- * @package PhpMyAdmin
- * @name Relation_Stats_Svg
- * @see PMA_SVG::printElementLine
- */
- class Relation_Stats_Svg extends RelationStats
- {
- /**
- * The "Relation_Stats_Svg" constructor
- *
- * @param object $diagram The SVG diagram
- * @param string $master_table The master table name
- * @param string $master_field The relation field in the master table
- * @param string $foreign_table The foreign table name
- * @param string $foreign_field The relation field in the foreign table
- */
- public function __construct(
- $diagram, $master_table, $master_field, $foreign_table, $foreign_field
- ) {
- $this->wTick = 10;
- parent::__construct(
- $diagram, $master_table, $master_field, $foreign_table, $foreign_field
- );
- }
- /**
- * draws relation links and arrows shows foreign key relations
- *
- * @param boolean $showColor Whether to use one color per relation or not
- *
- * @return void
- * @access public
- *
- * @see PMA_SVG
- */
- public function relationDraw($showColor)
- {
- if ($showColor) {
- $listOfColors = array(
- '#c00',
- '#bbb',
- '#333',
- '#cb0',
- '#0b0',
- '#0bf',
- '#b0b'
- );
- shuffle($listOfColors);
- $color = $listOfColors[0];
- } else {
- $color = '#333';
- }
- $this->diagram->printElementLine(
- 'line', $this->xSrc, $this->ySrc,
- $this->xSrc + $this->srcDir * $this->wTick, $this->ySrc,
- 'stroke:' . $color . ';stroke-width:1;'
- );
- $this->diagram->printElementLine(
- 'line', $this->xDest + $this->destDir * $this->wTick,
- $this->yDest, $this->xDest, $this->yDest,
- 'stroke:' . $color . ';stroke-width:1;'
- );
- $this->diagram->printElementLine(
- 'line', $this->xSrc + $this->srcDir * $this->wTick, $this->ySrc,
- $this->xDest + $this->destDir * $this->wTick, $this->yDest,
- 'stroke:' . $color . ';stroke-width:1;'
- );
- $root2 = 2 * sqrt(2);
- $this->diagram->printElementLine(
- 'line', $this->xSrc + $this->srcDir * $this->wTick * 0.75, $this->ySrc,
- $this->xSrc + $this->srcDir * (0.75 - 1 / $root2) * $this->wTick,
- $this->ySrc + $this->wTick / $root2,
- 'stroke:' . $color . ';stroke-width:2;'
- );
- $this->diagram->printElementLine(
- 'line', $this->xSrc + $this->srcDir * $this->wTick * 0.75, $this->ySrc,
- $this->xSrc + $this->srcDir * (0.75 - 1 / $root2) * $this->wTick,
- $this->ySrc - $this->wTick / $root2,
- 'stroke:' . $color . ';stroke-width:2;'
- );
- $this->diagram->printElementLine(
- 'line', $this->xDest + $this->destDir * $this->wTick / 2, $this->yDest,
- $this->xDest + $this->destDir * (0.5 + 1 / $root2) * $this->wTick,
- $this->yDest + $this->wTick / $root2,
- 'stroke:' . $color . ';stroke-width:2;'
- );
- $this->diagram->printElementLine(
- 'line', $this->xDest + $this->destDir * $this->wTick / 2, $this->yDest,
- $this->xDest + $this->destDir * (0.5 + 1 / $root2) * $this->wTick,
- $this->yDest - $this->wTick / $root2,
- 'stroke:' . $color . ';stroke-width:2;'
- );
- }
- }
|