PAD_TOOL: enable 'Apply' after copying a pad
This commit is contained in:
parent
2fa17b4460
commit
6fdccc1829
|
@ -90,21 +90,18 @@ private:
|
||||||
ENABLEMENTS enablements;
|
ENABLEMENTS enablements;
|
||||||
|
|
||||||
auto anyPadSel = S_C::HasType( PCB_PAD_T );
|
auto anyPadSel = S_C::HasType( PCB_PAD_T );
|
||||||
|
auto singlePadSel = S_C::Count( 1 ) && S_C::OnlyType( PCB_PAD_T );
|
||||||
auto singlePadSel = S_C::Count( 1 )
|
|
||||||
&& S_C::OnlyType( PCB_PAD_T );
|
|
||||||
|
|
||||||
// Apply pads enabled when any pads selected (it applies to each one
|
// Apply pads enabled when any pads selected (it applies to each one
|
||||||
// individually), plus need a valid global pad setting
|
// individually), plus need a valid global pad setting
|
||||||
enablements.canImport = m_haveGlobalPadSettings()
|
enablements.canImport = m_haveGlobalPadSettings() && ( anyPadSel )( aSelection );
|
||||||
&& ( anyPadSel )( aSelection );
|
|
||||||
|
|
||||||
// Copy pads item enabled only when there is a single pad selected
|
// Copy pads item enabled only when there is a single pad selected
|
||||||
// (otherwise how would we know which one to copy?)
|
// (otherwise how would we know which one to copy?)
|
||||||
enablements.canExport = ( singlePadSel )( aSelection );
|
enablements.canExport = ( singlePadSel )( aSelection );
|
||||||
|
|
||||||
// Push pads available when there is a single pad to push from
|
// Push pads available when there is a single pad to push from
|
||||||
enablements.canPush = ( singlePadSel ) ( aSelection );
|
enablements.canPush = ( singlePadSel )( aSelection );
|
||||||
|
|
||||||
return enablements;
|
return enablements;
|
||||||
}
|
}
|
||||||
|
@ -127,7 +124,7 @@ private:
|
||||||
|
|
||||||
|
|
||||||
PAD_TOOL::PAD_TOOL() :
|
PAD_TOOL::PAD_TOOL() :
|
||||||
PCB_TOOL( "pcbnew.PadTool" )
|
PCB_TOOL( "pcbnew.PadTool" ), m_padCopied( false )
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -138,14 +135,7 @@ PAD_TOOL::~PAD_TOOL()
|
||||||
|
|
||||||
void PAD_TOOL::Reset( RESET_REASON aReason )
|
void PAD_TOOL::Reset( RESET_REASON aReason )
|
||||||
{
|
{
|
||||||
}
|
m_padCopied = false;
|
||||||
|
|
||||||
|
|
||||||
bool PAD_TOOL::hasMasterPadSettings()
|
|
||||||
{
|
|
||||||
auto& frame = *getEditFrame<PCB_EDIT_FRAME>();
|
|
||||||
D_PAD& masterPad = frame.GetDesignSettings().m_Pad_Master;
|
|
||||||
return masterPad.GetParent() != nullptr;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -158,13 +148,8 @@ bool PAD_TOOL::haveFootprints()
|
||||||
|
|
||||||
bool PAD_TOOL::Init()
|
bool PAD_TOOL::Init()
|
||||||
{
|
{
|
||||||
// functor to report if the current frame has master pad settings
|
auto contextMenu = std::make_shared<PAD_CONTEXT_MENU>( EditingModules(),
|
||||||
std::function<bool()> haveMasterPad = [this] () {
|
[this]() { return m_padCopied; } );
|
||||||
return hasMasterPadSettings();
|
|
||||||
};
|
|
||||||
|
|
||||||
auto contextMenu = std::make_shared<PAD_CONTEXT_MENU>(
|
|
||||||
EditingModules(), haveMasterPad );
|
|
||||||
contextMenu->SetTool( this );
|
contextMenu->SetTool( this );
|
||||||
|
|
||||||
SELECTION_TOOL* selTool = m_toolMgr->GetTool<SELECTION_TOOL>();
|
SELECTION_TOOL* selTool = m_toolMgr->GetTool<SELECTION_TOOL>();
|
||||||
|
@ -243,6 +228,7 @@ int PAD_TOOL::copyPadSettings( const TOOL_EVENT& aEvent )
|
||||||
{
|
{
|
||||||
const auto& selPad = static_cast<const D_PAD&>( *item );
|
const auto& selPad = static_cast<const D_PAD&>( *item );
|
||||||
masterPad.ImportSettingsFromMaster( selPad );
|
masterPad.ImportSettingsFromMaster( selPad );
|
||||||
|
m_padCopied = true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -304,7 +290,6 @@ static void globalChangePadSettings( BOARD& board,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
int PAD_TOOL::pushPadSettings( const TOOL_EVENT& aEvent )
|
int PAD_TOOL::pushPadSettings( const TOOL_EVENT& aEvent )
|
||||||
{
|
{
|
||||||
auto& selTool = *m_toolMgr->GetTool<SELECTION_TOOL>();
|
auto& selTool = *m_toolMgr->GetTool<SELECTION_TOOL>();
|
||||||
|
@ -377,6 +362,7 @@ int PAD_TOOL::pushPadSettings( const TOOL_EVENT& aEvent )
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void PAD_TOOL::SetTransitions()
|
void PAD_TOOL::SetTransitions()
|
||||||
{
|
{
|
||||||
Go( &PAD_TOOL::applyPadSettings, COMMON_ACTIONS::applyPadSettings.MakeEvent() );
|
Go( &PAD_TOOL::applyPadSettings, COMMON_ACTIONS::applyPadSettings.MakeEvent() );
|
||||||
|
|
|
@ -50,9 +50,6 @@ public:
|
||||||
void SetTransitions() override;
|
void SetTransitions() override;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
///> Determine if the frame has a valid master pad setting
|
|
||||||
bool hasMasterPadSettings();
|
|
||||||
|
|
||||||
///> Determine if there are any footprints on the board
|
///> Determine if there are any footprints on the board
|
||||||
bool haveFootprints();
|
bool haveFootprints();
|
||||||
|
|
||||||
|
@ -64,7 +61,9 @@ private:
|
||||||
|
|
||||||
///> Push pad settings from a pad to other pads on board or module
|
///> Push pad settings from a pad to other pads on board or module
|
||||||
int pushPadSettings( const TOOL_EVENT& aEvent );
|
int pushPadSettings( const TOOL_EVENT& aEvent );
|
||||||
|
|
||||||
|
///> Flag to indicate there are valid settings stored in the Master Pad object
|
||||||
|
bool m_padCopied;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
#endif // __PAD_TOOL_H
|
#endif // __PAD_TOOL_H
|
||||||
|
|
Loading…
Reference in New Issue