summaryrefslogtreecommitdiffstats
path: root/src/kbfxplasmacanvasgroupview.cpp
diff options
context:
space:
mode:
authortpearson <tpearson@283d02a7-25f6-0310-bc7c-ecb5cbfe19da>2010-02-17 00:43:50 +0000
committertpearson <tpearson@283d02a7-25f6-0310-bc7c-ecb5cbfe19da>2010-02-17 00:43:50 +0000
commitceea23677c61f20759ae986bd77b0d5c4d673edb (patch)
tree3fcec1702eaf9c14d1dd736e594f5df08dab4001 /src/kbfxplasmacanvasgroupview.cpp
downloadkbfx-ceea23677c61f20759ae986bd77b0d5c4d673edb.tar.gz
kbfx-ceea23677c61f20759ae986bd77b0d5c4d673edb.zip
Added old KDE3 version of kbfx
git-svn-id: svn://anonsvn.kde.org/home/kde/branches/trinity/applications/kbfx@1091549 283d02a7-25f6-0310-bc7c-ecb5cbfe19da
Diffstat (limited to 'src/kbfxplasmacanvasgroupview.cpp')
-rw-r--r--src/kbfxplasmacanvasgroupview.cpp213
1 files changed, 213 insertions, 0 deletions
diff --git a/src/kbfxplasmacanvasgroupview.cpp b/src/kbfxplasmacanvasgroupview.cpp
new file mode 100644
index 0000000..04c7f8e
--- /dev/null
+++ b/src/kbfxplasmacanvasgroupview.cpp
@@ -0,0 +1,213 @@
+/*
+ * Copyright (C) 2006
+ * Siraj Razick <[email protected]>
+ * PhobosK <[email protected]>
+ * see Also AUTHORS
+ *
+ * This program is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU Library General Public License version 2 as
+ * published by the Free Software Foundation
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details
+ *
+ * You should have received a copy of the GNU Library General Public
+ * License along with this program; if not, write to the
+ * Free Software Foundation, Inc.,
+ * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
+ */
+
+#include "kbfxplasmacanvasgroupview.h"
+
+KbfxPlasmaCanvasGroupView::KbfxPlasmaCanvasGroupView ()
+{
+ m_groupChain.setAutoDelete ( true );
+ m_count = 0;
+ m_height = 0;
+ m_width = 0;
+ m_name = QString ( "Unkown" );
+ m_fullExpand = false;
+
+}
+
+KbfxPlasmaCanvasGroupView::~KbfxPlasmaCanvasGroupView ()
+{
+// delete [] m_name;
+ for ( uint i = 0; i < m_groupChain.count (); ++i )
+ {
+ m_groupChain.at ( i )->~KbfxPlasmaCanvasGroup();
+ m_groupChain.remove ( m_groupChain.at ( i ) );
+ }
+
+}
+
+void
+KbfxPlasmaCanvasGroupView::addGroup ( KbfxPlasmaCanvasGroup * gPtr )
+{
+ if ( gPtr == NULL )
+ {
+ qDebug
+ ( "KbfxPlasmaCanvasGroupView.cpp:39:Null Pointer Passed to addGroup()" );
+ return;
+ }
+ else
+ {
+ gPtr->setGroupID ( ( uint ) m_count );
+ m_height+= gPtr->height();
+ m_width = gPtr->width();
+ gPtr->move ( 0,m_height-gPtr->height() );
+ m_groupChain.append ( gPtr );
+// gPtr->show();
+// qDebug("adding Groupy");
+ m_count++;
+ connect ( gPtr, SIGNAL ( groupShade ( uint ) ), this,
+ SLOT ( foldGroup ( uint ) ) );
+ connect ( gPtr, SIGNAL ( groupUnShade ( uint ) ), this,
+ SLOT ( unFoldGroup ( uint ) ) );
+
+
+ }
+
+
+}
+
+KbfxPlasmaCanvasGroupView *
+KbfxPlasmaCanvasGroupView::contains ( KbfxPlasmaCanvasGroup * )
+{
+//maybe I don't need this
+ return 0;
+
+}
+
+void
+KbfxPlasmaCanvasGroupView::setName ( QString name )
+{
+ m_name = name;
+ //delete [] name;
+}
+
+QString
+KbfxPlasmaCanvasGroupView::name()
+{
+ return m_name;
+}
+
+
+void
+KbfxPlasmaCanvasGroupView::foldGroupAll ()
+{
+///not too many groups and needs fast shading so ...this
+
+ for ( uint i = 0; i < m_groupChain.count (); ++i )
+ {
+ if ( m_groupChain.at ( i ) )
+ if ( !m_groupChain.at ( i )->isShaded() )
+ m_groupChain.at ( i )->shade ();
+ }
+
+ m_fullExpand = true;
+}
+
+void
+KbfxPlasmaCanvasGroupView::unfoldGroupAll ()
+{
+///not too many groups and needs fast shading so ...this
+
+ for ( uint i = 0; i < m_groupChain.count (); ++i )
+ {
+ if ( m_groupChain.at ( i ) )
+ if ( m_groupChain.at ( i )->isShaded() )
+ m_groupChain.at ( i )->shade ();
+ }
+
+ m_fullExpand = true;
+}
+
+void
+KbfxPlasmaCanvasGroupView::hide ()
+{
+
+ for ( uint i = 0; i < m_groupChain.count (); ++i )
+ {
+ if ( m_groupChain.at ( i ) )
+// if( m_groupChain.at (i)->isShaded())
+ m_groupChain.at ( i )->hide();
+ }
+
+}
+
+
+void
+KbfxPlasmaCanvasGroupView::show()
+{
+
+ for ( uint i = 0; i < m_groupChain.count (); ++i )
+ {
+// if (m_groupChain.at (i))
+// if( m_groupChain.at (i)->isShaded())
+/// unFoldGroup(i);
+
+ m_groupChain.at ( i )->show();
+ ///qDebug("Showing group %d",i);
+ }
+
+}
+
+
+void
+KbfxPlasmaCanvasGroupView::foldGroup ( uint e_id )
+{
+
+ KbfxPlasmaCanvasGroup *_it;
+ KbfxPlasmaCanvasGroup *_et = m_groupChain.at ( e_id );
+ if ( _et == NULL )
+ return;
+
+ int _height = _et->height ();
+ //int _shadestate = _et->isShaded ();
+
+ for ( _it = m_groupChain.first (); _it; _it = m_groupChain.next () )
+ {
+ if ( e_id != _it->groupID () )
+ {
+ if ( _it->groupID () > e_id )
+ {
+ _it->moveUp ( _height );
+
+ }
+
+ }
+ }
+
+}
+
+void
+KbfxPlasmaCanvasGroupView::unFoldGroup ( uint e_id )
+{
+ KbfxPlasmaCanvasGroup *_it;
+ KbfxPlasmaCanvasGroup *_et = m_groupChain.at ( e_id );
+ if ( _et == NULL )
+ {
+ qDebug ( "OOps no such groups can't unfold" );
+ return;
+ }
+
+ int _height = _et->height ();
+ //int _shadestate = _et->isShaded ();
+
+ for ( _it = m_groupChain.first (); _it; _it = m_groupChain.next () )
+ {
+ if ( e_id != _it->groupID () )
+ {
+ if ( _it->groupID () > e_id )
+ {
+ _it->moveDown ( _height );
+ }
+
+ }
+ }
+}
+
+#include "kbfxplasmacanvasgroupview.moc"