103 lines
2.9 KiB
PHP
103 lines
2.9 KiB
PHP
<?php
|
|
/**
|
|
* Generate HTML for MySQL Documentation
|
|
*/
|
|
|
|
declare(strict_types=1);
|
|
|
|
namespace PhpMyAdmin\Html;
|
|
|
|
use PhpMyAdmin\Core;
|
|
use PhpMyAdmin\Util;
|
|
|
|
use function __;
|
|
use function defined;
|
|
use function file_exists;
|
|
use function htmlspecialchars;
|
|
|
|
/**
|
|
* Generate HTML for MySQL Documentation
|
|
*/
|
|
class MySQLDocumentation
|
|
{
|
|
/**
|
|
* Displays a link to the official MySQL documentation
|
|
*
|
|
* @param string $link contains name of page/anchor that is being linked
|
|
* @param bool $bigIcon whether to use big icon (like in left frame)
|
|
* @param string|null $url href attribute
|
|
* @param string|null $text text of link
|
|
* @param string $anchor anchor to page part
|
|
*
|
|
* @return string the html link
|
|
*/
|
|
public static function show(
|
|
$link,
|
|
bool $bigIcon = false,
|
|
$url = null,
|
|
$text = null,
|
|
$anchor = ''
|
|
): string {
|
|
if ($url === null) {
|
|
$url = Util::getMySQLDocuURL($link, $anchor);
|
|
}
|
|
|
|
$openLink = '<a href="' . htmlspecialchars($url) . '" target="mysql_doc">';
|
|
$closeLink = '</a>';
|
|
|
|
if ($bigIcon) {
|
|
$html = $openLink .
|
|
Generator::getImage('b_sqlhelp', __('Documentation'))
|
|
. $closeLink;
|
|
} elseif ($text !== null) {
|
|
$html = $openLink . $text . $closeLink;
|
|
} else {
|
|
$html = Generator::showDocumentationLink($url, 'mysql_doc');
|
|
}
|
|
|
|
return $html;
|
|
}
|
|
|
|
/**
|
|
* Displays a link to the phpMyAdmin documentation
|
|
*
|
|
* @param string $page Page in documentation
|
|
* @param string $anchor Optional anchor in page
|
|
* @param bool $bbcode Optional flag indicating whether to output bbcode
|
|
*
|
|
* @return string the html link
|
|
*/
|
|
public static function showDocumentation($page, $anchor = '', $bbcode = false): string
|
|
{
|
|
return Generator::showDocumentationLink(self::getDocumentationLink($page, $anchor), 'documentation', $bbcode);
|
|
}
|
|
|
|
/**
|
|
* Returns link to documentation.
|
|
*
|
|
* @param string $page Page in documentation
|
|
* @param string $anchor Optional anchor in page
|
|
* @param string $pathPrefix Optional path in case it is called in a folder (e.g. setup)
|
|
*
|
|
* @return string URL
|
|
*/
|
|
public static function getDocumentationLink($page, $anchor = '', string $pathPrefix = './'): string
|
|
{
|
|
/* Construct base URL */
|
|
$url = $page . '.html';
|
|
if (! empty($anchor)) {
|
|
$url .= '#' . $anchor;
|
|
}
|
|
|
|
/**
|
|
* Check if we have built local documentation, however
|
|
* provide consistent URL for testsuite
|
|
*/
|
|
if (! defined('TESTSUITE') && @file_exists(ROOT_PATH . 'doc/html/index.html')) {
|
|
return $pathPrefix . 'doc/html/' . $url;
|
|
}
|
|
|
|
return Core::linkURL('https://docs.phpmyadmin.net/en/latest/' . $url);
|
|
}
|
|
}
|