29#include <wx/tooltip.h>
45#include "wx/dcclient.h"
48 bool* aClearAnnotationNewItems ) :
51 m_clearAnnotationNewItems( aClearAnnotationNewItems ),
52 m_borderWidth( aParent, m_borderWidthLabel, m_borderWidthCtrl, m_borderWidthUnits ),
53 m_dummySheet( *aSheet ),
62 m_grid->SetDefaultRowSize(
m_grid->GetDefaultRowSize() + 4 );
66 [&]( wxCommandEvent& aEvent )
70 m_grid->SetSelectionMode( wxGrid::wxGridSelectRows );
87 wxToolTip::Enable(
true );
101 m_grid->Connect( wxEVT_GRID_CELL_CHANGING,
112 cfg->m_Appearance.edit_sheet_width = GetSize().x;
113 cfg->m_Appearance.edit_sheet_height = GetSize().y;
119 m_grid->Disconnect( wxEVT_GRID_CELL_CHANGING,
124 m_grid->PopEventHandler(
true );
130 if( !wxDialog::TransferDataToWindow() )
142 wxString filename = field_copy.
GetText();
143 filename.Replace( wxT(
"/" ), wxT(
"\\" ) );
144 field_copy.
SetText( filename );
155 wxGridTableMessage msg(
m_fields, wxGRIDTABLE_NOTIFY_ROWS_APPENDED,
m_fields->size() );
156 m_grid->ProcessTableMessage( msg );
187 pageNumber.Printf( wxT(
"%d" ),
static_cast<int>( hierarchy.size() ) + 1 );
260 if( !wxDialog::TransferDataFromWindow() )
268 if( sheetFileName.IsEmpty() )
270 DisplayError(
this,
_(
"A sheet must have a valid file name." ) );
278 wxFileName fn( sheetFileName );
279 wxString newRelativeFilename = fn.GetFullPath();
282 newRelativeFilename.Replace( wxT(
"\\" ), wxT(
"/" ) );
285 oldFilename.Replace( wxT(
"\\" ), wxT(
"/" ) );
287 bool filename_changed = oldFilename != newRelativeFilename;
293 wxCHECK( currentScreen,
false );
295 bool clearFileName =
false;
300 clearFileName =
true;
304 wxFileName tmp( fn );
305 wxFileName screenFileName = currentScreen->
GetFileName();
307 if( fn.IsAbsolute() && fn.MakeRelativeTo( screenFileName.GetPath() ) )
309 wxMessageDialog makeRelDlg(
this,
_(
"Use relative path for sheet file?" ),
310 _(
"Sheet File Path" ),
311 wxYES_NO | wxYES_DEFAULT | wxICON_QUESTION | wxCENTER );
313 makeRelDlg.SetExtendedMessage(
_(
"Using relative hierarchical sheet file name paths "
314 "improves schematic portability across systems and "
315 "platforms. Using absolute paths can result in "
316 "portability issues." ) );
317 makeRelDlg.SetYesNoLabels( wxMessageDialog::ButtonLabel(
_(
"Use Relative Path" ) ),
318 wxMessageDialog::ButtonLabel(
_(
"Use Absolute Path" ) ) );
320 if( makeRelDlg.ShowModal() == wxID_YES )
323 "\n to relative path: '%s'",
327 newRelativeFilename = fn.GetFullPath();
348 if( newSheetname.IsEmpty() )
349 newSheetname =
_(
"Untitled Sheet" );
354 for(
unsigned i = 0; i <
m_fields->size(); ++i )
367 else if( fieldName.IsEmpty() )
381 wxPanel temp(
this );
386 KIDIALOG dlg(
this,
_(
"Note: item colors are overridden in the current color theme." ),
388 dlg.ShowDetailedText( wxString::Format(
_(
"To see individual item colors uncheck '%s'\n"
389 "in Preferences > Schematic Editor > Colors." ),
425 wxFileName screenFileName( sheetFileName );
426 wxFileName tmp( sheetFileName );
430 wxCHECK( currentScreen,
false );
433 wxFileName currentScreenFileName = currentScreen->
GetFileName();
436 currentScreenFileName.GetPath() ) )
438 msg = wxString::Format(
_(
"Cannot normalize new sheet schematic file path:\n"
440 "against parent sheet schematic file path:\n"
442 sheetFileName.GetPath(),
443 currentScreenFileName.GetPath() );
448 wxString newAbsoluteFilename = screenFileName.GetFullPath();
451 newAbsoluteFilename.Replace( wxT(
"\\" ), wxT(
"/" ) );
453 bool renameFile =
false;
454 bool loadFromFile =
false;
455 bool clearAnnotation =
false;
456 bool isExistingSheet =
false;
464 loadFromFile = wxFileExists( newAbsoluteFilename );
468 loadFromFile ?
"found" :
"not found" );
476 if( useScreen || loadFromFile )
478 clearAnnotation =
true;
480 if( !
IsOK(
this, wxString::Format(
_(
"'%s' already exists." ),
481 sheetFileName.GetFullName() )
483 + wxString::Format(
_(
"Link '%s' to this file?" ),
484 newAbsoluteFilename ) ) )
496 bool isUndoable =
true;
497 isExistingSheet =
true;
512 oldAbsoluteFilename.Replace( wxT(
"\\" ), wxT(
"/" ) );
514 if( newAbsoluteFilename.Cmp( oldAbsoluteFilename ) != 0 )
519 if( useScreen || loadFromFile )
521 clearAnnotation =
true;
523 if( !
IsOK(
this, wxString::Format(
_(
"Change '%s' link from '%s' to '%s'?" ),
526 sheetFileName.GetFullName() )
528 +
_(
"This action cannot be undone." ) ) )
540 if( !
IsOK(
this, wxString::Format(
_(
"Create new file '%s' with contents "
542 sheetFileName.GetFullName(),
545 +
_(
"This action cannot be undone." ) ) )
578 msg = wxString::Format(
_(
"Error occurred saving schematic file '%s'." ),
579 newAbsoluteFilename );
582 msg = wxString::Format(
_(
"Failed to save schematic '%s'" ),
583 newAbsoluteFilename );
605 std::unique_ptr< SCH_SHEET> tmpSheet = std::make_unique<SCH_SHEET>( &schematic );
607 tmpSheet->GetFields()[
SHEETFILENAME].SetText( sheetFileName.GetFullPath() );
608 tmpSheet->SetScreen( useScreen );
617 else if( loadFromFile )
619 bool restoreSheet =
false;
621 if( isExistingSheet )
658 wxGridCellEditor*
editor =
m_grid->GetCellEditor( event.GetRow(), event.GetCol() );
659 wxControl* control =
editor->GetControl();
660 wxTextEntry* textControl =
dynamic_cast<wxTextEntry*
>( control );
666 if( textControl && textControl->IsEmpty() )
668 wxMessageBox(
_(
"A sheet must have a name." ) );
674 if( textControl->IsEmpty() )
676 wxMessageBox(
_(
"A sheet must have a file specified." ) );
681 if( success && control && control->GetValidator() )
682 success = control->GetValidator()->Validate( control );
709 wxGridTableMessage msg(
m_fields, wxGRIDTABLE_NOTIFY_ROWS_APPENDED, 1 );
710 m_grid->ProcessTableMessage( msg );
715 m_grid->EnableCellEditControl();
716 m_grid->ShowCellEditControl();
722 wxArrayInt selectedRows =
m_grid->GetSelectedRows();
724 if( selectedRows.empty() &&
m_grid->GetGridCursorRow() >= 0 )
725 selectedRows.push_back(
m_grid->GetGridCursorRow() );
727 if( selectedRows.empty() )
730 for(
int row : selectedRows )
734 DisplayError(
this, wxString::Format(
_(
"The first %d fields are mandatory." ),
743 selectedRows.Sort( [](
int* first,
int* second ) {
return *second - *first; } );
745 for(
int row : selectedRows )
750 wxGridTableMessage msg(
m_fields, wxGRIDTABLE_NOTIFY_ROWS_DELETED, row, 1 );
751 m_grid->ProcessTableMessage( msg );
753 if(
m_grid->GetNumberRows() > 0 )
755 m_grid->MakeCellVisible( std::max( 0, row-1 ),
m_grid->GetGridCursorCol() );
756 m_grid->SetGridCursor( std::max( 0, row-1 ),
m_grid->GetGridCursorCol() );
767 int i =
m_grid->GetGridCursorRow();
776 m_grid->SetGridCursor( i - 1,
m_grid->GetGridCursorCol() );
791 int i =
m_grid->GetGridCursorRow();
800 m_grid->SetGridCursor( i + 1,
m_grid->GetGridCursorCol() );
815 m_grid->AutoSizeColumn( 0 );
816 m_grid->SetColSize( 0, std::max( 72,
m_grid->GetColSize( 0 ) ) );
818 int fixedColsWidth =
m_grid->GetColSize( 0 );
820 for(
int i = 2; i <
m_grid->GetNumberCols(); i++ )
821 fixedColsWidth +=
m_grid->GetColSize( i );
823 m_grid->SetColSize( 1, std::max( 120, width - fixedColsWidth ) );
835 if( !
m_grid->IsCellEditControlShown() )
842 if(
path.Last() !=
'/' )
846 wxControl* control =
editor->GetControl();
847 wxTextEntry* textControl =
dynamic_cast<wxTextEntry*
>( control );
851 sheetName = textControl->GetValue();
866 path = wxControl::Ellipsize(
path, dc, wxELLIPSIZE_START, width, wxELLIPSIZE_FLAGS_NONE );
878 m_grid->EnableCellEditControl(
true );
879 m_grid->ShowCellEditControl();
889 auto new_size =
event.GetSize();
KIFACE_BASE & Kiface()
Global KIFACE_BASE "get" accessor.
wxBitmapBundle KiBitmapBundle(BITMAPS aBitmap)
Color settings are a bit different than most of the settings objects in that there can be more than o...
bool GetOverrideSchItemColors() const
COLOR4D GetColor(int aLayer) const
void SetSwatchColor(const KIGFX::COLOR4D &aColor, bool aSendEvent)
Set the current swatch color directly.
KIGFX::COLOR4D GetSwatchColor() const
void SetDefaultColor(const KIGFX::COLOR4D &aColor)
Sets the color that will be chosen with the "Reset to Default" button in the chooser.
void SetSwatchBackground(const KIGFX::COLOR4D &aBackground)
Set the swatch background color.
Class DIALOG_SHEET_PROPERTIES_BASE.
STD_BITMAP_BUTTON * m_bpMoveUp
wxTextCtrl * m_pageNumberTextCtrl
COLOR_SWATCH * m_backgroundSwatch
wxStaticText * m_hierarchicalPath
STD_BITMAP_BUTTON * m_bpAdd
wxStdDialogButtonSizer * m_stdDialogButtonSizer
wxBoxSizer * m_sizerBottom
STD_BITMAP_BUTTON * m_bpDelete
COLOR_SWATCH * m_borderSwatch
wxStaticText * m_hierarchicalPathLabel
STD_BITMAP_BUTTON * m_bpMoveDown
bool TransferDataToWindow() override
DIALOG_SHEET_PROPERTIES(SCH_EDIT_FRAME *aParent, SCH_SHEET *aSheet, bool *aClearAnnotationNewItems)
void OnAddField(wxCommandEvent &event) override
void OnMoveDown(wxCommandEvent &event) override
UNIT_BINDER m_borderWidth
std::bitset< 64 > m_shownColumns
SCH_FIELD m_dummySheetNameField
bool TransferDataFromWindow() override
void OnGridCellChanging(wxGridEvent &event)
void OnDeleteField(wxCommandEvent &event) override
bool onSheetFilenameChanged(const wxString &aNewFilename)
void OnSizeGrid(wxSizeEvent &event) override
FIELDS_GRID_TABLE< SCH_FIELD > * m_fields
void OnInitDlg(wxInitDialogEvent &event) override
void OnUpdateUI(wxUpdateUIEvent &event) override
bool * m_clearAnnotationNewItems
void OnMoveUp(wxCommandEvent &event) override
~DIALOG_SHEET_PROPERTIES() override
void SetupStandardButtons(std::map< int, wxString > aLabels={})
void finishDialogSettings()
In all dialogs, we must call the same functions to fix minimal dlg size, the default position and per...
virtual void ClearUndoRedoList()
Clear the undo and redo list using ClearUndoORRedoList()
void SetMsgPanel(const std::vector< MSG_PANEL_ITEM > &aList)
Clear the message panel and populates it with the contents of aList.
const EDA_ANGLE & GetTextAngle() const
virtual const wxString & GetText() const
Return the string associated with the text object.
void Offset(const VECTOR2I &aOffset)
GR_TEXT_H_ALIGN_T GetHorizJustify() const
GR_TEXT_V_ALIGN_T GetVertJustify() const
virtual void SetTextAngle(const EDA_ANGLE &aAngle)
EE_TYPE OfType(KICAD_T aType) const
int GetNumberRows() override
Hold an error message and may be used when throwing exceptions containing meaningful error messages.
virtual const wxString What() const
A composite of Problem() and Where()
Helper class to create more flexible dialogs, including 'do not show again' checkbox handling.
void DoNotShowCheckbox(wxString file, int line)
Checks the 'do not show again' setting for the dialog.
APP_SETTINGS_BASE * KifaceSettings() const
A color representation with 4 components: red, green, blue, alpha.
PROJECT & Prj() const
Return a reference to the PROJECT associated with this KIWAY.
A logical library item identifier and consists of various portions much like a URI.
wxCheckBox * m_optOverrideColors
virtual const wxString AbsolutePath(const wxString &aFileName) const
Fix up aFileName if it is relative to the project's directory to be an absolute path and filename.
Holds all the data relating to one schematic.
SCH_SHEET_LIST & GetFullHierarchy() const
Return the full schematic flattened hierarchical sheet list.
COLOR_SETTINGS * GetColorSettings(bool aForceRefresh=false) const override
Returns a pointer to the active color theme settings.
Schematic editor (Eeschema) main window.
bool LoadSheetFromFile(SCH_SHEET *aSheet, SCH_SHEET_PATH *aHierarchy, const wxString &aFileName)
Load a the KiCad schematic file aFileName into the sheet aSheet.
void OnModify() override
Must be called after a schematic change in order to set the "modify" flag and update other data struc...
bool AllowCaseSensitiveFileNameClashes(const wxString &aSchematicFileName)
Check aSchematicFileName for a potential file name case sensitivity clashes.
SCH_SCREEN * GetScreen() const override
Return a pointer to a BASE_SCREEN or one of its derivatives.
void InitSheet(SCH_SHEET *aSheet, const wxString &aNewFilename)
bool CheckSheetForRecursion(SCH_SHEET *aSheet, SCH_SHEET_PATH *aHierarchy)
Verify that aSheet will not cause a recursion error in aHierarchy.
void SaveCopyInUndoList(SCH_SCREEN *aScreen, SCH_ITEM *aItemToCopy, UNDO_REDO aTypeCommand, bool aAppend, bool aDirtyConnectivity=true)
Create a copy of the current schematic item, and put it in the undo list.
SCH_SHEET_PATH & GetCurrentSheet() const
SCHEMATIC & Schematic() const
void UpdateItem(EDA_ITEM *aItem, bool isAddOrDelete=false, bool aUpdateRtree=false) override
Mark an item for refresh.
void TestDanglingEnds()
Test all of the connectable objects in the schematic for unused connection points.
Instances are attached to a symbol or sheet and provide a place for the symbol's value,...
VECTOR2I GetPosition() const override
wxString GetCanonicalName() const
Get a non-language-specific name for a field which can be used for storage, variable look-up,...
bool IsEmpty()
Return true if both the name and value of the field are empty.
wxString GetName(bool aUseDefaultName=true) const
Return the field name (not translated).
void SetName(const wxString &aName)
wxString GetShownText(const SCH_SHEET_PATH *aPath, bool aAllowExtraText, int aDepth=0) const
void SetText(const wxString &aText) override
Base class for any item which can be embedded within the SCHEMATIC container class,...
void ClearFieldsAutoplaced()
Helper object to release a SCH_PLUGIN in the context of a potential thrown exception through its dest...
virtual void SaveSchematicFile(const wxString &aFileName, SCH_SHEET *aSheet, SCHEMATIC *aSchematic, const STRING_UTF8_MAP *aProperties=nullptr)
Write aSchematic to a storage file in a format that this SCH_PLUGIN implementation knows about,...
void Append(SCH_ITEM *aItem, bool aUpdateLibSymbol=true)
EE_RTREE & Items()
Gets the full RTree, usually for iterating.
const wxString & GetFileName() const
void SetFileName(const wxString &aFileName)
Set the file name for this screen to aFileName.
bool Remove(SCH_ITEM *aItem, bool aUpdateLibSymbol=true)
Remove aItem from the schematic associated with this screen.
A container for handling SCH_SHEET_PATH objects in a flattened hierarchy.
Handle access to a stack of flattened SCH_SHEET objects by way of a path for creating a flattened sch...
wxString PathHumanReadable(bool aUseShortRootName=true, bool aStripTrailingSeparator=false) const
Return the sheet path in a human readable form made from the sheet names.
SCH_SCREEN * LastScreen()
wxString GetPageNumber() const
void SetPageNumber(const wxString &aPageNumber)
Set the sheet instance user definable page number.
void push_back(SCH_SHEET *aSheet)
Forwarded method from std::vector.
Sheet symbol placed in a schematic, and is the entry point for a sub schematic.
void SetBorderColor(KIGFX::COLOR4D aColor)
wxString GetFileName() const
Return the filename corresponding to this sheet.
static const wxString GetDefaultFieldName(int aFieldNdx, bool aTranslated=true)
std::vector< SCH_FIELD > & GetFields()
bool SearchHierarchy(const wxString &aFilename, SCH_SCREEN **aScreen)
Search the existing hierarchy for an instance of screen loaded from aFileName.
void SetBackgroundColor(KIGFX::COLOR4D aColor)
SCH_SCREEN * GetScreen() const
VECTOR2I GetPosition() const override
void SetFields(const std::vector< SCH_FIELD > &aFields)
Set multiple schematic fields.
int GetScreenCount() const
Return the number of times the associated screen for the sheet is being used.
void SetScreen(SCH_SCREEN *aScreen)
Set the SCH_SCREEN associated with this sheet to aScreen.
KIGFX::COLOR4D GetBorderColor() const
void SetBorderWidth(int aWidth)
int GetBorderWidth() const
KIGFX::COLOR4D GetBackgroundColor() const
virtual long long int GetValue()
Return the current value in Internal Units.
virtual void SetValue(long long int aValue)
Set new value (in Internal Units) for the text field, taking care of units conversion.
void ShowHideColumns(const wxString &shownColumns)
Show/hide the grid columns based on a tokenized string of shown column indexes.
void SetTable(wxGridTableBase *table, bool aTakeOwnership=false)
Hide wxGrid's SetTable() method with one which doesn't mess up the grid column widths when setting th...
void DestroyTable(wxGridTableBase *aTable)
Work-around for a bug in wxGrid which crashes when deleting the table if the cell edit control was no...
wxString GetShownColumnsAsString()
Get a tokenized string containing the shown column indexes.
std::bitset< 64 > GetShownColumns()
bool CommitPendingChanges(bool aQuietMode=false)
Close any open cell edit controls.
void ShowMessage(const wxString &aMessage, int aFlags=wxICON_INFORMATION) override
Show the info bar with the provided message and icon.
wxString EnsureFileExtension(const wxString &aFilename, const wxString &aExtension)
It's annoying to throw up nag dialogs when the extension isn't right.
bool IsOK(wxWindow *aParent, const wxString &aMessage)
Display a yes/no dialog with aMessage and returns the user response.
void DisplayError(wxWindow *aParent, const wxString &aText, int aDisplayTime)
Display an error or warning message box with aMessage.
void DisplayErrorMessage(wxWindow *aParent, const wxString &aText, const wxString &aExtraInfo)
Display an error message with aMessage.
This file is part of the common library.
static bool positioningChanged(const SCH_FIELD &a, const SCH_FIELD &b)
static bool positioningChanged(const SCH_FIELD &a, const SCH_FIELD &b)
const int minSize
Push and Shove router track width and via size dialog.
const std::string KiCadSchematicFileExtension
const wxChar *const tracePathsAndFiles
Flag to enable path and file name debug output.
@ LAYER_SCHEMATIC_BACKGROUND
wxFont GetInfoFont(wxWindow *aWindow)
@ SHEET_MANDATORY_FIELDS
The first 2 are mandatory, and must be instantiated in SCH_SHEET.
wxLogTrace helper definitions.
Custom text control validator definitions.
Definition of file extensions used in Kicad.
#define FN_NORMALIZE_FLAGS
Default flags to pass to wxFileName::Normalize().