diff --git a/common/tool/action_manager.cpp b/common/tool/action_manager.cpp
index e079ff0895..9a79f69d77 100644
--- a/common/tool/action_manager.cpp
+++ b/common/tool/action_manager.cpp
@@ -58,8 +58,9 @@ ACTION_MANAGER::ACTION_MANAGER( TOOL_MANAGER* aToolManager ) :
 
         wxLogTrace( kicadTraceToolStack,
                     "ACTION_MANAGER::ACTION_MANAGER: Registering action %s with ID %d, UI ID %d, "
-                    "and group %s(%d)",
-                    action->m_name, action->m_id, action->GetUIId(), groupName, groupID );
+                    "group %s(%d), toolbar state %s",
+                    action->m_name, action->m_id, action->GetUIId(), groupName, groupID,
+                    action->m_toolbarState.to_string() );
 
         RegisterAction( action );
     }
diff --git a/common/tool/action_toolbar.cpp b/common/tool/action_toolbar.cpp
index cfea2ca577..4cf9bf867f 100644
--- a/common/tool/action_toolbar.cpp
+++ b/common/tool/action_toolbar.cpp
@@ -237,6 +237,18 @@ ACTION_TOOLBAR::~ACTION_TOOLBAR()
 }
 
 
+void ACTION_TOOLBAR::Add( const TOOL_ACTION& aAction )
+{
+    wxASSERT_MSG( !aAction.CheckToolbarState( TOOLBAR_STATE::HIDDEN ),
+                  wxString::Format( "Attempting to add hidden action %s to the toolbar", aAction.GetName() ) );
+
+    bool isToggleEntry = aAction.CheckToolbarState( TOOLBAR_STATE::TOGGLE );
+    bool isCancellable = aAction.CheckToolbarState( TOOLBAR_STATE::CANCEL );
+
+    Add( aAction, isToggleEntry, isCancellable );
+}
+
+
 void ACTION_TOOLBAR::Add( const TOOL_ACTION& aAction, bool aIsToggleEntry, bool aIsCancellable )
 {
     wxASSERT( GetParent() );
diff --git a/common/tool/actions.cpp b/common/tool/actions.cpp
index 061ae1555e..4da5ad8750 100644
--- a/common/tool/actions.cpp
+++ b/common/tool/actions.cpp
@@ -168,6 +168,7 @@ TOOL_ACTION ACTIONS::finishInteractive( TOOL_ACTION_ARGS()
         .FriendlyName( _( "Finish" ) )
         .Tooltip( _( "Finish current tool" ) )
         .Icon( BITMAPS::checked_ok )
+        .ToolbarState( TOOLBAR_STATE::HIDDEN )
         .Flags( AF_NONE ) );
 
 TOOL_ACTION ACTIONS::showContextMenu( TOOL_ACTION_ARGS()
@@ -176,10 +177,12 @@ TOOL_ACTION ACTIONS::showContextMenu( TOOL_ACTION_ARGS()
         .FriendlyName( _( "Show Context Menu" ) )
         .Tooltip( _( "Perform the right-mouse-button action" ) )
         .Flags( AF_NONE )
-        .Parameter( CURSOR_RIGHT_CLICK ) );
+        .Parameter( CURSOR_RIGHT_CLICK )
+        .ToolbarState( TOOLBAR_STATE::HIDDEN ) );
 
 TOOL_ACTION ACTIONS::updateMenu( TOOL_ACTION_ARGS()
         .Name( "common.Interactive.updateMenu" )
+        .ToolbarState( TOOLBAR_STATE::HIDDEN )
         .Scope( AS_GLOBAL ) );
 
 TOOL_ACTION ACTIONS::undo( TOOL_ACTION_ARGS()
@@ -298,6 +301,7 @@ TOOL_ACTION ACTIONS::deleteTool( TOOL_ACTION_ARGS()
         .Scope( AS_GLOBAL )
         .FriendlyName( _( "Interactive Delete Tool" ) )
         .Tooltip( _( "Delete clicked items" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE )
         .Icon( BITMAPS::delete_cursor )
         .Flags( AF_ACTIVATE ) );
 
@@ -456,6 +460,7 @@ TOOL_ACTION ACTIONS::editTable( TOOL_ACTION_ARGS()
 
 TOOL_ACTION ACTIONS::activatePointEditor( TOOL_ACTION_ARGS()
         .Name( "common.Control.activatePointEditor" )
+        .ToolbarState( TOOLBAR_STATE::HIDDEN )
         .Scope( AS_GLOBAL ) );
 
 TOOL_ACTION ACTIONS::cycleArcEditMode( TOOL_ACTION_ARGS()
@@ -528,6 +533,7 @@ TOOL_ACTION ACTIONS::replaceAll( TOOL_ACTION_ARGS()
 
 TOOL_ACTION ACTIONS::updateFind( TOOL_ACTION_ARGS()
         .Name( "common.Control.updateFind" )
+        .ToolbarState( TOOLBAR_STATE::HIDDEN )
         .Scope( AS_GLOBAL ) );
 
 
@@ -667,6 +673,7 @@ TOOL_ACTION ACTIONS::zoomTool( TOOL_ACTION_ARGS()
         .LegacyHotkeyName( "Zoom to Selection" )
         .FriendlyName( _( "Zoom to Selection" ) )
         .Icon( BITMAPS::zoom_area )
+        .ToolbarState( { TOOLBAR_STATE::TOGGLE, TOOLBAR_STATE::CANCEL } )
         .Flags( AF_ACTIVATE ) );
 
 TOOL_ACTION ACTIONS::zoomUndo( TOOL_ACTION_ARGS()
@@ -703,6 +710,7 @@ TOOL_ACTION ACTIONS::cursorUp( TOOL_ACTION_ARGS()
         .Scope( AS_GLOBAL )
         .DefaultHotkey( WXK_UP )
         .FriendlyName( _( "Cursor Up" ) )
+        .ToolbarState( TOOLBAR_STATE::HIDDEN )
         .Flags( AF_NONE )
         .Parameter( CURSOR_UP ) );
 
@@ -711,6 +719,7 @@ TOOL_ACTION ACTIONS::cursorDown( TOOL_ACTION_ARGS()
         .Scope( AS_GLOBAL )
         .DefaultHotkey( WXK_DOWN )
         .FriendlyName( _( "Cursor Down" ) )
+        .ToolbarState( TOOLBAR_STATE::HIDDEN )
         .Flags( AF_NONE )
         .Parameter( CURSOR_DOWN ) );
 
@@ -719,6 +728,7 @@ TOOL_ACTION ACTIONS::cursorLeft( TOOL_ACTION_ARGS()
         .Scope( AS_GLOBAL )
         .DefaultHotkey( WXK_LEFT )
         .FriendlyName( _( "Cursor Left" ) )
+        .ToolbarState( TOOLBAR_STATE::HIDDEN )
         .Flags( AF_NONE )
         .Parameter( CURSOR_LEFT ) );
 
@@ -727,6 +737,7 @@ TOOL_ACTION ACTIONS::cursorRight( TOOL_ACTION_ARGS()
         .Scope( AS_GLOBAL )
         .DefaultHotkey( WXK_RIGHT )
         .FriendlyName( _( "Cursor Right" ) )
+        .ToolbarState( TOOLBAR_STATE::HIDDEN )
         .Flags( AF_NONE )
         .Parameter( CURSOR_RIGHT ) );
 
@@ -736,6 +747,7 @@ TOOL_ACTION ACTIONS::cursorUpFast( TOOL_ACTION_ARGS()
         .Scope( AS_GLOBAL )
         .DefaultHotkey( MD_CTRL + static_cast<int>( WXK_UP ) )
         .FriendlyName( _( "Cursor Up Fast" ) )
+        .ToolbarState( TOOLBAR_STATE::HIDDEN )
         .Flags( AF_NONE )
         .Parameter( CURSOR_UP_FAST ) );
 
@@ -744,6 +756,7 @@ TOOL_ACTION ACTIONS::cursorDownFast( TOOL_ACTION_ARGS()
         .Scope( AS_GLOBAL )
         .DefaultHotkey( MD_CTRL + static_cast<int>( WXK_DOWN ) )
         .FriendlyName( _( "Cursor Down Fast" ) )
+        .ToolbarState( TOOLBAR_STATE::HIDDEN )
         .Flags( AF_NONE )
         .Parameter( CURSOR_DOWN_FAST ) );
 
@@ -752,6 +765,7 @@ TOOL_ACTION ACTIONS::cursorLeftFast( TOOL_ACTION_ARGS()
         .Scope( AS_GLOBAL )
         .DefaultHotkey( MD_CTRL + static_cast<int>( WXK_LEFT ) )
         .FriendlyName( _( "Cursor Left Fast" ) )
+        .ToolbarState( TOOLBAR_STATE::HIDDEN )
         .Flags( AF_NONE )
         .Parameter( CURSOR_LEFT_FAST ) );
 
@@ -760,6 +774,7 @@ TOOL_ACTION ACTIONS::cursorRightFast( TOOL_ACTION_ARGS()
         .Scope( AS_GLOBAL )
         .DefaultHotkey( MD_CTRL + static_cast<int>( WXK_RIGHT ) )
         .FriendlyName( _( "Cursor Right Fast" ) )
+        .ToolbarState( TOOLBAR_STATE::HIDDEN )
         .Flags( AF_NONE )
         .Parameter( CURSOR_RIGHT_FAST ) );
 
@@ -770,6 +785,7 @@ TOOL_ACTION ACTIONS::cursorClick( TOOL_ACTION_ARGS()
         .LegacyHotkeyName( "Mouse Left Click" )
         .FriendlyName( _( "Click" ) )
         .Tooltip( _( "Performs left mouse button click" ) )
+        .ToolbarState( TOOLBAR_STATE::HIDDEN )
         .Flags( AF_NONE )
         .Parameter( CURSOR_CLICK ) );
 
@@ -780,11 +796,13 @@ TOOL_ACTION ACTIONS::cursorDblClick( TOOL_ACTION_ARGS()
         .LegacyHotkeyName( "Mouse Left Double Click" )
         .FriendlyName( _( "Double-click" ) )
         .Tooltip( _( "Performs left mouse button double-click" ) )
+        .ToolbarState( TOOLBAR_STATE::HIDDEN )
         .Flags( AF_NONE )
         .Parameter( CURSOR_DBL_CLICK ) );
 
 TOOL_ACTION ACTIONS::refreshPreview( TOOL_ACTION_ARGS()
         .Name( "common.Control.refreshPreview" )
+        .ToolbarState( TOOLBAR_STATE::HIDDEN )
         .Scope( AS_GLOBAL ) );
 
 TOOL_ACTION ACTIONS::pinLibrary( TOOL_ACTION_ARGS()
@@ -803,6 +821,7 @@ TOOL_ACTION ACTIONS::showLibraryTree( TOOL_ACTION_ARGS()
         .Name( "common.Control.showLibraryTree" )
         .Scope( AS_GLOBAL )
         .FriendlyName( _( "Library Tree" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE )
         .Icon( BITMAPS::search_tree ) );
 
 TOOL_ACTION ACTIONS::hideLibraryTree( TOOL_ACTION_ARGS()
@@ -825,7 +844,8 @@ TOOL_ACTION ACTIONS::libraryTreeSearch( TOOL_ACTION_ARGS()
         .Name( "common.Control.libraryTreeSearch" )
         .Scope( AS_GLOBAL )
         .FriendlyName( _( "Focus Library Tree Search Field" ) )
-        .DefaultHotkey( MD_CTRL + 'L' ) );
+        .DefaultHotkey( MD_CTRL + 'L' )
+        .ToolbarState( TOOLBAR_STATE::HIDDEN ) );
 
 TOOL_ACTION ACTIONS::panUp( TOOL_ACTION_ARGS()
         .Name( "common.Control.panUp" )
@@ -901,6 +921,7 @@ TOOL_ACTION ACTIONS::gridSetOrigin( TOOL_ACTION_ARGS()
         .LegacyHotkeyName( "Set Grid Origin" )
         .FriendlyName( _( "Grid Origin" ) )
         .Tooltip( _( "Place the grid origin point" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE )
         .Icon( BITMAPS::grid_select_axis )
         .Parameter<VECTOR2D*>( nullptr ) );
 
@@ -920,6 +941,7 @@ TOOL_ACTION ACTIONS::toggleGrid( TOOL_ACTION_ARGS()
         .Scope( AS_GLOBAL)
         .FriendlyName( _( "Show Grid" ) )
         .Tooltip( _( "Display background grid in the edit window" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE )
         .Icon( BITMAPS::grid ) );
 
 TOOL_ACTION ACTIONS::toggleGridOverrides( TOOL_ACTION_ARGS()
@@ -928,6 +950,7 @@ TOOL_ACTION ACTIONS::toggleGridOverrides( TOOL_ACTION_ARGS()
         .Scope( AS_GLOBAL)
         .FriendlyName( _( "Grid Overrides" ) )
         .Tooltip( _( "Enables item-specific grids that override the current grid" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE )
         .Icon( BITMAPS::grid_override ) );
 
 TOOL_ACTION ACTIONS::gridProperties( TOOL_ACTION_ARGS()
@@ -948,6 +971,7 @@ TOOL_ACTION ACTIONS::inchesUnits( TOOL_ACTION_ARGS()
         .Scope( AS_GLOBAL )
         .FriendlyName( _( "Inches" ) )
         .Icon( BITMAPS::unit_inch )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE )
         .Flags( AF_NONE )
         .Parameter( EDA_UNITS::INCHES ) );
 
@@ -955,6 +979,7 @@ TOOL_ACTION ACTIONS::milsUnits( TOOL_ACTION_ARGS()
         .Name( "common.Control.mils" )
         .Scope( AS_GLOBAL )
         .FriendlyName( _( "Mils" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE )
         .Icon( BITMAPS::unit_mil )
         .Flags( AF_NONE )
         .Parameter( EDA_UNITS::MILS ) );
@@ -963,20 +988,24 @@ TOOL_ACTION ACTIONS::millimetersUnits( TOOL_ACTION_ARGS()
         .Name( "common.Control.metricUnits" )
         .Scope( AS_GLOBAL )
         .FriendlyName( _( "Millimeters" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE )
         .Icon( BITMAPS::unit_mm )
         .Flags( AF_NONE )
         .Parameter( EDA_UNITS::MILLIMETRES ) );
 
 TOOL_ACTION ACTIONS::updateUnits( TOOL_ACTION_ARGS()
         .Name( "common.Control.updateUnits" )
+        .ToolbarState( TOOLBAR_STATE::HIDDEN )
         .Scope( AS_GLOBAL ) );
 
 TOOL_ACTION ACTIONS::updatePreferences( TOOL_ACTION_ARGS()
         .Name( "common.Control.updatePreferences" )
+        .ToolbarState( TOOLBAR_STATE::HIDDEN )
         .Scope( AS_GLOBAL ) );
 
 TOOL_ACTION ACTIONS::selectLibTreeColumns( TOOL_ACTION_ARGS()
         .Name( "common.Control.selectColumns" )
+        .ToolbarState( TOOLBAR_STATE::HIDDEN )
         .Scope( AS_GLOBAL )
         .FriendlyName( _( "Select Columns..." ) ) );
 
@@ -994,6 +1023,7 @@ TOOL_ACTION ACTIONS::togglePolarCoords( TOOL_ACTION_ARGS()
         .Scope( AS_GLOBAL )
         .FriendlyName( _( "Polar Coordinates" ) )
         .Tooltip( _( "Switch between polar and cartesian coordinate systems" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE )
         .Icon( BITMAPS::polar_coord ) );
 
 TOOL_ACTION ACTIONS::resetLocalCoords( TOOL_ACTION_ARGS()
@@ -1017,6 +1047,7 @@ TOOL_ACTION ACTIONS::toggleCursorStyle( TOOL_ACTION_ARGS()
         .Scope( AS_GLOBAL )
         .FriendlyName( _( "Full-Window Crosshairs" ) )
         .Tooltip( _( "Switch display of full-window crosshairs" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE )
         .Icon( BITMAPS::cursor_shape ) );
 
 TOOL_ACTION ACTIONS::highContrastMode( TOOL_ACTION_ARGS()
@@ -1025,6 +1056,7 @@ TOOL_ACTION ACTIONS::highContrastMode( TOOL_ACTION_ARGS()
         .LegacyHotkeyName( "Toggle High Contrast Mode" )
         .FriendlyName( _( "Inactive Layer View Mode" ) )
         .Tooltip( _( "Toggle inactive layers between normal and dimmed" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE )
         .Icon( BITMAPS::contrast_mode ) );
 
 TOOL_ACTION ACTIONS::highContrastModeCycle( TOOL_ACTION_ARGS()
@@ -1039,12 +1071,14 @@ TOOL_ACTION ACTIONS::toggleBoundingBoxes( TOOL_ACTION_ARGS()
         .Name( "common.Control.toggleBoundingBoxes" )
         .Scope( AS_GLOBAL )
         .FriendlyName( _( "Draw Bounding Boxes" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE )
         .Icon( BITMAPS::gerbview_show_negative_objects ) );
 
 TOOL_ACTION ACTIONS::selectionTool( TOOL_ACTION_ARGS()
         .Name( "common.InteractiveSelection.selectionTool" )
         .Scope( AS_GLOBAL )
         .FriendlyName( _( "Select item(s)" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE )
         .Icon( BITMAPS::cursor )
         .Flags( AF_ACTIVATE ) );
 
@@ -1056,16 +1090,19 @@ TOOL_ACTION ACTIONS::measureTool( TOOL_ACTION_ARGS()
         .LegacyHotkeyName( "Measure Distance (Modern Toolset only)" )
         .FriendlyName( _( "Measure Tool" ) )
         .Tooltip( _( "Interactively measure distance between points" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE )
         .Icon( BITMAPS::measurement )
         .Flags( AF_ACTIVATE ) );
 
 TOOL_ACTION ACTIONS::pickerTool( TOOL_ACTION_ARGS()
         .Name( "common.InteractivePicker.pickerTool" )
+        .ToolbarState( TOOLBAR_STATE::HIDDEN )
         .Scope( AS_GLOBAL )
         .Flags( AF_ACTIVATE ) );
 
 TOOL_ACTION ACTIONS::pickerSubTool( TOOL_ACTION_ARGS()
         .Name( "common.InteractivePicker.pickerSubTool" )
+        .ToolbarState( TOOLBAR_STATE::HIDDEN )
         .Scope( AS_GLOBAL ) );
 
 TOOL_ACTION ACTIONS::showProjectManager( TOOL_ACTION_ARGS()
@@ -1123,6 +1160,7 @@ TOOL_ACTION ACTIONS::showProperties( TOOL_ACTION_ARGS()
         .Scope( AS_GLOBAL )
         .FriendlyName( _( "Properties" ) )
         .Tooltip( _( "Show/hide the properties manager" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE )
         .Icon( BITMAPS::tools ) );
 
 TOOL_ACTION ACTIONS::showDatasheet( TOOL_ACTION_ARGS()
diff --git a/common/tool/tool_action.cpp b/common/tool/tool_action.cpp
index b5a856da27..5f745615b8 100644
--- a/common/tool/tool_action.cpp
+++ b/common/tool/tool_action.cpp
@@ -62,7 +62,6 @@ TOOL_ACTION::TOOL_ACTION() :
         m_group( std::nullopt ),
         m_defaultHotKey( 0 ),
         m_defaultHotKeyAlt( 0 ),
-        m_icon( BITMAPS::INVALID_BITMAP ),
         m_id( -1 ),
         m_flags( AF_NONE )
 {
@@ -80,7 +79,6 @@ TOOL_ACTION::TOOL_ACTION( const TOOL_ACTION_ARGS& aArgs ) :
         m_legacyName( aArgs.m_legacyName.value_or( "" ) ),
         m_friendlyName( TowxString( aArgs.m_friendlyName.value_or( "" ) ) ),
         m_tooltip( TowxString( aArgs.m_tooltip.value_or( "" ) ) ),
-        m_icon( aArgs.m_icon.value_or( BITMAPS::INVALID_BITMAP) ),
         m_id( -1 ),
         m_uiid( std::nullopt ),
         m_flags( aArgs.m_flags.value_or( AF_NONE ) )
@@ -103,6 +101,16 @@ TOOL_ACTION::TOOL_ACTION( const TOOL_ACTION_ARGS& aArgs ) :
     if( aArgs.m_group.has_value() )
         m_group = aArgs.m_group;
 
+    if( aArgs.m_icon.has_value() )
+        m_icon = aArgs.m_icon.value();
+
+    if( aArgs.m_toolbarState.has_value() )
+        m_toolbarState = aArgs.m_toolbarState.value();
+
+    // If there is no icon, then the action should be hidden from the toolbar
+    if( !m_icon.has_value() )
+        m_toolbarState.set( static_cast<size_t>( TOOLBAR_STATE::HIDDEN ) );
+
     ACTION_MANAGER::GetActionList().push_back( this );
 }
 
diff --git a/cvpcb/display_footprints_frame.cpp b/cvpcb/display_footprints_frame.cpp
index c737baadb1..b7e3a35351 100644
--- a/cvpcb/display_footprints_frame.cpp
+++ b/cvpcb/display_footprints_frame.cpp
@@ -244,22 +244,22 @@ void DISPLAY_FOOTPRINTS_FRAME::ReCreateOptToolbar()
         m_optionsToolBar->SetAuiManager( &m_auimgr );
     }
 
-    m_optionsToolBar->Add( ACTIONS::selectionTool,          ACTION_TOOLBAR::TOGGLE );
-    m_optionsToolBar->Add( ACTIONS::measureTool,            ACTION_TOOLBAR::TOGGLE );
+    m_optionsToolBar->Add( ACTIONS::selectionTool );
+    m_optionsToolBar->Add( ACTIONS::measureTool );
 
     m_optionsToolBar->AddScaledSeparator( this );
-    m_optionsToolBar->Add( ACTIONS::toggleGrid,             ACTION_TOOLBAR::TOGGLE );
-    m_optionsToolBar->Add( ACTIONS::togglePolarCoords,      ACTION_TOOLBAR::TOGGLE );
-    m_optionsToolBar->Add( ACTIONS::inchesUnits,            ACTION_TOOLBAR::TOGGLE );
-    m_optionsToolBar->Add( ACTIONS::milsUnits,              ACTION_TOOLBAR::TOGGLE );
-    m_optionsToolBar->Add( ACTIONS::millimetersUnits,       ACTION_TOOLBAR::TOGGLE );
-    m_optionsToolBar->Add( ACTIONS::toggleCursorStyle,      ACTION_TOOLBAR::TOGGLE );
+    m_optionsToolBar->Add( ACTIONS::toggleGrid );
+    m_optionsToolBar->Add( ACTIONS::togglePolarCoords );
+    m_optionsToolBar->Add( ACTIONS::inchesUnits );
+    m_optionsToolBar->Add( ACTIONS::milsUnits );
+    m_optionsToolBar->Add( ACTIONS::millimetersUnits );
+    m_optionsToolBar->Add( ACTIONS::toggleCursorStyle );
 
     m_optionsToolBar->AddScaledSeparator( this );
-    m_optionsToolBar->Add( PCB_ACTIONS::showPadNumbers,     ACTION_TOOLBAR::TOGGLE );
-    m_optionsToolBar->Add( PCB_ACTIONS::padDisplayMode,     ACTION_TOOLBAR::TOGGLE );
-    m_optionsToolBar->Add( PCB_ACTIONS::textOutlines,       ACTION_TOOLBAR::TOGGLE );
-    m_optionsToolBar->Add( PCB_ACTIONS::graphicsOutlines,   ACTION_TOOLBAR::TOGGLE );
+    m_optionsToolBar->Add( PCB_ACTIONS::showPadNumbers );
+    m_optionsToolBar->Add( PCB_ACTIONS::padDisplayMode );
+    m_optionsToolBar->Add( PCB_ACTIONS::textOutlines );
+    m_optionsToolBar->Add( PCB_ACTIONS::graphicsOutlines );
 
     m_optionsToolBar->Realize();
 }
@@ -289,7 +289,7 @@ void DISPLAY_FOOTPRINTS_FRAME::ReCreateHToolbar()
     m_mainToolBar->Add( ACTIONS::zoomInCenter );
     m_mainToolBar->Add( ACTIONS::zoomOutCenter );
     m_mainToolBar->Add( ACTIONS::zoomFitScreen );
-    m_mainToolBar->Add( ACTIONS::zoomTool, ACTION_TOOLBAR::TOGGLE, ACTION_TOOLBAR::CANCEL );
+    m_mainToolBar->Add( ACTIONS::zoomTool );
 
     m_mainToolBar->AddScaledSeparator( this );
     m_mainToolBar->Add( ACTIONS::show3DViewer );
diff --git a/eeschema/symbol_editor/toolbars_symbol_editor.cpp b/eeschema/symbol_editor/toolbars_symbol_editor.cpp
index db25b4a369..14b6df1228 100644
--- a/eeschema/symbol_editor/toolbars_symbol_editor.cpp
+++ b/eeschema/symbol_editor/toolbars_symbol_editor.cpp
@@ -59,20 +59,20 @@ void SYMBOL_EDIT_FRAME::ReCreateVToolbar()
 
     // Set up toolbar
     // clang-format off
-    m_drawToolBar->Add( ACTIONS::selectionTool,           ACTION_TOOLBAR::TOGGLE );
+    m_drawToolBar->Add( ACTIONS::selectionTool );
 
     m_drawToolBar->AddScaledSeparator( this );
-    m_drawToolBar->Add( EE_ACTIONS::placeSymbolPin,       ACTION_TOOLBAR::TOGGLE );
-    m_drawToolBar->Add( EE_ACTIONS::placeSymbolText,      ACTION_TOOLBAR::TOGGLE );
-    m_drawToolBar->Add( EE_ACTIONS::drawSymbolTextBox,    ACTION_TOOLBAR::TOGGLE );
-    m_drawToolBar->Add( EE_ACTIONS::drawRectangle,        ACTION_TOOLBAR::TOGGLE );
-    m_drawToolBar->Add( EE_ACTIONS::drawCircle,           ACTION_TOOLBAR::TOGGLE );
-    m_drawToolBar->Add( EE_ACTIONS::drawArc,              ACTION_TOOLBAR::TOGGLE );
-    m_drawToolBar->Add( EE_ACTIONS::drawBezier,           ACTION_TOOLBAR::TOGGLE );
-    m_drawToolBar->Add( EE_ACTIONS::drawSymbolLines,      ACTION_TOOLBAR::TOGGLE );
-    m_drawToolBar->Add( EE_ACTIONS::drawSymbolPolygon,    ACTION_TOOLBAR::TOGGLE );
-    m_drawToolBar->Add( EE_ACTIONS::placeSymbolAnchor,    ACTION_TOOLBAR::TOGGLE );
-    m_drawToolBar->Add( ACTIONS::deleteTool,              ACTION_TOOLBAR::TOGGLE );
+    m_drawToolBar->Add( EE_ACTIONS::placeSymbolPin );
+    m_drawToolBar->Add( EE_ACTIONS::placeSymbolText );
+    m_drawToolBar->Add( EE_ACTIONS::drawSymbolTextBox );
+    m_drawToolBar->Add( EE_ACTIONS::drawRectangle );
+    m_drawToolBar->Add( EE_ACTIONS::drawCircle );
+    m_drawToolBar->Add( EE_ACTIONS::drawArc );
+    m_drawToolBar->Add( EE_ACTIONS::drawBezier );
+    m_drawToolBar->Add( EE_ACTIONS::drawSymbolLines );
+    m_drawToolBar->Add( EE_ACTIONS::drawSymbolPolygon );
+    m_drawToolBar->Add( EE_ACTIONS::placeSymbolAnchor );
+    m_drawToolBar->Add( ACTIONS::deleteTool);
     // clang-format on
 
     m_drawToolBar->Realize();
@@ -109,7 +109,7 @@ void SYMBOL_EDIT_FRAME::ReCreateHToolbar()
     m_mainToolBar->Add( ACTIONS::zoomInCenter );
     m_mainToolBar->Add( ACTIONS::zoomOutCenter );
     m_mainToolBar->Add( ACTIONS::zoomFitScreen );
-    m_mainToolBar->Add( ACTIONS::zoomTool, ACTION_TOOLBAR::TOGGLE, ACTION_TOOLBAR::CANCEL );
+    m_mainToolBar->Add( ACTIONS::zoomTool );
 
     m_mainToolBar->AddScaledSeparator( this );
     m_mainToolBar->Add( EE_ACTIONS::rotateCCW );
@@ -126,8 +126,8 @@ void SYMBOL_EDIT_FRAME::ReCreateHToolbar()
     m_mainToolBar->Add( EE_ACTIONS::checkSymbol );
 
     m_mainToolBar->AddScaledSeparator( this );
-    m_mainToolBar->Add( EE_ACTIONS::showDeMorganStandard,  ACTION_TOOLBAR::TOGGLE );
-    m_mainToolBar->Add( EE_ACTIONS::showDeMorganAlternate, ACTION_TOOLBAR::TOGGLE );
+    m_mainToolBar->Add( EE_ACTIONS::showDeMorganStandard );
+    m_mainToolBar->Add( EE_ACTIONS::showDeMorganAlternate );
 
     m_mainToolBar->AddScaledSeparator( this );
 
@@ -138,7 +138,7 @@ void SYMBOL_EDIT_FRAME::ReCreateHToolbar()
     m_mainToolBar->AddControl( m_unitSelectBox );
 
     m_mainToolBar->AddScaledSeparator( this );
-    m_mainToolBar->Add( EE_ACTIONS::toggleSyncedPinsMode, ACTION_TOOLBAR::TOGGLE );
+    m_mainToolBar->Add( EE_ACTIONS::toggleSyncedPinsMode );
 
     m_mainToolBar->AddScaledSeparator( this );
     m_mainToolBar->Add( EE_ACTIONS::addSymbolToSchematic );
@@ -162,25 +162,25 @@ void SYMBOL_EDIT_FRAME::ReCreateOptToolbar()
         m_optionsToolBar->SetAuiManager( &m_auimgr );
     }
 
-    m_optionsToolBar->Add( ACTIONS::toggleGrid,             ACTION_TOOLBAR::TOGGLE );
-    m_optionsToolBar->Add( ACTIONS::toggleGridOverrides,    ACTION_TOOLBAR::TOGGLE );
-    m_optionsToolBar->Add( ACTIONS::inchesUnits,            ACTION_TOOLBAR::TOGGLE );
-    m_optionsToolBar->Add( ACTIONS::milsUnits,              ACTION_TOOLBAR::TOGGLE );
-    m_optionsToolBar->Add( ACTIONS::millimetersUnits,       ACTION_TOOLBAR::TOGGLE );
-    m_optionsToolBar->Add( ACTIONS::toggleCursorStyle,      ACTION_TOOLBAR::TOGGLE );
+    m_optionsToolBar->Add( ACTIONS::toggleGrid );
+    m_optionsToolBar->Add( ACTIONS::toggleGridOverrides );
+    m_optionsToolBar->Add( ACTIONS::inchesUnits );
+    m_optionsToolBar->Add( ACTIONS::milsUnits );
+    m_optionsToolBar->Add( ACTIONS::millimetersUnits );
+    m_optionsToolBar->Add( ACTIONS::toggleCursorStyle );
 
     m_optionsToolBar->AddScaledSeparator( this );
-    m_optionsToolBar->Add( EE_ACTIONS::showElectricalTypes, ACTION_TOOLBAR::TOGGLE );
-    m_optionsToolBar->Add( EE_ACTIONS::showHiddenPins,      ACTION_TOOLBAR::TOGGLE );
-    m_optionsToolBar->Add( EE_ACTIONS::showHiddenFields,    ACTION_TOOLBAR::TOGGLE );
-    // m_optionsToolBar->Add( EE_ACTIONS::togglePinAltIcons,   ACTION_TOOLBAR::TOGGLE );
+    m_optionsToolBar->Add( EE_ACTIONS::showElectricalTypes );
+    m_optionsToolBar->Add( EE_ACTIONS::showHiddenPins );
+    m_optionsToolBar->Add( EE_ACTIONS::showHiddenFields );
+    // m_optionsToolBar->Add( EE_ACTIONS::togglePinAltIcons );
 
     if( ADVANCED_CFG::GetCfg().m_DrawBoundingBoxes )
-        m_optionsToolBar->Add( ACTIONS::toggleBoundingBoxes, ACTION_TOOLBAR::TOGGLE );
+        m_optionsToolBar->Add( ACTIONS::toggleBoundingBoxes );
 
     m_optionsToolBar->AddScaledSeparator( this );
-    m_optionsToolBar->Add( ACTIONS::showLibraryTree,        ACTION_TOOLBAR::TOGGLE );
-    m_optionsToolBar->Add( ACTIONS::showProperties,         ACTION_TOOLBAR::TOGGLE );
+    m_optionsToolBar->Add( ACTIONS::showLibraryTree );
+    m_optionsToolBar->Add( ACTIONS::showProperties );
 
     EE_SELECTION_TOOL* selTool = m_toolManager->GetTool<EE_SELECTION_TOOL>();
     std::unique_ptr<ACTION_MENU> gridMenu = std::make_unique<ACTION_MENU>( false, selTool );
diff --git a/eeschema/toolbars_sch_editor.cpp b/eeschema/toolbars_sch_editor.cpp
index a3a5220135..5c41399a56 100644
--- a/eeschema/toolbars_sch_editor.cpp
+++ b/eeschema/toolbars_sch_editor.cpp
@@ -94,7 +94,7 @@ void SCH_EDIT_FRAME::ReCreateHToolbar()
     m_mainToolBar->Add( ACTIONS::zoomOutCenter );
     m_mainToolBar->Add( ACTIONS::zoomFitScreen );
     m_mainToolBar->Add( ACTIONS::zoomFitObjects );
-    m_mainToolBar->Add( ACTIONS::zoomTool, ACTION_TOOLBAR::TOGGLE, ACTION_TOOLBAR::CANCEL );
+    m_mainToolBar->Add( ACTIONS::zoomTool );
 
     m_mainToolBar->AddScaledSeparator( this );
     m_mainToolBar->Add( EE_ACTIONS::navigateBack );
@@ -161,37 +161,37 @@ void SCH_EDIT_FRAME::ReCreateVToolbar()
 
     // Set up toolbar
     // clang-format off
-    m_drawToolBar->Add( ACTIONS::selectionTool,             ACTION_TOOLBAR::TOGGLE );
-    m_drawToolBar->Add( EE_ACTIONS::highlightNetTool,       ACTION_TOOLBAR::TOGGLE );
+    m_drawToolBar->Add( ACTIONS::selectionTool );
+    m_drawToolBar->Add( EE_ACTIONS::highlightNetTool );
 
     m_drawToolBar->AddScaledSeparator( this );
-    m_drawToolBar->Add( EE_ACTIONS::placeSymbol,            ACTION_TOOLBAR::TOGGLE );
-    m_drawToolBar->Add( EE_ACTIONS::placePower,             ACTION_TOOLBAR::TOGGLE );
-    m_drawToolBar->Add( EE_ACTIONS::drawWire,               ACTION_TOOLBAR::TOGGLE );
-    m_drawToolBar->Add( EE_ACTIONS::drawBus,                ACTION_TOOLBAR::TOGGLE );
-    m_drawToolBar->Add( EE_ACTIONS::placeBusWireEntry,      ACTION_TOOLBAR::TOGGLE );
-    m_drawToolBar->Add( EE_ACTIONS::placeNoConnect,         ACTION_TOOLBAR::TOGGLE );
-    m_drawToolBar->Add( EE_ACTIONS::placeJunction,          ACTION_TOOLBAR::TOGGLE );
-    m_drawToolBar->Add( EE_ACTIONS::placeLabel,             ACTION_TOOLBAR::TOGGLE );
-    m_drawToolBar->Add( EE_ACTIONS::placeClassLabel,        ACTION_TOOLBAR::TOGGLE );
-    m_drawToolBar->Add( EE_ACTIONS::drawRuleArea,           ACTION_TOOLBAR::TOGGLE );
-    m_drawToolBar->Add( EE_ACTIONS::placeGlobalLabel,       ACTION_TOOLBAR::TOGGLE );
-    m_drawToolBar->Add( EE_ACTIONS::placeHierLabel,         ACTION_TOOLBAR::TOGGLE );
-    m_drawToolBar->Add( EE_ACTIONS::drawSheet,              ACTION_TOOLBAR::TOGGLE );
-    m_drawToolBar->Add( EE_ACTIONS::placeSheetPin,          ACTION_TOOLBAR::TOGGLE );
+    m_drawToolBar->Add( EE_ACTIONS::placeSymbol );
+    m_drawToolBar->Add( EE_ACTIONS::placePower );
+    m_drawToolBar->Add( EE_ACTIONS::drawWire );
+    m_drawToolBar->Add( EE_ACTIONS::drawBus );
+    m_drawToolBar->Add( EE_ACTIONS::placeBusWireEntry );
+    m_drawToolBar->Add( EE_ACTIONS::placeNoConnect );
+    m_drawToolBar->Add( EE_ACTIONS::placeJunction );
+    m_drawToolBar->Add( EE_ACTIONS::placeLabel );
+    m_drawToolBar->Add( EE_ACTIONS::placeClassLabel );
+    m_drawToolBar->Add( EE_ACTIONS::drawRuleArea );
+    m_drawToolBar->Add( EE_ACTIONS::placeGlobalLabel );
+    m_drawToolBar->Add( EE_ACTIONS::placeHierLabel );
+    m_drawToolBar->Add( EE_ACTIONS::drawSheet );
+    m_drawToolBar->Add( EE_ACTIONS::placeSheetPin );
     m_drawToolBar->Add( EE_ACTIONS::syncAllSheetsPins );
 
     m_drawToolBar->AddScaledSeparator( this );
-    m_drawToolBar->Add( EE_ACTIONS::placeSchematicText,     ACTION_TOOLBAR::TOGGLE );
-    m_drawToolBar->Add( EE_ACTIONS::drawTextBox,            ACTION_TOOLBAR::TOGGLE );
-    m_drawToolBar->Add( EE_ACTIONS::drawTable,              ACTION_TOOLBAR::TOGGLE );
-    m_drawToolBar->Add( EE_ACTIONS::drawRectangle,          ACTION_TOOLBAR::TOGGLE );
-    m_drawToolBar->Add( EE_ACTIONS::drawCircle,             ACTION_TOOLBAR::TOGGLE );
-    m_drawToolBar->Add( EE_ACTIONS::drawArc,                ACTION_TOOLBAR::TOGGLE );
-    m_drawToolBar->Add( EE_ACTIONS::drawBezier,             ACTION_TOOLBAR::TOGGLE );
-    m_drawToolBar->Add( EE_ACTIONS::drawLines,              ACTION_TOOLBAR::TOGGLE );
-    m_drawToolBar->Add( EE_ACTIONS::placeImage,             ACTION_TOOLBAR::TOGGLE );
-    m_drawToolBar->Add( ACTIONS::deleteTool,                ACTION_TOOLBAR::TOGGLE );
+    m_drawToolBar->Add( EE_ACTIONS::placeSchematicText );
+    m_drawToolBar->Add( EE_ACTIONS::drawTextBox );
+    m_drawToolBar->Add( EE_ACTIONS::drawTable );
+    m_drawToolBar->Add( EE_ACTIONS::drawRectangle );
+    m_drawToolBar->Add( EE_ACTIONS::drawCircle );
+    m_drawToolBar->Add( EE_ACTIONS::drawArc );
+    m_drawToolBar->Add( EE_ACTIONS::drawBezier );
+    m_drawToolBar->Add( EE_ACTIONS::drawLines );
+    m_drawToolBar->Add( EE_ACTIONS::placeImage );
+    m_drawToolBar->Add( ACTIONS::deleteTool );
     // clang-format on
 
     m_drawToolBar->KiRealize();
@@ -214,30 +214,30 @@ void SCH_EDIT_FRAME::ReCreateOptToolbar()
         m_optionsToolBar->SetAuiManager( &m_auimgr );
     }
 
-    m_optionsToolBar->Add( ACTIONS::toggleGrid,          ACTION_TOOLBAR::TOGGLE );
-    m_optionsToolBar->Add( ACTIONS::toggleGridOverrides, ACTION_TOOLBAR::TOGGLE );
-    m_optionsToolBar->Add( ACTIONS::inchesUnits,         ACTION_TOOLBAR::TOGGLE );
-    m_optionsToolBar->Add( ACTIONS::milsUnits,           ACTION_TOOLBAR::TOGGLE );
-    m_optionsToolBar->Add( ACTIONS::millimetersUnits,    ACTION_TOOLBAR::TOGGLE );
-    m_optionsToolBar->Add( ACTIONS::toggleCursorStyle,   ACTION_TOOLBAR::TOGGLE );
+    m_optionsToolBar->Add( ACTIONS::toggleGrid );
+    m_optionsToolBar->Add( ACTIONS::toggleGridOverrides );
+    m_optionsToolBar->Add( ACTIONS::inchesUnits );
+    m_optionsToolBar->Add( ACTIONS::milsUnits );
+    m_optionsToolBar->Add( ACTIONS::millimetersUnits );
+    m_optionsToolBar->Add( ACTIONS::toggleCursorStyle );
 
     m_optionsToolBar->AddScaledSeparator( this );
-    m_optionsToolBar->Add( EE_ACTIONS::toggleHiddenPins, ACTION_TOOLBAR::TOGGLE );
+    m_optionsToolBar->Add( EE_ACTIONS::toggleHiddenPins );
 
     m_optionsToolBar->AddScaledSeparator( this );
-    m_optionsToolBar->Add( EE_ACTIONS::lineModeFree,     ACTION_TOOLBAR::TOGGLE );
-    m_optionsToolBar->Add( EE_ACTIONS::lineMode90,       ACTION_TOOLBAR::TOGGLE );
-    m_optionsToolBar->Add( EE_ACTIONS::lineMode45,       ACTION_TOOLBAR::TOGGLE );
+    m_optionsToolBar->Add( EE_ACTIONS::lineModeFree );
+    m_optionsToolBar->Add( EE_ACTIONS::lineMode90 );
+    m_optionsToolBar->Add( EE_ACTIONS::lineMode45 );
 
     m_optionsToolBar->AddScaledSeparator( this );
-    m_optionsToolBar->Add( EE_ACTIONS::toggleAnnotateAuto,      ACTION_TOOLBAR::TOGGLE );
+    m_optionsToolBar->Add( EE_ACTIONS::toggleAnnotateAuto );
 
     m_optionsToolBar->AddScaledSeparator( this );
-    m_optionsToolBar->Add( EE_ACTIONS::showHierarchy,           ACTION_TOOLBAR::TOGGLE );
-    m_optionsToolBar->Add( ACTIONS::showProperties,             ACTION_TOOLBAR::TOGGLE );
+    m_optionsToolBar->Add( EE_ACTIONS::showHierarchy );
+    m_optionsToolBar->Add( ACTIONS::showProperties );
 
     if( ADVANCED_CFG::GetCfg().m_DrawBoundingBoxes )
-        m_optionsToolBar->Add( ACTIONS::toggleBoundingBoxes,    ACTION_TOOLBAR::TOGGLE );
+        m_optionsToolBar->Add( ACTIONS::toggleBoundingBoxes );
 
     EE_SELECTION_TOOL* selTool = m_toolManager->GetTool<EE_SELECTION_TOOL>();
     std::unique_ptr<ACTION_MENU> gridMenu = std::make_unique<ACTION_MENU>( false, selTool );
diff --git a/eeschema/toolbars_symbol_viewer.cpp b/eeschema/toolbars_symbol_viewer.cpp
index 54d05fa639..d559b54979 100644
--- a/eeschema/toolbars_symbol_viewer.cpp
+++ b/eeschema/toolbars_symbol_viewer.cpp
@@ -62,12 +62,12 @@ void SYMBOL_VIEWER_FRAME::ReCreateHToolbar()
     m_mainToolBar->Add( ACTIONS::zoomFitScreen );
 
     m_mainToolBar->AddScaledSeparator( this );
-    m_mainToolBar->Add( EE_ACTIONS::showElectricalTypes,   ACTION_TOOLBAR::TOGGLE );
-    m_mainToolBar->Add( EE_ACTIONS::showPinNumbers,        ACTION_TOOLBAR::TOGGLE );
+    m_mainToolBar->Add( EE_ACTIONS::showElectricalTypes );
+    m_mainToolBar->Add( EE_ACTIONS::showPinNumbers );
 
     m_mainToolBar->AddScaledSeparator( this );
-    m_mainToolBar->Add( EE_ACTIONS::showDeMorganStandard,  ACTION_TOOLBAR::TOGGLE );
-    m_mainToolBar->Add( EE_ACTIONS::showDeMorganAlternate, ACTION_TOOLBAR::TOGGLE );
+    m_mainToolBar->Add( EE_ACTIONS::showDeMorganStandard );
+    m_mainToolBar->Add( EE_ACTIONS::showDeMorganAlternate );
 
     m_mainToolBar->AddScaledSeparator( this );
 
diff --git a/eeschema/tools/ee_actions.cpp b/eeschema/tools/ee_actions.cpp
index 73385ba3a9..91caf8010f 100644
--- a/eeschema/tools/ee_actions.cpp
+++ b/eeschema/tools/ee_actions.cpp
@@ -293,6 +293,7 @@ TOOL_ACTION EE_ACTIONS::showElectricalTypes( TOOL_ACTION_ARGS()
         .Scope( AS_GLOBAL )
         .FriendlyName( _( "Show Pin Electrical Types" ) )
         .Tooltip( _( "Annotate pins with their electrical types" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE )
         .Icon( BITMAPS::pin_show_etype ) );
 
 TOOL_ACTION EE_ACTIONS::showPinNumbers( TOOL_ACTION_ARGS()
@@ -300,6 +301,7 @@ TOOL_ACTION EE_ACTIONS::showPinNumbers( TOOL_ACTION_ARGS()
         .Scope( AS_GLOBAL )
         .FriendlyName( _( "Show Pin Numbers" ) )
         .Tooltip( _( "Annotate pins with their numbers" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE )
         .Icon( BITMAPS::pin ) );
 
 TOOL_ACTION EE_ACTIONS::exportSymbolView( TOOL_ACTION_ARGS()
@@ -323,18 +325,21 @@ TOOL_ACTION EE_ACTIONS::toggleSyncedPinsMode( TOOL_ACTION_ARGS()
         .Tooltip( _( "Synchronized Pins Mode\n"
                      "When enabled propagates all changes (except pin numbers) to other units.\n"
                      "Enabled by default for multiunit parts with interchangeable units." ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE )
         .Icon( BITMAPS::pin2pin ) );
 
 TOOL_ACTION EE_ACTIONS::showHiddenPins( TOOL_ACTION_ARGS()
         .Name( "eeschema.SymbolLibraryControl.showHiddenPins" )
         .Scope( AS_GLOBAL )
         .FriendlyName( _( "Show Hidden Pins" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE )
         .Icon( BITMAPS::hidden_pin ) );
 
 TOOL_ACTION EE_ACTIONS::showHiddenFields( TOOL_ACTION_ARGS()
         .Name( "eeschema.SymbolLibraryControl.showHiddenFields" )
         .Scope( AS_GLOBAL )
         .FriendlyName( _( "Show Hidden Fields" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE )
         .Icon( BITMAPS::text_sketch ) );
 
 
@@ -346,6 +351,7 @@ TOOL_ACTION EE_ACTIONS::placeSymbolPin( TOOL_ACTION_ARGS()
         .DefaultHotkey( 'P' )
         .LegacyHotkeyName( "Create Pin" )
         .FriendlyName( _( "Draw Pins" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE )
         .Icon( BITMAPS::pin )
         .Flags( AF_ACTIVATE )
         .Parameter( SCH_PIN_T ) );
@@ -354,6 +360,7 @@ TOOL_ACTION EE_ACTIONS::placeSymbolText( TOOL_ACTION_ARGS()
         .Name( "eeschema.SymbolDrawing.placeSymbolText" )
         .Scope( AS_GLOBAL )
         .FriendlyName( _( "Draw Text" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE )
         .Icon( BITMAPS::text )
         .Flags( AF_ACTIVATE )
         .Parameter( SCH_TEXT_T ) );
@@ -362,6 +369,7 @@ TOOL_ACTION EE_ACTIONS::drawSymbolTextBox( TOOL_ACTION_ARGS()
         .Name( "eeschema.SymbolDrawing.drawSymbolTextBox" )
         .Scope( AS_GLOBAL )
         .FriendlyName( _( "Draw Text Boxes" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE )
         .Icon( BITMAPS::add_textbox )
         .Flags( AF_ACTIVATE ) );
 
@@ -370,6 +378,7 @@ TOOL_ACTION EE_ACTIONS::drawSymbolLines( TOOL_ACTION_ARGS()
         .Scope( AS_GLOBAL )
         .FriendlyName( _( "Draw Lines" ) )
         .Tooltip( _( "Draw connected graphic lines" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE )
         .Icon( BITMAPS::add_graphical_segments )
         .Flags( AF_ACTIVATE )
         .Parameter( SHAPE_T::POLY ) );
@@ -378,6 +387,7 @@ TOOL_ACTION EE_ACTIONS::drawSymbolPolygon( TOOL_ACTION_ARGS()
         .Name( "eeschema.SymbolDrawing.drawSymbolPolygon" )
         .Scope( AS_GLOBAL )
         .FriendlyName( _( "Draw Polygons" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE )
         .Icon( BITMAPS::add_graphical_polygon )
         .Flags( AF_ACTIVATE )
         .Parameter( SHAPE_T::POLY ) );
@@ -386,6 +396,7 @@ TOOL_ACTION EE_ACTIONS::placeSymbolAnchor( TOOL_ACTION_ARGS()
         .Name( "eeschema.SymbolDrawing.placeSymbolAnchor" )
         .Scope( AS_GLOBAL )
         .FriendlyName( _( "Move Symbol Anchor" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE )
         .Icon( BITMAPS::anchor  )
         .Flags( AF_ACTIVATE ) );
 
@@ -421,6 +432,7 @@ TOOL_ACTION EE_ACTIONS::placeSymbol( TOOL_ACTION_ARGS()
         .DefaultHotkey( 'A' )
         .LegacyHotkeyName( "Add Symbol" )
         .FriendlyName( _( "Place Symbols" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE )
         .Icon( BITMAPS::add_component )
         .Flags( AF_ACTIVATE )
         .Parameter<EE_ACTIONS::PLACE_SYMBOL_PARAMS>( {} ) );
@@ -440,6 +452,7 @@ TOOL_ACTION EE_ACTIONS::placePower( TOOL_ACTION_ARGS()
         .DefaultHotkey( 'P' )
         .LegacyHotkeyName( "Add Power" )
         .FriendlyName( _( "Place Power Symbols" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE )
         .Icon( BITMAPS::add_power )
         .Flags( AF_ACTIVATE )
         .Parameter<EE_ACTIONS::PLACE_SYMBOL_PARAMS>( {} ) );
@@ -461,6 +474,7 @@ TOOL_ACTION EE_ACTIONS::placeNoConnect( TOOL_ACTION_ARGS()
         .DefaultHotkey( 'Q' )
         .LegacyHotkeyName( "Add No Connect Flag" )
         .FriendlyName( _( "Place No Connect Flags" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE )
         .Icon( BITMAPS::noconn )
         .Flags( AF_ACTIVATE )
         .Parameter( SCH_NO_CONNECT_T ) );
@@ -471,6 +485,7 @@ TOOL_ACTION EE_ACTIONS::placeJunction( TOOL_ACTION_ARGS()
         .DefaultHotkey( 'J' )
         .LegacyHotkeyName( "Add Junction" )
         .FriendlyName( _( "Place Junctions" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE )
         .Icon( BITMAPS::add_junction )
         .Flags( AF_ACTIVATE )
         .Parameter( SCH_JUNCTION_T ) );
@@ -481,6 +496,7 @@ TOOL_ACTION EE_ACTIONS::placeBusWireEntry( TOOL_ACTION_ARGS()
         .DefaultHotkey( 'Z' )
         .LegacyHotkeyName( "Add Wire Entry" )
         .FriendlyName( _( "Place Wire to Bus Entries" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE )
         .Icon( BITMAPS::add_line2bus )
         .Flags( AF_ACTIVATE )
         .Parameter( SCH_BUS_WIRE_ENTRY_T ) );
@@ -491,16 +507,17 @@ TOOL_ACTION EE_ACTIONS::placeLabel( TOOL_ACTION_ARGS()
         .DefaultHotkey( 'L' )
         .LegacyHotkeyName( "Add Label" )
         .FriendlyName( _( "Place Net Labels" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE )
         .Icon( BITMAPS::add_label )
         .Flags( AF_ACTIVATE ) );
 
-TOOL_ACTION
-        EE_ACTIONS::placeClassLabel( TOOL_ACTION_ARGS()
-                                             .Name( "eeschema.InteractiveDrawing.placeClassLabel" )
-                                             .Scope( AS_GLOBAL )
-                                             .FriendlyName( _( "Place Directive Labels" ) )
-                                             .Icon( BITMAPS::add_class_flag )
-                                             .Flags( AF_ACTIVATE ) );
+TOOL_ACTION EE_ACTIONS::placeClassLabel( TOOL_ACTION_ARGS()
+        .Name( "eeschema.InteractiveDrawing.placeClassLabel" )
+        .Scope( AS_GLOBAL )
+        .FriendlyName( _( "Place Directive Labels" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE )
+        .Icon( BITMAPS::add_class_flag )
+        .Flags( AF_ACTIVATE ) );
 
 TOOL_ACTION EE_ACTIONS::placeHierLabel( TOOL_ACTION_ARGS()
         .Name( "eeschema.InteractiveDrawing.placeHierarchicalLabel" )
@@ -508,6 +525,7 @@ TOOL_ACTION EE_ACTIONS::placeHierLabel( TOOL_ACTION_ARGS()
         .DefaultHotkey( 'H' )
         .LegacyHotkeyName( "Add Hierarchical Label" )
         .FriendlyName( _( "Place Hierarchical Labels" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE )
         .Icon( BITMAPS::add_hierarchical_label )
         .Flags( AF_ACTIVATE ) );
 
@@ -517,6 +535,7 @@ TOOL_ACTION EE_ACTIONS::drawSheet( TOOL_ACTION_ARGS()
         .DefaultHotkey( 'S' )
         .LegacyHotkeyName( "Add Sheet" )
         .FriendlyName( _( "Draw Hierarchical Sheets" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE )
         .Icon( BITMAPS::add_hierarchical_subsheet )
         .Flags( AF_ACTIVATE )
         .Parameter( SCH_SHEET_T ) );
@@ -543,6 +562,7 @@ TOOL_ACTION EE_ACTIONS::placeSheetPin( TOOL_ACTION_ARGS()
         .Name( "eeschema.InteractiveDrawing.placeSheetPin" )
         .Scope( AS_GLOBAL )
         .FriendlyName( _( "Place Sheet Pins" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE )
         .Icon( BITMAPS::add_hierar_pin )
         .Flags( AF_ACTIVATE ) );
 
@@ -583,6 +603,7 @@ TOOL_ACTION EE_ACTIONS::placeGlobalLabel( TOOL_ACTION_ARGS()
         .DefaultHotkey( MD_CTRL + 'L' )
         .LegacyHotkeyName( "Add Global Label" )
         .FriendlyName( _( "Place Global Labels" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE )
         .Icon( BITMAPS::add_glabel )
         .Flags( AF_ACTIVATE ) );
 
@@ -592,6 +613,7 @@ TOOL_ACTION EE_ACTIONS::placeSchematicText( TOOL_ACTION_ARGS()
         .DefaultHotkey( 'T' )
         .LegacyHotkeyName( "Add Graphic Text" )
         .FriendlyName( _( "Draw Text" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE )
         .Icon( BITMAPS::text )
         .Flags( AF_ACTIVATE ) );
 
@@ -599,6 +621,7 @@ TOOL_ACTION EE_ACTIONS::drawTextBox( TOOL_ACTION_ARGS()
         .Name( "eeschema.InteractiveDrawing.drawTextBox" )
         .Scope( AS_GLOBAL )
         .FriendlyName( _( "Draw Text Boxes" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE )
         .Icon( BITMAPS::add_textbox )
         .Flags( AF_ACTIVATE )
         .Parameter( SHAPE_T::RECTANGLE ) );
@@ -607,6 +630,7 @@ TOOL_ACTION EE_ACTIONS::drawTable( TOOL_ACTION_ARGS()
         .Name( "eeschema.InteractiveDrawing.drawTable" )
         .Scope( AS_GLOBAL )
         .FriendlyName( _( "Draw Tables" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE )
         .Icon( BITMAPS::table )
         .Flags( AF_ACTIVATE ) );
 
@@ -614,6 +638,7 @@ TOOL_ACTION EE_ACTIONS::drawRectangle( TOOL_ACTION_ARGS()
         .Name( "eeschema.InteractiveDrawing.drawRectangle" )
         .Scope( AS_GLOBAL )
         .FriendlyName( _( "Draw Rectangles" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE )
         .Icon( BITMAPS::add_rectangle )
         .Flags( AF_ACTIVATE )
         .Parameter( SHAPE_T::RECTANGLE ) );
@@ -622,6 +647,7 @@ TOOL_ACTION EE_ACTIONS::drawCircle( TOOL_ACTION_ARGS()
         .Name( "eeschema.InteractiveDrawing.drawCircle" )
         .Scope( AS_GLOBAL )
         .FriendlyName( _( "Draw Circles" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE )
         .Icon( BITMAPS::add_circle )
         .Flags( AF_ACTIVATE )
         .Parameter( SHAPE_T::CIRCLE ) );
@@ -630,6 +656,7 @@ TOOL_ACTION EE_ACTIONS::drawArc( TOOL_ACTION_ARGS()
         .Name( "eeschema.InteractiveDrawing.drawArc" )
         .Scope( AS_GLOBAL )
         .FriendlyName( _( "Draw Arcs" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE )
         .Icon( BITMAPS::add_arc )
         .Flags( AF_ACTIVATE )
         .Parameter( SHAPE_T::ARC ) );
@@ -638,6 +665,7 @@ TOOL_ACTION EE_ACTIONS::drawBezier( TOOL_ACTION_ARGS()
         .Name( "eeschema.InteractiveDrawing.drawBezier" )
         .Scope( AS_GLOBAL )
         .FriendlyName( _( "Draw Bezier Curve" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE )
         .Icon( BITMAPS::add_bezier )
         .Flags( AF_ACTIVATE )
         .Parameter( SHAPE_T::BEZIER ) );
@@ -646,6 +674,7 @@ TOOL_ACTION EE_ACTIONS::placeImage( TOOL_ACTION_ARGS()
         .Name( "eeschema.InteractiveDrawing.placeImage" )
         .Scope( AS_GLOBAL )
         .FriendlyName( _( "Place Images" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE )
         .Icon( BITMAPS::image )
         .Flags( AF_ACTIVATE )
         .Parameter<SCH_BITMAP*>( nullptr ) );
@@ -654,6 +683,7 @@ TOOL_ACTION EE_ACTIONS::drawRuleArea( TOOL_ACTION_ARGS()
         .Name( "eeschema.InteractiveDrawing.drawRuleArea" )
         .Scope( AS_GLOBAL )
         .FriendlyName( _( "Draw Rule Areas" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE )
         .Icon( BITMAPS::add_keepout_area )
         .Flags( AF_ACTIVATE )
         .Parameter( SHAPE_T::RECTANGLE ) );
@@ -815,6 +845,7 @@ TOOL_ACTION EE_ACTIONS::showDeMorganStandard( TOOL_ACTION_ARGS()
         .Scope( AS_GLOBAL )
         .FriendlyName( _( "De Morgan Standard" ) )
         .Tooltip( _( "Switch to standard De Morgan representation" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE )
         .Icon( BITMAPS::morgan1 ) );
 
 TOOL_ACTION EE_ACTIONS::showDeMorganAlternate( TOOL_ACTION_ARGS()
@@ -822,6 +853,7 @@ TOOL_ACTION EE_ACTIONS::showDeMorganAlternate( TOOL_ACTION_ARGS()
         .Scope( AS_GLOBAL )
         .FriendlyName( _( "De Morgan Alternate" ) )
         .Tooltip( _( "Switch to alternate De Morgan representation" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE )
         .Icon( BITMAPS::morgan2 ) );
 
 TOOL_ACTION EE_ACTIONS::toLabel( TOOL_ACTION_ARGS()
@@ -948,6 +980,7 @@ TOOL_ACTION EE_ACTIONS::highlightNetTool( TOOL_ACTION_ARGS()
         .Scope( AS_GLOBAL )
         .FriendlyName( _( "Highlight Nets" ) )
         .Tooltip( _( "Highlight wires and pins of a net" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE )
         .Icon( BITMAPS::net_highlight_schematic )
         .Flags( AF_ACTIVATE ) );
 
@@ -1148,65 +1181,76 @@ TOOL_ACTION EE_ACTIONS::toggleHiddenPins( TOOL_ACTION_ARGS()
         .Name( "eeschema.EditorControl.showHiddenPins" )
         .Scope( AS_GLOBAL )
         .FriendlyName( _( "Show Hidden Pins" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE )
         .Icon( BITMAPS::hidden_pin ) );
 
 TOOL_ACTION EE_ACTIONS::toggleHiddenFields( TOOL_ACTION_ARGS()
         .Name( "eeschema.EditorControl.showHiddenFields" )
         .Scope( AS_GLOBAL )
-        .FriendlyName( _( "Show Hidden Fields" ) ) );
+        .FriendlyName( _( "Show Hidden Fields" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE ) );
 
 TOOL_ACTION EE_ACTIONS::toggleDirectiveLabels( TOOL_ACTION_ARGS()
         .Name( "eeschema.EditorControl.showDirectiveLabels" )
         .Scope( AS_GLOBAL )
-        .FriendlyName( _( "Show Directive Labels" ) ) );
+        .FriendlyName( _( "Show Directive Labels" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE ) );
 
 TOOL_ACTION EE_ACTIONS::toggleERCWarnings( TOOL_ACTION_ARGS()
         .Name( "eeschema.EditorControl.showERCWarnings" )
         .Scope( AS_GLOBAL )
         .FriendlyName( _( "Show ERC Warnings" ) )
-        .Tooltip( _( "Show markers for electrical rules checker warnings" ) ) );
+        .Tooltip( _( "Show markers for electrical rules checker warnings" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE ) );
 
 TOOL_ACTION EE_ACTIONS::toggleERCErrors( TOOL_ACTION_ARGS()
         .Name( "eeschema.EditorControl.showERCErrors" )
         .Scope( AS_GLOBAL )
         .FriendlyName( _( "Show ERC Errors" ) )
-        .Tooltip( _( "Show markers for electrical rules checker errors" ) ) );
+        .Tooltip( _( "Show markers for electrical rules checker errors" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE ) );
 
 TOOL_ACTION EE_ACTIONS::toggleERCExclusions( TOOL_ACTION_ARGS()
         .Name( "eeschema.EditorControl.showERCExclusions" )
         .Scope( AS_GLOBAL )
         .FriendlyName( _( "Show ERC Exclusions" ) )
-        .Tooltip( _( "Show markers for excluded electrical rules checker violations" ) ) );
+        .Tooltip( _( "Show markers for excluded electrical rules checker violations" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE ) );
 
 TOOL_ACTION EE_ACTIONS::markSimExclusions( TOOL_ACTION_ARGS()
         .Name( "eeschema.EditorControl.markSimExclusions" )
         .Scope( AS_GLOBAL )
         .FriendlyName( _( "Mark items excluded from simulation" ) )
-        .Tooltip( _( "Draw 'X's over items which have been excluded from simulation" ) ) );
+        .Tooltip( _( "Draw 'X's over items which have been excluded from simulation" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE ) );
 
 TOOL_ACTION EE_ACTIONS::toggleOPVoltages( TOOL_ACTION_ARGS()
         .Name( "eeschema.EditorControl.showOperatingPointVoltages" )
         .Scope( AS_GLOBAL )
         .FriendlyName( _( "Show OP Voltages" ) )
-        .Tooltip( _( "Show operating point voltage data from simulation" ) ) );
+        .Tooltip( _( "Show operating point voltage data from simulation" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE ));
 
 TOOL_ACTION EE_ACTIONS::toggleOPCurrents( TOOL_ACTION_ARGS()
         .Name( "eeschema.EditorControl.showOperatingPointCurrents" )
         .Scope( AS_GLOBAL )
         .FriendlyName( _( "Show OP Currents" ) )
-        .Tooltip( _( "Show operating point current data from simulation" ) ) );
+        .Tooltip( _( "Show operating point current data from simulation" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE ) );
 
 TOOL_ACTION EE_ACTIONS::togglePinAltIcons( TOOL_ACTION_ARGS()
         .Name( "eeschema.EditorControl.togglePinAltIcons" )
         .Scope( AS_GLOBAL )
         .FriendlyName( _( "Show Pin Alternate Icons" ) )
-        .Tooltip( _( "Show indicator icons for pins with alternate modes" ) ) );
+        .Tooltip( _( "Show indicator icons for pins with alternate modes" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE ) );
 
 TOOL_ACTION EE_ACTIONS::lineModeFree( TOOL_ACTION_ARGS()
         .Name( "eeschema.EditorControl.lineModeFree" )
         .Scope( AS_GLOBAL )
         .FriendlyName( _( "Line Mode for Wires and Buses" ) )
         .Tooltip( _( "Draw and drag at any angle" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE )
         .Icon( BITMAPS::lines_any )
         .Flags( AF_NONE )
         .Parameter( LINE_MODE::LINE_MODE_FREE ) );
@@ -1216,6 +1260,7 @@ TOOL_ACTION EE_ACTIONS::lineMode90( TOOL_ACTION_ARGS()
         .Scope( AS_GLOBAL )
         .FriendlyName( _( "Line Mode for Wires and Buses" ) )
         .Tooltip( _( "Constrain drawing and dragging to horizontal or vertical motions" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE )
         .Icon( BITMAPS::lines90 )
         .Flags( AF_NONE )
         .Parameter( LINE_MODE::LINE_MODE_90) );
@@ -1225,6 +1270,7 @@ TOOL_ACTION EE_ACTIONS::lineMode45( TOOL_ACTION_ARGS()
         .Scope( AS_GLOBAL )
         .FriendlyName( _( "Line Mode for Wires and Buses" ) )
         .Tooltip( _( "Constrain drawing and dragging to horizontal, vertical, or 45-degree angle motions" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE )
         .Icon( BITMAPS::hv45mode )
         .Flags( AF_NONE )
         .Parameter( LINE_MODE::LINE_MODE_45 ) );
@@ -1241,6 +1287,7 @@ TOOL_ACTION EE_ACTIONS::toggleAnnotateAuto( TOOL_ACTION_ARGS()
         .Scope( AS_GLOBAL )
         .FriendlyName( _( "Annotate Automatically" ) )
         .Tooltip( _( "Toggle automatic annotation of new symbols" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE )
         .Icon( BITMAPS::annotate ) );
 
 TOOL_ACTION EE_ACTIONS::repairSchematic( TOOL_ACTION_ARGS()
@@ -1335,6 +1382,7 @@ TOOL_ACTION EE_ACTIONS::showHierarchy( TOOL_ACTION_ARGS()
         .DefaultHotkey( MD_CTRL + 'H' )
         .FriendlyName( _( "Hierarchy Navigator" ) )
         .Tooltip( _( "Show/hide the schematic sheet hierarchy navigator" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE )
         .Icon( BITMAPS::hierarchy_nav ) );
 
 
@@ -1347,6 +1395,7 @@ TOOL_ACTION EE_ACTIONS::drawWire( TOOL_ACTION_ARGS()
         .DefaultHotkey( 'W' )
         .LegacyHotkeyName( "Begin Wire" )
         .FriendlyName( _( "Draw Wires" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE )
         .Icon( BITMAPS::add_line )
         .Flags( AF_ACTIVATE )
         .Parameter( &drawWireActionParam ) );
@@ -1358,6 +1407,7 @@ TOOL_ACTION EE_ACTIONS::drawBus( TOOL_ACTION_ARGS()
         .DefaultHotkey( 'B' )
         .LegacyHotkeyName( "Begin Bus" )
         .FriendlyName( _( "Draw Buses" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE )
         .Icon( BITMAPS::add_bus )
         .Flags( AF_ACTIVATE )
         .Parameter( &drawBusActionParam ) );
@@ -1380,6 +1430,7 @@ TOOL_ACTION EE_ACTIONS::drawLines( TOOL_ACTION_ARGS()
         .DefaultHotkey( 'I' )
         .LegacyHotkeyName( "Add Graphic PolyLine" )
         .FriendlyName( _( "Draw Lines" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE )
         .Icon( BITMAPS::add_graphical_segments )
         .Flags( AF_ACTIVATE )
         .Parameter( &drawLinesActionParam ) );
diff --git a/gerbview/toolbars_gerber.cpp b/gerbview/toolbars_gerber.cpp
index 8762375f89..0cf2b31d7b 100644
--- a/gerbview/toolbars_gerber.cpp
+++ b/gerbview/toolbars_gerber.cpp
@@ -72,7 +72,7 @@ void GERBVIEW_FRAME::ReCreateHToolbar()
     m_mainToolBar->Add( ACTIONS::zoomInCenter );
     m_mainToolBar->Add( ACTIONS::zoomOutCenter );
     m_mainToolBar->Add( ACTIONS::zoomFitScreen );
-    m_mainToolBar->Add( ACTIONS::zoomTool, ACTION_TOOLBAR::TOGGLE, ACTION_TOOLBAR::CANCEL );
+    m_mainToolBar->Add( ACTIONS::zoomTool );
 
 
     m_mainToolBar->AddScaledSeparator( this );
@@ -238,31 +238,31 @@ void GERBVIEW_FRAME::ReCreateOptToolbar()
     // TODO: these can be moved to the 'proper' vertical toolbar if and when there are
     // actual tools to put there. That, or I'll get around to implementing configurable
     // toolbars.
-    m_optionsToolBar->Add( ACTIONS::selectionTool,                    ACTION_TOOLBAR::TOGGLE );
-    m_optionsToolBar->Add( ACTIONS::measureTool,                      ACTION_TOOLBAR::TOGGLE );
+    m_optionsToolBar->Add( ACTIONS::selectionTool );
+    m_optionsToolBar->Add( ACTIONS::measureTool );
 
     m_optionsToolBar->AddScaledSeparator( this );
-    m_optionsToolBar->Add( ACTIONS::toggleGrid,                       ACTION_TOOLBAR::TOGGLE );
-    m_optionsToolBar->Add( ACTIONS::togglePolarCoords,                ACTION_TOOLBAR::TOGGLE );
-    m_optionsToolBar->Add( ACTIONS::inchesUnits,                      ACTION_TOOLBAR::TOGGLE );
-    m_optionsToolBar->Add( ACTIONS::milsUnits,                        ACTION_TOOLBAR::TOGGLE );
-    m_optionsToolBar->Add( ACTIONS::millimetersUnits,                 ACTION_TOOLBAR::TOGGLE );
-    m_optionsToolBar->Add( ACTIONS::toggleCursorStyle,                ACTION_TOOLBAR::TOGGLE );
+    m_optionsToolBar->Add( ACTIONS::toggleGrid );
+    m_optionsToolBar->Add( ACTIONS::togglePolarCoords );
+    m_optionsToolBar->Add( ACTIONS::inchesUnits );
+    m_optionsToolBar->Add( ACTIONS::milsUnits );
+    m_optionsToolBar->Add( ACTIONS::millimetersUnits );
+    m_optionsToolBar->Add( ACTIONS::toggleCursorStyle );
 
     m_optionsToolBar->AddScaledSeparator( this );
-    m_optionsToolBar->Add( GERBVIEW_ACTIONS::flashedDisplayOutlines,  ACTION_TOOLBAR::TOGGLE );
-    m_optionsToolBar->Add( GERBVIEW_ACTIONS::linesDisplayOutlines,    ACTION_TOOLBAR::TOGGLE );
-    m_optionsToolBar->Add( GERBVIEW_ACTIONS::polygonsDisplayOutlines, ACTION_TOOLBAR::TOGGLE );
-    m_optionsToolBar->Add( GERBVIEW_ACTIONS::negativeObjectDisplay,   ACTION_TOOLBAR::TOGGLE );
-    m_optionsToolBar->Add( GERBVIEW_ACTIONS::dcodeDisplay,            ACTION_TOOLBAR::TOGGLE );
+    m_optionsToolBar->Add( GERBVIEW_ACTIONS::flashedDisplayOutlines );
+    m_optionsToolBar->Add( GERBVIEW_ACTIONS::linesDisplayOutlines );
+    m_optionsToolBar->Add( GERBVIEW_ACTIONS::polygonsDisplayOutlines );
+    m_optionsToolBar->Add( GERBVIEW_ACTIONS::negativeObjectDisplay );
+    m_optionsToolBar->Add( GERBVIEW_ACTIONS::dcodeDisplay );
     m_optionsToolBar->AddScaledSeparator( this );
-    m_optionsToolBar->Add( GERBVIEW_ACTIONS::toggleForceOpacityMode,  ACTION_TOOLBAR::TOGGLE );
-    m_optionsToolBar->Add( GERBVIEW_ACTIONS::toggleXORMode,           ACTION_TOOLBAR::TOGGLE );
-    m_optionsToolBar->Add( ACTIONS::highContrastMode,                 ACTION_TOOLBAR::TOGGLE );
-    m_optionsToolBar->Add( GERBVIEW_ACTIONS::flipGerberView,          ACTION_TOOLBAR::TOGGLE );
+    m_optionsToolBar->Add( GERBVIEW_ACTIONS::toggleForceOpacityMode );
+    m_optionsToolBar->Add( GERBVIEW_ACTIONS::toggleXORMode );
+    m_optionsToolBar->Add( ACTIONS::highContrastMode );
+    m_optionsToolBar->Add( GERBVIEW_ACTIONS::flipGerberView );
 
     m_optionsToolBar->AddScaledSeparator( this );
-    m_optionsToolBar->Add( GERBVIEW_ACTIONS::toggleLayerManager,      ACTION_TOOLBAR::TOGGLE );
+    m_optionsToolBar->Add( GERBVIEW_ACTIONS::toggleLayerManager );
 
     m_optionsToolBar->KiRealize();
 }
diff --git a/gerbview/tools/gerbview_actions.cpp b/gerbview/tools/gerbview_actions.cpp
index 19def7a243..217d2ae51c 100644
--- a/gerbview/tools/gerbview_actions.cpp
+++ b/gerbview/tools/gerbview_actions.cpp
@@ -74,6 +74,7 @@ TOOL_ACTION GERBVIEW_ACTIONS::toggleLayerManager( TOOL_ACTION_ARGS()
         .Name( "gerbview.Control.toggleLayerManager" )
         .Scope( AS_GLOBAL )
         .FriendlyName( _( "Show Layers Manager" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE )
         .Icon( BITMAPS::layers_manager ) );
 
 TOOL_ACTION GERBVIEW_ACTIONS::showDCodes( TOOL_ACTION_ARGS()
@@ -185,6 +186,7 @@ TOOL_ACTION GERBVIEW_ACTIONS::linesDisplayOutlines( TOOL_ACTION_ARGS()
         .LegacyHotkeyName( "Gbr Lines Display Mode" )
         .FriendlyName( _( "Sketch Lines" ) )
         .Tooltip( _( "Show lines in outline mode" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE )
         .Icon( BITMAPS::showtrack ) );
 
 TOOL_ACTION GERBVIEW_ACTIONS::flashedDisplayOutlines( TOOL_ACTION_ARGS()
@@ -194,6 +196,7 @@ TOOL_ACTION GERBVIEW_ACTIONS::flashedDisplayOutlines( TOOL_ACTION_ARGS()
         .LegacyHotkeyName( "Gbr Flashed Display Mode" )
         .FriendlyName( _( "Sketch Flashed Items" ) )
         .Tooltip( _( "Show flashed items in outline mode" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE )
         .Icon( BITMAPS::pad_sketch ) );
 
 TOOL_ACTION GERBVIEW_ACTIONS::polygonsDisplayOutlines( TOOL_ACTION_ARGS()
@@ -203,6 +206,7 @@ TOOL_ACTION GERBVIEW_ACTIONS::polygonsDisplayOutlines( TOOL_ACTION_ARGS()
         .LegacyHotkeyName( "Gbr Polygons Display Mode" )
         .FriendlyName( _( "Sketch Polygons" ) )
         .Tooltip( _( "Show polygons in outline mode" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE )
         .Icon( BITMAPS::opt_show_polygon ) );
 
 TOOL_ACTION GERBVIEW_ACTIONS::negativeObjectDisplay( TOOL_ACTION_ARGS()
@@ -211,6 +215,7 @@ TOOL_ACTION GERBVIEW_ACTIONS::negativeObjectDisplay( TOOL_ACTION_ARGS()
         .LegacyHotkeyName( "Gbr Negative Obj Display Mode" )
         .FriendlyName( _( "Ghost Negative Objects" ) )
         .Tooltip( _( "Show negative objects in ghost color" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE )
         .Icon( BITMAPS::gerbview_show_negative_objects ) );
 
 TOOL_ACTION GERBVIEW_ACTIONS::dcodeDisplay( TOOL_ACTION_ARGS()
@@ -220,6 +225,7 @@ TOOL_ACTION GERBVIEW_ACTIONS::dcodeDisplay( TOOL_ACTION_ARGS()
         .LegacyHotkeyName( "DCodes Display Mode" )
         .FriendlyName( _( "Show DCodes" ) )
         .Tooltip( _( "Show dcode numbers" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE )
         .Icon( BITMAPS::show_dcodenumber ) );
 
 TOOL_ACTION GERBVIEW_ACTIONS::toggleForceOpacityMode( TOOL_ACTION_ARGS()
@@ -227,6 +233,7 @@ TOOL_ACTION GERBVIEW_ACTIONS::toggleForceOpacityMode( TOOL_ACTION_ARGS()
         .Scope( AS_GLOBAL )
         .FriendlyName( _( "Show with Forced Opacity Mode" ) )
         .Tooltip( _( "Show layers using opacity color forced mode" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE )
         .Icon( BITMAPS::gbr_select_mode1 ) );
 
 TOOL_ACTION GERBVIEW_ACTIONS::toggleXORMode( TOOL_ACTION_ARGS()
@@ -234,6 +241,7 @@ TOOL_ACTION GERBVIEW_ACTIONS::toggleXORMode( TOOL_ACTION_ARGS()
         .Scope( AS_GLOBAL )
         .FriendlyName( _( "Show in XOR Mode" ) )
         .Tooltip( _( "Show layers in exclusive-or compare mode" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE )
         .Icon( BITMAPS::gbr_select_mode2 ) );
 
 TOOL_ACTION GERBVIEW_ACTIONS::flipGerberView( TOOL_ACTION_ARGS()
@@ -241,6 +249,7 @@ TOOL_ACTION GERBVIEW_ACTIONS::flipGerberView( TOOL_ACTION_ARGS()
         .Scope( AS_GLOBAL )
         .FriendlyName( _( "Flip Gerber View" ) )
         .Tooltip( _( "Show as mirror image" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE )
         .Icon( BITMAPS::flip_board ) );
 
 
diff --git a/include/tool/action_toolbar.h b/include/tool/action_toolbar.h
index 7fb8bd782e..a90c6e20b0 100644
--- a/include/tool/action_toolbar.h
+++ b/include/tool/action_toolbar.h
@@ -198,6 +198,17 @@ public:
 
     void SetToolManager( TOOL_MANAGER* aManager ) { m_toolManager = aManager; }
 
+    /**
+     * Add a TOOL_ACTION-based button to the toolbar.
+     *
+     * The toggle/cancel attributes are set using the attributes in the action.
+     *
+     * After selecting the entry, a #TOOL_EVENT command containing name of the action is sent.
+     *
+     * @param aAction is the action to add.
+     */
+    void Add( const TOOL_ACTION& aAction );
+
     /**
      * Add a TOOL_ACTION-based button to the toolbar.
      *
@@ -207,7 +218,7 @@ public:
      * @param aIsToggleEntry makes the toolbar item a toggle entry when true.
      * @param aIsCancellable when true, cancels the tool if clicked when tool is active.
      */
-    void Add( const TOOL_ACTION& aAction, bool aIsToggleEntry = false,
+    void Add( const TOOL_ACTION& aAction, bool aIsToggleEntry,
               bool aIsCancellable = false );
 
     /**
diff --git a/include/tool/tool_action.h b/include/tool/tool_action.h
index 7a2287eeba..7d35048172 100644
--- a/include/tool/tool_action.h
+++ b/include/tool/tool_action.h
@@ -28,6 +28,7 @@
 #ifndef __TOOL_ACTION_H
 #define __TOOL_ACTION_H
 
+#include <bitset>
 #include <cassert>
 #include <optional>
 #include <string>
@@ -56,6 +57,21 @@ enum TOOL_ACTION_FLAGS
     AF_NOTIFY   = 2     ///< Action is a notification (it is by default passed to all tools)
 };
 
+/// Flags that control how actions appear and interact on the toolbar
+enum class TOOLBAR_STATE
+{
+    HIDDEN = 0,         ///< Action is hidden from the toolbar
+    TOGGLE = 1,         ///< Action is a toggle button on the toolbar
+    CANCEL = 2,         ///< Action can be cancelled by clicking the toolbar button again
+
+    ENUM_LENGTH = 3
+};
+
+// The length of the TOOLBAR_STATE enum as a size_t (used for bitset creation)
+const size_t gToolbarStateNumber = static_cast<size_t>( TOOLBAR_STATE::ENUM_LENGTH );
+
+typedef std::bitset<gToolbarStateNumber> TOOLBAR_STATE_FLAGS;
+
 /**
  * Define a group that can be used to group actions (and their events) of similar operations.
  */
@@ -228,6 +244,23 @@ public:
         return *this;
     }
 
+    TOOL_ACTION_ARGS& ToolbarState( TOOLBAR_STATE aState )
+    {
+        m_toolbarState = TOOLBAR_STATE_FLAGS();
+        m_toolbarState.value().set( static_cast<size_t>( aState ) );
+        return *this;
+    }
+
+    TOOL_ACTION_ARGS& ToolbarState( std::initializer_list<TOOLBAR_STATE> aState )
+    {
+        m_toolbarState = TOOLBAR_STATE_FLAGS();
+
+        for( auto flag : aState )
+            m_toolbarState.value().set( static_cast<size_t>( flag ) );
+
+        return *this;
+    }
+
 protected:
     // Let the TOOL_ACTION constructor have direct access to the members here
     friend class TOOL_ACTION;
@@ -251,6 +284,8 @@ protected:
 
     std::optional<TOOL_ACTION_GROUP>    m_group;
 
+    std::optional<TOOLBAR_STATE_FLAGS>  m_toolbarState;
+
     ki::any                             m_param;
 };
 
@@ -423,9 +458,24 @@ public:
      */
     BITMAPS GetIcon() const
     {
-        return m_icon;
+        // The value of 0 corresponds to BITMAPS::INVALID_BITMAP, but is just
+        // used here to make it so we don't need to include the full list in this
+        // header.
+        return m_icon.value_or( static_cast<BITMAPS>( 0 ) );
     }
 
+    /**
+     * Check if a specific toolbar state is required for this action.
+     *
+     * @param aState The state (from TOOLBAR_STATE enum) to check
+     * @return true if the state should be used for this action
+     */
+    bool CheckToolbarState( TOOLBAR_STATE aState ) const
+    {
+        return m_toolbarState[static_cast<std::size_t>( aState )];
+    }
+
+
 protected:
     TOOL_ACTION();
 
@@ -453,11 +503,13 @@ protected:
     wxString                m_tooltip;      ///< User facing tooltip help text.
     std::optional<wxString> m_description;  ///< Description of the action.
 
-    BITMAPS m_icon; ///< Icon for the menu entry
+    std::optional<BITMAPS> m_icon; ///< Icon for the menu entry
 
     int                m_id;   ///< Unique ID for maps. Assigned by #ACTION_MANAGER.
     std::optional<int> m_uiid; ///< ID to use when interacting with the UI (if empty, generate one).
 
+    TOOLBAR_STATE_FLAGS m_toolbarState;    ///< Toolbar state behavior for the action
+
     TOOL_ACTION_FLAGS m_flags;
     ki::any           m_param; ///< Generic parameter.
 };
diff --git a/pagelayout_editor/toolbars_pl_editor.cpp b/pagelayout_editor/toolbars_pl_editor.cpp
index 803ff403ef..6f8c136cfe 100644
--- a/pagelayout_editor/toolbars_pl_editor.cpp
+++ b/pagelayout_editor/toolbars_pl_editor.cpp
@@ -58,7 +58,7 @@ void PL_EDITOR_FRAME::ReCreateHToolbar()
     m_mainToolBar->Add( ACTIONS::zoomInCenter );
     m_mainToolBar->Add( ACTIONS::zoomOutCenter );
     m_mainToolBar->Add( ACTIONS::zoomFitScreen );
-    m_mainToolBar->Add( ACTIONS::zoomTool, ACTION_TOOLBAR::TOGGLE, ACTION_TOOLBAR::CANCEL );
+    m_mainToolBar->Add( ACTIONS::zoomTool );
 
     m_mainToolBar->AddScaledSeparator( this );
     m_mainToolBar->Add( PL_ACTIONS::showInspector );
@@ -66,8 +66,8 @@ void PL_EDITOR_FRAME::ReCreateHToolbar()
 
     // Display mode switch
     m_mainToolBar->AddScaledSeparator( this );
-    m_mainToolBar->Add( PL_ACTIONS::layoutNormalMode, ACTION_TOOLBAR::TOGGLE );
-    m_mainToolBar->Add( PL_ACTIONS::layoutEditMode,   ACTION_TOOLBAR::TOGGLE );
+    m_mainToolBar->Add( PL_ACTIONS::layoutNormalMode );
+    m_mainToolBar->Add( PL_ACTIONS::layoutEditMode );
     m_mainToolBar->AddScaledSeparator( this );
 
     wxString choiceList[5] =
@@ -141,17 +141,17 @@ void PL_EDITOR_FRAME::ReCreateVToolbar()
         m_drawToolBar->SetAuiManager( &m_auimgr );
     }
 
-    m_drawToolBar->Add( ACTIONS::selectionTool,                 ACTION_TOOLBAR::TOGGLE );
+    m_drawToolBar->Add( ACTIONS::selectionTool );
 
     m_drawToolBar->AddScaledSeparator( this );
-    m_drawToolBar->Add( PL_ACTIONS::drawLine,                   ACTION_TOOLBAR::TOGGLE );
-    m_drawToolBar->Add( PL_ACTIONS::drawRectangle,              ACTION_TOOLBAR::TOGGLE );
-    m_drawToolBar->Add( PL_ACTIONS::placeText,                  ACTION_TOOLBAR::TOGGLE );
-    m_drawToolBar->Add( PL_ACTIONS::placeImage,                 ACTION_TOOLBAR::TOGGLE );
-    m_drawToolBar->Add( PL_ACTIONS::appendImportedDrawingSheet, ACTION_TOOLBAR::TOGGLE );
+    m_drawToolBar->Add( PL_ACTIONS::drawLine );
+    m_drawToolBar->Add( PL_ACTIONS::drawRectangle );
+    m_drawToolBar->Add( PL_ACTIONS::placeText );
+    m_drawToolBar->Add( PL_ACTIONS::placeImage );
+    m_drawToolBar->Add( PL_ACTIONS::appendImportedDrawingSheet );
 
     m_drawToolBar->AddScaledSeparator( this );
-    m_drawToolBar->Add( ACTIONS::deleteTool,                    ACTION_TOOLBAR::TOGGLE );
+    m_drawToolBar->Add( ACTIONS::deleteTool );
 
     m_drawToolBar->KiRealize();
 }
@@ -176,10 +176,10 @@ void PL_EDITOR_FRAME::ReCreateOptToolbar()
     gridMenu->Add( ACTIONS::gridProperties );
     m_optionsToolBar->AddToolContextMenu( ACTIONS::toggleGrid, std::move( gridMenu ) );
 
-    m_optionsToolBar->Add( ACTIONS::toggleGrid, ACTION_TOOLBAR::TOGGLE );
-    m_optionsToolBar->Add( ACTIONS::inchesUnits, ACTION_TOOLBAR::TOGGLE );
-    m_optionsToolBar->Add( ACTIONS::milsUnits, ACTION_TOOLBAR::TOGGLE );
-    m_optionsToolBar->Add( ACTIONS::millimetersUnits, ACTION_TOOLBAR::TOGGLE );
+    m_optionsToolBar->Add( ACTIONS::toggleGrid );
+    m_optionsToolBar->Add( ACTIONS::inchesUnits );
+    m_optionsToolBar->Add( ACTIONS::milsUnits );
+    m_optionsToolBar->Add( ACTIONS::millimetersUnits );
 
     m_optionsToolBar->KiRealize();
 }
diff --git a/pagelayout_editor/tools/pl_actions.cpp b/pagelayout_editor/tools/pl_actions.cpp
index ac7abba7dd..b5dd61aed7 100644
--- a/pagelayout_editor/tools/pl_actions.cpp
+++ b/pagelayout_editor/tools/pl_actions.cpp
@@ -43,6 +43,7 @@ TOOL_ACTION PL_ACTIONS::drawLine( TOOL_ACTION_ARGS()
         .Name( "plEditor.InteractiveDrawing.drawLine" )
         .Scope( AS_GLOBAL )
         .FriendlyName( _( "Draw Lines" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE )
         .Icon( BITMAPS::add_graphical_segments )
         .Flags( AF_ACTIVATE )
         .Parameter( DS_DATA_ITEM::DS_SEGMENT ) );
@@ -51,6 +52,7 @@ TOOL_ACTION PL_ACTIONS::drawRectangle( TOOL_ACTION_ARGS()
         .Name( "plEditor.InteractiveDrawing.drawRectangle" )
         .Scope( AS_GLOBAL )
         .FriendlyName( _( "Draw Rectangles" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE )
         .Icon( BITMAPS::add_rectangle )
         .Flags( AF_ACTIVATE )
         .Parameter( DS_DATA_ITEM::DS_RECT ) );
@@ -59,6 +61,7 @@ TOOL_ACTION PL_ACTIONS::placeText( TOOL_ACTION_ARGS()
         .Name( "plEditor.InteractiveDrawing.placeText" )
         .Scope( AS_GLOBAL )
         .FriendlyName( _( "Draw Text" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE )
         .Icon( BITMAPS::text )
         .Flags( AF_ACTIVATE )
         .Parameter( DS_DATA_ITEM::DS_TEXT ) );
@@ -67,6 +70,7 @@ TOOL_ACTION PL_ACTIONS::placeImage( TOOL_ACTION_ARGS()
         .Name( "plEditor.InteractiveDrawing.placeImage" )
         .Scope( AS_GLOBAL )
         .FriendlyName( _( "Place Bitmaps" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE )
         .Icon( BITMAPS::image )
         .Flags( AF_ACTIVATE )
         .Parameter( DS_DATA_ITEM::DS_BITMAP ) );
@@ -88,6 +92,7 @@ TOOL_ACTION PL_ACTIONS::appendImportedDrawingSheet( TOOL_ACTION_ARGS()
         .Scope( AS_GLOBAL )
         .FriendlyName( _( "Append Existing Drawing Sheet..." ) )
         .Tooltip( _( "Append an existing drawing sheet file to the current file" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE )
         .Icon( BITMAPS::import )
         .Flags( AF_ACTIVATE ) );
 
@@ -112,6 +117,7 @@ TOOL_ACTION PL_ACTIONS::layoutNormalMode( TOOL_ACTION_ARGS()
         .Scope( AS_GLOBAL )
         .FriendlyName( _( "Show Title Block in Preview Mode" ) )
         .Tooltip( _( "Text placeholders will be replaced with preview data" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE )
         .Icon( BITMAPS::pagelayout_normal_view_mode ) );
 
 TOOL_ACTION PL_ACTIONS::layoutEditMode( TOOL_ACTION_ARGS()
@@ -119,6 +125,7 @@ TOOL_ACTION PL_ACTIONS::layoutEditMode( TOOL_ACTION_ARGS()
         .Scope( AS_GLOBAL )
         .FriendlyName( _( "Show Title Block in Edit Mode" ) )
         .Tooltip( _( "Text placeholders are shown as ${keyword} tokens" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE )
         .Icon( BITMAPS::pagelayout_special_view_mode  ) );
 
 
diff --git a/pcbnew/footprint_edit_frame.cpp b/pcbnew/footprint_edit_frame.cpp
index 7d99120221..280d19a621 100644
--- a/pcbnew/footprint_edit_frame.cpp
+++ b/pcbnew/footprint_edit_frame.cpp
@@ -1333,7 +1333,7 @@ void FOOTPRINT_EDIT_FRAME::setupUIConditions()
 
     mgr->SetConditions( ACTIONS::showLibraryTree,           CHECK( libraryTreeCond ) );
     mgr->SetConditions( PCB_ACTIONS::showLayersManager,     CHECK( layerManagerCond ) );
-    mgr->SetConditions( PCB_ACTIONS::showProperties,        CHECK( propertiesCond ) );
+    mgr->SetConditions( ACTIONS::showProperties,            CHECK( propertiesCond ) );
 
     mgr->SetConditions( ACTIONS::print,                     ENABLE( haveFootprintCond ) );
     mgr->SetConditions( PCB_ACTIONS::exportFootprint,       ENABLE( haveFootprintCond ) );
@@ -1388,7 +1388,7 @@ void FOOTPRINT_EDIT_FRAME::setupUIConditions()
     CURRENT_EDIT_TOOL( PCB_ACTIONS::drawRadialDimension );
     CURRENT_EDIT_TOOL( PCB_ACTIONS::drawLeader );
     CURRENT_EDIT_TOOL( PCB_ACTIONS::setAnchor );
-    CURRENT_EDIT_TOOL( PCB_ACTIONS::gridSetOrigin );
+    CURRENT_EDIT_TOOL( ACTIONS::gridSetOrigin );
 
 #undef CURRENT_EDIT_TOOL
 #undef ENABLE
diff --git a/pcbnew/pcb_edit_frame.cpp b/pcbnew/pcb_edit_frame.cpp
index 8f75c25c96..f46476ddd0 100644
--- a/pcbnew/pcb_edit_frame.cpp
+++ b/pcbnew/pcb_edit_frame.cpp
@@ -934,7 +934,7 @@ void PCB_EDIT_FRAME::setupUIConditions()
     mgr->SetConditions( PCB_ACTIONS::ratsnestLineMode,     CHECK( curvedRatsnestCond ) );
     mgr->SetConditions( PCB_ACTIONS::toggleNetHighlight,   CHECK( netHighlightCond )
                                                            .Enable( enableNetHighlightCond ) );
-    mgr->SetConditions( PCB_ACTIONS::showProperties,       CHECK( propertiesCond ) );
+    mgr->SetConditions( ACTIONS::showProperties,           CHECK( propertiesCond ) );
     mgr->SetConditions( PCB_ACTIONS::showNetInspector,     CHECK( netInspectorCond ) );
     mgr->SetConditions( PCB_ACTIONS::showSearch,           CHECK( searchPaneCond ) );
 
@@ -1071,7 +1071,7 @@ void PCB_EDIT_FRAME::setupUIConditions()
     CURRENT_EDIT_TOOL( PCB_ACTIONS::drawRadialDimension );
     CURRENT_EDIT_TOOL( PCB_ACTIONS::drawLeader );
     CURRENT_EDIT_TOOL( PCB_ACTIONS::drillOrigin );
-    CURRENT_EDIT_TOOL( PCB_ACTIONS::gridSetOrigin );
+    CURRENT_EDIT_TOOL( ACTIONS::gridSetOrigin );
     CURRENT_EDIT_TOOL( PCB_ACTIONS::createArray );
 
     CURRENT_EDIT_TOOL( PCB_ACTIONS::microwaveCreateLine );
diff --git a/pcbnew/toolbars_footprint_editor.cpp b/pcbnew/toolbars_footprint_editor.cpp
index 151feb5f05..8a38c60ee4 100644
--- a/pcbnew/toolbars_footprint_editor.cpp
+++ b/pcbnew/toolbars_footprint_editor.cpp
@@ -72,7 +72,7 @@ void FOOTPRINT_EDIT_FRAME::ReCreateHToolbar()
     m_mainToolBar->Add( ACTIONS::zoomInCenter );
     m_mainToolBar->Add( ACTIONS::zoomOutCenter );
     m_mainToolBar->Add( ACTIONS::zoomFitScreen );
-    m_mainToolBar->Add( ACTIONS::zoomTool, ACTION_TOOLBAR::TOGGLE, ACTION_TOOLBAR::CANCEL );
+    m_mainToolBar->Add( ACTIONS::zoomTool );
 
     m_mainToolBar->AddScaledSeparator( this );
     m_mainToolBar->Add( PCB_ACTIONS::rotateCcw );
@@ -175,30 +175,30 @@ void FOOTPRINT_EDIT_FRAME::ReCreateVToolbar()
     }
 
     // clang-format off
-    m_drawToolBar->Add( ACTIONS::selectionTool,           ACTION_TOOLBAR::TOGGLE );
+    m_drawToolBar->Add( ACTIONS::selectionTool );
 
     m_drawToolBar->AddScaledSeparator( this );
-    m_drawToolBar->Add( PCB_ACTIONS::placePad,            ACTION_TOOLBAR::TOGGLE );
-    m_drawToolBar->Add( PCB_ACTIONS::drawRuleArea,        ACTION_TOOLBAR::TOGGLE );
+    m_drawToolBar->Add( PCB_ACTIONS::placePad );
+    m_drawToolBar->Add( PCB_ACTIONS::drawRuleArea );
 
     m_drawToolBar->AddScaledSeparator( this );
-    m_drawToolBar->Add( PCB_ACTIONS::drawLine,            ACTION_TOOLBAR::TOGGLE );
-    m_drawToolBar->Add( PCB_ACTIONS::drawArc,             ACTION_TOOLBAR::TOGGLE );
-    m_drawToolBar->Add( PCB_ACTIONS::drawRectangle,       ACTION_TOOLBAR::TOGGLE );
-    m_drawToolBar->Add( PCB_ACTIONS::drawCircle,          ACTION_TOOLBAR::TOGGLE );
-    m_drawToolBar->Add( PCB_ACTIONS::drawPolygon,         ACTION_TOOLBAR::TOGGLE );
-    m_drawToolBar->Add( PCB_ACTIONS::drawBezier,          ACTION_TOOLBAR::TOGGLE );
-    m_drawToolBar->Add( PCB_ACTIONS::placeReferenceImage, ACTION_TOOLBAR::TOGGLE );
-    m_drawToolBar->Add( PCB_ACTIONS::placeText,           ACTION_TOOLBAR::TOGGLE );
-    m_drawToolBar->Add( PCB_ACTIONS::drawTextBox,         ACTION_TOOLBAR::TOGGLE );
-    m_drawToolBar->Add( PCB_ACTIONS::drawTable,           ACTION_TOOLBAR::TOGGLE );
+    m_drawToolBar->Add( PCB_ACTIONS::drawLine );
+    m_drawToolBar->Add( PCB_ACTIONS::drawArc );
+    m_drawToolBar->Add( PCB_ACTIONS::drawRectangle );
+    m_drawToolBar->Add( PCB_ACTIONS::drawCircle );
+    m_drawToolBar->Add( PCB_ACTIONS::drawPolygon );
+    m_drawToolBar->Add( PCB_ACTIONS::drawBezier );
+    m_drawToolBar->Add( PCB_ACTIONS::placeReferenceImage );
+    m_drawToolBar->Add( PCB_ACTIONS::placeText );
+    m_drawToolBar->Add( PCB_ACTIONS::drawTextBox );
+    m_drawToolBar->Add( PCB_ACTIONS::drawTable );
     m_drawToolBar->AddGroup( dimensionGroup,              ACTION_TOOLBAR::TOGGLE );
-    m_drawToolBar->Add( ACTIONS::deleteTool,              ACTION_TOOLBAR::TOGGLE );
+    m_drawToolBar->Add( ACTIONS::deleteTool );
 
     m_drawToolBar->AddScaledSeparator( this );
-    m_drawToolBar->Add( PCB_ACTIONS::setAnchor,           ACTION_TOOLBAR::TOGGLE );
-    m_drawToolBar->Add( PCB_ACTIONS::gridSetOrigin,       ACTION_TOOLBAR::TOGGLE );
-    m_drawToolBar->Add( ACTIONS::measureTool,             ACTION_TOOLBAR::TOGGLE );
+    m_drawToolBar->Add( PCB_ACTIONS::setAnchor );
+    m_drawToolBar->Add( ACTIONS::gridSetOrigin );
+    m_drawToolBar->Add( ACTIONS::measureTool );
     // clang-format on
 
     PCB_SELECTION_TOOL* selTool = m_toolManager->GetTool<PCB_SELECTION_TOOL>();
@@ -233,30 +233,30 @@ void FOOTPRINT_EDIT_FRAME::ReCreateOptToolbar()
         m_optionsToolBar->SetAuiManager( &m_auimgr );
     }
 
-    m_optionsToolBar->Add( ACTIONS::toggleGrid,              ACTION_TOOLBAR::TOGGLE );
-    m_optionsToolBar->Add( ACTIONS::toggleGridOverrides,     ACTION_TOOLBAR::TOGGLE );
-    m_optionsToolBar->Add( PCB_ACTIONS::togglePolarCoords,   ACTION_TOOLBAR::TOGGLE );
-    m_optionsToolBar->Add( ACTIONS::inchesUnits,             ACTION_TOOLBAR::TOGGLE );
-    m_optionsToolBar->Add( ACTIONS::milsUnits,               ACTION_TOOLBAR::TOGGLE );
-    m_optionsToolBar->Add( ACTIONS::millimetersUnits,        ACTION_TOOLBAR::TOGGLE );
-    m_optionsToolBar->Add( ACTIONS::toggleCursorStyle,       ACTION_TOOLBAR::TOGGLE );
+    m_optionsToolBar->Add( ACTIONS::toggleGrid );
+    m_optionsToolBar->Add( ACTIONS::toggleGridOverrides );
+    m_optionsToolBar->Add( PCB_ACTIONS::togglePolarCoords );
+    m_optionsToolBar->Add( ACTIONS::inchesUnits );
+    m_optionsToolBar->Add( ACTIONS::milsUnits );
+    m_optionsToolBar->Add( ACTIONS::millimetersUnits );
+    m_optionsToolBar->Add( ACTIONS::toggleCursorStyle );
 
     m_optionsToolBar->AddScaledSeparator( this );
-    m_optionsToolBar->Add( PCB_ACTIONS::toggleHV45Mode,      ACTION_TOOLBAR::TOGGLE );
+    m_optionsToolBar->Add( PCB_ACTIONS::toggleHV45Mode );
 
     m_optionsToolBar->AddScaledSeparator( this );
-    m_optionsToolBar->Add( PCB_ACTIONS::padDisplayMode,      ACTION_TOOLBAR::TOGGLE );
-    m_optionsToolBar->Add( PCB_ACTIONS::graphicsOutlines,    ACTION_TOOLBAR::TOGGLE );
-    m_optionsToolBar->Add( PCB_ACTIONS::textOutlines,        ACTION_TOOLBAR::TOGGLE );
-    m_optionsToolBar->Add( ACTIONS::highContrastMode,        ACTION_TOOLBAR::TOGGLE );
+    m_optionsToolBar->Add( PCB_ACTIONS::padDisplayMode );
+    m_optionsToolBar->Add( PCB_ACTIONS::graphicsOutlines );
+    m_optionsToolBar->Add( PCB_ACTIONS::textOutlines );
+    m_optionsToolBar->Add( ACTIONS::highContrastMode );
 
     if( ADVANCED_CFG::GetCfg().m_DrawBoundingBoxes )
-        m_optionsToolBar->Add( ACTIONS::toggleBoundingBoxes, ACTION_TOOLBAR::TOGGLE );
+        m_optionsToolBar->Add( ACTIONS::toggleBoundingBoxes );
 
     m_optionsToolBar->AddScaledSeparator( this );
-    m_optionsToolBar->Add( ACTIONS::showLibraryTree,         ACTION_TOOLBAR::TOGGLE );
-    m_optionsToolBar->Add( PCB_ACTIONS::showLayersManager,   ACTION_TOOLBAR::TOGGLE );
-    m_optionsToolBar->Add( PCB_ACTIONS::showProperties,      ACTION_TOOLBAR::TOGGLE );
+    m_optionsToolBar->Add( ACTIONS::showLibraryTree );
+    m_optionsToolBar->Add( PCB_ACTIONS::showLayersManager );
+    m_optionsToolBar->Add( ACTIONS::showProperties );
 
     PCB_SELECTION_TOOL*          selTool = m_toolManager->GetTool<PCB_SELECTION_TOOL>();
     std::unique_ptr<ACTION_MENU> gridMenu = std::make_unique<ACTION_MENU>( false, selTool );
diff --git a/pcbnew/toolbars_footprint_viewer.cpp b/pcbnew/toolbars_footprint_viewer.cpp
index d5abc61b3a..efe8c8852a 100644
--- a/pcbnew/toolbars_footprint_viewer.cpp
+++ b/pcbnew/toolbars_footprint_viewer.cpp
@@ -69,7 +69,7 @@ void FOOTPRINT_VIEWER_FRAME::ReCreateHToolbar()
     m_mainToolBar->Add( ACTIONS::zoomInCenter );
     m_mainToolBar->Add( ACTIONS::zoomOutCenter );
     m_mainToolBar->Add( ACTIONS::zoomFitScreen );
-    m_mainToolBar->Add( ACTIONS::zoomTool, ACTION_TOOLBAR::TOGGLE, ACTION_TOOLBAR::CANCEL );
+    m_mainToolBar->Add( ACTIONS::zoomTool );
 
     m_mainToolBar->AddScaledSeparator( this );
     m_mainToolBar->Add( ACTIONS::show3DViewer );
@@ -129,25 +129,25 @@ void FOOTPRINT_VIEWER_FRAME::ReCreateOptToolbar()
         m_optionsToolBar->SetAuiManager( &m_auimgr );
     }
 
-    m_optionsToolBar->Add( ACTIONS::selectionTool,          ACTION_TOOLBAR::TOGGLE );
-    m_optionsToolBar->Add( ACTIONS::measureTool,            ACTION_TOOLBAR::TOGGLE );
+    m_optionsToolBar->Add( ACTIONS::selectionTool );
+    m_optionsToolBar->Add( ACTIONS::measureTool );
 
     m_optionsToolBar->AddScaledSeparator( this );
-    m_optionsToolBar->Add( ACTIONS::toggleGrid,             ACTION_TOOLBAR::TOGGLE );
-    m_optionsToolBar->Add( ACTIONS::togglePolarCoords,      ACTION_TOOLBAR::TOGGLE );
-    m_optionsToolBar->Add( ACTIONS::inchesUnits,            ACTION_TOOLBAR::TOGGLE );
-    m_optionsToolBar->Add( ACTIONS::milsUnits,              ACTION_TOOLBAR::TOGGLE );
-    m_optionsToolBar->Add( ACTIONS::millimetersUnits,       ACTION_TOOLBAR::TOGGLE );
-    m_optionsToolBar->Add( ACTIONS::toggleCursorStyle,      ACTION_TOOLBAR::TOGGLE );
+    m_optionsToolBar->Add( ACTIONS::toggleGrid );
+    m_optionsToolBar->Add( ACTIONS::togglePolarCoords );
+    m_optionsToolBar->Add( ACTIONS::inchesUnits );
+    m_optionsToolBar->Add( ACTIONS::milsUnits );
+    m_optionsToolBar->Add( ACTIONS::millimetersUnits );
+    m_optionsToolBar->Add( ACTIONS::toggleCursorStyle );
 
     m_optionsToolBar->AddScaledSeparator( this );
-    m_optionsToolBar->Add( PCB_ACTIONS::showPadNumbers,     ACTION_TOOLBAR::TOGGLE );
-    m_optionsToolBar->Add( PCB_ACTIONS::padDisplayMode,     ACTION_TOOLBAR::TOGGLE );
-    m_optionsToolBar->Add( PCB_ACTIONS::textOutlines,       ACTION_TOOLBAR::TOGGLE );
-    m_optionsToolBar->Add( PCB_ACTIONS::graphicsOutlines,   ACTION_TOOLBAR::TOGGLE );
+    m_optionsToolBar->Add( PCB_ACTIONS::showPadNumbers );
+    m_optionsToolBar->Add( PCB_ACTIONS::padDisplayMode );
+    m_optionsToolBar->Add( PCB_ACTIONS::textOutlines );
+    m_optionsToolBar->Add( PCB_ACTIONS::graphicsOutlines );
 
     if( ADVANCED_CFG::GetCfg().m_DrawBoundingBoxes )
-        m_optionsToolBar->Add( ACTIONS::toggleBoundingBoxes, ACTION_TOOLBAR::TOGGLE );
+        m_optionsToolBar->Add( ACTIONS::toggleBoundingBoxes );
 
     m_optionsToolBar->KiRealize();
 }
diff --git a/pcbnew/toolbars_pcb_editor.cpp b/pcbnew/toolbars_pcb_editor.cpp
index 079d10c354..599684b7b1 100644
--- a/pcbnew/toolbars_pcb_editor.cpp
+++ b/pcbnew/toolbars_pcb_editor.cpp
@@ -170,7 +170,7 @@ void PCB_EDIT_FRAME::ReCreateHToolbar()
     m_mainToolBar->Add( ACTIONS::zoomOutCenter );
     m_mainToolBar->Add( ACTIONS::zoomFitScreen );
     m_mainToolBar->Add( ACTIONS::zoomFitObjects );
-    m_mainToolBar->Add( ACTIONS::zoomTool, ACTION_TOOLBAR::TOGGLE, ACTION_TOOLBAR::CANCEL );
+    m_mainToolBar->Add( ACTIONS::zoomTool );
 
     m_mainToolBar->AddScaledSeparator( this );
     m_mainToolBar->Add( PCB_ACTIONS::rotateCcw );
@@ -250,48 +250,48 @@ void PCB_EDIT_FRAME::ReCreateOptToolbar()
         m_optionsToolBar->SetAuiManager( &m_auimgr );
     }
 
-    m_optionsToolBar->Add( ACTIONS::toggleGrid,               ACTION_TOOLBAR::TOGGLE );
-    m_optionsToolBar->Add( ACTIONS::toggleGridOverrides,      ACTION_TOOLBAR::TOGGLE );
+    m_optionsToolBar->Add( ACTIONS::toggleGrid );
+    m_optionsToolBar->Add( ACTIONS::toggleGridOverrides );
 
-    m_optionsToolBar->Add( PCB_ACTIONS::togglePolarCoords,    ACTION_TOOLBAR::TOGGLE );
-    m_optionsToolBar->Add( ACTIONS::inchesUnits,              ACTION_TOOLBAR::TOGGLE );
-    m_optionsToolBar->Add( ACTIONS::milsUnits,                ACTION_TOOLBAR::TOGGLE );
-    m_optionsToolBar->Add( ACTIONS::millimetersUnits,         ACTION_TOOLBAR::TOGGLE );
-    m_optionsToolBar->Add( ACTIONS::toggleCursorStyle,        ACTION_TOOLBAR::TOGGLE );
+    m_optionsToolBar->Add( PCB_ACTIONS::togglePolarCoords );
+    m_optionsToolBar->Add( ACTIONS::inchesUnits );
+    m_optionsToolBar->Add( ACTIONS::milsUnits );
+    m_optionsToolBar->Add( ACTIONS::millimetersUnits );
+    m_optionsToolBar->Add( ACTIONS::toggleCursorStyle );
 
     m_optionsToolBar->AddScaledSeparator( this );
-    m_optionsToolBar->Add( PCB_ACTIONS::toggleHV45Mode,       ACTION_TOOLBAR::TOGGLE );
+    m_optionsToolBar->Add( PCB_ACTIONS::toggleHV45Mode );
 
     m_optionsToolBar->AddScaledSeparator( this );
-    m_optionsToolBar->Add( PCB_ACTIONS::showRatsnest,         ACTION_TOOLBAR::TOGGLE );
-    m_optionsToolBar->Add( PCB_ACTIONS::ratsnestLineMode,     ACTION_TOOLBAR::TOGGLE );
+    m_optionsToolBar->Add( PCB_ACTIONS::showRatsnest );
+    m_optionsToolBar->Add( PCB_ACTIONS::ratsnestLineMode );
 
     m_optionsToolBar->AddScaledSeparator( this );
-    m_optionsToolBar->Add( ACTIONS::highContrastMode,         ACTION_TOOLBAR::TOGGLE );
-    m_optionsToolBar->Add( PCB_ACTIONS::toggleNetHighlight,   ACTION_TOOLBAR::TOGGLE );
+    m_optionsToolBar->Add( ACTIONS::highContrastMode );
+    m_optionsToolBar->Add( PCB_ACTIONS::toggleNetHighlight );
 
     m_optionsToolBar->AddScaledSeparator( this );
-    m_optionsToolBar->Add( PCB_ACTIONS::zoneDisplayFilled,    ACTION_TOOLBAR::TOGGLE );
-    m_optionsToolBar->Add( PCB_ACTIONS::zoneDisplayOutline,   ACTION_TOOLBAR::TOGGLE );
+    m_optionsToolBar->Add( PCB_ACTIONS::zoneDisplayFilled );
+    m_optionsToolBar->Add( PCB_ACTIONS::zoneDisplayOutline );
 
     if( ADVANCED_CFG::GetCfg().m_ExtraZoneDisplayModes )
     {
-        m_optionsToolBar->Add( PCB_ACTIONS::zoneDisplayFractured,    ACTION_TOOLBAR::TOGGLE );
-        m_optionsToolBar->Add( PCB_ACTIONS::zoneDisplayTriangulated, ACTION_TOOLBAR::TOGGLE );
+        m_optionsToolBar->Add( PCB_ACTIONS::zoneDisplayFractured );
+        m_optionsToolBar->Add( PCB_ACTIONS::zoneDisplayTriangulated );
     }
 
     m_optionsToolBar->AddScaledSeparator( this );
-    m_optionsToolBar->Add( PCB_ACTIONS::padDisplayMode,       ACTION_TOOLBAR::TOGGLE );
-    m_optionsToolBar->Add( PCB_ACTIONS::viaDisplayMode,       ACTION_TOOLBAR::TOGGLE );
-    m_optionsToolBar->Add( PCB_ACTIONS::trackDisplayMode,     ACTION_TOOLBAR::TOGGLE );
+    m_optionsToolBar->Add( PCB_ACTIONS::padDisplayMode );
+    m_optionsToolBar->Add( PCB_ACTIONS::viaDisplayMode );
+    m_optionsToolBar->Add( PCB_ACTIONS::trackDisplayMode );
 
     if( ADVANCED_CFG::GetCfg().m_DrawBoundingBoxes )
-        m_optionsToolBar->Add( ACTIONS::toggleBoundingBoxes,  ACTION_TOOLBAR::TOGGLE );
+        m_optionsToolBar->Add( ACTIONS::toggleBoundingBoxes );
 
     // Tools to show/hide toolbars:
     m_optionsToolBar->AddScaledSeparator( this );
-    m_optionsToolBar->Add( PCB_ACTIONS::showLayersManager,    ACTION_TOOLBAR::TOGGLE );
-    m_optionsToolBar->Add( PCB_ACTIONS::showProperties, ACTION_TOOLBAR::TOGGLE );
+    m_optionsToolBar->Add( PCB_ACTIONS::showLayersManager );
+    m_optionsToolBar->Add( ACTIONS::showProperties );
 
     PCB_SELECTION_TOOL*          selTool = m_toolManager->GetTool<PCB_SELECTION_TOOL>();
     std::unique_ptr<ACTION_MENU> gridMenu = std::make_unique<ACTION_MENU>( false, selTool );
@@ -337,7 +337,7 @@ void PCB_EDIT_FRAME::ReCreateVToolbar()
     if( !originGroup )
     {
         originGroup = new ACTION_GROUP( "group.pcbOrigins",
-                                        { &PCB_ACTIONS::gridSetOrigin,
+                                        { &ACTIONS::gridSetOrigin,
                                           &PCB_ACTIONS::drillOrigin } );
     }
 
@@ -357,34 +357,34 @@ void PCB_EDIT_FRAME::ReCreateVToolbar()
     }
 
     // clang-format off
-    m_drawToolBar->Add( ACTIONS::selectionTool,            ACTION_TOOLBAR::TOGGLE );
-    m_drawToolBar->Add( PCB_ACTIONS::localRatsnestTool,    ACTION_TOOLBAR::TOGGLE );
+    m_drawToolBar->Add( ACTIONS::selectionTool );
+    m_drawToolBar->Add( PCB_ACTIONS::localRatsnestTool );
 
     m_drawToolBar->AddScaledSeparator( this );
-    m_drawToolBar->Add( PCB_ACTIONS::placeFootprint,       ACTION_TOOLBAR::TOGGLE );
+    m_drawToolBar->Add( PCB_ACTIONS::placeFootprint );
     m_drawToolBar->AddGroup( routingGroup,                 ACTION_TOOLBAR::TOGGLE );
     m_drawToolBar->AddGroup( tuneGroup,                    ACTION_TOOLBAR::TOGGLE );
-    m_drawToolBar->Add( PCB_ACTIONS::drawVia,              ACTION_TOOLBAR::TOGGLE );
-    m_drawToolBar->Add( PCB_ACTIONS::drawZone,             ACTION_TOOLBAR::TOGGLE );
-    m_drawToolBar->Add( PCB_ACTIONS::drawRuleArea,         ACTION_TOOLBAR::TOGGLE );
+    m_drawToolBar->Add( PCB_ACTIONS::drawVia );
+    m_drawToolBar->Add( PCB_ACTIONS::drawZone );
+    m_drawToolBar->Add( PCB_ACTIONS::drawRuleArea );
 
     m_drawToolBar->AddScaledSeparator( this );
-    m_drawToolBar->Add( PCB_ACTIONS::drawLine,             ACTION_TOOLBAR::TOGGLE );
-    m_drawToolBar->Add( PCB_ACTIONS::drawArc,              ACTION_TOOLBAR::TOGGLE );
-    m_drawToolBar->Add( PCB_ACTIONS::drawRectangle,        ACTION_TOOLBAR::TOGGLE );
-    m_drawToolBar->Add( PCB_ACTIONS::drawCircle,           ACTION_TOOLBAR::TOGGLE );
-    m_drawToolBar->Add( PCB_ACTIONS::drawPolygon,          ACTION_TOOLBAR::TOGGLE );
-    m_drawToolBar->Add( PCB_ACTIONS::drawBezier,           ACTION_TOOLBAR::TOGGLE );
-    m_drawToolBar->Add( PCB_ACTIONS::placeReferenceImage,  ACTION_TOOLBAR::TOGGLE );
-    m_drawToolBar->Add( PCB_ACTIONS::placeText,            ACTION_TOOLBAR::TOGGLE );
-    m_drawToolBar->Add( PCB_ACTIONS::drawTextBox,          ACTION_TOOLBAR::TOGGLE );
-    m_drawToolBar->Add( PCB_ACTIONS::drawTable,            ACTION_TOOLBAR::TOGGLE );
+    m_drawToolBar->Add( PCB_ACTIONS::drawLine );
+    m_drawToolBar->Add( PCB_ACTIONS::drawArc );
+    m_drawToolBar->Add( PCB_ACTIONS::drawRectangle );
+    m_drawToolBar->Add( PCB_ACTIONS::drawCircle );
+    m_drawToolBar->Add( PCB_ACTIONS::drawPolygon );
+    m_drawToolBar->Add( PCB_ACTIONS::drawBezier );
+    m_drawToolBar->Add( PCB_ACTIONS::placeReferenceImage );
+    m_drawToolBar->Add( PCB_ACTIONS::placeText );
+    m_drawToolBar->Add( PCB_ACTIONS::drawTextBox );
+    m_drawToolBar->Add( PCB_ACTIONS::drawTable );
     m_drawToolBar->AddGroup( dimensionGroup,               ACTION_TOOLBAR::TOGGLE );
-    m_drawToolBar->Add( ACTIONS::deleteTool,               ACTION_TOOLBAR::TOGGLE );
+    m_drawToolBar->Add( ACTIONS::deleteTool );
 
     m_drawToolBar->AddScaledSeparator( this );
     m_drawToolBar->AddGroup( originGroup,                  ACTION_TOOLBAR::TOGGLE );
-    m_drawToolBar->Add( ACTIONS::measureTool,              ACTION_TOOLBAR::TOGGLE );
+    m_drawToolBar->Add( ACTIONS::measureTool );
     // clang-format on
 
     PCB_SELECTION_TOOL* selTool   = m_toolManager->GetTool<PCB_SELECTION_TOOL>();
diff --git a/pcbnew/tools/footprint_editor_control.cpp b/pcbnew/tools/footprint_editor_control.cpp
index b5d98ca2d7..9d8c301f5d 100644
--- a/pcbnew/tools/footprint_editor_control.cpp
+++ b/pcbnew/tools/footprint_editor_control.cpp
@@ -939,6 +939,6 @@ void FOOTPRINT_EDITOR_CONTROL::setTransitions()
     Go( &FOOTPRINT_EDITOR_CONTROL::Properties,           PCB_ACTIONS::footprintProperties.MakeEvent() );
     Go( &FOOTPRINT_EDITOR_CONTROL::DefaultPadProperties, PCB_ACTIONS::defaultPadProperties.MakeEvent() );
     Go( &FOOTPRINT_EDITOR_CONTROL::ToggleLayersManager,  PCB_ACTIONS::showLayersManager.MakeEvent() );
-    Go( &FOOTPRINT_EDITOR_CONTROL::ToggleProperties,     PCB_ACTIONS::showProperties.MakeEvent() );
+    Go( &FOOTPRINT_EDITOR_CONTROL::ToggleProperties,     ACTIONS::showProperties.MakeEvent() );
     // clang-format on
 }
diff --git a/pcbnew/tools/pcb_actions.cpp b/pcbnew/tools/pcb_actions.cpp
index 6c76d20415..975a59c9e8 100644
--- a/pcbnew/tools/pcb_actions.cpp
+++ b/pcbnew/tools/pcb_actions.cpp
@@ -106,6 +106,7 @@ TOOL_ACTION PCB_ACTIONS::drawLine( TOOL_ACTION_ARGS()
         .DefaultHotkey( MD_CTRL + MD_SHIFT + 'L' )
         .LegacyHotkeyName( "Draw Line" )
         .FriendlyName( _( "Draw Lines" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE )
         .Icon( BITMAPS::add_graphical_segments )
         .Flags( AF_ACTIVATE ) );
 
@@ -115,6 +116,7 @@ TOOL_ACTION PCB_ACTIONS::drawPolygon( TOOL_ACTION_ARGS()
         .DefaultHotkey( MD_CTRL + MD_SHIFT + 'P' )
         .LegacyHotkeyName( "Draw Graphic Polygon" )
         .FriendlyName( _( "Draw Polygons" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE )
         .Icon( BITMAPS::add_graphical_polygon )
         .Flags( AF_ACTIVATE )
         .Parameter( ZONE_MODE::GRAPHIC_POLYGON ) );
@@ -123,6 +125,7 @@ TOOL_ACTION PCB_ACTIONS::drawRectangle( TOOL_ACTION_ARGS()
         .Name( "pcbnew.InteractiveDrawing.rectangle" )
         .Scope( AS_GLOBAL )
         .FriendlyName( _( "Draw Rectangles" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE )
         .Icon( BITMAPS::add_rectangle )
         .Flags( AF_ACTIVATE ) );
 
@@ -132,6 +135,7 @@ TOOL_ACTION PCB_ACTIONS::drawCircle( TOOL_ACTION_ARGS()
         .DefaultHotkey( MD_CTRL + MD_SHIFT + 'C' )
         .LegacyHotkeyName( "Draw Circle" )
         .FriendlyName( _( "Draw Circles" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE )
         .Icon( BITMAPS::add_circle )
         .Flags( AF_ACTIVATE ) );
 
@@ -141,6 +145,7 @@ TOOL_ACTION PCB_ACTIONS::drawArc( TOOL_ACTION_ARGS()
         .DefaultHotkey( MD_CTRL + MD_SHIFT + 'A' )
         .LegacyHotkeyName( "Draw Arc" )
         .FriendlyName( _( "Draw Arcs" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE )
         .Icon( BITMAPS::add_arc )
         .Flags( AF_ACTIVATE ) );
 
@@ -149,6 +154,7 @@ TOOL_ACTION PCB_ACTIONS::drawBezier( TOOL_ACTION_ARGS()
         .Scope( AS_GLOBAL )
         .DefaultHotkey( MD_CTRL + MD_SHIFT + 'B' )
         .FriendlyName( _( "Draw Bezier Curve" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE )
         .Icon( BITMAPS::add_bezier )
         .Flags( AF_ACTIVATE ) );
 
@@ -158,6 +164,7 @@ TOOL_ACTION PCB_ACTIONS::placeCharacteristics( TOOL_ACTION_ARGS()
         .LegacyHotkeyName( "Add Board Characteristics" )
         .FriendlyName( _( "Add Board Characteristics" ) )
         .Tooltip( _( "Add a board characteristics table on a graphic layer" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE )
         .Flags( AF_ACTIVATE ) );
 
 TOOL_ACTION PCB_ACTIONS::placeStackup( TOOL_ACTION_ARGS()
@@ -166,6 +173,7 @@ TOOL_ACTION PCB_ACTIONS::placeStackup( TOOL_ACTION_ARGS()
         .LegacyHotkeyName( "Add Stackup Table" )
         .FriendlyName( _( "Add Stackup Table" ) )
         .Tooltip( _( "Add a board stackup table on a graphic layer" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE )
         .Flags( AF_ACTIVATE ) );
 
 TOOL_ACTION PCB_ACTIONS::placeReferenceImage( TOOL_ACTION_ARGS()
@@ -173,6 +181,7 @@ TOOL_ACTION PCB_ACTIONS::placeReferenceImage( TOOL_ACTION_ARGS()
         .Scope( AS_GLOBAL )
         .FriendlyName( _( "Place Reference Images" ) )
         .Tooltip( _( "Add bitmap images to be used as reference (images will not be included in any output)" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE )
         .Icon( BITMAPS::image )
         .Flags( AF_ACTIVATE )
         .Parameter<PCB_REFERENCE_IMAGE*>( nullptr ) );
@@ -183,6 +192,7 @@ TOOL_ACTION PCB_ACTIONS::placeText( TOOL_ACTION_ARGS()
         .DefaultHotkey( MD_CTRL + MD_SHIFT + 'T' )
         .LegacyHotkeyName( "Add Text" )
         .FriendlyName( _( "Draw Text" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE )
         .Icon( BITMAPS::text )
         .Flags( AF_ACTIVATE ) );
 
@@ -190,6 +200,7 @@ TOOL_ACTION PCB_ACTIONS::drawTextBox( TOOL_ACTION_ARGS()
         .Name( "pcbnew.InteractiveDrawing.textbox" )
         .Scope( AS_GLOBAL )
         .FriendlyName( _( "Draw Text Boxes" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE )
         .Icon( BITMAPS::add_textbox )
         .Flags( AF_ACTIVATE ) );
 
@@ -197,6 +208,7 @@ TOOL_ACTION PCB_ACTIONS::drawTable( TOOL_ACTION_ARGS()
         .Name( "pcbnew.InteractiveDrawing.drawTable" )
         .Scope( AS_GLOBAL )
         .FriendlyName( _( "Draw Tables" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE )
         .Icon( BITMAPS::table )
         .Flags( AF_ACTIVATE ) );
 
@@ -242,6 +254,7 @@ TOOL_ACTION PCB_ACTIONS::drawAlignedDimension( TOOL_ACTION_ARGS()
         .Scope( AS_GLOBAL )
         .LegacyHotkeyName( "Add Dimension" )
         .FriendlyName( _( "Draw Aligned Dimensions" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE )
         .Icon( BITMAPS::add_aligned_dimension )
         .Flags( AF_ACTIVATE ) );
 
@@ -249,6 +262,7 @@ TOOL_ACTION PCB_ACTIONS::drawCenterDimension( TOOL_ACTION_ARGS()
         .Name( "pcbnew.InteractiveDrawing.centerDimension" )
         .Scope( AS_GLOBAL )
         .FriendlyName( _( "Draw Center Dimensions" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE )
         .Icon( BITMAPS::add_center_dimension )
         .Flags( AF_ACTIVATE ) );
 
@@ -256,6 +270,7 @@ TOOL_ACTION PCB_ACTIONS::drawRadialDimension( TOOL_ACTION_ARGS()
         .Name( "pcbnew.InteractiveDrawing.radialDimension" )
         .Scope( AS_GLOBAL )
         .FriendlyName( _( "Draw Radial Dimensions" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE )
         .Icon( BITMAPS::add_radial_dimension )
         .Flags( AF_ACTIVATE ) );
 
@@ -264,6 +279,7 @@ TOOL_ACTION PCB_ACTIONS::drawOrthogonalDimension( TOOL_ACTION_ARGS()
         .Scope( AS_GLOBAL )
         .DefaultHotkey( MD_CTRL + MD_SHIFT + 'H' )
         .FriendlyName( _( "Draw Orthogonal Dimensions" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE )
         .Icon( BITMAPS::add_orthogonal_dimension )
         .Flags( AF_ACTIVATE ) );
 
@@ -271,6 +287,7 @@ TOOL_ACTION PCB_ACTIONS::drawLeader( TOOL_ACTION_ARGS()
         .Name( "pcbnew.InteractiveDrawing.leader" )
         .Scope( AS_GLOBAL )
         .FriendlyName( _( "Draw Leaders" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE )
         .Icon( BITMAPS::add_leader )
         .Flags( AF_ACTIVATE ) );
 
@@ -284,6 +301,7 @@ TOOL_ACTION PCB_ACTIONS::drawZone( TOOL_ACTION_ARGS()
 #endif
         .LegacyHotkeyName( "Add Filled Zone" )
         .FriendlyName( _( "Draw Filled Zones" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE )
         .Icon( BITMAPS::add_zone )
         .Flags( AF_ACTIVATE )
         .Parameter( ZONE_MODE::ADD ) );
@@ -295,6 +313,7 @@ TOOL_ACTION PCB_ACTIONS::drawVia( TOOL_ACTION_ARGS()
         .LegacyHotkeyName( "Add Vias" )
         .FriendlyName( _( "Place Vias" ) )
         .Tooltip( _( "Place free-standing vias" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE )
         .Icon( BITMAPS::add_via )
         .Flags( AF_ACTIVATE ) );
 
@@ -304,6 +323,7 @@ TOOL_ACTION PCB_ACTIONS::drawRuleArea( TOOL_ACTION_ARGS()
         .DefaultHotkey( MD_CTRL + MD_SHIFT + 'K' )
         .LegacyHotkeyName( "Add Keepout Area" )
         .FriendlyName( _( "Draw Rule Areas" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE )
         .Icon( BITMAPS::add_keepout_area )
         .Flags( AF_ACTIVATE )
         .Parameter( ZONE_MODE::ADD ) );
@@ -315,6 +335,7 @@ TOOL_ACTION PCB_ACTIONS::drawZoneCutout( TOOL_ACTION_ARGS()
         .LegacyHotkeyName( "Add a Zone Cutout" )
         .FriendlyName( _( "Add a Zone Cutout" ) )
         .Tooltip( _( "Add a cutout to an existing zone or rule area" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE )
         .Icon( BITMAPS::add_zone_cutout )
         .Flags(  AF_ACTIVATE )
         .Parameter( ZONE_MODE::CUTOUT ) );
@@ -347,6 +368,7 @@ TOOL_ACTION PCB_ACTIONS::setAnchor( TOOL_ACTION_ARGS()
         .LegacyHotkeyName( "Place the Footprint Anchor" )
         .FriendlyName( _( "Place the Footprint Anchor" ) )
         .Tooltip( _( "Set the anchor point of the footprint" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE )
         .Icon( BITMAPS::anchor )
         .Flags( AF_ACTIVATE ) );
 
@@ -945,6 +967,7 @@ TOOL_ACTION PCB_ACTIONS::placePad( TOOL_ACTION_ARGS()
         .Scope( AS_GLOBAL )
         .FriendlyName( _( "Add Pad" ) )
         .Tooltip( _( "Add a pad" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE )
         .Icon( BITMAPS::pad )
         .Flags( AF_ACTIVATE ) );
 
@@ -1135,6 +1158,7 @@ TOOL_ACTION PCB_ACTIONS::placeFootprint( TOOL_ACTION_ARGS()
         .DefaultHotkey( 'A' )
         .LegacyHotkeyName( "Add Footprint" )
         .FriendlyName( _( "Place Footprints" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE )
         .Icon( BITMAPS::module )
         .Flags( AF_ACTIVATE )
         .Parameter<FOOTPRINT*>( nullptr ) );
@@ -1173,6 +1197,7 @@ TOOL_ACTION PCB_ACTIONS::toggleHV45Mode( TOOL_ACTION_ARGS()
         .DefaultHotkey( MD_SHIFT + ' ' )
         .FriendlyName( _( "Constrain to H, V, 45" ) )
         .Tooltip( _( "Limit actions to horizontal, vertical, or 45 degrees from the starting point" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE )
         .Icon( BITMAPS::hv45mode ) );
 
 TOOL_ACTION PCB_ACTIONS::lock( TOOL_ACTION_ARGS()
@@ -1260,6 +1285,7 @@ TOOL_ACTION PCB_ACTIONS::toggleNetHighlight( TOOL_ACTION_ARGS()
         .Scope( AS_GLOBAL )
         .DefaultHotkey( MD_ALT + '`' )
         .FriendlyName( _( "Toggle Net Highlight" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE )
         .Icon( BITMAPS::net_highlight )
         .Parameter<int>( 0 ) );
 
@@ -1307,6 +1333,7 @@ TOOL_ACTION PCB_ACTIONS::localRatsnestTool( TOOL_ACTION_ARGS()
         .Scope( AS_GLOBAL )
         .FriendlyName( _( "Local Ratsnest" ) )
         .Tooltip( _( "Toggle ratsnest display of selected item(s)" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE )
         .Icon( BITMAPS::tool_ratsnest )
         .Flags( AF_ACTIVATE ) );
 
@@ -1331,6 +1358,7 @@ TOOL_ACTION PCB_ACTIONS::showLayersManager( TOOL_ACTION_ARGS()
         .Scope( AS_GLOBAL )
         .FriendlyName( _( "Appearance" ) )
         .Tooltip( _( "Show/hide the appearance manager" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE )
         .Icon( BITMAPS::layers_manager ) );
 
 TOOL_ACTION PCB_ACTIONS::showNetInspector( TOOL_ACTION_ARGS()
@@ -1338,6 +1366,7 @@ TOOL_ACTION PCB_ACTIONS::showNetInspector( TOOL_ACTION_ARGS()
         .Scope( AS_GLOBAL )
         .FriendlyName( _( "Net Inspector" ) )
         .Tooltip( _( "Show/hide the net inspector" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE )
         .Icon( BITMAPS::tools ) );
 
 TOOL_ACTION PCB_ACTIONS::zonesManager( "pcbnew.Control.zonesManager",
@@ -1359,6 +1388,7 @@ TOOL_ACTION PCB_ACTIONS::showRatsnest( TOOL_ACTION_ARGS()
         .Scope( AS_GLOBAL )
         .FriendlyName( _( "Show Ratsnest" ) )
         .Tooltip( _( "Show lines/arcs representing missing connections on the board" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE )
         .Icon( BITMAPS::general_ratsnest ) );
 
 TOOL_ACTION PCB_ACTIONS::ratsnestLineMode( TOOL_ACTION_ARGS()
@@ -1366,6 +1396,7 @@ TOOL_ACTION PCB_ACTIONS::ratsnestLineMode( TOOL_ACTION_ARGS()
         .Scope( AS_GLOBAL )
         .FriendlyName( _( "Curved Ratsnest Lines" ) )
         .Tooltip( _( "Show ratsnest with curved lines" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE )
         .Icon( BITMAPS::curved_ratsnest ) );
 
 TOOL_ACTION PCB_ACTIONS::ratsnestModeCycle( TOOL_ACTION_ARGS()
@@ -1387,6 +1418,7 @@ TOOL_ACTION PCB_ACTIONS::trackDisplayMode( TOOL_ACTION_ARGS()
         .LegacyHotkeyName( "Track Display Mode" )
         .FriendlyName( _( "Sketch Tracks" ) )
         .Tooltip( _( "Show tracks in outline mode" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE )
         .Icon( BITMAPS::showtrack ) );
 
 TOOL_ACTION PCB_ACTIONS::padDisplayMode( TOOL_ACTION_ARGS()
@@ -1394,6 +1426,7 @@ TOOL_ACTION PCB_ACTIONS::padDisplayMode( TOOL_ACTION_ARGS()
         .Scope( AS_GLOBAL )
         .FriendlyName( _( "Sketch Pads" ) )
         .Tooltip( _( "Show pads in outline mode" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE )
         .Icon( BITMAPS::pad_sketch ) );
 
 TOOL_ACTION PCB_ACTIONS::viaDisplayMode( TOOL_ACTION_ARGS()
@@ -1401,6 +1434,7 @@ TOOL_ACTION PCB_ACTIONS::viaDisplayMode( TOOL_ACTION_ARGS()
         .Scope( AS_GLOBAL )
         .FriendlyName( _( "Sketch Vias" ) )
         .Tooltip( _( "Show vias in outline mode" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE )
         .Icon( BITMAPS::via_sketch ) );
 
 TOOL_ACTION PCB_ACTIONS::graphicsOutlines( TOOL_ACTION_ARGS()
@@ -1408,6 +1442,7 @@ TOOL_ACTION PCB_ACTIONS::graphicsOutlines( TOOL_ACTION_ARGS()
         .Scope( AS_GLOBAL )
         .FriendlyName( _( "Sketch Graphic Items" ) )
         .Tooltip( _( "Show graphic items in outline mode" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE )
         .Icon( BITMAPS::show_mod_edge ) );
 
 TOOL_ACTION PCB_ACTIONS::textOutlines( TOOL_ACTION_ARGS()
@@ -1415,12 +1450,14 @@ TOOL_ACTION PCB_ACTIONS::textOutlines( TOOL_ACTION_ARGS()
         .Scope( AS_GLOBAL )
         .FriendlyName( _( "Sketch Text Items" ) )
         .Tooltip( _( "Show footprint texts in line mode" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE )
         .Icon( BITMAPS::text_sketch ) );
 
 TOOL_ACTION PCB_ACTIONS::showPadNumbers( TOOL_ACTION_ARGS()
         .Name( "pcbnew.Control.showPadNumbers" )
         .Scope( AS_GLOBAL )
         .FriendlyName( _( "Show Pad Numbers" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE )
         .Icon( BITMAPS::pad_number ) );
 
 TOOL_ACTION PCB_ACTIONS::zoneDisplayFilled( TOOL_ACTION_ARGS()
@@ -1428,6 +1465,7 @@ TOOL_ACTION PCB_ACTIONS::zoneDisplayFilled( TOOL_ACTION_ARGS()
         .Scope( AS_GLOBAL )
         .FriendlyName( _( "Draw Zone Fills" ) )
         .Tooltip( _( "Show filled areas of zones" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE )
         .Icon( BITMAPS::show_zone ) );
 
 TOOL_ACTION PCB_ACTIONS::zoneDisplayOutline( TOOL_ACTION_ARGS()
@@ -1435,18 +1473,21 @@ TOOL_ACTION PCB_ACTIONS::zoneDisplayOutline( TOOL_ACTION_ARGS()
         .Scope( AS_GLOBAL )
         .FriendlyName( _( "Draw Zone Outlines" ) )
         .Tooltip( _( "Show only zone boundaries" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE )
         .Icon( BITMAPS::show_zone_disable ) );
 
 TOOL_ACTION PCB_ACTIONS::zoneDisplayFractured( TOOL_ACTION_ARGS()
         .Name( "pcbnew.Control.zoneDisplayOutlines" )
         .Scope( AS_GLOBAL )
         .FriendlyName( _( "Draw Zone Fill Fracture Borders" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE )
         .Icon( BITMAPS::show_zone_outline_only ) );
 
 TOOL_ACTION PCB_ACTIONS::zoneDisplayTriangulated( TOOL_ACTION_ARGS()
         .Name( "pcbnew.Control.zoneDisplayTesselation" )
         .Scope( AS_GLOBAL )
         .FriendlyName( _( "Draw Zone Fill Triangulation" ) )
+        .ToolbarState( TOOLBAR_STATE::TOGGLE )
         .Icon( BITMAPS::show_zone_triangulation ) );
 
 TOOL_ACTION PCB_ACTIONS::zoneDisplayToggle( TOOL_ACTION_ARGS()