Ejemplo n.º 1
0
void DatabaseCanvas::OnRightDown(wxMouseEvent &event)
{
    FieldShape *erdField = NULL;
    MyErdTable *erdTable = NULL;
    ConstraintSign *erdSign = NULL;
    wxPoint pt = event.GetPosition();
    ShapeList selection;
    this->GetSelectedShapes( selection );
    for( ShapeList::iterator it = selection.begin(); it != selection.end(); ++it )
    {
        MyErdTable *table = wxDynamicCast( (*it), MyErdTable );
        if( table )
            m_realSelectedShape = table;
    }
    wxMenu mnu;
    int allSelected = 0;
    mnu.Bind( wxEVT_COMMAND_MENU_SELECTED, &DatabaseCanvas::OnDropTable, this, wxID_DROPOBJECT );
    mnu.Bind( wxEVT_COMMAND_MENU_SELECTED, &DatabaseCanvas::OnDropTable, this, wxID_TABLECLOSE );
    m_selectedShape = GetShapeUnderCursor();
    ViewType type = dynamic_cast<DrawingView *>( m_view )->GetViewType();
    if( m_selectedShape )
    {
        ShapeList list;
        GetShapesAtPosition( pt, list );
        if( type == DatabaseView )
            if( m_selectedShape->IsKindOf( CLASSINFO( MyErdTable ) ) )
                DeselectAll();
        wxRect tableRect;
        bool fieldSelected = false;
        bool signSelected = false;
        for( ShapeList::iterator it = list.begin(); it != list.end(); ++it )
        {
            MyErdTable *table = wxDynamicCast( (*it), MyErdTable );
            if( table )
            {
                if( type == DatabaseView )
                    table->Select( true );
                tableRect = table->GetBoundingBox();
                erdTable = table;
            }
            else
            {
                FieldShape *field = wxDynamicCast( (*it), FieldShape );
                if( field )
                {
                    if( type == DatabaseView )
                        field->Select( true );
                    field->SetParentRect( tableRect );
                    fieldSelected = true;
                    erdField = field;
                }
                else
                {
                    ConstraintSign *sign = wxDynamicCast( (*it), ConstraintSign );
                    if( sign )
                    {
                        if( type == DatabaseView )
                            sign->Select( true );
                        signSelected = true;
                        erdSign = sign;
                    }
                }
            }
        }
        if( type == DatabaseView && list.empty() )
        {
            MyErdTable *table = wxDynamicCast( m_selectedShape, MyErdTable );
            if( table )
            {
                table->Select( true );
            }
            else
            {
                table = wxDynamicCast( m_selectedShape->GetParentShape()->GetParentShape(), MyErdTable );
                table->Select( true );
            }
        }
        if( type == QueryView )
        {
            size_t selectedCount = 0;
            SerializableList tableFields;
			if( erdTable )
			{
                erdTable->GetChildrenRecursively( CLASSINFO( FieldShape ), tableFields );
                SerializableList::compatibility_iterator node = tableFields.GetFirst();
                while( node )
                {
                    FieldShape *shape = dynamic_cast<FieldShape *>( node->GetData() );
                    if( shape->IsSelected() )
                        selectedCount++;
                    node = node->GetNext();
                }
                if( selectedCount == const_cast<DatabaseTable &>( erdTable->GetTable() ).GetFields().size() )
                    allSelected = 1;
                else
                    allSelected = -1;
			}
        }
        Refresh();
        if( type == DatabaseView )
        {
            if( !fieldSelected && !signSelected )
            {
                mnu.Append( wxID_TABLECLOSE, _( "Close" ), _( "Close Table" ), false );
                mnu.AppendSeparator();
                mnu.Append( wxID_TABLEALTERTABLE, _( "Alter Table" ), _( "Alter Table" ), false );
                mnu.Append( wxID_PROPERTIES, _( "Properties..." ), _( "Table Properties" ), false );
                mnu.AppendSeparator();
                wxMenu *newObjectMenu = new wxMenu();
                newObjectMenu->Append( wxID_OBJECTNEWINDEX, _( "Index..." ), _( "New Index" ) );
                newObjectMenu->Append( wxID_OBJECTNEWFF, _( "Foreign Key..." ), _( "New Foreign Key" ) );
                mnu.AppendSubMenu( newObjectMenu, _( "New" ), _( "New" ) );
                mnu.AppendSeparator();
                mnu.Append( wxID_DROPOBJECT, _( "Drop Table" ), _( "Drop Table" ), false );
                mnu.AppendSeparator();
                mnu.Append( wxID_TABLEEDITDATA, _( "Edit Data" ), _( "Edit Data" ), false );
                mnu.AppendSeparator();
                mnu.Append( wxID_TABLEDATATRANSFER, _( "Data Transfer" ), _( "Data Transfer" ), false );
                mnu.AppendSeparator();
                mnu.Append( wxID_TABLEPRINTDEFINITION, _( "Print Definition" ), _( "Print Definition" ), false );
            }
            else if( fieldSelected )
            {
                mnu.Append( wxID_FIELDDEFINITION, _( "Definition" ), _( "Edit definition of selected object" ), false );
                mnu.Append( wxID_FIELDPROPERTIES, _( "Properties..." ), _( "Show properties of selected object" ), false );
            }
            else
            {
                mnu.Append( wxID_FKDEFINITION, _( "Definition..." ), _( "Edit definition of selected object" ) );
                mnu.Append( wxID_FKOPENREFTABLE, _( "Open Referenced Table" ), _( "Open Referenced Table" ) );
                mnu.Append( wxID_DROPOBJECT, _( "Drop Foreign Key..." ), _( "Drop Foreign Key for the table" ) );
            }
        }
        else
        {
            if( erdTable )
            {
                mnu.Append( wxID_SELECTALLFIELDS, _( "Select All" ), _( "Select all columns for display" ) );
                mnu.Append( wxID_DESELECTALLFIELDS, _("Deselect All" ), _( "Deselect all columns for display" ) );
                mnu.Append( wxID_TABLECLOSE, _( "Close" ), _( "Close Table" ), false );
                if( !allSelected )
                    mnu.FindItem( wxID_DESELECTALLFIELDS )->Enable( false );
                else if( allSelected == 1 )
                    mnu.FindItem( wxID_SELECTALLFIELDS )->Enable( false );
            }
        }
    }
    else
    {
        if( type == DatabaseView )
        {
            mnu.Append( wxID_SELECTTABLE, _( "Select Table..." ), _( "Select Table" ), false );
            mnu.Append( wxID_VIEWARRANGETABLES, _( "Arramge Tables..." ), _( "Arrange Tables" ), false );
            mnu.AppendCheckItem( wxID_VIEWSHOWCOMMENTS, _( "Show Comments" ), _( "Show Comments" ) );
            mnu.AppendCheckItem( wxID_VIEWSHOWINDEXKEYS, _( "Show Index Keys" ), _( "Show Index Keys" ) );
            mnu.AppendCheckItem( wxID_VIEWSHOWINTEGRITY, _( "Show Referential Integrity" ), _( "Show Referential Integrity" ) );
            if( m_showComments )
                mnu.Check( wxID_VIEWSHOWCOMMENTS, true );
            if( m_showIndexKeys )
                mnu.Check( wxID_VIEWSHOWINDEXKEYS, true );
            if( m_showIntegrity )
                mnu.Check( wxID_VIEWSHOWINTEGRITY, true );
        }
        else
        {
            mnu.Append( wxID_SELECTTABLE, _( "Select Table..." ), _( "Select addtional tables for the query" )  );
            mnu.Append( wxID_ARRANGETABLES, _( "Arrange Tables" ), _( "Arrange Tables" ) );
            wxMenu *showMenu = new wxMenu();
            showMenu->AppendCheckItem( wxID_SHOWDATATYPES, _( "Datatypes" ), _( "Datatypes" ) );
            showMenu->AppendCheckItem( wxID_SHOWLABELS, _( "Labels" ), _( "Labels" ) );
            showMenu->AppendCheckItem( wxID_VIEWSHOWCOMMENTS, _( "Comments" ), _( "Comments" ) );
            showMenu->AppendCheckItem( wxID_SHOWSQLTOOLBOX, _( "SQL Toolbox" ), _( "SQL Toolbox" ) );
            mnu.AppendSubMenu( showMenu, _( "Show" ) );
            if( m_showDataTypes )
                showMenu->Check( wxID_SHOWDATATYPES, true );
            if( m_showLabels )
                showMenu->Check( wxID_SHOWLABELS, true );
            if( m_showComments )
                showMenu->Check( wxID_VIEWSHOWCOMMENTS, true );
            if( m_showToolBox )
                showMenu->Check( wxID_SHOWSQLTOOLBOX, true );
        }
    }
    int rc = GetPopupMenuSelectionFromUser( mnu, pt );
    if( rc == wxID_NONE && erdField )
    {
//        if( field )
        {
            erdField->Select( false );
            erdTable->GetFieldGrid()->Refresh();
            erdTable->Refresh();
        }
    }
    else
    {
        if( erdField )
        {
            erdField->Select( false );
            erdTable->GetFieldGrid()->Refresh();
            erdTable->Refresh();
        }
        wxCommandEvent evt( wxEVT_MENU, rc );
        if( erdField )
            evt.SetEventObject( erdField );
        else
            evt.SetEventObject( erdTable );
        if( rc == wxID_SHOWSQLTOOLBOX || rc == wxID_VIEWSHOWCOMMENTS )
            GetEventHandler()->ProcessEvent( evt );
        else
            m_view->ProcessEvent( evt );
    }
}