relation = new Relation(); } /** * Function to get html for displaying the page edit/delete form * * @param string $db database name * @param string $operation 'edit' or 'delete' depending on the operation * * @return string html content */ public function getHtmlForEditOrDeletePages($db, $operation) { $cfgRelation = $this->relation->getRelationsParam(); return Template::get('database/designer/edit_delete_pages')->render([ 'db' => $db, 'operation' => $operation, 'pdfwork' => $cfgRelation['pdfwork'], 'pages' => $this->getPageIdsAndNames($db), ]); } /** * Function to get html for displaying the page save as form * * @param string $db database name * * @return string html content */ public function getHtmlForPageSaveAs($db) { $cfgRelation = $this->relation->getRelationsParam(); return Template::get('database/designer/page_save_as')->render([ 'db' => $db, 'pdfwork' => $cfgRelation['pdfwork'], 'pages' => $this->getPageIdsAndNames($db), ]); } /** * Retrieve IDs and names of schema pages * * @param string $db database name * * @return array array of schema page id and names */ private function getPageIdsAndNames($db) { $result = []; $cfgRelation = $this->relation->getRelationsParam(); if (! $cfgRelation['pdfwork']) { return $result; } $page_query = "SELECT `page_nr`, `page_descr` FROM " . Util::backquote($cfgRelation['db']) . "." . Util::backquote($cfgRelation['pdf_pages']) . " WHERE db_name = '" . $GLOBALS['dbi']->escapeString($db) . "'" . " ORDER BY `page_descr`"; $page_rs = $this->relation->queryAsControlUser( $page_query, false, DatabaseInterface::QUERY_STORE ); while ($curr_page = $GLOBALS['dbi']->fetchAssoc($page_rs)) { $result[intval($curr_page['page_nr'])] = $curr_page['page_descr']; } return $result; } /** * Function to get html for displaying the schema export * * @param string $db database name * @param int $page the page to be exported * * @return string */ public function getHtmlForSchemaExport($db, $page) { /* Scan for schema plugins */ /* @var $export_list SchemaPlugin[] */ $export_list = Plugins::getPlugins( "schema", 'libraries/classes/Plugins/Schema/', null ); /* Fail if we didn't find any schema plugin */ if (empty($export_list)) { return Message::error( __('Could not load schema plugins, please check your installation!') )->getDisplay(); } return Template::get('database/designer/schema_export') ->render( [ 'db' => $db, 'page' => $page, 'export_list' => $export_list ] ); } /** * Returns HTML for including some variable to be accessed by JavaScript * * @param array $script_tables array on foreign key support for each table * @param array $script_contr initialization data array * @param Designer\DesignerTable[] $script_display_field displayed tables in designer with their display fields * @param int $display_page page number of the selected page * * @return string html */ public function getHtmlForJsFields( array $script_tables, array $script_contr, array $script_display_field, $display_page ) { $displayedFields = []; foreach ($script_display_field as $designerTable) { if ($designerTable->getDisplayField() !== null) { $displayedFields[$designerTable->getTableName()] = $designerTable->getDisplayField(); } } $cfgRelation = $this->relation->getRelationsParam(); $designerConfig = new \stdClass(); $designerConfig->db = $_GET['db']; $designerConfig->scriptTables = $script_tables; $designerConfig->scriptContr = $script_contr; $designerConfig->server = $GLOBALS['server']; $designerConfig->scriptDisplayField = $displayedFields; $designerConfig->displayPage = (int) $display_page; $designerConfig->tablesEnabled = $cfgRelation['pdfwork']; return Template::get('database/designer/js_fields')->render([ 'designer_config' => json_encode($designerConfig) ]); } /** * Returns HTML for the menu bar of the designer page * * @param boolean $visualBuilder whether this is visual query builder * @param string $selectedPage name of the selected page * @param array $paramsArray array with class name for various buttons * on side menu * * @return string html */ public function getPageMenu($visualBuilder, $selectedPage, array $paramsArray) { return Template::get('database/designer/side_menu')->render([ 'visual_builder' => $visualBuilder, 'selected_page' => $selectedPage, 'params_array' => $paramsArray, 'theme' => $GLOBALS['PMA_Theme'], ]); } /** * Returns array of stored values of Designer Settings * * @return array stored values */ private function getSideMenuParamsArray() { $params = []; $cfgRelation = $this->relation->getRelationsParam(); if ($cfgRelation['designersettingswork']) { $query = 'SELECT `settings_data` FROM ' . Util::backquote($cfgRelation['db']) . '.' . Util::backquote($cfgRelation['designer_settings']) . ' WHERE ' . Util::backquote('username') . ' = "' . $GLOBALS['dbi']->escapeString($GLOBALS['cfg']['Server']['user']) . '";'; $result = $GLOBALS['dbi']->fetchSingleRow($query); $params = json_decode($result['settings_data'], true); } return $params; } /** * Returns class names for various buttons on Designer Side Menu * * @return array class names of various buttons */ public function returnClassNamesFromMenuButtons() { $classes_array = []; $params_array = $this->getSideMenuParamsArray(); if (isset($params_array['angular_direct']) && $params_array['angular_direct'] == 'angular' ) { $classes_array['angular_direct'] = 'M_butt_Selected_down'; } else { $classes_array['angular_direct'] = 'M_butt'; } if (isset($params_array['snap_to_grid']) && $params_array['snap_to_grid'] == 'on' ) { $classes_array['snap_to_grid'] = 'M_butt_Selected_down'; } else { $classes_array['snap_to_grid'] = 'M_butt'; } if (isset($params_array['pin_text']) && $params_array['pin_text'] == 'true' ) { $classes_array['pin_text'] = 'M_butt_Selected_down'; } else { $classes_array['pin_text'] = 'M_butt'; } if (isset($params_array['relation_lines']) && $params_array['relation_lines'] == 'false' ) { $classes_array['relation_lines'] = 'M_butt_Selected_down'; } else { $classes_array['relation_lines'] = 'M_butt'; } if (isset($params_array['small_big_all']) && $params_array['small_big_all'] == 'v' ) { $classes_array['small_big_all'] = 'M_butt_Selected_down'; } else { $classes_array['small_big_all'] = 'M_butt'; } if (isset($params_array['side_menu']) && $params_array['side_menu'] == 'true' ) { $classes_array['side_menu'] = 'M_butt_Selected_down'; } else { $classes_array['side_menu'] = 'M_butt'; } return $classes_array; } /** * Returns HTML for the canvas element * * @return string html */ public function getHtmlCanvas() { return Template::get('database/designer/canvas')->render(); } /** * Return HTML for the table list * * @return string html */ public function getHtmlTableList() { return Template::get('database/designer/table_list')->render([ 'theme' => $GLOBALS['PMA_Theme'], ]); } /** * Get HTML to display tables on designer page * * @param string $db The database name from the request * @param array $designerTables The designer tables * @param array $tab_pos tables positions * @param int $display_page page number of the selected page * @param array $tab_column table column info * @param array $tables_all_keys all indices * @param array $tables_pk_or_unique_keys unique or primary indices * * @return string html */ public function getDatabaseTables( $db, array $designerTables, array $tab_pos, $display_page, array $tab_column, array $tables_all_keys, array $tables_pk_or_unique_keys ) { return Template::get('database/designer/database_tables')->render([ 'db' => $GLOBALS['db'], 'get_db' => $db, 'has_query' => isset($_REQUEST['query']), 'tab_pos' => $tab_pos, 'display_page' => $display_page, 'tab_column' => $tab_column, 'tables_all_keys' => $tables_all_keys, 'tables_pk_or_unique_keys' => $tables_pk_or_unique_keys, 'tables' => $designerTables, 'theme' => $GLOBALS['PMA_Theme'], ]); } /** * Returns HTML for the new relations panel. * * @return string html */ public function getNewRelationPanel() { return Template::get('database/designer/new_relation_panel') ->render(); } /** * Returns HTML for the relations delete panel * * @return string html */ public function getDeleteRelationPanel() { return Template::get('database/designer/delete_relation_panel') ->render(); } /** * Returns HTML for the options panel * * @return string html */ public function getOptionsPanel() { return Template::get('database/designer/options_panel')->render(); } /** * Get HTML for the 'rename to' panel * * @return string html */ public function getRenameToPanel() { return Template::get('database/designer/rename_to_panel') ->render(); } /** * Returns HTML for the 'having' panel * * @return string html */ public function getHavingQueryPanel() { return Template::get('database/designer/having_query_panel') ->render(); } /** * Returns HTML for the 'aggregate' panel * * @return string html */ public function getAggregateQueryPanel() { return Template::get('database/designer/aggregate_query_panel') ->render(); } /** * Returns HTML for the 'where' panel * * @return string html */ public function getWhereQueryPanel() { return Template::get('database/designer/where_query_panel') ->render(); } /** * Returns HTML for the query details panel * * @param string $db Database name * * @return string html */ public function getQueryDetails($db) { return Template::get('database/designer/query_details')->render([ 'db' => $db, ]); } }