KiCad PCB EDA Suite
Loading...
Searching...
No Matches
eda_base_frame.h
Go to the documentation of this file.
1/*
2 * This program source code file is part of KiCad, a free EDA CAD application.
3 *
4 * Copyright (C) 2009-2015 Jean-Pierre Charras, jp.charras wanadoo.fr
5 * Copyright (C) 2011 Wayne Stambaugh <[email protected]>
6 * Copyright (C) 2023 CERN (www.cern.ch)
7 * Copyright The KiCad Developers, see AUTHORS.txt for contributors.
8 *
9 * This program is free software; you can redistribute it and/or
10 * modify it under the terms of the GNU General Public License
11 * as published by the Free Software Foundation; either version 2
12 * of the License, or (at your option) any later version.
13 *
14 * This program is distributed in the hope that it will be useful,
15 * but WITHOUT ANY WARRANTY; without even the implied warranty of
16 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17 * GNU General Public License for more details.
18 *
19 * You should have received a copy of the GNU General Public License
20 * along with this program. If not, see <https://www.gnu.org/licenses/>.
21 */
22
27
28#ifndef EDA_BASE_FRAME_H_
29#define EDA_BASE_FRAME_H_
30
31
32#include <functional>
33#include <map>
34#include <optional>
35#include <string>
36#include <vector>
37
38#include <memory>
39#include <nlohmann/json_fwd.hpp>
40
41#include <wx/aui/aui.h>
42#include <layer_ids.h>
43#include <frame_type.h>
44#include <hotkeys_basic.h>
45#include <kiway_holder.h>
46#include <tool/tools_holder.h>
47#include <widgets/ui_common.h>
49#include <undo_redo_container.h>
50#include <units_provider.h>
51#include <origin_transforms.h>
52#include <ui_events.h>
53
54// Option for main frames
55#define KICAD_DEFAULT_DRAWFRAME_STYLE wxDEFAULT_FRAME_STYLE | wxWANTS_CHARS
56
57
58#define VIEWER3D_FRAMENAME wxT( "Viewer3DFrameName" )
59#define QUALIFIED_VIEWER3D_FRAMENAME( parent ) \
60 ( wxString( VIEWER3D_FRAMENAME ) + wxT( ":" ) + parent->GetName() )
61
62#define KICAD_MANAGER_FRAME_NAME wxT( "KicadFrame" )
63
64
65class wxChoice;
66class wxEvent;
67class wxFileName;
68class EDA_ITEM;
70class EDA_MSG_PANEL;
71class BASE_SCREEN;
72class PAGE_INFO;
73class PLOTTER;
74class TITLE_BLOCK;
75class MSG_PANEL_ITEM;
76class TOOL_MANAGER;
77class TOOL_DISPATCHER;
78class ACTIONS;
79class PAGED_DIALOG;
82class FILE_HISTORY;
84class SEARCH_STACK;
87struct WINDOW_SETTINGS;
88struct WINDOW_STATE;
89class ACTION_MENU;
90class ACTION_TOOLBAR;
94class WX_INFOBAR;
95
96using ACTION_TOOLBAR_CONTROL_FACTORY = std::function<void( ACTION_TOOLBAR* )>;
97
98#define DEFAULT_MAX_UNDO_ITEMS 0
99#define ABS_MAX_UNDO_ITEMS (INT_MAX / 2)
100
102typedef std::function< void( wxUpdateUIEvent& ) > UIUpdateHandler;
103
104
114class EDA_BASE_FRAME : public wxFrame, public TOOLS_HOLDER, public KIWAY_HOLDER,
115 public UNITS_PROVIDER
116{
117public:
126
127 EDA_BASE_FRAME( wxWindow* aParent, FRAME_T aFrameType, const wxString& aTitle,
128 const wxPoint& aPos, const wxSize& aSize, long aStyle,
129 const wxString& aFrameName, KIWAY* aKiway, const EDA_IU_SCALE& aIuScale );
130
132
133 void ChangeUserUnits( EDA_UNITS aUnits );
134
135 virtual void ToggleUserUnits() { }
136
141 {
142 return m_originTransforms;
143 }
144
145
147
148 virtual SEVERITY GetSeverity( int aErrorCode ) const { return RPT_SEVERITY_UNDEFINED; }
149
156 bool ProcessEvent( wxEvent& aEvent ) override;
157
165 virtual void OnCharHook( wxKeyEvent& aKeyEvent );
166
171 void OnMenuEvent( wxMenuEvent& event );
172
179 virtual void RegisterUIUpdateHandler( int aID, const ACTION_CONDITIONS& aConditions ) override;
180
186 virtual void UnregisterUIUpdateHandler( int aID ) override;
187
196 static void HandleUpdateUIEvent( wxUpdateUIEvent& aEvent, EDA_BASE_FRAME* aFrame,
197 ACTION_CONDITIONS aCond );
198
199 virtual void OnMove( wxMoveEvent& aEvent )
200 {
201 aEvent.Skip();
202 }
203
204 virtual void OnSize( wxSizeEvent& aEvent );
205
210 void SelectToolbarAction( const TOOL_ACTION& aAction );
211
212 void OnMaximize( wxMaximizeEvent& aEvent );
213
214 int GetAutoSaveInterval() const;
215
216 bool IsType( FRAME_T aType ) const { return m_ident == aType; }
217 FRAME_T GetFrameType() const { return m_ident; }
218
224 virtual const SEARCH_STACK& sys_search();
225
226 virtual wxString help_name();
227
228 // Event handlers for menu events generated by the macOS application menu
229 void OnKicadAbout( wxCommandEvent& event );
230 void OnPreferences( wxCommandEvent& event );
231
236 void ShowPreferences( wxString aStartPage, wxString aStartParentPage );
237
238 void PrintMsg( const wxString& text );
239
240 void CreateInfoBar();
241
242 void RestoreAuiLayout();
243
245
250
260 void ShowInfoBarError( const wxString& aErrorMsg, bool aShowCloseButton = false,
262
277 void ShowInfoBarError( const wxString& aErrorMsg, bool aShowCloseButton,
278 std::function<void(void)> aCallback );
279
289 void ShowInfoBarWarning( const wxString& aWarningMsg, bool aShowCloseButton = false );
290
300 void ShowInfoBarMsg( const wxString& aMsg, bool aShowCloseButton = false );
301
306 virtual APP_SETTINGS_BASE* config() const;
307
308 void LoadWindowState( const wxString& aFileName );
309
316 void LoadWindowSettings( const WINDOW_SETTINGS* aCfg );
317
325
332 virtual void LoadSettings( APP_SETTINGS_BASE* aCfg );
333
340 virtual void SaveSettings( APP_SETTINGS_BASE* aCfg );
341
350
354 virtual void LoadWindowState( const WINDOW_STATE& aState );
355
366 wxString ConfigBaseName() override
367 {
368 wxString baseCfgName = m_configName.IsEmpty() ? GetName() : m_configName;
369 return baseCfgName;
370 }
371
383 virtual void SaveProjectLocalSettings() {};
384
392 void ImportHotkeyConfigFromFile( std::map<std::string, TOOL_ACTION*> aActionMap,
393 const wxString& aDefaultShortname );
394
407 wxString GetFileFromHistory( int cmdId, const wxString& type,
408 FILE_HISTORY* aFileHistory = nullptr );
409
413 virtual void ClearFileHistory();
414
424 void UpdateFileHistory( const wxString& FullFileName, FILE_HISTORY* aFileHistory = nullptr );
425
432 {
433 return *m_fileHistory;
434 }
435
436 void SetMruPath( const wxString& aPath ) { m_mruPath = aPath; }
437
438 wxString GetMruPath() const { return m_mruPath; }
439
447 virtual wxString GetCurrentFileName() const { return wxEmptyString; }
448
449 virtual void RecreateToolbars();
450
455
459 virtual void UpdateToolbarControlSizes();
460
471 const ACTION_TOOLBAR_CONTROL_FACTORY& aControlFactory );
472
477
483 void ReCreateMenuBar();
484
488 void AddStandardHelpMenu( wxMenuBar* aMenuBar );
489
490 wxString GetRunMenuCommandDescription( const TOOL_ACTION& aAction );
491
507 bool IsWritable( const wxFileName& aFileName, bool aVerbose = true );
508
516 virtual void UpdateStatusBar() { }
517
521 void ShowChangedLanguage() override;
522
527 void CommonSettingsChanged( int aFlags ) override;
528
532 virtual void ThemeChanged();
533
537 virtual void ProjectChanged() {}
538
539 wxString GetAboutTitle() const { return wxGetTranslation( m_aboutTitle ); }
540
541 const wxString& GetUntranslatedAboutTitle() const { return m_aboutTitle; }
542
548 virtual bool IsContentModified() const;
549
558 wxSize GetWindowSize();
559
572 virtual void ClearUndoORRedoList( UNDO_REDO_LIST aList, int aItemCount = -1 )
573 { }
574
580 virtual void ClearUndoRedoList();
581
587 virtual void PushCommandToUndoList( PICKED_ITEMS_LIST* aItem );
588
594 virtual void PushCommandToRedoList( PICKED_ITEMS_LIST* aItem );
595
600
605
606 virtual int GetUndoCommandCount() const { return m_undoList.m_CommandsList.size(); }
607 virtual int GetRedoCommandCount() const { return m_redoList.m_CommandsList.size(); }
608
609 virtual wxString GetUndoActionDescription() const;
610 virtual wxString GetRedoActionDescription() const;
611
612 int GetMaxUndoItems() const { return m_undoRedoCountMax; }
613
618 virtual void OnModify();
619
620 bool IsClosing() const { return m_isClosing; }
621
622 bool NonUserClose( bool aForce )
623 {
624 m_isNonUserClose = true;
625 return Close( aForce );
626 }
627
628 virtual void ClearToolbarControl( int aId ) { }
629
633 virtual void HandleSystemColorChange();
634
641 virtual bool CanAcceptApiCommands() { return IsEnabled(); }
642
643protected:
645 static constexpr int KICAD_AUI_TB_STYLE = wxAUI_TB_DEFAULT_STYLE | wxAUI_TB_PLAIN_BACKGROUND;
646
647 virtual void doReCreateMenuBar() {}
648
649 virtual void configureToolbars();
650
654 void onAutoSaveTimer( wxTimerEvent& aEvent );
655
656
662 virtual void handleIconizeEvent( wxIconizeEvent& aEvent ) {}
663 void onIconize( wxIconizeEvent& aEvent );
664
670 virtual bool isAutoSaveRequired() const { return m_autoSaveRequired; }
671
677 virtual bool doAutoSave();
678
694 void CheckForAutosaveFiles( const wxString& aProjectPath, const std::vector<wxString>& aExtensions );
695
696 virtual bool canCloseWindow( wxCloseEvent& aCloseEvent ) { return true; }
697 virtual void doCloseWindow() { }
698
699 void onSystemColorChange( wxSysColourChangedEvent& aEvent );
700
708 virtual void unitsChangeRefresh() { }
709
713 virtual void setupUIConditions();
714
721 void initExitKey();
722
724
731 virtual void saveProjectSettings() {}
732
739 virtual void OnDropFiles( wxDropFilesEvent& aEvent );
740
747 void AddMenuLanguageList( ACTION_MENU* aMasterMenu, TOOL_INTERACTIVE* aControlTool );
748
752 void OnLanguageSelectionEvent( wxCommandEvent& aEvent );
753
760 virtual void DoWithAcceptedFiles();
761 std::vector<wxFileName> m_AcceptedFiles;
762
763 DECLARE_EVENT_TABLE()
764
765private:
766 void onUpdateUI( wxUpdateUIEvent& aEvent );
767
778 void windowClosing( wxCloseEvent& event );
779
783 void commonInit( FRAME_T aFrameType );
784
785 wxWindow* findQuasiModalDialog();
786
794 virtual bool IsModal() const { return false; }
795
796#ifdef __WXMSW__
800 WXLRESULT MSWWindowProc( WXUINT message, WXWPARAM wParam, WXLPARAM lParam ) override;
801#endif
802
803 protected:
804 FRAME_T m_ident; // Id Type (pcb, schematic, library..)
805 wxPoint m_framePos;
809
810 // These contain the frame size and position for when it is not maximized
813
814 wxString m_aboutTitle; // Name of program displayed in About.
815
816 wxAuiManager m_auimgr;
817 wxString m_perspective; // wxAuiManager perspective.
818 std::unique_ptr<nlohmann::json> m_auiLayoutState;
819 WX_INFOBAR* m_infoBar; // Infobar for the frame
821 wxString m_configName; // Prefix used to identify some params (frame
822 // size) and to name some config files (legacy
823 // hotkey files)
825
826 FILE_HISTORY* m_fileHistory; // The frame's recently opened file list
832
833 int m_undoRedoCountMax; // undo/Redo command Max depth
834
835 UNDO_REDO_CONTAINER m_undoList; // Objects list for the undo command (old data)
836 UNDO_REDO_CONTAINER m_redoList; // Objects list for the redo command (old data)
837
838 wxString m_mruPath; // Most recently used path.
839
840 ORIGIN_TRANSFORMS m_originTransforms; // Default display origin transforms object.
841
843 std::map<int, UIUpdateHandler> m_uiUpdateMap;
844
847
851
854
858 std::map<const wxString, TOOL_ACTION*> m_acceptedExts;
859
860 // Toolbar Settings - this is not owned by the frame
862
863 // Toolbar UI elements
865 ACTION_TOOLBAR* m_tbTopAux; // Additional tools under main toolbar
866 ACTION_TOOLBAR* m_tbRight; // Drawing tools (typically on right edge of window)
867 ACTION_TOOLBAR* m_tbLeft; // Options (typically on left edge of window)
868
869 std::map<std::string, ACTION_TOOLBAR_CONTROL_FACTORY> m_toolbarControlFactories;
870};
871
872
894class EDA_PANE : public wxAuiPaneInfo
895{
896public:
898 {
899 Gripper( false );
900 CloseButton( false );
901 PaneBorder( false );
902 }
903
908 {
909 SetFlag( optionToolbar, true );
910 CaptionVisible( false );
911 TopDockable().BottomDockable();
912 DockFixed( true );
913 Movable( false );
914 Resizable( true ); // expand to fit available space
915 return *this;
916 }
917
922 {
923 SetFlag( optionToolbar, true );
924 CaptionVisible( false );
925 LeftDockable().RightDockable();
926 DockFixed( true );
927 Movable( false );
928 Resizable( true ); // expand to fit available space
929 return *this;
930 }
931
936 {
937 CaptionVisible( true );
938 PaneBorder( true );
939 return *this;
940 }
941
946 {
947 CaptionVisible( false );
948 Layer( 0 );
949 PaneBorder( true );
950 Resizable( true ); // expand to fit available space
951 return *this;
952 }
953
958 {
959 CaptionVisible( false );
960 BottomDockable( true );
961 DockFixed( true );
962 Movable( false );
963 Resizable( true ); // expand to fit available space
964 return *this;
965 }
966
971 {
972 CaptionVisible( false );
973 Movable( false );
974 Resizable( true );
975 PaneBorder( false );
976 DockFixed( true );
977 return *this;
978 }
979};
980
981#endif // EDA_BASE_FRAME_H_
Gather all the actions that are shared by tools.
Definition actions.h:44
Define the structure of a menu based on ACTIONs.
Definition action_menu.h:43
Class to hold basic information about controls that can be added to the toolbars.
Define the structure of a toolbar with buttons that invoke ACTIONs.
APP_SETTINGS_BASE is a settings class that should be derived for each standalone KiCad application.
Handles how to draw a screen (a board, a schematic ...)
Definition base_screen.h:37
The base frame for deriving all KiCad main window classes.
virtual wxString help_name()
virtual void saveProjectSettings()
Save any design-related project settings associated with this frame.
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
wxString ConfigBaseName() override
Get the configuration base name.
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...
APPEARANCE_CONTROLS_3D * m_appearancePanel
virtual void OnCharHook(wxKeyEvent &aKeyEvent)
Capture the key event before it is sent to the GUI.
virtual int GetRedoCommandCount() const
bool NonUserClose(bool aForce)
virtual void ProjectChanged()
Notification event that the project has changed.
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()
const wxString & GetUntranslatedAboutTitle() const
virtual void UpdateStatusBar()
Update the status bar information.
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.
bool m_isNonUserClose
Set by NonUserClose() to indicate that the user did not request the current close.
void CheckForAutosaveFiles(const wxString &aProjectPath, const std::vector< wxString > &aExtensions)
Check for autosave files newer than their source files for the given project.
virtual void ClearToolbarControl(int aId)
void LoadWindowSettings(const WINDOW_SETTINGS *aCfg)
Load window settings from the given settings object.
std::vector< wxFileName > m_AcceptedFiles
virtual SEVERITY GetSeverity(int aErrorCode) const
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()
SETTINGS_MANAGER * GetSettingsManager() const
virtual void DoWithAcceptedFiles()
Execute action on accepted dropped file.
UNDO_REDO_LIST
Specify whether we are interacting with the undo or redo stacks.
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...
wxString m_perspective
bool IsClosing() const
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.
WX_INFOBAR * m_infoBar
void onAutoSaveTimer(wxTimerEvent &aEvent)
Handle the auto save timer event.
void SaveWindowSettings(WINDOW_SETTINGS *aCfg)
Save window settings to the given settings object.
virtual void ToggleUserUnits()
virtual wxString GetRedoActionDescription() const
wxString GetAboutTitle() const
TOOLBAR_SETTINGS * m_toolbarSettings
virtual wxString GetCurrentFileName() const
Get the full filename + path of the currently opened file in the frame.
void ChangeUserUnits(EDA_UNITS aUnits)
wxString m_configName
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.
wxAuiManager m_auimgr
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 ...
int GetMaxUndoItems() const
virtual PICKED_ITEMS_LIST * PopCommandFromRedoList()
Return the last command to undo and remove it from list, nothing is deleted.
virtual bool CanAcceptApiCommands()
Check if this frame is ready to accept API commands.
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.
wxString GetMruPath() const
FILE_HISTORY * m_fileHistory
ACTION_TOOLBAR * m_tbLeft
SETTINGS_MANAGER * m_settingsManager
FILE_HISTORY & GetFileHistory()
Get the frame's main file history.
virtual void OnSize(wxSizeEvent &aEvent)
virtual wxString GetUndoActionDescription() const
void ImportHotkeyConfigFromFile(std::map< std::string, TOOL_ACTION * > aActionMap, const wxString &aDefaultShortname)
Prompt the user for a hotkey file to read, and read it.
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.
wxPoint m_normalFramePos
void OnMaximize(wxMaximizeEvent &aEvent)
std::unique_ptr< nlohmann::json > m_auiLayoutState
virtual void ClearFileHistory()
Remove all files from the file history.
ORIGIN_TRANSFORMS & GetOriginTransforms() override
Return a reference to the default ORIGIN_TRANSFORMS object.
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 SetMruPath(const wxString &aPath)
void onSystemColorChange(wxSysColourChangedEvent &aEvent)
virtual int GetUndoCommandCount() const
ORIGIN_TRANSFORMS m_originTransforms
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 SaveProjectLocalSettings()
Save changes to the project local settings.
wxString m_aboutTitle
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.
bool IsType(FRAME_T aType) const
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()
A base class for most all the KiCad significant classes used in schematics and boards.
Definition eda_item.h:96
A panel to display various information messages.
Definition msgpanel.h:97
EDA_PANE & Canvas()
Turn *this into an undecorated pane suitable for a drawing canvas.
EDA_PANE & Messages()
Turn *this into a messages pane for KiCad.
EDA_PANE & InfoBar()
Turn *this into a infobar for KiCad.
EDA_PANE & HToolbar()
Turn *this to a horizontal toolbar for KiCad.
EDA_PANE & VToolbar()
Turn *this into a vertical toolbar for KiCad.
EDA_PANE & Palette()
Turn *this into a captioned palette suitable for a symbol tree, layers manager, etc.
This class implements a file history object to store a list of files, that can then be added to a men...
KIWAY_HOLDER(KIWAY *aKiway, HOLDER_TYPE aType)
A minimalistic software bus for communications between various DLLs/DSOs (DSOs) within the same KiCad...
Definition kiway.h:311
EDA_MSG_PANEL items for displaying messages.
Definition msgpanel.h:50
A class to perform either relative or absolute display origin transforms for a single axis of a point...
Describe the page size and margins of a paper page on which to eventually print or plot.
Definition page_info.h:75
A holder to handle information on schematic or board items.
Base plotter engine class.
Definition plotter.h:133
Look for files in a number of paths.
Hold the information shown in the lower right corner of a plot, printout, or editing view.
Definition title_block.h:37
Represent a single user action.
Master controller class:
A holder to handle a list of undo (or redo) commands.
UNITS_PROVIDER(const EDA_IU_SCALE &aIuScale, EDA_UNITS aUnits)
A modified version of the wxInfoBar class that allows us to:
Definition wx_infobar.h:77
std::function< void(ACTION_TOOLBAR *)> ACTION_TOOLBAR_CONTROL_FACTORY
std::function< void(wxUpdateUIEvent &) > UIUpdateHandler
This is the handler functor for the update UI events.
EDA_UNITS
Definition eda_units.h:44
FRAME_T
The set of EDA_BASE_FRAME derivatives, typically stored in EDA_BASE_FRAME::m_Ident.
Definition frame_type.h:29
SEVERITY
@ RPT_SEVERITY_UNDEFINED
Functors that can be used to figure out how the action controls should be displayed in the UI and if ...
Store the common settings that are saved and loaded for each window / frame.
Store the window positioning/state.
Functions to provide common constants and other functions to assist in making a consistent UI.
INFOBAR_MESSAGE_TYPE
Sets the type of message for special handling if needed.
@ GENERIC
GENERIC Are messages that do not have special handling.