Вход Регистрация
Файл: Tools/phpmyadmin/tbl_gis_visualization.php
Строк: 227
<?php
/**
 * handles creation of the GIS visualizations.
 *
 * @package PhpMyAdmin
 */

/**
 * do not import request variable into global scope
 * @ignore
 */
if (! defined('PMA_NO_VARIABLES_IMPORT')) {
    
define('PMA_NO_VARIABLES_IMPORT'true);
}

require_once 
'./libraries/common.inc.php';

$GLOBALS['js_include'][] = 'openlayers/OpenLayers.js';
$GLOBALS['js_include'][] = 'jquery/jquery.svg.js';
$GLOBALS['js_include'][] = 'jquery/jquery.mousewheel.js';
$GLOBALS['js_include'][] = 'jquery/jquery.event.drag-2.0.js';
$GLOBALS['js_include'][] = 'tbl_gis_visualization.js';
$GLOBALS['js_include'][] = 'OpenStreetMap.js';

// Allows for resending headers even after sending some data
ob_start();

// Runs common work
require_once './libraries/db_common.inc.php';
$url_params['goto'] = $cfg['DefaultTabDatabase'];
$url_params['back'] = 'sql.php';

// Import visualization functions
require_once './libraries/gis_visualization.lib.php';

// Execute the query and return the result
$result PMA_DBI_try_query($sql_query);
// Get the meta data of results
$meta PMA_DBI_get_fields_meta($result);

// Find the candidate fields for label column and spatial column
$labelCandidates = array(); $spatialCandidates = array();
foreach (
$meta as $column_meta) {
    if (
$column_meta->type == 'geometry') {
        
$spatialCandidates[] = $column_meta->name;
    } else {
        
$labelCandidates[] = $column_meta->name;
    }
}

// Get settings if any posted
$visualizationSettings = array();
if (
PMA_isValid($_REQUEST['visualizationSettings'], 'array')) {
    
$visualizationSettings $_REQUEST['visualizationSettings'];
}

if (! isset(
$visualizationSettings['labelColumn']) && isset($labelCandidates[0])) {
    
$visualizationSettings['labelColumn'] = '';
}

// If spatial column is not set, use first geometric colum as spatial column
if (! isset($visualizationSettings['spatialColumn'])) {
    
$visualizationSettings['spatialColumn'] = $spatialCandidates[0];
}

// Convert geometric columns from bytes to text.
$modified_query PMA_GIS_modifyQuery($sql_query$visualizationSettings);
$modified_result PMA_DBI_try_query($modified_query);

$data = array();
while (
$row PMA_DBI_fetch_assoc($modified_result)) {
    
$data[] = $row;
}

// If all the rows contain SRID, use OpenStreetMaps on the initial loading.
if (! isset($_REQUEST['displayVisualization'])) {
    
$visualizationSettings['choice'] = 'useBaseLayer';
    foreach (
$data as $row) {
        if (
$row['srid'] == 0) {
            unset(
$visualizationSettings['choice']);
            break;
        }
    }
}

if (isset(
$_REQUEST['saveToFile'])) {
    
$file_name $_REQUEST['fileName'];
    if (
$file_name == '') {
        
$file_name $visualizationSettings['spatialColumn'];
    }

    
$save_format $_REQUEST['fileFormat'];
    
PMA_GIS_saveToFile($data$visualizationSettings$save_format$file_name);
    exit();
}

$svg_support = (PMA_USR_BROWSER_AGENT == 'IE' && PMA_USR_BROWSER_VER <= 8) ? false true;
$format $svg_support 'svg' 'png';

// get the chart and settings after chart generation
$visualization PMA_GIS_visualizationResults($data$visualizationSettings$format);

/**
 * Displays the page
 */
?>
<!-- Display visulalization options -->
<div id="div_view_options">
<form method="post" action="tbl_gis_visualization.php">
<?php echo PMA_generate_common_hidden_inputs($url_params); ?>
<fieldset>
    <legend><?php echo __('Display GIS Visualization'); ?></legend>
    <div id="placeholder" style="width:<?php echo($visualizationSettings['width']); ?>px;height:<?php echo($visualizationSettings['height']); ?>px;">
        <?php echo $visualization?>
    </div>
    <div id="openlayersmap"></div>
    <input type="hidden" id="pmaThemeImage" value="<?php echo($GLOBALS['pmaThemeImage']); ?>" />

    <script language="javascript" type="text/javascript">
        function drawOpenLayers() {
            <?php echo (PMA_GIS_visualizationResults($data$visualizationSettings'ol')); ?>
        }
    </script>

    <input type="hidden" name="sql_query" id="sql_query" value="<?php echo htmlspecialchars($sql_query); ?>" />

    <table class="gis_table">
    <tr><td><label for="width"><?php echo __("Width"); ?></label></td>
        <td><input type="text" name="visualizationSettings[width]" id="width" value="<?php echo (isset($visualizationSettings['width']) ? htmlspecialchars($visualizationSettings['width']) : ''); ?>" /></td>
    </tr>

    <tr><td><label for="height"><?php echo __("Height"); ?></label></td>
        <td><input type="text" name="visualizationSettings[height]" id="height" value="<?php echo (isset($visualizationSettings['height']) ? htmlspecialchars($visualizationSettings['height']) : ''); ?>" /></td>
    </tr>

    <tr><td><label for="labelColumn"><?php echo __("Label column"); ?></label></td>
        <td><select name="visualizationSettings[labelColumn]" id="labelColumn">
            <option value=""><?php echo __("-- None --"); ?></option>
        <?php
            
foreach ($labelCandidates as $labelCandidate) {
                echo(
'<option value="' htmlspecialchars($labelCandidate) . '"');
                if (
$labelCandidate == $visualizationSettings['labelColumn']) {
                    echo(
' selected="selected"');
                }
                echo(
'>' htmlspecialchars($labelCandidate) . '</option>');
            }
        
?>
        </select></td>
    </tr>

    <tr><td><label for="spatial Column"><?php echo __("Spatial column"); ?></label></td>
        <td><select name="visualizationSettings[spatialColumn]" id="spatialColumn">
        <?php
            
foreach ($spatialCandidates as $spatialCandidate) {
                echo(
'<option value="' htmlspecialchars($spatialCandidate) . '"');
                if (
$spatialCandidate == $visualizationSettings['spatialColumn']) {
                    echo(
' selected="selected"');
                }
                echo(
'>' htmlspecialchars($spatialCandidate) . '</option>');
            }
        
?>
        </select></td>
    </tr>
    <tr><td class="choice" colspan="2">
        <input type="checkbox" name="visualizationSettings[choice]" id="choice" value="useBaseLayer"
        <?php
            
if (isset($visualizationSettings['choice'])) {
                echo(
' checked="checked"');
            }
        
?>
        />
        <label for="choice"><?php echo __("Use OpenStreetMaps as Base Layer"); ?></label>
    </td></tr>
    <tr><td></td>
        <td class="button"><input type="submit" name="displayVisualization" value="<?php echo __('Redraw'); ?>" /></td>
    </tr>
    <tr><td class="save"><?php echo __("Save to file"); ?></td></tr>
    <tr><td><label for="fileName"><?php echo __("File name"); ?></label></td>
        <td><input type="text" name="fileName" id="fileName" /></td>
    </tr>
    <tr><td><label for="fileFormat"><?php echo __("Format"); ?></label></td>
        <td><select name="fileFormat" id="fileFormat">
            <option value="png">PNG</option>
            <option value="pdf">PDF</option>
            <?php
            
if ($svg_support) {
                echo (
'<option value="svg" selected="selected">SVG</option>');
            }
            
?>
        </select></td>
    </tr>
    <tr><td></td>
        <td class="button"><input type="submit" name="saveToFile" value="<?php echo __('Save'); ?>" /></td>
    </tr>
    </table>
</fieldset>
</form>
</div>
<?php
/**
 * Displays the footer
 */
require './libraries/footer.inc.php';

?>
Онлайн: 0
Реклама