data = new StdClass(); } // -------------------------------------------------------------------------- /** * Add a new tab with the provided label * * @param string $label * @param GObject $widget * @return void */ public function add_tab($label, $widget = NULL) { if (is_null($widget)) { $widget = new Data_Grid(); } $this->append_page($widget, new GtkLabel($label)); } // -------------------------------------------------------------------------- /** * Create tabs for database aspects * * @param Query_Builder $conn * @return void */ public static function get_db_tabs(&$conn) { // Empty the tabs self::reset(); self::$instance->hide_all(); // 'Databases' Tab { self::_add_tab($conn, 'Databases', 'Db Name', 'get_dbs'); } // 'Schemas' Tab { self::_add_tab($conn, 'Schemas', 'Schema Name', 'get_schemas'); } // 'Tables' Tab { self::_add_tab($conn, 'Tables', 'Table Name', 'get_tables', array( array( 'row-activated', array(self::$instance, 'show_table_data'), $conn ) )); } // 'System Tables' Tab { self::_add_tab($conn, 'System Tables', 'Table Name', 'get_system_tables'); } // 'Views' Tab { self::_add_tab($conn, 'Views', 'View Name', 'get_views', array( array( 'row-activated', array(self::$instance, 'show_table_data'), $conn ) )); } // 'Sequences' Tab { self::_add_tab($conn, 'Sequences', 'Sequence Name', 'get_sequences'); } // 'Triggers' Tab { self::_add_row_tab($conn, 'Triggers','get_triggers'); } // 'Procedures' Tab { self::_add_row_tab($conn, 'Procedures', 'get_procedures'); } // 'Functions' Tab { self::_add_row_tab($conn, 'Functions', 'get_functions'); } self::$instance->show_all(); } // -------------------------------------------------------------------------- /** * Remove current tabs */ public static function reset() { self::$instance->hide_all(); for($i=self::$instance->get_n_pages(); $i >= 0; $i--) { self::$instance->remove_page($i); } self::$instance->show_all(); } // -------------------------------------------------------------------------- /** * Simplify adding tabs to the Notebook object * * @param object $conn * @param string $tab_name * @param string $col_name * @param string $method * @param array $events * @return void */ private static function _add_tab(&$conn, $tab_name, $col_name, $method, $events=array()) { $tab = new Data_Grid(); $tab_model = $tab->get_model(); $conn_name = $conn->conn_name; if ( ! isset(self::$instance->data->{$conn_name})) { self::$instance->data->{$conn_name}= array(); } $instance_data =& self::$instance->data->{$conn_name}; $tab_data = (empty($instance_data[$tab_name])) ? call_user_func_array(array($conn, $method), array()) : $instance_data[$tab_name]; $instance_data[$tab_name] = $tab_data; if ($tab_data !== FALSE) { foreach($tab_data as $d) { $tab_model->append(null, array($d)); } $cell_renderer = new GtkCellRendererText(); $cell_renderer->set_property('editable', FALSE); $tab->insert_column_with_data_func(0, $col_name, $cell_renderer, array($tab, 'add_data_col')); if ( ! empty($events)) { foreach($events as $method) { call_user_func_array(array($tab, 'connect'), $method); } } self::$instance->add_tab($tab_name, $tab); } return; } // -------------------------------------------------------------------------- /** * Add a multidimensional array to a tab * * @param object $conn * @param string $tab_name * @param string $method * @return void */ private static function _add_row_tab(&$conn, $tab_name, $method) { $conn_name = $conn->conn_name; if ( ! isset(self::$instance->data->{$conn_name})) { self::$instance->data->{$conn_name}= array(); } $instance_data =& self::$instance->data->{$conn_name}; $tab_data = (empty($instance_data[$tab_name])) ? call_user_func_array(array($conn, $method), array()) : $instance_data[$tab_name]; $instance_data[$tab_name] = $tab_data; if ( ! empty($tab_data)) { $tab = new Data_Grid(); $tab->render_data($tab_data); self::$instance->add_tab($tab_name, $tab); } return; } // -------------------------------------------------------------------------- /** * Create popup window with table data * * @param GTKTreeView $view * @param array $path * @param GtkTreeviewColumn $col * @param Query_Builder $conn * @return void */ public function show_table_data($view, $path, $col, &$conn) { $table = $view->get(0); $query = $conn->get($table); $data = $query->fetchAll(PDO::FETCH_ASSOC); return new DB_Table_data($data); } } // End of db_tabs.php