#include <YTable.h>
Public Member Functions | |
virtual | ~YTable () |
virtual const char * | widgetClass () const |
int | columns () const |
bool | hasColumn (int column) const |
std::string | header (int column) const |
YAlignmentType | alignment (int column) const |
bool | immediateMode () const |
void | setImmediateMode (bool immediateMode=true) |
bool | keepSorting () const |
virtual void | setKeepSorting (bool keepSorting) |
bool | hasMultiSelection () const |
YItem * | findItem (const std::string &wantedItemLabel, int column) const |
YItem * | findItem (const std::string &wantedItemLabel, int column, YItemConstIterator begin, YItemConstIterator end) const |
virtual void | cellChanged (const YTableCell *cell)=0 |
virtual bool | setProperty (const std::string &propertyName, const YPropertyValue &val) |
virtual YPropertyValue | getProperty (const std::string &propertyName) |
virtual const YPropertySet & | propertySet () |
const char * | userInputProperty () |
![]() | |
virtual | ~YSelectionWidget () |
std::string | label () const |
virtual void | setLabel (const std::string &newLabel) |
virtual void | addItem (YItem *item_disown) |
void | addItem (const std::string &itemLabel, bool selected=false) |
void | addItem (const std::string &itemLabel, const std::string &iconName, bool selected=false) |
virtual void | addItems (const YItemCollection &itemCollection) |
virtual void | deleteAllItems () |
void | setItems (const YItemCollection &itemCollection) |
YItemIterator | itemsBegin () |
YItemConstIterator | itemsBegin () const |
YItemIterator | itemsEnd () |
YItemConstIterator | itemsEnd () const |
bool | hasItems () const |
int | itemsCount () const |
YItem * | itemAt (int index) const |
YItem * | firstItem () const |
virtual YItem * | selectedItem () |
virtual YItemCollection | selectedItems () |
bool | hasSelectedItem () |
virtual void | selectItem (YItem *item, bool selected=true) |
virtual void | setItemStatus (YItem *item, int status) |
virtual void | deselectAllItems () |
void | setIconBasePath (const std::string &basePath) |
std::string | iconBasePath () const |
std::string | iconFullPath (const std::string &iconName) const |
std::string | iconFullPath (YItem *item) const |
bool | itemsContain (YItem *item) const |
YItem * | findItem (const std::string &itemLabel) const |
void | dumpItems () const |
bool | enforceSingleSelection () const |
virtual void | shortcutChanged () |
virtual std::string | shortcutString () const |
virtual void | setShortcutString (const std::string &str) |
![]() | |
virtual | ~YWidget () |
virtual std::string | debugLabel () const |
std::string | helpText () const |
void | setHelpText (const std::string &helpText) |
bool | hasChildren () const |
YWidget * | firstChild () const |
YWidget * | lastChild () const |
YWidgetListIterator | childrenBegin () const |
YWidgetListIterator | childrenEnd () const |
YWidgetListConstIterator | childrenConstBegin () const |
YWidgetListConstIterator | childrenConstEnd () const |
YWidgetListIterator | begin () |
YWidgetListIterator | end () |
int | childrenCount () const |
bool | contains (YWidget *child) const |
virtual void | addChild (YWidget *child) |
virtual void | removeChild (YWidget *child) |
void | deleteChildren () |
YWidget * | parent () const |
bool | hasParent () const |
void | setParent (YWidget *newParent) |
YDialog * | findDialog () |
YWidget * | findWidget (YWidgetID *id, bool doThrow=true) const |
virtual int | preferredWidth ()=0 |
virtual int | preferredHeight ()=0 |
virtual int | preferredSize (YUIDimension dim) |
virtual void | setSize (int newWidth, int newHeight)=0 |
bool | isValid () const |
bool | beingDestroyed () const |
void * | widgetRep () const |
void | setWidgetRep (void *toolkitWidgetRep) |
bool | hasId () const |
YWidgetID * | id () const |
void | setId (YWidgetID *newId_disown) |
virtual void | setEnabled (bool enabled=true) |
void | setDisabled () |
virtual bool | isEnabled () const |
virtual bool | stretchable (YUIDimension dim) const |
void | setStretchable (YUIDimension dim, bool newStretch) |
void | setDefaultStretchable (YUIDimension dim, bool newStretch) |
virtual int | weight (YUIDimension dim) |
bool | hasWeight (YUIDimension dim) |
void | setWeight (YUIDimension dim, int weight) |
void | setNotify (bool notify=true) |
bool | notify () const |
void | setNotifyContextMenu (bool notifyContextMenu=true) |
bool | notifyContextMenu () const |
bool | sendKeyEvents () const |
void | setSendKeyEvents (bool doSend) |
bool | autoShortcut () const |
void | setAutoShortcut (bool _newAutoShortcut) |
int | functionKey () const |
bool | hasFunctionKey () const |
virtual void | setFunctionKey (int fkey_no) |
virtual bool | setKeyboardFocus () |
void | dumpWidgetTree (int indentationLevel=0) |
void | dumpDialogWidgetTree () |
void | setChildrenEnabled (bool enabled) |
virtual void | saveUserInput (YMacroRecorder *macroRecorder) |
void * | operator new (size_t size) |
void | operator delete (void *ptr) noexcept |
virtual void | startMultipleChanges () |
virtual void | doneMultipleChanges () |
Table: Selection list with multiple columns. The user can select exactly one row (with all its columns) from that list. Each cell (each column within each row) has a label text, an optional icon (*) and an optional sort-key (used instead of the label text during sorting).
This widget is similar to SelectionBox, but it has several columns for each item (each row). If just one column is desired, consider using SelectionBox instead.
Note: This is not something like a spread sheet, and it doesn't pretend or want to be. Actions are performed on rows, not on individual cells (columns within one row).
(*) Not all UIs (in particular not text-based UIs) support displaying icons, so an icon should never be an exclusive means to display any kind of information.
See also https://github.com/libyui/libyui-ncurses/blob/master/doc/nctable-and-nctree.md
|
protected |
Constructor.
'header' describes the table's headers: Number of columns, column headings, and column alignment. The widget assumes ownership of this object and will delete it when appropriate. The header cannot be changed after creating the widget.
'multiSelection' indicates whether or not the user can select multiple items at the same time (e.g., with shift-click or ctrl-click). This can only be set in the constructor.
|
virtual |
Destructor.
YAlignmentType YTable::alignment | ( | int | column | ) | const |
Return the alignment for the specified column.
|
pure virtual |
Notification that a cell (its text, its icon and/or sort-key) was changed from the outside. Applications are required to call this whenever a table cell is changed after adding the corresponding table item (the row) to the table widget.
Derived classes are required to implement this and update the display accordingly.
Note that the position of this cell can be retrieved with cell->column() and cell->itemIndex().
int YTable::columns | ( | ) | const |
Return the number of columns of this table.
YItem * YTable::findItem | ( | const std::string & | wantedItemLabel, |
int | column ) const |
Try to find an item with label 'wantedItemLabel' in column 'column' between iterators 'begin' and 'end'. Return that item or 0 if there is none.
|
virtual |
bool YTable::hasColumn | ( | int | column | ) | const |
Return 'true' if this table has a column no. 'column' (counting from 0 on).
bool YTable::hasMultiSelection | ( | ) | const |
Return 'true' if the user can select multiple items at the same time (e.g., with shift-click or ctrl-click).
string YTable::header | ( | int | column | ) | const |
Return the header text for the specified column.
bool YTable::immediateMode | ( | ) | const |
Deliver even more events than with notify() set.
With "notify" alone, a table widget sends an ActivatedEvent when the user double-clicks an item or presses the "space" key on it. It does not send an event when the user just sends another item.
With "immediate", it also sends a SelectionChangedEvent when the user selects another item. "immediate" implicitly includes "notify".
bool YTable::keepSorting | ( | ) | const |
Return 'true' if the sort order is to be kept in item insertion order, i.e. if sorting the table by clicking on a column header should be disabled.
|
virtual |
void YTable::setImmediateMode | ( | bool | immediateMode = true | ) |
Set immediateMode() on or off.
|
virtual |
Switch between sorting by item insertion order (keepSorting: true) or allowing the user to sort by an arbitrary column (by clicking on the column header).
Derived classes can overwrite this function, but they should call this base class function in the new implementation.
|
virtual |
|
protected |
Exchange the previous table header with a new one. This will delete the old YTableHeader object.
If the new header has a different number of columns than the old one, all items will implicitly be deleted.
|
inlinevirtual |
|
inlinevirtual |
Return a descriptive name of this widget class for logging, debugging etc.
Reimplemented from YSelectionWidget.