GenericPanel and its subclasses now use the title and icon provided by collections.

git-svn-id: svn+ssh://svn.tuxfamily.org/svnroot/qet/qet/branches/0.3@1492 bfdf4180-ca20-0410-9c96-a3a8aa849046
This commit is contained in:
xavier
2012-02-06 22:34:52 +00:00
parent 7661b2f47e
commit 9fb4eb7c2d
5 changed files with 90 additions and 25 deletions

View File

@@ -66,7 +66,7 @@ void ElementsCategoriesList::reload() {
foreach(ElementsCollection *collection, QETApp::availableCollections()) { foreach(ElementsCollection *collection, QETApp::availableCollections()) {
if (collection == QETApp::commonElementsCollection()) continue; if (collection == QETApp::commonElementsCollection()) continue;
if (collection == QETApp::customElementsCollection()) continue; if (collection == QETApp::customElementsCollection()) continue;
addElementsCollection(collection, invisibleRootItem(), options, tr("Collection projet")) -> setExpanded(true); addElementsCollection(collection, invisibleRootItem(), options) -> setExpanded(true);
} }
// chargement des elements de la collection commune si droits d'ecriture // chargement des elements de la collection commune si droits d'ecriture
@@ -74,9 +74,7 @@ void ElementsCategoriesList::reload() {
addElementsCollection( addElementsCollection(
QETApp::commonElementsCollection(), QETApp::commonElementsCollection(),
invisibleRootItem(), invisibleRootItem(),
options, options
tr("Collection QET"),
QIcon(":/ico/16x16/qet.png")
) -> setExpanded(true); ) -> setExpanded(true);
} }
@@ -84,9 +82,7 @@ void ElementsCategoriesList::reload() {
addElementsCollection( addElementsCollection(
QETApp::customElementsCollection(), QETApp::customElementsCollection(),
invisibleRootItem(), invisibleRootItem(),
options, options
tr("Collection utilisateur"),
QIcon(":/ico/16x16/go-home.png")
) -> setExpanded(true); ) -> setExpanded(true);
if (first_load) first_load = false; if (first_load) first_load = false;

View File

@@ -399,10 +399,10 @@ QTreeWidgetItem *ElementsPanel::addProject(QETProject *project) {
@param icon Icone a utiliser pour l'affichage de la collection @param icon Icone a utiliser pour l'affichage de la collection
@return Le QTreeWidgetItem insere le plus haut @return Le QTreeWidgetItem insere le plus haut
*/ */
QTreeWidgetItem *ElementsPanel::addCollection(ElementsCollection *collection, const QString &coll_name, const QIcon &icon) { QTreeWidgetItem *ElementsPanel::addCollection(ElementsCollection *collection) {
PanelOptions options = GenericPanel::AddAllChild; PanelOptions options = GenericPanel::AddAllChild;
options |= GenericPanel::DisplayElementsPreview; options |= GenericPanel::DisplayElementsPreview;
return(addElementsCollection(collection, invisibleRootItem(), options, coll_name, icon)); return(addElementsCollection(collection, invisibleRootItem(), options));
} }
QTreeWidgetItem *ElementsPanel::updateTemplateItem(QTreeWidgetItem *tb_template_qtwi, const TitleBlockTemplateLocation &tb_template, PanelOptions options, bool freshly_created) { QTreeWidgetItem *ElementsPanel::updateTemplateItem(QTreeWidgetItem *tb_template_qtwi, const TitleBlockTemplateLocation &tb_template, PanelOptions options, bool freshly_created) {
@@ -507,7 +507,7 @@ void ElementsPanel::reload(bool reload_collections) {
// load the common elements collection // load the common elements collection
if (QETApp::commonElementsCollection()->rootCategory()) { if (QETApp::commonElementsCollection()->rootCategory()) {
common_collection_item_ = addCollection(QETApp::commonElementsCollection(), tr("Collection QET"), system_icon); common_collection_item_ = addCollection(QETApp::commonElementsCollection());
if (first_reload_) common_collection_item_ -> setExpanded(true); if (first_reload_) common_collection_item_ -> setExpanded(true);
} }
@@ -519,7 +519,7 @@ void ElementsPanel::reload(bool reload_collections) {
// load the custom elements collection // load the custom elements collection
if (QETApp::customElementsCollection()->rootCategory()) { if (QETApp::customElementsCollection()->rootCategory()) {
custom_collection_item_ = addCollection(QETApp::customElementsCollection(), tr("Collection utilisateur"), user_icon); custom_collection_item_ = addCollection(QETApp::customElementsCollection());
if (first_reload_) custom_collection_item_ -> setExpanded(true); if (first_reload_) custom_collection_item_ -> setExpanded(true);
} }

View File

@@ -92,7 +92,7 @@ class ElementsPanel : public GenericPanel {
private: private:
QTreeWidgetItem *addProject (QETProject *); QTreeWidgetItem *addProject (QETProject *);
QTreeWidgetItem *addCollection(ElementsCollection *, const QString & = QString(), const QIcon & = QIcon()); QTreeWidgetItem *addCollection(ElementsCollection *);
QTreeWidgetItem *updateTemplateItem (QTreeWidgetItem *, const TitleBlockTemplateLocation &, PanelOptions, bool = false); QTreeWidgetItem *updateTemplateItem (QTreeWidgetItem *, const TitleBlockTemplateLocation &, PanelOptions, bool = false);
QTreeWidgetItem *updateElementsCategoryItem(QTreeWidgetItem *, ElementsCategory *, PanelOptions, bool = false); QTreeWidgetItem *updateElementsCategoryItem(QTreeWidgetItem *, ElementsCategory *, PanelOptions, bool = false);
QTreeWidgetItem *updateElementItem (QTreeWidgetItem *, ElementDefinition *, PanelOptions, bool = false); QTreeWidgetItem *updateElementItem (QTreeWidgetItem *, ElementDefinition *, PanelOptions, bool = false);

View File

@@ -276,8 +276,7 @@ QTreeWidgetItem *GenericPanel::fillProjectItem(QTreeWidgetItem *project_qtwi, QE
addElementsCollection( addElementsCollection(
project -> embeddedCollection(), project -> embeddedCollection(),
project_qtwi, project_qtwi,
options, options
tr("Collection projet")
); );
} }
return(project_qtwi); return(project_qtwi);
@@ -544,14 +543,76 @@ QTreeWidgetItem *GenericPanel::fillTemplateItem(QTreeWidgetItem *tb_template_qtw
Add an elements category to the panel. Add an elements category to the panel.
@param parent_item Parent for the created QTreeWidgetItem @param parent_item Parent for the created QTreeWidgetItem
@param collection Collection to be added to the panel @param collection Collection to be added to the panel
@param label Name displayed by the created QTreeWidgetItem
@param icon Icon displayed by the created QTreeWidgetItem
@param options Control the creation of child items @param options Control the creation of child items
@return the created QTreeWidgetItem @return the created QTreeWidgetItem
*/ */
QTreeWidgetItem *GenericPanel::addElementsCollection(ElementsCollection *collection, QTreeWidgetItem *parent_item, PanelOptions options, const QString &label, const QIcon &icon) { QTreeWidgetItem *GenericPanel::addElementsCollection(ElementsCollection *collection, QTreeWidgetItem *parent_item, PanelOptions options) {
if (!collection) return(0);
bool creation_required;
QTreeWidgetItem *collection_qtwi = getItemForElementsCollection(collection, &creation_required);
updateElementsCollectionItem(collection_qtwi, collection, options, creation_required);
reparent(collection_qtwi, parent_item);
fillElementsCollectionItem(collection_qtwi, collection, options, creation_required);
return(collection_qtwi);
}
/**
*/
QTreeWidgetItem *GenericPanel::itemForElementsCollection(ElementsCollection *collection) {
if (!collection) return(0);
return(elements_.value(collection -> rootCategory() -> location(), 0));
}
/**
*/
QTreeWidgetItem *GenericPanel::getItemForElementsCollection(ElementsCollection *collection, bool *created) {
if (!collection) return(0); if (!collection) return(0);
QTreeWidgetItem *collection_item = elements_.value(collection -> rootCategory() -> location(), 0);
if (collection_item) {
if (created) *created = false;
return(collection_item);
}
collection_item = makeItem(QET::ElementsCollection);
if (created) *created = true;
return(collection_item);
}
/**
*/
QTreeWidgetItem *GenericPanel::updateElementsCollectionItem(QTreeWidgetItem *collection_qtwi, ElementsCollection *collection, PanelOptions options, bool freshly_created) {
Q_UNUSED(options)
if (!collection) return(0);
QString collection_title = collection -> title();
QIcon collection_icon = collection -> icon();
if (!collection_title.isEmpty()) collection_qtwi -> setText(0, collection_title);
if (!collection_icon.isNull()) collection_qtwi -> setIcon(0, collection_icon);
if (freshly_created) {
collection_qtwi -> setData(0, GenericPanel::Item, qVariantFromValue(collection -> rootCategory() -> location()));
elements_.insert(collection -> rootCategory() -> location(), collection_qtwi);
connect(
collection, SIGNAL(elementsCollectionChanged(ElementsCollection*)),
this, SLOT(elementsCollectionChanged(ElementsCollection*))
);
}
return(collection_qtwi);
}
/**
*/
QTreeWidgetItem *GenericPanel::fillElementsCollectionItem(QTreeWidgetItem *collection_qtwi, ElementsCollection *collection, PanelOptions options, bool freshly_created) {
// use the cache from the provided collection, if any // use the cache from the provided collection, if any
bool restore_previous_cache = false; bool restore_previous_cache = false;
ElementsCollectionCache *previous_cache = 0; ElementsCollectionCache *previous_cache = 0;
@@ -562,16 +623,13 @@ QTreeWidgetItem *GenericPanel::addElementsCollection(ElementsCollection *collect
ElementsCollectionCache *cache = getElementsCache(); ElementsCollectionCache *cache = getElementsCache();
cache -> beginCollection(collection); cache -> beginCollection(collection);
QTreeWidgetItem *collection_qtwi = addElementsCategory(collection -> rootCategory(), parent_item, options); fillElementsCategoryItem(collection_qtwi, collection -> rootCategory(), options, freshly_created);
cache -> endCollection(collection); cache -> endCollection(collection);
if (!label.isEmpty()) collection_qtwi -> setText(0, label);
if (!icon.isNull()) collection_qtwi -> setIcon(0, icon);
// restore the former cache // restore the former cache
if (restore_previous_cache) { if (restore_previous_cache) {
setElementsCache(previous_cache); setElementsCache(previous_cache);
} }
return(collection_qtwi); return(collection_qtwi);
} }
@@ -621,8 +679,7 @@ QTreeWidgetItem *GenericPanel::getItemForElementsCategory(ElementsCategory *cate
return(category_item); return(category_item);
} }
QET::ItemType type = category -> isRootCategory() ? QET::ElementsCollection : QET::ElementsCategory; category_item = makeItem(QET::ElementsCategory);
category_item = makeItem(type);
if (created) *created = true; if (created) *created = true;
return(category_item); return(category_item);
} }
@@ -852,12 +909,18 @@ void GenericPanel::templatesCollectionChanged(TitleBlockTemplatesCollection*coll
void GenericPanel::diagramUsedTemplate(TitleBlockTemplatesCollection *collection, const QString &name) { void GenericPanel::diagramUsedTemplate(TitleBlockTemplatesCollection *collection, const QString &name) {
Q_UNUSED(collection) Q_UNUSED(collection)
Q_UNUSED(name) Q_UNUSED(name)
qDebug() << Q_FUNC_INFO << name;
addTemplatesCollection(collection); addTemplatesCollection(collection);
} }
/** /**
*/
void GenericPanel::elementsCollectionChanged(ElementsCollection *collection) {
addElementsCollection(collection, 0, 0);
}
/**
*/ */
QString GenericPanel::defaultText(QET::ItemType type) { QString GenericPanel::defaultText(QET::ItemType type) {
switch(type) { switch(type) {

View File

@@ -127,8 +127,13 @@ class GenericPanel : public QTreeWidget {
// elements collections methods // elements collections methods
public: public:
virtual QTreeWidgetItem *addElementsCollection(ElementsCollection *, QTreeWidgetItem *, PanelOptions = AddAllChild, const QString & = QString(), const QIcon & = QIcon());
virtual QTreeWidgetItem *itemForElementsLocation(const ElementsLocation &); virtual QTreeWidgetItem *itemForElementsLocation(const ElementsLocation &);
virtual QTreeWidgetItem *addElementsCollection(ElementsCollection *, QTreeWidgetItem *, PanelOptions = AddAllChild);
virtual QTreeWidgetItem *itemForElementsCollection(ElementsCollection *);
protected:
virtual QTreeWidgetItem *getItemForElementsCollection(ElementsCollection *, bool * = 0);
virtual QTreeWidgetItem *updateElementsCollectionItem(QTreeWidgetItem *, ElementsCollection *, PanelOptions = AddAllChild, bool = false);
virtual QTreeWidgetItem *fillElementsCollectionItem (QTreeWidgetItem *, ElementsCollection *, PanelOptions = AddAllChild, bool = false);
// elements categories methods // elements categories methods
public: public:
@@ -157,6 +162,7 @@ class GenericPanel : public QTreeWidget {
void diagramTitleChanged(Diagram *, const QString &); void diagramTitleChanged(Diagram *, const QString &);
void templatesCollectionChanged(TitleBlockTemplatesCollection*, const QString &); void templatesCollectionChanged(TitleBlockTemplatesCollection*, const QString &);
void diagramUsedTemplate(TitleBlockTemplatesCollection *, const QString &); void diagramUsedTemplate(TitleBlockTemplatesCollection *, const QString &);
void elementsCollectionChanged(ElementsCollection *);
// various other methods // various other methods
protected: protected: