30#include <nlohmann/json.hpp>
75#include <wx/display.h>
76#include <wx/stdpaths.h>
79#include <wx/wupdlock.h>
84#include <nlohmann/json.hpp>
100 return wxWindow::FromDIP( wxSize( 406, 354 ), aWindow );
103 return wxWindow::FromDIP( wxSize( 500, 400 ), aWindow );
113 return wxWindow::FromDIP( wxSize( 850, 540 ), aWindow );
116 return wxWindow::FromDIP( wxSize( 1280, 720 ), aWindow );
183 const wxPoint& aPos,
const wxSize& aSize,
long aStyle,
184 const wxString& aFrameName,
KIWAY* aKiway,
186 wxFrame( aParent, wxID_ANY, aTitle, aPos, aSize, aStyle, aFrameName ),
199 Bind( wxEVT_DPI_CHANGED,
200 [&]( wxDPIChangedEvent& aEvent )
206 wxAuiPaneInfoArray& panes =
m_auimgr.GetAllPanes();
208 for(
size_t ii = 0; ii < panes.GetCount(); ii++ )
210 wxAuiPaneInfo& pinfo = panes.Item( ii );
211 pinfo.best_size = pinfo.window->GetSize();
214 pinfo.best_size.IncTo( pinfo.window->GetBestSize() );
215 pinfo.best_size.IncTo( pinfo.min_size );
229 for( wxWindow* child : aParent->GetChildren() )
233 if( dlg->IsQuasiModal() )
254 wxWindow* cvpcb = wxWindow::FindWindowByName( wxS(
"CvpcbFrame" ) );
282 if( event.CanVeto() )
289 if( event.GetId() == wxEVT_QUERY_END_SESSION
290 || event.GetId() == wxEVT_END_SESSION )
317 if( event.CanVeto() )
347 if( !IsEnabled() && IsActive() )
361 if( aEvent.GetEventType() == wxEVT_DPI_CHANGED )
363 wxFrame::ProcessEvent( aEvent );
368 if( !wxFrame::ProcessEvent( aEvent ) )
371 if(
Pgm().m_Quitting )
380 wxLogTrace(
traceAutoSave, wxT(
"Starting auto save timer." ) );
386 wxLogTrace(
traceAutoSave, wxT(
"Stopping auto save timer." ) );
423 if( !
Prj().IsReadOnly() )
462 std::placeholders::_1,
479 it->second( aEvent );
488 bool checkRes =
false;
489 bool enableRes =
true;
502 catch( std::exception& )
511 wxString msg =
_(
"Undo" );
516 aEvent.SetText( msg );
518 else if( showRes && aEvent.GetId() ==
ACTIONS::redo.GetUIId() )
520 wxString msg =
_(
"Redo" );
525 aEvent.SetText( msg );
528 if( isCut || isCopy || isPaste )
530 wxWindow* focus = wxWindow::FindFocus();
531 wxTextEntry* textEntry =
dynamic_cast<wxTextEntry*
>( focus );
533 if( textEntry && isCut && textEntry->CanCut() )
535 else if( textEntry && isCopy && textEntry->CanCopy() )
537 else if( textEntry && isPaste && textEntry->CanPaste() )
539 else if(
dynamic_cast<WX_GRID*
>( focus ) )
543 aEvent.Enable( enableRes );
544 aEvent.Show( showRes );
546 if( aEvent.IsCheckable() )
547 aEvent.Check( checkRes );
555 [] (
const SELECTION& aSel,
int aLangIdentifier )
560 for(
unsigned ii = 0;
LanguagesList[ii].m_KI_Lang_Identifier != 0; ii++ )
563 cond.
Check( std::bind( isCurrentLang, std::placeholders::_1,
581 if( control.first == aName )
582 return &control.second;
612 wxWindowUpdateLocker
dummy(
this );
628 std::optional<TOOLBAR_CONFIGURATION> tbConfig;
633 if( tbConfig.has_value() )
638 new ACTION_TOOLBAR(
this, wxID_ANY, wxDefaultPosition, wxDefaultSize,
643 m_tbRight->ApplyConfiguration( tbConfig.value() );
649 if( tbConfig.has_value() )
658 m_tbLeft->ApplyConfiguration( tbConfig.value() );
664 if( tbConfig.has_value() )
670 | wxAUI_TB_TEXT | wxAUI_TB_OVERFLOW );
674 m_tbTopMain->ApplyConfiguration( tbConfig.value() );
680 if( tbConfig.has_value() )
686 | wxAUI_TB_TEXT | wxAUI_TB_OVERFLOW );
690 m_tbTopAux->ApplyConfiguration( tbConfig.value() );
759 helpMenu->AppendSeparator();
762 aMenuBar->Append( helpMenu,
_(
"&Help" ) );
770 wxMenuBar* menuBar = GetMenuBar();
772 for(
size_t ii = 0; ii < menuBar->GetMenuCount(); ++ii )
774 for( wxMenuItem* menuItem : menuBar->GetMenu( ii )->GetMenuItems() )
776 if( menuItem->GetItemLabelText() == menuItemLabel )
778 wxString menuTitleLabel = menuBar->GetMenuLabelText( ii );
780 menuTitleLabel.Replace( wxS(
"&" ), wxS(
"&&" ) );
781 menuItemLabel.Replace( wxS(
"&" ), wxS(
"&&" ) );
783 return wxString::Format(
_(
"Run: %s > %s" ),
801 GetMenuBar()->Refresh();
813 bool running =
Pgm().GetApiServer().Running();
816 Pgm().GetApiServer().Stop();
818 Pgm().GetApiServer().Start();
824 m_fileHistory->SetMaxFiles( (
unsigned) std::max( 0, historySize ) );
827 if(
Pgm().GetCommonSettings()->m_Backup.enabled )
837 GetMenuBar()->Refresh();
850 wxAuiPaneInfoArray panes =
m_auimgr.GetAllPanes();
852 for(
size_t i = 0; i < panes.GetCount(); ++i )
855 toolbar->RefreshBitmaps();
863 int currentDisplay = wxDisplay::GetFromWindow(
this );
880 if( !
Pgm().GetCommonSettings()->m_Session.remember_open_files )
885 if( state !=
nullptr )
894 bool wasDefault =
false;
918 if( aState.
display >= wxDisplay::GetCount() )
924 const unsigned int index = 0;
925 wxDisplay display(
index );
926 wxRect clientSize = display.GetGeometry();
942 wxDisplay display( aState.
display );
943 wxRect clientSize = display.GetClientArea();
945 int yLimTop = clientSize.y;
946 int yLimBottom = clientSize.y + clientSize.height;
947 int xLimLeft = clientSize.x;
948 int xLimRight = clientSize.x + clientSize.width;
950 if( upperLeft.x > xLimRight ||
951 upperRight.x < xLimLeft ||
952 upperLeft.y < yLimTop ||
953 upperLeft.y > yLimBottom )
990 wxDisplay display( wxDisplay::GetFromWindow(
this ) );
991 wxRect clientSize = display.GetClientArea();
992 wxPoint pos = GetPosition();
996 wxS(
"ensureWindowIsOnScreen: clientArea (%d, %d) w %d h %d" ),
997 clientSize.x, clientSize.y,
998 clientSize.width, clientSize.height );
1000 if( pos.y < clientSize.y )
1003 wxS(
"ensureWindowIsOnScreen: y pos %d below minimum, setting to %d" ), pos.y,
1005 pos.y = clientSize.y;
1008 if( pos.x < clientSize.x )
1011 wxS(
"ensureWindowIsOnScreen: x pos %d is off the client rect, setting to %d" ),
1012 pos.x, clientSize.x );
1013 pos.x = clientSize.x;
1016 if( pos.x + size.x - clientSize.x > clientSize.width )
1018 int newWidth = clientSize.width - ( pos.x - clientSize.x );
1020 wxS(
"ensureWindowIsOnScreen: effective width %d above available %d, setting "
1021 "to %d" ), pos.x + size.x, clientSize.width, newWidth );
1025 if( pos.y + size.y - clientSize.y > clientSize.height )
1027 int newHeight = clientSize.height - ( pos.y - clientSize.y );
1029 wxS(
"ensureWindowIsOnScreen: effective height %d above available %d, setting "
1030 "to %d" ), pos.y + size.y, clientSize.height, newHeight );
1034 wxLogTrace(
traceDisplayLocation, wxS(
"Updating window position (%d, %d) with size (%d, %d)" ),
1035 pos.x, pos.y, size.x, size.y );
1037 SetSize( pos.x, pos.y, size.x, size.y );
1075 aCfg->
state.
display = wxDisplay::GetFromWindow(
this );
1078 IsMaximized() ? wxS(
"true" ) : wxS(
"false" ) );
1085#if wxCHECK_VERSION( 3, 3, 0 )
1088 nlohmann::json state = serializer.
Serialize();
1090 if( state.is_null() || state.empty() )
1130 if(
Pgm().GetCommonSettings()->m_Session.remember_open_files && !currentlyOpenedFile.IsEmpty() )
1132 wxFileName rfn( currentlyOpenedFile );
1133 rfn.MakeRelativeTo(
Prj().GetProjectPath() );
1141 if( !currentlyOpenedFile.IsEmpty() )
1176 SetStatusText(
text );
1182#if defined( __WXOSX_MAC__ )
1194#if defined( __WXOSX_MAC__ )
1202 m_auimgr.GetPane( wxS(
"InfoBar" ) ).Hide();
1213 bool restored =
false;
1215#if wxCHECK_VERSION( 3, 3, 0 )
1238 wxAuiPaneInfoArray& panes =
m_auimgr.GetAllPanes();
1240 for(
size_t i = 0; i < panes.GetCount(); ++i )
1242 if( panes.Item( i ).IsToolbar() )
1243 panes.Item( i ).Show(
true );
1253 if( aShowCloseButton )
1261 std::function<
void(
void)> aCallback )
1265 if( aShowCloseButton )
1279 if( aShowCloseButton )
1290 if( aShowCloseButton )
1302 wxASSERT( aFileHistory );
1310 GetMenuBar()->Refresh();
1320 wxASSERT( aFileHistory );
1322 int baseId = aFileHistory->GetBaseId();
1324 wxASSERT( cmdId >= baseId && cmdId < baseId + (
int) aFileHistory->GetCount() );
1325 int i = cmdId - baseId;
1327 wxString fn = aFileHistory->GetHistoryFile( i );
1329 if( !wxFileName::FileExists( fn ) )
1332 wxYES_NO | wxYES_DEFAULT | wxICON_ERROR | wxCENTER );
1334 dlg.SetExtendedMessage(
_(
"Do you want to remove it from list of recently opened files?" ) );
1335 dlg.SetYesNoLabels( KICAD_MESSAGE_DIALOG::ButtonLabel(
_(
"Remove" ) ),
1336 KICAD_MESSAGE_DIALOG::ButtonLabel(
_(
"Keep" ) ) );
1338 if( dlg.ShowModal() == wxID_YES )
1339 aFileHistory->RemoveFileFromHistory( i );
1348 GetMenuBar()->Refresh();
1365 GetMenuBar()->Refresh();
1385 PAGED_DIALOG dlg(
this,
_(
"Preferences" ),
true,
true, wxEmptyString,
1386 wxWindow::FromDIP( wxSize( 980, 560 ),
nullptr ) );
1388 dlg.SetEvtHandlerEnabled(
false );
1395 std::vector<int> expand;
1401 ACTION_MANAGER* actionMgr = kicadMgr->GetToolManager()->GetActionManager();
1408 []( wxWindow* aParent ) -> wxWindow*
1415 []( wxWindow* aParent ) -> wxWindow*
1418 },
_(
"Mouse and Touchpad" ) );
1420#if defined(__linux__) || defined(__FreeBSD__)
1422 [] ( wxWindow* aParent ) -> wxWindow*
1425 },
_(
"SpaceMouse" ) );
1428 book->AddPage( hotkeysPanel,
_(
"Hotkeys" ) );
1431 []( wxWindow* aParent ) -> wxWindow*
1434 },
_(
"Version Control" ) );
1436#ifdef KICAD_USE_SENTRY
1438 []( wxWindow* aParent ) -> wxWindow*
1441 },
_(
"Data Collection" ) );
1444#define LAZY_CTOR( key ) \
1445 [this, kiface]( wxWindow* aParent ) \
1447 return kiface->CreateKiWindow( aParent, key, &Kiway() ); \
1459 expand.push_back( (
int) book->GetPageCount() );
1461 book->AddPage(
new wxPanel( book ),
_(
"Symbol Editor" ) );
1469 expand.push_back( (
int) book->GetPageCount() );
1471 book->AddPage(
new wxPanel( book ),
_(
"Schematic Editor" ) );
1493 expand.push_back( (
int) book->GetPageCount() );
1495 book->AddPage(
new wxPanel( book ),
_(
"Footprint Editor" ) );
1507 expand.push_back( (
int) book->GetPageCount() );
1509 book->AddPage(
new wxPanel( book ),
_(
"PCB Editor" ) );
1519 expand.push_back( (
int) book->GetPageCount() );
1521 book->AddPage(
new wxPanel( book ),
_(
"3D Viewer" ) );
1539 expand.push_back( (
int) book->GetPageCount() );
1541 book->AddPage(
new wxPanel( book ),
_(
"Gerber Viewer" ) );
1560 expand.push_back( (
int) book->GetPageCount() );
1562 book->AddPage(
new wxPanel( book ),
_(
"Drawing Sheet Editor" ) );
1569 []( wxWindow* aParent ) -> wxWindow*
1572 },
_(
"Packages and Updates" ) );
1589 for(
size_t i = 0; i < book->GetPageCount(); ++i )
1590 book->GetPage( i )->Layout();
1592 for(
int page : expand )
1593 book->ExpandNode( page );
1595 if( !aStartPage.IsEmpty() )
1598 dlg.SetEvtHandlerEnabled(
true );
1617 wxString* files = aEvent.GetFiles();
1619 for(
int nb = 0; nb < aEvent.GetNumberOfFiles(); nb++ )
1621 const wxFileName fn = wxFileName( files[nb] );
1622 wxString ext = fn.GetExt();
1641 wxString fn = file.GetFullPath();
1650 wxFileName fn = aFileName;
1656 if( fn.GetPath().IsEmpty() && fn.HasName() )
1659 wxCHECK_MSG( fn.IsOk(),
false,
1660 wxT(
"File name object is invalid. Bad programmer!" ) );
1661 wxCHECK_MSG( !fn.GetPath().IsEmpty(),
false,
1662 wxT(
"File name object path <" ) + fn.GetFullPath() +
1663 wxT(
"> is not set. Bad programmer!" ) );
1665 if( fn.IsDir() && !fn.IsDirWritable() )
1667 msg.Printf(
_(
"Insufficient permissions to folder '%s'." ), fn.GetPath() );
1669 else if( !fn.FileExists() && !fn.IsDirWritable() )
1671 msg.Printf(
_(
"Insufficient permissions to save file '%s'." ), fn.GetFullPath() );
1673 else if( fn.FileExists() && !fn.IsFileWritable() )
1675 msg.Printf(
_(
"Insufficient permissions to save file '%s'." ), fn.GetFullPath() );
1678 if( !msg.IsEmpty() )
1699 wxAcceleratorEntry entries[1];
1700 entries[0].Set( wxACCEL_CTRL,
int(
'Q' ), wxID_EXIT );
1701 wxAcceleratorTable accel( 1, entries );
1702 SetAcceleratorTable( accel );
1722 if( extraitems > 0 )
1737 if( extraitems > 0 )
1758 return m_undoList.m_CommandsList.back()->GetDescription();
1760 return wxEmptyString;
1767 return m_redoList.m_CommandsList.back()->GetDescription();
1769 return wxEmptyString;
1784 wxCommandEvent e( EDA_EVT_UNITS_CHANGED );
1785 e.SetInt(
static_cast<int>( aUnits ) );
1786 e.SetClientData(
this );
1787 ProcessEventLocally( e );
1799 if( !IsMaximized() )
1805 "Maximizing window - Saving position (%d, %d) with size (%d, %d)",
1817#if defined( __WXGTK__ ) && !wxCHECK_VERSION( 3, 2, 9 )
1818 wxSize winSize = GetSize();
1827 GTKDoGetSize( &width, &height );
1829 winSize.Set( width, height );
1832 wxSize winSize = GetSize();
1850 GetMenuBar()->Refresh();
1876WXLRESULT EDA_BASE_FRAME::MSWWindowProc( WXUINT message, WXWPARAM wParam, WXLPARAM lParam )
1880 if( message == WM_SYSCOMMAND )
1882 if( wParam == SC_KEYMENU && ( lParam >> 16 ) <= 0 )
1886 return wxFrame::MSWWindowProc( message, wParam, lParam );
1894 langsMenu->
SetTitle(
_(
"Set Language" ) );
1899 for(
unsigned ii = 0;
LanguagesList[ii].m_KI_Lang_Identifier != 0; ii++ )
1909 new wxMenuItem( langsMenu,
1911 label, tooltip, wxITEM_CHECK );
1913 langsMenu->Append( item );
1917 aMasterMenu->
Add( langsMenu );
1923 int id =
event.GetId();
void ShowAboutDialog(EDA_BASE_FRAME *aParent)
KIFACE_BASE & Kiface()
Global KIFACE_BASE "get" accessor.
void ClearScaledBitmapCache()
Wipes out the scaled bitmap cache so that the icon theme can be changed.
BITMAP_STORE * GetBitmapStore()
static TOOL_ACTION reportBug
static TOOL_ACTION donate
static TOOL_ACTION listHotKeys
static TOOL_ACTION getInvolved
static TOOL_ACTION gettingStarted
Manage TOOL_ACTION objects.
const std::map< std::string, TOOL_ACTION * > & GetActions() const
Get a list of currently-registered actions mapped by their name.
static const ADVANCED_CFG & GetCfg()
Get the singleton instance's config, which is shared by all consumers.
APP_SETTINGS_BASE is a settings class that should be derived for each standalone KiCad application.
void ThemeChanged()
Notifies the store that the icon theme has been changed by the user, so caches must be invalidated.
Handle actions that are shared between different applications.
Dialog helper object to sit in the inheritance tree between wxDialog and any class written by wxFormB...
The base frame for deriving all KiCad main window classes.
virtual wxString help_name()
virtual bool doAutoSave()
This should be overridden by the derived class to handle the auto save feature.
void LoadWindowState(const wxString &aFileName)
FRAME_T GetFrameType() const
virtual void UnregisterUIUpdateHandler(int aID) override
Unregister a UI handler for a given ID that was registered using RegisterUIUpdateHandler.
virtual bool isAutoSaveRequired() const
Return the auto save status of the application.
virtual APP_SETTINGS_BASE * config() const
Return the settings object used in SaveSettings(), and is overloaded in KICAD_MANAGER_FRAME.
virtual void handleIconizeEvent(wxIconizeEvent &aEvent)
Handle a window iconize event.
virtual void PushCommandToUndoList(PICKED_ITEMS_LIST *aItem)
Add a command to undo in the undo list.
void windowClosing(wxCloseEvent &event)
(with its unexpected name so it does not collide with the real OnWindowClose() function provided in d...
virtual void OnCharHook(wxKeyEvent &aKeyEvent)
Capture the key event before it is sent to the GUI.
virtual int GetRedoCommandCount() const
void CommonSettingsChanged(int aFlags) override
Notification event that some of the common (suite-wide) settings have changed.
UNDO_REDO_CONTAINER m_undoList
virtual void OnMove(wxMoveEvent &aEvent)
virtual WINDOW_SETTINGS * GetWindowSettings(APP_SETTINGS_BASE *aCfg)
Return a pointer to the window settings for this frame.
virtual void doCloseWindow()
void OnToolbarSizeChanged()
Update toolbars if desired toolbar icon changed.
void OnMenuEvent(wxMenuEvent &event)
The TOOL_DISPATCHER needs these to work around some issues in wxWidgets where the menu events aren't ...
virtual bool IsModal() const
Return true if the frame is shown in our modal mode and false if the frame is shown as an usual frame...
void ShowChangedLanguage() override
Redraw the menus and what not in current language.
virtual void HandleSystemColorChange()
Update the UI in response to a change in the system colors.
virtual void setupUIConditions()
Setup the UI conditions for the various actions and their controls in this frame.
void ensureWindowIsOnScreen()
bool m_isNonUserClose
Set by NonUserClose() to indicate that the user did not request the current close.
void LoadWindowSettings(const WINDOW_SETTINGS *aCfg)
Load window settings from the given settings object.
std::vector< wxFileName > m_AcceptedFiles
bool m_uiUpdateHandlerBound
True once the single wxID_ANY UPDATE_UI handler has been bound.
bool m_autoSavePermissionError
void OnKicadAbout(wxCommandEvent &event)
virtual void UpdateToolbarControlSizes()
Update the sizes of any controls in the toolbars of the frame.
virtual void ClearUndoRedoList()
Clear the undo and redo list using ClearUndoORRedoList()
virtual void DoWithAcceptedFiles()
Execute action on accepted dropped file.
virtual void OnModify()
Must be called after a model change in order to set the "modify" flag and do other frame-specific pro...
wxWindow * findQuasiModalDialog()
static void HandleUpdateUIEvent(wxUpdateUIEvent &aEvent, EDA_BASE_FRAME *aFrame, ACTION_CONDITIONS aCond)
Handle events generated when the UI is trying to figure out the current state of the UI controls rela...
virtual void ClearUndoORRedoList(UNDO_REDO_LIST aList, int aItemCount=-1)
Remove the aItemCount of old commands from aList and delete commands, pickers and picked items if nee...
virtual void ThemeChanged()
Process light/dark theme change.
EDA_BASE_FRAME(wxWindow *aParent, FRAME_T aFrameType, const wxString &aTitle, const wxPoint &aPos, const wxSize &aSize, long aStyle, const wxString &aFrameName, KIWAY *aKiway, const EDA_IU_SCALE &aIuScale)
static constexpr int KICAD_AUI_TB_STYLE
Default style flags used for wxAUI toolbars.
ACTION_TOOLBAR * m_tbRight
void ShowPreferences(wxString aStartPage, wxString aStartParentPage)
Display the preferences and settings of all opened editors paged dialog, starting with a particular p...
void initExitKey()
Set the common key-pair for exiting the application (Ctrl-Q) and ties it to the wxID_EXIT event id.
void OnPreferences(wxCommandEvent &event)
virtual const SEARCH_STACK & sys_search()
Return a SEARCH_STACK pertaining to entire program.
void onAutoSaveTimer(wxTimerEvent &aEvent)
Handle the auto save timer event.
void SaveWindowSettings(WINDOW_SETTINGS *aCfg)
Save window settings to the given settings object.
virtual wxString GetRedoActionDescription() const
TOOLBAR_SETTINGS * m_toolbarSettings
void FinishAUIInitialization()
virtual wxString GetCurrentFileName() const
Get the full filename + path of the currently opened file in the frame.
void ChangeUserUnits(EDA_UNITS aUnits)
void AddMenuLanguageList(ACTION_MENU *aMasterMenu, TOOL_INTERACTIVE *aControlTool)
Create a menu list for language choice, and add it as submenu to MasterMenu.
void RegisterCustomToolbarControlFactory(const ACTION_TOOLBAR_CONTROL &aControlDesc, const ACTION_TOOLBAR_CONTROL_FACTORY &aControlFactory)
Register a creation factory for toolbar controls that are present in this frame.
void ShowInfoBarMsg(const wxString &aMsg, bool aShowCloseButton=false)
Show the WX_INFOBAR displayed on the top of the canvas with a message and an info icon on the left of...
virtual void configureToolbars()
wxTimer * m_autoSaveTimer
void ShowInfoBarError(const wxString &aErrorMsg, bool aShowCloseButton=false, INFOBAR_MESSAGE_TYPE aType=INFOBAR_MESSAGE_TYPE::GENERIC)
Show the WX_INFOBAR displayed on the top of the canvas with a message and an error icon on the left o...
void UpdateFileHistory(const wxString &FullFileName, FILE_HISTORY *aFileHistory=nullptr)
Update the list of recently opened files.
void PrintMsg(const wxString &text)
void SelectToolbarAction(const TOOL_ACTION &aAction)
Select the given action in the toolbar group which contains it, if any.
void onUpdateUI(wxUpdateUIEvent &aEvent)
void commonInit(FRAME_T aFrameType)
Collect common initialization functions used in all CTORs.
virtual bool IsContentModified() const
Get if the contents of the frame have been modified since the last save.
void ShowInfoBarWarning(const wxString &aWarningMsg, bool aShowCloseButton=false)
Show the WX_INFOBAR displayed on the top of the canvas with a message and a warning icon on the left ...
virtual PICKED_ITEMS_LIST * PopCommandFromRedoList()
Return the last command to undo and remove it from list, nothing is deleted.
virtual void RecreateToolbars()
std::map< int, UIUpdateHandler > m_uiUpdateMap
Map containing the UI update handlers registered with wx for each action.
std::map< std::string, ACTION_TOOLBAR_CONTROL_FACTORY > m_toolbarControlFactories
ACTION_TOOLBAR_CONTROL_FACTORY * GetCustomToolbarControlFactory(const std::string &aName)
UNDO_REDO_CONTAINER m_redoList
virtual void LoadSettings(APP_SETTINGS_BASE *aCfg)
Load common frame parameters from a configuration file.
FILE_HISTORY * m_fileHistory
ACTION_TOOLBAR * m_tbLeft
SETTINGS_MANAGER * m_settingsManager
virtual void OnSize(wxSizeEvent &aEvent)
virtual wxString GetUndoActionDescription() const
virtual PICKED_ITEMS_LIST * PopCommandFromUndoList()
Return the last command to undo and remove it from list, nothing is deleted.
void OnLanguageSelectionEvent(wxCommandEvent &aEvent)
An event handler called on a language menu selection.
wxString GetRunMenuCommandDescription(const TOOL_ACTION &aAction)
virtual bool canCloseWindow(wxCloseEvent &aCloseEvent)
bool ProcessEvent(wxEvent &aEvent) override
Override the default process event handler to implement the auto save feature.
bool IsWritable(const wxFileName &aFileName, bool aVerbose=true)
Check if aFileName can be written.
void OnMaximize(wxMaximizeEvent &aEvent)
std::unique_ptr< nlohmann::json > m_auiLayoutState
virtual void ClearFileHistory()
Remove all files from the file history.
ACTION_TOOLBAR * m_tbTopAux
virtual void OnDropFiles(wxDropFilesEvent &aEvent)
Handle event fired when a file is dropped to the window.
std::map< const wxString, TOOL_ACTION * > m_acceptedExts
Associate file extensions with action to execute.
void onIconize(wxIconizeEvent &aEvent)
virtual void unitsChangeRefresh()
Called when when the units setting has changed to allow for any derived classes to handle refreshing ...
wxString GetFileFromHistory(int cmdId, const wxString &type, FILE_HISTORY *aFileHistory=nullptr)
Fetch the file name from the file history list.
wxSize GetWindowSize()
Get the undecorated window size that can be used for restoring the window size.
int GetAutoSaveInterval() const
virtual void SaveSettings(APP_SETTINGS_BASE *aCfg)
Save common frame parameters to a configuration data file.
void onSystemColorChange(wxSysColourChangedEvent &aEvent)
virtual int GetUndoCommandCount() const
virtual void RegisterUIUpdateHandler(int aID, const ACTION_CONDITIONS &aConditions) override
Register a UI update handler for the control with ID aID.
ACTION_TOOLBAR * m_tbTopMain
virtual void PushCommandToRedoList(PICKED_ITEMS_LIST *aItem)
Add a command to redo in the redo list.
bool m_isClosing
Set by the close window event handler after frames are asked if they can close.
void AddStandardHelpMenu(wxMenuBar *aMenuBar)
Add the standard KiCad help menu to the menubar.
void ReCreateMenuBar()
Recreate the menu bar.
virtual void doReCreateMenuBar()
WX_INFOBAR * GetInfoBar()
Specialization of the wxAuiPaneInfo class for KiCad panels.
This class implements a file history object to store a list of files, that can then be added to a men...
void AddFileToHistory(const wxString &aFile) override
Adds a file to the history.
The main KiCad project manager frame.
SEARCH_STACK & KifaceSearch()
Only for DSO specific 'non-library' files.
APP_SETTINGS_BASE * KifaceSettings() const
const wxString & GetHelpFileName() const
Return just the basename portion of the current help file.
PROJECT & Prj() const
Return a reference to the PROJECT associated with this KIWAY.
KIWAY_HOLDER(KIWAY *aKiway, HOLDER_TYPE aType)
KIWAY & Kiway() const
Return a reference to the KIWAY that this object has an opportunity to participate in.
A minimalistic software bus for communications between various DLLs/DSOs (DSOs) within the same KiCad...
virtual void SetLanguage(int aLanguage)
Change the language and then calls ShowChangedLanguage() on all #KIWAY_PLAYERs.
LOCAL_HISTORY & LocalHistory()
Return the LOCAL_HISTORY associated with this KIWAY.
virtual void CommonSettingsChanged(int aFlags=0)
Call CommonSettingsChanged() on all KIWAY_PLAYERs.
bool Init(const wxString &aProjectPath)
Initialize the local history repository for the given project path.
bool RunRegisteredSaversAndCommit(const wxString &aProjectPath, const wxString &aTitle)
Run all registered savers and, if any staged changes differ from HEAD, create a commit.
WX_TREEBOOK * GetTreebook()
void SetInitialPage(const wxString &aPage, const wxString &aParentPage=wxEmptyString)
std::vector< TOOL_ACTION * > & ActionsList()
static wxString GetDefaultUserProjectsPath()
Gets the default path we point users to create projects.
virtual COMMON_SETTINGS * GetCommonSettings() const
virtual int GetSelectedLanguageIdentifier() const
virtual SETTINGS_MANAGER & GetSettingsManager() const
A holder to handle information on schematic or board items.
void SaveFileState(const wxString &aFileName, const WINDOW_SETTINGS *aWindowCfg, bool aOpen)
const PROJECT_FILE_STATE * GetFileState(const wxString &aFileName)
virtual PROJECT_LOCAL_SETTINGS & GetLocalSettings() const
Look for files in a number of paths.
UNITS_PROVIDER(const EDA_IU_SCALE &aIuScale, EDA_UNITS aUnits)
void SetUserUnits(EDA_UNITS aUnits)
bool Deserialize(const nlohmann::json &aState) const
nlohmann::json Serialize() const
Simple wrapper around wxBusyCursor for used with the generic BUSY_INDICATOR interface.
A modified version of the wxInfoBar class that allows us to:
void ShowMessageFor(const wxString &aMessage, int aTime, int aFlags=wxICON_INFORMATION, MESSAGE_TYPE aType=WX_INFOBAR::MESSAGE_TYPE::GENERIC)
Show the infobar with the provided message and icon for a specific period of time.
bool AddLazyPage(std::function< wxWindow *(wxWindow *aParent)> aLazyCtor, const wxString &text, bool bSelect=false, int imageId=NO_IMAGE)
bool AddLazySubPage(std::function< wxWindow *(wxWindow *aParent)> aLazyCtor, const wxString &text, bool bSelect=false, int imageId=NO_IMAGE)
void DisplayErrorMessage(wxWindow *aParent, const wxString &aText, const wxString &aExtraInfo)
Display an error message with aMessage.
This file is part of the common library.
#define KICAD_MESSAGE_DIALOG
const int minSize
Push and Shove router track width and via size dialog.
static const wxSize minSizeLookup(FRAME_T aFrameType, wxWindow *aWindow)
static const wxSize defaultSize(FRAME_T aFrameType, wxWindow *aWindow)
wxWindow * findQuasiModalDialog(wxWindow *aParent)
Base window classes and related definitions.
#define KICAD_MANAGER_FRAME_NAME
std::function< void(ACTION_TOOLBAR *)> ACTION_TOOLBAR_CONTROL_FACTORY
#define DEFAULT_MAX_UNDO_ITEMS
void SocketCleanup()
Must be called to clean up the socket thread used by SendCommand.
EVT_MENU_RANGE(ID_GERBVIEW_DRILL_FILE1, ID_GERBVIEW_DRILL_FILEMAX, GERBVIEW_FRAME::OnDrlFileHistory) EVT_MENU_RANGE(ID_GERBVIEW_ZIP_FILE1
FRAME_T
The set of EDA_BASE_FRAME derivatives, typically stored in EDA_BASE_FRAME::m_Ident.
@ FRAME_SCH_SYMBOL_EDITOR
@ PANEL_SCH_FIELD_NAME_TEMPLATES
@ PANEL_GBR_DISPLAY_OPTIONS
@ PANEL_FP_DEFAULT_GRAPHICS_VALUES
@ PANEL_FP_DISPLAY_OPTIONS
@ PANEL_FP_DEFAULT_FIELDS
@ PANEL_PCB_ACTION_PLUGINS
@ PANEL_3DV_DISPLAY_OPTIONS
@ PANEL_DS_DISPLAY_OPTIONS
@ PANEL_GBR_EXCELLON_OPTIONS
static const std::string GerberFileExtension
static bool IsGerberFileExtension(const wxString &ext)
const wxChar *const traceAutoSave
Flag to enable auto save feature debug tracing.
const wxChar *const kicadTraceKeyEvent
Flag to enable wxKeyEvent debug tracing.
const wxChar *const traceDisplayLocation
Flag to enable debug output of display positioning logic.
void ReadHotKeyConfigIntoActions(const wxString &aFileName, std::vector< TOOL_ACTION * > &aActions)
Read a hotkey config file into a list of actions.
PGM_BASE & Pgm()
The global program "get" accessor.
LANGUAGE_DESCR LanguagesList[]
An array containing all the languages that KiCad supports.
std::vector< FAB_LAYER_COLOR > dummy
Functors that can be used to figure out how the action controls should be displayed in the UI and if ...
SELECTION_CONDITION enableCondition
Returns true if the UI control should be enabled.
SELECTION_CONDITION checkCondition
Returns true if the UI control should be checked.
SELECTION_CONDITION showCondition
Returns true if the UI control should be shown.
ACTION_CONDITIONS & Check(const SELECTION_CONDITION &aCondition)
int local_history_debounce
Implement a participant in the KIWAY alchemy.
struct WINDOW_STATE window
Store the common settings that are saved and loaded for each window / frame.
Store the window positioning/state.
IFACE KIFACE_BASE kiface("pcb_test_frame", KIWAY::FACE_PCB)
wxString dump(const wxArrayString &aArray)
Debug helper for printing wxArrayString contents.
wxLogTrace helper definitions.
INFOBAR_MESSAGE_TYPE
Sets the type of message for special handling if needed.