summaryrefslogtreecommitdiff
path: root/noncore/graphics/opie-eye/impl/doc
Side-by-side diff
Diffstat (limited to 'noncore/graphics/opie-eye/impl/doc') (more/less context) (show whitespace changes)
-rw-r--r--noncore/graphics/opie-eye/impl/doc/doc_dirview.cpp7
-rw-r--r--noncore/graphics/opie-eye/impl/doc/doc_dirview.h4
-rw-r--r--noncore/graphics/opie-eye/impl/doc/doc_lister.cpp41
-rw-r--r--noncore/graphics/opie-eye/impl/doc/doc_lister.h7
4 files changed, 57 insertions, 2 deletions
diff --git a/noncore/graphics/opie-eye/impl/doc/doc_dirview.cpp b/noncore/graphics/opie-eye/impl/doc/doc_dirview.cpp
index 0d6e25f..2cc897b 100644
--- a/noncore/graphics/opie-eye/impl/doc/doc_dirview.cpp
+++ b/noncore/graphics/opie-eye/impl/doc/doc_dirview.cpp
@@ -28 +28,8 @@ PDirLister* Doc_DirView::dirLister()const{
}
+
+QWidget* Doc_DirView::widget(QWidget*parent)
+{
+ if (!m_lister)
+ dirLister();
+ return m_lister->widget(parent);
+}
diff --git a/noncore/graphics/opie-eye/impl/doc/doc_dirview.h b/noncore/graphics/opie-eye/impl/doc/doc_dirview.h
index 3a2fd71..55ba6f2 100644
--- a/noncore/graphics/opie-eye/impl/doc/doc_dirview.h
+++ b/noncore/graphics/opie-eye/impl/doc/doc_dirview.h
@@ -9,2 +9,3 @@
+class Doc_DirLister;
@@ -16,5 +17,6 @@ struct Doc_DirView : public PDirView {
PDirLister* dirLister()const;
+ QWidget* widget(QWidget*parent);
private:
bool m_cfg : 1;
- mutable PDirLister* m_lister;
+ mutable Doc_DirLister* m_lister;
mutable PInterfaceInfo *m_info;
diff --git a/noncore/graphics/opie-eye/impl/doc/doc_lister.cpp b/noncore/graphics/opie-eye/impl/doc/doc_lister.cpp
index 722fb95..d60149f 100644
--- a/noncore/graphics/opie-eye/impl/doc/doc_lister.cpp
+++ b/noncore/graphics/opie-eye/impl/doc/doc_lister.cpp
@@ -14,2 +14,5 @@
+#include <qtopia/private/categories.h>
+#include <qtopia/categoryselect.h>
+
using namespace Opie::Core;
@@ -24,2 +27,3 @@ Doc_DirLister::Doc_DirLister()
/* connect the signals */
+ m_catFilter = 0;
SlaveMaster* master = SlaveMaster::self();
@@ -42,2 +46,11 @@ QString Doc_DirLister::defaultPath()const {
+bool Doc_DirLister::matchCat(const AppLnk* app)
+{
+ if (!app) return false;
+ if (m_catFilter==0 || app->categories().contains(m_catFilter) || m_catFilter == -1 && app->categories().count() == 0 ) {
+ return true;
+ }
+ return false;
+}
+
QString Doc_DirLister::setStartPath(const QString&) {
@@ -49,3 +62,4 @@ QString Doc_DirLister::setStartPath(const QString&) {
for( ; dit.current(); ++dit) {
-// if (! (*dit)->isValid()) continue;
+ if (! (*dit)->isValid()) continue;
+ if (!matchCat((*dit))) continue;
m_namemap[(*dit)->name()]=(*dit)->file();
@@ -149 +163,26 @@ QString Doc_DirLister::dirUp( const QString& p ) const{
}
+
+QWidget* Doc_DirLister::widget(QWidget*parent)
+{
+ CategorySelect * catmb = new CategorySelect(parent);
+ Categories cats( 0 );
+ cats.load( categoryFileName() );
+ QArray<int> vl( 0 );
+ catmb->setCategories( vl, "Document View", // No tr
+ "Document View" );
+ catmb->setRemoveCategoryEdit( TRUE );
+ catmb->setAllCategories( TRUE );
+ connect(catmb, SIGNAL(signalSelected(int)), this, SLOT(showCategory(int)));
+ catmb->setCurrentCategory(-2);
+ return catmb;
+}
+
+void Doc_DirLister::showCategory(int which)
+{
+ Categories cat;
+ cat.load( categoryFileName() );
+ m_catFilter = which==-2?0:which;
+ m_namemap.clear();
+ setStartPath("");
+ emit sig_reloadDir();
+}
diff --git a/noncore/graphics/opie-eye/impl/doc/doc_lister.h b/noncore/graphics/opie-eye/impl/doc/doc_lister.h
index 5884a35..e148ac0 100644
--- a/noncore/graphics/opie-eye/impl/doc/doc_lister.h
+++ b/noncore/graphics/opie-eye/impl/doc/doc_lister.h
@@ -13,2 +13,4 @@
class Config;
+class AppLnk;
+
class Doc_DirLister : public PDirLister {
@@ -32,2 +34,3 @@ public:
QString dirUp( const QString& )const;
+ QWidget* widget(QWidget*parent);
@@ -35,2 +38,5 @@ private:
QMap<QString,QString> m_namemap,m_filemap;
+ int m_catFilter;
+ bool matchCat(const AppLnk* app);
+
protected slots:
@@ -39,2 +45,3 @@ protected slots:
virtual void slotThumbNail(const QString&, const QPixmap&);
+ virtual void showCategory(int);
};