author | llornkcor <llornkcor> | 2002-06-01 18:38:27 (UTC) |
---|---|---|
committer | llornkcor <llornkcor> | 2002-06-01 18:38:27 (UTC) |
commit | bc167b7ef02ccd5f6127d9f9640f4b7af6c5a496 (patch) (unidiff) | |
tree | d885205c7c2b6c690db1a9e9ff993fd09b2e78bd | |
parent | 2815c0b50bd52d58022eb1d5f4364079a0e99e0a (diff) | |
download | opie-bc167b7ef02ccd5f6127d9f9640f4b7af6c5a496.zip opie-bc167b7ef02ccd5f6127d9f9640f4b7af6c5a496.tar.gz opie-bc167b7ef02ccd5f6127d9f9640f4b7af6c5a496.tar.bz2 |
fixed bug woth my eyes no seeing the path combo very well, also fixed bug with popupmenu
-rw-r--r-- | noncore/apps/advancedfm/advancedfm.cpp | 245 | ||||
-rw-r--r-- | noncore/apps/advancedfm/advancedfm.h | 16 |
2 files changed, 155 insertions, 106 deletions
diff --git a/noncore/apps/advancedfm/advancedfm.cpp b/noncore/apps/advancedfm/advancedfm.cpp index f32031b..869a433 100644 --- a/noncore/apps/advancedfm/advancedfm.cpp +++ b/noncore/apps/advancedfm/advancedfm.cpp | |||
@@ -71,6 +71,7 @@ AdvancedFm::AdvancedFm( ) | |||
71 | : QMainWindow( ) | 71 | : QMainWindow( ) |
72 | { | 72 | { |
73 | setCaption( tr( "AdvancedFm" ) ); | 73 | setCaption( tr( "AdvancedFm" ) ); |
74 | // menuTimer( this ); | ||
74 | 75 | ||
75 | QGridLayout *layout = new QGridLayout( this ); | 76 | QGridLayout *layout = new QGridLayout( this ); |
76 | layout->setSpacing( 2); | 77 | layout->setSpacing( 2); |
@@ -144,8 +145,25 @@ AdvancedFm::AdvancedFm( ) | |||
144 | viewMenu->insertItem( tr( "About" ), this, SLOT( doAbout() )); | 145 | viewMenu->insertItem( tr( "About" ), this, SLOT( doAbout() )); |
145 | viewMenu->setCheckable(TRUE); | 146 | viewMenu->setCheckable(TRUE); |
146 | 147 | ||
148 | |||
149 | currentPathCombo = new QComboBox( FALSE, this, "currentPathCombo" ); | ||
150 | currentPathCombo->setEditable(TRUE); | ||
151 | layout->addMultiCellWidget( currentPathCombo, 1, 1, 0, 7); | ||
152 | currentPathCombo->lineEdit()->setText( currentDir.canonicalPath()); | ||
153 | |||
154 | connect( currentPathCombo, SIGNAL( activated( const QString & ) ), | ||
155 | this, SLOT( currentPathComboActivated( const QString & ) ) ); | ||
156 | |||
157 | connect( currentPathCombo->lineEdit(),SIGNAL(returnPressed()), | ||
158 | this,SLOT(currentPathComboChanged())); | ||
159 | |||
160 | currentPathCombo->lineEdit()->setText( currentDir.canonicalPath()); | ||
161 | |||
162 | layout->addMultiCellWidget( currentPathCombo, 1, 1, 0, 7); | ||
163 | |||
164 | |||
147 | TabWidget = new QTabWidget( this, "TabWidget" ); | 165 | TabWidget = new QTabWidget( this, "TabWidget" ); |
148 | layout->addMultiCellWidget( TabWidget, 1, 1, 0, 7); | 166 | layout->addMultiCellWidget( TabWidget, 2, 2, 0, 7); |
149 | 167 | ||
150 | tab = new QWidget( TabWidget, "tab" ); | 168 | tab = new QWidget( TabWidget, "tab" ); |
151 | tabLayout = new QGridLayout( tab ); | 169 | tabLayout = new QGridLayout( tab ); |
@@ -165,12 +183,15 @@ AdvancedFm::AdvancedFm( ) | |||
165 | 183 | ||
166 | QPEApplication::setStylusOperation( Local_View->viewport(),QPEApplication::RightOnHold); | 184 | QPEApplication::setStylusOperation( Local_View->viewport(),QPEApplication::RightOnHold); |
167 | 185 | ||
186 | |||
187 | |||
168 | tabLayout->addWidget( Local_View, 0, 0 ); | 188 | tabLayout->addWidget( Local_View, 0, 0 ); |
169 | 189 | ||
170 | connect( Local_View, SIGNAL( clicked( QListViewItem*)), | 190 | connect( Local_View, SIGNAL( clicked( QListViewItem*)), |
171 | this,SLOT( localListClicked(QListViewItem *)) ); | 191 | this,SLOT( localListClicked(QListViewItem *)) ); |
172 | connect( Local_View, SIGNAL( mouseButtonPressed( int, QListViewItem *, const QPoint&, int)), | 192 | connect( Local_View, SIGNAL( mouseButtonPressed( int, QListViewItem *, const QPoint&, int)), |
173 | this,SLOT( localListPressed(int, QListViewItem *, const QPoint&, int)) ); | 193 | this,SLOT( localListPressed(int, QListViewItem *, const QPoint&, int)) ); |
194 | connect( Local_View, SIGNAL( selectionChanged() ), SLOT( cancelMenuTimer() ) ); | ||
174 | 195 | ||
175 | TabWidget->insertTab( tab, tr("1")); | 196 | TabWidget->insertTab( tab, tr("1")); |
176 | 197 | ||
@@ -195,6 +216,7 @@ AdvancedFm::AdvancedFm( ) | |||
195 | this,SLOT( remoteListClicked(QListViewItem *)) ); | 216 | this,SLOT( remoteListClicked(QListViewItem *)) ); |
196 | connect( Remote_View, SIGNAL( mouseButtonPressed( int, QListViewItem *, const QPoint&, int)), | 217 | connect( Remote_View, SIGNAL( mouseButtonPressed( int, QListViewItem *, const QPoint&, int)), |
197 | this,SLOT( remoteListPressed(int, QListViewItem *, const QPoint&, int)) ); | 218 | this,SLOT( remoteListPressed(int, QListViewItem *, const QPoint&, int)) ); |
219 | connect( Remote_View, SIGNAL( selectionChanged() ), SLOT( cancelMenuTimer() ) ); | ||
198 | 220 | ||
199 | tabLayout_2->addWidget( Remote_View, 0, 0 ); | 221 | tabLayout_2->addWidget( Remote_View, 0, 0 ); |
200 | 222 | ||
@@ -221,23 +243,12 @@ AdvancedFm::AdvancedFm( ) | |||
221 | currentRemoteDir.setPath( QDir::currentDirPath()); | 243 | currentRemoteDir.setPath( QDir::currentDirPath()); |
222 | 244 | ||
223 | b = TRUE; | 245 | b = TRUE; |
224 | currentPathCombo = new QComboBox( FALSE, this, "currentPathCombo" ); | ||
225 | currentPathCombo->setEditable(TRUE); | ||
226 | layout->addMultiCellWidget( currentPathCombo, 3, 3, 0, 7); | ||
227 | currentPathCombo->lineEdit()->setText( currentDir.canonicalPath()); | ||
228 | |||
229 | connect( currentPathCombo, SIGNAL( activated( const QString & ) ), | ||
230 | this, SLOT( currentPathComboActivated( const QString & ) ) ); | ||
231 | |||
232 | connect( currentPathCombo->lineEdit(),SIGNAL(returnPressed()), | ||
233 | this,SLOT(currentPathComboChanged())); | ||
234 | |||
235 | currentPathCombo->lineEdit()->setText( currentDir.canonicalPath()); | ||
236 | |||
237 | layout->addMultiCellWidget( currentPathCombo, 3, 3, 0, 7); | ||
238 | 246 | ||
239 | filterStr="*"; | 247 | filterStr="*"; |
240 | b=FALSE; | 248 | b=FALSE; |
249 | |||
250 | connect( &menuTimer, SIGNAL( timeout() ), SLOT( showFileMenu() ) ); | ||
251 | |||
241 | populateLocalView(); | 252 | populateLocalView(); |
242 | populateRemoteView(); | 253 | populateRemoteView(); |
243 | } | 254 | } |
@@ -641,107 +652,29 @@ void AdvancedFm::localListPressed( int mouse, QListViewItem *item, const QPoint | |||
641 | case 1: | 652 | case 1: |
642 | break; | 653 | break; |
643 | case 2: | 654 | case 2: |
644 | showLocalMenu(item); | 655 | menuTimer.start( 500, TRUE ); |
645 | Local_View->clearSelection(); | ||
646 | break; | 656 | break; |
647 | }; | 657 | }; |
648 | } | 658 | } |
649 | 659 | ||
650 | void AdvancedFm::remoteListPressed( int mouse, QListViewItem *item, const QPoint &point, int i) | 660 | void AdvancedFm::remoteListPressed( int mouse, QListViewItem *item, const QPoint &point, int i) |
651 | { | 661 | { |
662 | |||
652 | switch (mouse) { | 663 | switch (mouse) { |
653 | case 1: | 664 | case 1: |
654 | break; | 665 | break; |
655 | case 2: | 666 | case 2: |
656 | showRemoteMenu(item); | 667 | menuTimer.start( 500, TRUE ); |
657 | Remote_View->clearSelection(); | ||
658 | break; | 668 | break; |
659 | }; | 669 | }; |
660 | } | 670 | } |
661 | 671 | ||
662 | void AdvancedFm::showLocalMenu(QListViewItem * item) | ||
663 | { | ||
664 | if(item) { | ||
665 | QPopupMenu m; | ||
666 | m.insertItem( tr( "Show Hidden Files" ), this, SLOT( showHidden() )); | ||
667 | m.insertSeparator(); | ||
668 | if( /*item->text(0).right(1) == "/" ||*/ item->text(0).find("/",0,TRUE) !=-1) | ||
669 | m.insertItem( tr( "Change Directory" ), this, SLOT( doLocalCd() )); | ||
670 | else | ||
671 | m.insertItem( tr( "Open / Execute" ), this, SLOT( runThis() )); | ||
672 | m.insertItem( tr( "Open as Text" ), this, SLOT( runText() )); | ||
673 | m.insertItem( tr( "Make Directory" ), this, SLOT( localMakDir() )); | ||
674 | m.insertItem( tr( "Make Symlink" ), this, SLOT( mkSym() )); | ||
675 | m.insertSeparator(); | ||
676 | m.insertItem( tr( "Rename" ), this, SLOT( localRename() )); | ||
677 | m.insertItem( tr( "Copy" ), this, SLOT( copy() )); | ||
678 | m.insertItem( tr( "Copy As" ), this, SLOT( copyAs() )); | ||
679 | m.insertItem( tr( "Move" ), this, SLOT( move() )); | ||
680 | m.insertSeparator(); | ||
681 | m.insertItem( tr( "Rescan" ), this, SLOT( populateLocalView() )); | ||
682 | m.insertItem( tr( "Run Command" ), this, SLOT( runCommand() )); | ||
683 | m.insertItem( tr( "File Info" ), this, SLOT( fileStatus() )); | ||
684 | m.insertSeparator(); | ||
685 | m.insertItem( tr( "Delete" ), this, SLOT( localDelete() )); | ||
686 | m.insertSeparator(); | ||
687 | m.insertItem( tr( "Set Permissions" ), this, SLOT( filePerms() )); | ||
688 | if( QFile(QPEApplication::qpeDir()+"lib/libopie.so").exists() ) //bad hack for Sharp zaurus failings | ||
689 | m.insertItem( tr( "Properties" ), this, SLOT( doProperties() )); | ||
690 | m.setCheckable(TRUE); | ||
691 | if (!b) | ||
692 | m.setItemChecked(m.idAt(0),TRUE); | ||
693 | else | ||
694 | m.setItemChecked(m.idAt(0),FALSE); | ||
695 | if(Ir::supported()) | ||
696 | m.insertItem( tr( "Beam File" ), this, SLOT( doBeam() )); | ||
697 | m.exec( QCursor::pos() ); | ||
698 | } | ||
699 | } | ||
700 | |||
701 | void AdvancedFm::showRemoteMenu(QListViewItem * item) | ||
702 | { | ||
703 | if(item) { | ||
704 | QPopupMenu m; | ||
705 | m.insertItem( tr( "Show Hidden Files" ), this, SLOT( showRemoteHidden() )); | ||
706 | m.insertSeparator(); | ||
707 | if( /*item->text(0).right(1) == "/" ||*/ item->text(0).find("/",0,TRUE) !=-1) | ||
708 | m.insertItem( tr( "Change Directory" ), this, SLOT( doRemoteCd() )); | ||
709 | else | ||
710 | m.insertItem( tr( "Open / Execute" ), this, SLOT( runThis() )); | ||
711 | m.insertItem( tr( "Open as Text" ), this, SLOT( runText() )); | ||
712 | m.insertItem( tr( "Make Directory" ), this, SLOT( remoteMakDir() )); | ||
713 | m.insertItem( tr( "Make Symlink" ), this, SLOT( mkSym() )); | ||
714 | m.insertSeparator(); | ||
715 | m.insertItem( tr( "Rename" ), this, SLOT( remoteRename() )); | ||
716 | m.insertItem( tr( "Copy" ), this, SLOT( copy() )); | ||
717 | m.insertItem( tr( "Copy As" ), this, SLOT( copyAs() )); | ||
718 | m.insertItem( tr( "Move" ), this, SLOT( move() )); | ||
719 | m.insertSeparator(); | ||
720 | m.insertItem( tr( "Rescan" ), this, SLOT( populateRemoteView() )); | ||
721 | m.insertItem( tr( "Run Command" ), this, SLOT( runCommand() )); | ||
722 | m.insertItem( tr( "File Info" ), this, SLOT( fileStatus() )); | ||
723 | m.insertSeparator(); | ||
724 | m.insertItem( tr( "Delete" ), this, SLOT( remoteDelete() )); | ||
725 | m.insertSeparator(); | ||
726 | m.insertItem( tr( "Set Permissions" ), this, SLOT( filePerms() )); | ||
727 | if( QFile(QPEApplication::qpeDir()+"lib/libopie.so").exists() ) //bad hack for Sharp zaurus failings | ||
728 | m.insertItem( tr( "Properties" ), this, SLOT( doProperties() )); | ||
729 | m.setCheckable(TRUE); | ||
730 | if (!b) | ||
731 | m.setItemChecked(m.idAt(0),TRUE); | ||
732 | else | ||
733 | m.setItemChecked(m.idAt(0),FALSE); | ||
734 | if(Ir::supported()) | ||
735 | m.insertItem( tr( "Beam File" ), this, SLOT( doBeam() )); | ||
736 | m.exec( QCursor::pos() ); | ||
737 | } | ||
738 | } | ||
739 | |||
740 | void AdvancedFm::runThis() { | 672 | void AdvancedFm::runThis() { |
741 | // QFileInfo *fi; | 673 | // QFileInfo *fi; |
742 | QString fs; | 674 | QString fs; |
743 | if (TabWidget->currentPageIndex() == 0) { | 675 | if (TabWidget->currentPageIndex() == 0) { |
744 | QString curFile = Local_View->currentItem()->text(0); | 676 | QString curFile = Local_View->currentItem()->text(0); |
677 | if(curFile != "../") { | ||
745 | 678 | ||
746 | fs= getFileSystemType((const QString &) currentDir.canonicalPath()); | 679 | fs= getFileSystemType((const QString &) currentDir.canonicalPath()); |
747 | QFileInfo fileInfo( currentDir.canonicalPath()+"/"+curFile); | 680 | QFileInfo fileInfo( currentDir.canonicalPath()+"/"+curFile); |
@@ -763,9 +696,12 @@ QString fs; | |||
763 | nf.execute(); | 696 | nf.execute(); |
764 | } | 697 | } |
765 | } | 698 | } |
699 | } | ||
766 | // MimeType mt( curFile); | 700 | // MimeType mt( curFile); |
767 | } else { | 701 | } else { |
768 | QString curFile = Remote_View->currentItem()->text(0); | 702 | QString curFile = Remote_View->currentItem()->text(0); |
703 | if(curFile != "../") { | ||
704 | |||
769 | fs= getFileSystemType((const QString &) currentRemoteDir.canonicalPath()); | 705 | fs= getFileSystemType((const QString &) currentRemoteDir.canonicalPath()); |
770 | qDebug("Filesystemtype is "+fs); | 706 | qDebug("Filesystemtype is "+fs); |
771 | QFileInfo fileInfo( currentRemoteDir.canonicalPath()+"/"+curFile); | 707 | QFileInfo fileInfo( currentRemoteDir.canonicalPath()+"/"+curFile); |
@@ -785,6 +721,7 @@ QString fs; | |||
785 | nf.execute(); | 721 | nf.execute(); |
786 | } | 722 | } |
787 | } | 723 | } |
724 | } | ||
788 | // MimeType mt( curFile); | 725 | // MimeType mt( curFile); |
789 | } | 726 | } |
790 | } | 727 | } |
@@ -792,17 +729,21 @@ QString fs; | |||
792 | void AdvancedFm::runText() { | 729 | void AdvancedFm::runText() { |
793 | if (TabWidget->currentPageIndex() == 0) { | 730 | if (TabWidget->currentPageIndex() == 0) { |
794 | QString curFile = Local_View->currentItem()->text(0); | 731 | QString curFile = Local_View->currentItem()->text(0); |
732 | if(curFile != "../") { | ||
795 | curFile = currentDir.canonicalPath()+"/"+curFile; | 733 | curFile = currentDir.canonicalPath()+"/"+curFile; |
796 | QCopEnvelope e("QPE/Application/textedit", "setDocument(QString)" ); | 734 | QCopEnvelope e("QPE/Application/textedit", "setDocument(QString)" ); |
797 | e << curFile; | 735 | e << curFile; |
736 | } | ||
798 | } else { | 737 | } else { |
799 | QString curFile = Remote_View->currentItem()->text(0); | 738 | QString curFile = Remote_View->currentItem()->text(0); |
739 | if(curFile != "../") { | ||
800 | curFile = currentRemoteDir.canonicalPath()+"/"+curFile; | 740 | curFile = currentRemoteDir.canonicalPath()+"/"+curFile; |
801 | DocLnk nf(curFile); | 741 | DocLnk nf(curFile); |
802 | QCopEnvelope e("QPE/Application/textedit", "setDocument(QString)" ); | 742 | QCopEnvelope e("QPE/Application/textedit", "setDocument(QString)" ); |
803 | e << curFile; | 743 | e << curFile; |
804 | } | 744 | } |
805 | } | 745 | } |
746 | } | ||
806 | 747 | ||
807 | void AdvancedFm::localMakDir() | 748 | void AdvancedFm::localMakDir() |
808 | { | 749 | { |
@@ -831,6 +772,7 @@ void AdvancedFm::remoteMakDir() | |||
831 | void AdvancedFm::localDelete() | 772 | void AdvancedFm::localDelete() |
832 | { | 773 | { |
833 | QStringList curFileList = getPath(); | 774 | QStringList curFileList = getPath(); |
775 | if(curFileList.count() > 0) { | ||
834 | QString myFile; | 776 | QString myFile; |
835 | for ( QStringList::Iterator it = curFileList.begin(); it != curFileList.end(); ++it ) { | 777 | for ( QStringList::Iterator it = curFileList.begin(); it != curFileList.end(); ++it ) { |
836 | myFile = (*it); | 778 | myFile = (*it); |
@@ -875,10 +817,12 @@ void AdvancedFm::localDelete() | |||
875 | } | 817 | } |
876 | } | 818 | } |
877 | } | 819 | } |
820 | } | ||
878 | 821 | ||
879 | void AdvancedFm::remoteDelete() | 822 | void AdvancedFm::remoteDelete() |
880 | { | 823 | { |
881 | QStringList curFileList = getPath(); | 824 | QStringList curFileList = getPath(); |
825 | if( curFileList.count() > 0) { | ||
882 | QString myFile; | 826 | QString myFile; |
883 | 827 | ||
884 | for ( QStringList::Iterator it = curFileList.begin(); it != curFileList.end(); ++it ) { | 828 | for ( QStringList::Iterator it = curFileList.begin(); it != curFileList.end(); ++it ) { |
@@ -923,10 +867,13 @@ void AdvancedFm::remoteDelete() | |||
923 | } | 867 | } |
924 | } | 868 | } |
925 | } | 869 | } |
870 | } | ||
926 | 871 | ||
927 | void AdvancedFm::localRename() | 872 | void AdvancedFm::localRename() |
928 | { | 873 | { |
929 | QString curFile = Local_View->currentItem()->text(0); | 874 | QString curFile = Local_View->currentItem()->text(0); |
875 | qDebug("currentItem "+curFile); | ||
876 | if( curFile !="../") { | ||
930 | InputDialog *fileDlg; | 877 | InputDialog *fileDlg; |
931 | fileDlg = new InputDialog(this,tr("Rename"),TRUE, 0); | 878 | fileDlg = new InputDialog(this,tr("Rename"),TRUE, 0); |
932 | fileDlg->setInputText((const QString &)curFile); | 879 | fileDlg->setInputText((const QString &)curFile); |
@@ -939,10 +886,12 @@ void AdvancedFm::localRename() | |||
939 | } | 886 | } |
940 | populateLocalView(); | 887 | populateLocalView(); |
941 | } | 888 | } |
889 | } | ||
942 | 890 | ||
943 | void AdvancedFm::remoteRename() | 891 | void AdvancedFm::remoteRename() |
944 | { | 892 | { |
945 | QString curFile = Local_View->currentItem()->text(0); | 893 | QString curFile = Remote_View->currentItem()->text(0); |
894 | if( curFile !="../") { | ||
946 | InputDialog *fileDlg; | 895 | InputDialog *fileDlg; |
947 | fileDlg = new InputDialog(this,tr("Rename"),TRUE, 0); | 896 | fileDlg = new InputDialog(this,tr("Rename"),TRUE, 0); |
948 | fileDlg->setInputText((const QString &)curFile); | 897 | fileDlg->setInputText((const QString &)curFile); |
@@ -955,6 +904,7 @@ void AdvancedFm::remoteRename() | |||
955 | } | 904 | } |
956 | populateRemoteView(); | 905 | populateRemoteView(); |
957 | } | 906 | } |
907 | } | ||
958 | 908 | ||
959 | void AdvancedFm::switchToLocalTab() | 909 | void AdvancedFm::switchToLocalTab() |
960 | { | 910 | { |
@@ -1055,15 +1005,12 @@ void AdvancedFm::filePerms() { | |||
1055 | } else { | 1005 | } else { |
1056 | populateRemoteView(); | 1006 | populateRemoteView(); |
1057 | } | 1007 | } |
1058 | |||
1059 | |||
1060 | } | 1008 | } |
1061 | 1009 | ||
1062 | void AdvancedFm::doProperties() { | 1010 | void AdvancedFm::doProperties() { |
1063 | QStringList curFileList = getPath(); | 1011 | QStringList curFileList = getPath(); |
1064 | QString filePath; | 1012 | QString filePath; |
1065 | if (TabWidget->currentPageIndex() == 0) { | 1013 | if (TabWidget->currentPageIndex() == 0) { |
1066 | |||
1067 | filePath = currentDir.canonicalPath()+"/"; | 1014 | filePath = currentDir.canonicalPath()+"/"; |
1068 | } else { | 1015 | } else { |
1069 | filePath= currentRemoteDir.canonicalPath()+"/"; | 1016 | filePath= currentRemoteDir.canonicalPath()+"/"; |
@@ -1184,6 +1131,7 @@ void AdvancedFm::upDir() | |||
1184 | void AdvancedFm::copy() | 1131 | void AdvancedFm::copy() |
1185 | { | 1132 | { |
1186 | QStringList curFileList = getPath(); | 1133 | QStringList curFileList = getPath(); |
1134 | if( curFileList.count() > 0) { | ||
1187 | QString curFile; | 1135 | QString curFile; |
1188 | if (TabWidget->currentPageIndex() == 0) { | 1136 | if (TabWidget->currentPageIndex() == 0) { |
1189 | for ( QStringList::Iterator it = curFileList.begin(); it != curFileList.end(); ++it ) { | 1137 | for ( QStringList::Iterator it = curFileList.begin(); it != curFileList.end(); ++it ) { |
@@ -1228,10 +1176,12 @@ void AdvancedFm::copy() | |||
1228 | TabWidget->setCurrentPage(0); | 1176 | TabWidget->setCurrentPage(0); |
1229 | } | 1177 | } |
1230 | } | 1178 | } |
1179 | } | ||
1231 | 1180 | ||
1232 | void AdvancedFm::copyAs() | 1181 | void AdvancedFm::copyAs() |
1233 | { | 1182 | { |
1234 | QStringList curFileList = getPath(); | 1183 | QStringList curFileList = getPath(); |
1184 | if( curFileList.count() > 0) { | ||
1235 | QString curFile; | 1185 | QString curFile; |
1236 | InputDialog *fileDlg; | 1186 | InputDialog *fileDlg; |
1237 | fileDlg = new InputDialog(this,tr("Copy As"),TRUE, 0); | 1187 | fileDlg = new InputDialog(this,tr("Copy As"),TRUE, 0); |
@@ -1286,10 +1236,12 @@ void AdvancedFm::copyAs() | |||
1286 | } | 1236 | } |
1287 | } | 1237 | } |
1288 | } | 1238 | } |
1239 | } | ||
1289 | 1240 | ||
1290 | void AdvancedFm::move() { | 1241 | void AdvancedFm::move() { |
1291 | 1242 | ||
1292 | QStringList curFileList = getPath(); | 1243 | QStringList curFileList = getPath(); |
1244 | if( curFileList.count() > 0) { | ||
1293 | QString curFile; | 1245 | QString curFile; |
1294 | // qDebug(curFile); | 1246 | // qDebug(curFile); |
1295 | QString destFile; | 1247 | QString destFile; |
@@ -1342,6 +1294,7 @@ void AdvancedFm::move() { | |||
1342 | populateRemoteView(); | 1294 | populateRemoteView(); |
1343 | populateLocalView(); | 1295 | populateLocalView(); |
1344 | } | 1296 | } |
1297 | } | ||
1345 | 1298 | ||
1346 | bool AdvancedFm::copyFile( const QString & dest, const QString & src ) | 1299 | bool AdvancedFm::copyFile( const QString & dest, const QString & src ) |
1347 | { | 1300 | { |
@@ -1574,6 +1527,7 @@ void AdvancedFm::keyReleaseEvent( QKeyEvent *e) | |||
1574 | void AdvancedFm::mkSym() { | 1527 | void AdvancedFm::mkSym() { |
1575 | QString cmd; | 1528 | QString cmd; |
1576 | QStringList curFileList = getPath(); | 1529 | QStringList curFileList = getPath(); |
1530 | if( curFileList.count() > 0) { | ||
1577 | 1531 | ||
1578 | if (TabWidget->currentPageIndex() == 0) { | 1532 | if (TabWidget->currentPageIndex() == 0) { |
1579 | for ( QStringList::Iterator it = curFileList.begin(); it != curFileList.end(); ++it ) { | 1533 | for ( QStringList::Iterator it = curFileList.begin(); it != curFileList.end(); ++it ) { |
@@ -1604,6 +1558,7 @@ void AdvancedFm::mkSym() { | |||
1604 | TabWidget->setCurrentPage(0); | 1558 | TabWidget->setCurrentPage(0); |
1605 | } | 1559 | } |
1606 | } | 1560 | } |
1561 | } | ||
1607 | 1562 | ||
1608 | void AdvancedFm::QPEButtonPushed() { | 1563 | void AdvancedFm::QPEButtonPushed() { |
1609 | QString current = QPEApplication::qpeDir(); | 1564 | QString current = QPEApplication::qpeDir(); |
@@ -1668,6 +1623,7 @@ void AdvancedFm::doBeam() { | |||
1668 | } else { | 1623 | } else { |
1669 | 1624 | ||
1670 | QStringList curFileList = getPath(); | 1625 | QStringList curFileList = getPath(); |
1626 | if( curFileList.count() > 0) { | ||
1671 | 1627 | ||
1672 | if (TabWidget->currentPageIndex() == 0) { | 1628 | if (TabWidget->currentPageIndex() == 0) { |
1673 | for ( QStringList::Iterator it = curFileList.begin(); it != curFileList.end(); ++it ) { | 1629 | for ( QStringList::Iterator it = curFileList.begin(); it != curFileList.end(); ++it ) { |
@@ -1693,6 +1649,8 @@ void AdvancedFm::doBeam() { | |||
1693 | } | 1649 | } |
1694 | } | 1650 | } |
1695 | 1651 | ||
1652 | } | ||
1653 | |||
1696 | void AdvancedFm::fileBeamFinished( Ir *ir) { | 1654 | void AdvancedFm::fileBeamFinished( Ir *ir) { |
1697 | QMessageBox::message( tr("Advancedfm Beam out"), tr("Ir sent.") ,tr("Ok") ); | 1655 | QMessageBox::message( tr("Advancedfm Beam out"), tr("Ir sent.") ,tr("Ok") ); |
1698 | 1656 | ||
@@ -1708,3 +1666,88 @@ void AdvancedFm::fileBeamFinished( Ir *ir) { | |||
1708 | // QFileInfo fi(localFile); | 1666 | // QFileInfo fi(localFile); |
1709 | // } | 1667 | // } |
1710 | // } | 1668 | // } |
1669 | |||
1670 | void AdvancedFm::showFileMenu() { | ||
1671 | QString curApp; | ||
1672 | bool isLocalView = false; | ||
1673 | if (TabWidget->currentPageIndex() == 0) { | ||
1674 | isLocalView = TRUE; | ||
1675 | curApp = Local_View->currentItem()->text(0); | ||
1676 | } else { | ||
1677 | curApp = Remote_View->currentItem()->text(0); | ||
1678 | } | ||
1679 | |||
1680 | MimeType mt( curApp ); | ||
1681 | const AppLnk* app = mt.application(); | ||
1682 | QFile fi(curApp); | ||
1683 | |||
1684 | QPopupMenu m; | ||
1685 | m.insertItem( tr( "Show Hidden Files" ), this, SLOT( showHidden() )); | ||
1686 | m.insertSeparator(); | ||
1687 | if ( QFileInfo(fi).isDir() ) { | ||
1688 | m.insertItem( tr( "Change Directory" ), this, SLOT( doLocalCd() )); | ||
1689 | } else { | ||
1690 | |||
1691 | if ( app ) | ||
1692 | m.insertItem( app->pixmap(), tr( "Open in " + app->name() ), this, SLOT( run() ) ); | ||
1693 | else if( QFileInfo(fi).isExecutable() ) | ||
1694 | m.insertItem( tr( "Execute" ), this, SLOT( run() ) ); | ||
1695 | |||
1696 | m.insertItem( /*Resource::loadPixmap( "txt" ),*/ tr( "Open as text" ),this, SLOT( runText() ) ); | ||
1697 | } | ||
1698 | m.insertSeparator(); | ||
1699 | |||
1700 | |||
1701 | if(isLocalView) | ||
1702 | m.insertItem( tr( "Make Directory" ), this, SLOT( localMakDir() )); | ||
1703 | else | ||
1704 | m.insertItem( tr( "Make Directory" ), this, SLOT( remoteMakDir() )); | ||
1705 | |||
1706 | m.insertItem( tr( "Make Symlink" ), this, SLOT( mkSym() )); | ||
1707 | m.insertSeparator(); | ||
1708 | |||
1709 | if(isLocalView) | ||
1710 | m.insertItem( tr( "Rename" ), this, SLOT( localRename() )); | ||
1711 | else | ||
1712 | m.insertItem( tr( "Rename" ), this, SLOT( remoteRename() )); | ||
1713 | |||
1714 | m.insertItem( tr( "Copy" ), this, SLOT( copy() )); | ||
1715 | m.insertItem( tr( "Copy As" ), this, SLOT( copyAs() )); | ||
1716 | m.insertItem( tr( "Move" ), this, SLOT( move() )); | ||
1717 | m.insertSeparator(); | ||
1718 | |||
1719 | if(isLocalView) | ||
1720 | m.insertItem( tr( "Rescan" ), this, SLOT( populateLocalView() )); | ||
1721 | else | ||
1722 | m.insertItem( tr( "Rescan" ), this, SLOT( populateRemoteView() )); | ||
1723 | |||
1724 | m.insertItem( tr( "Run Command" ), this, SLOT( runCommand() )); | ||
1725 | m.insertItem( tr( "File Info" ), this, SLOT( fileStatus() )); | ||
1726 | m.insertSeparator(); | ||
1727 | |||
1728 | if(isLocalView) | ||
1729 | m.insertItem( tr( "Delete" ), this, SLOT( localDelete() )); | ||
1730 | else | ||
1731 | m.insertItem( tr( "Delete" ), this, SLOT( remoteDelete() )); | ||
1732 | |||
1733 | m.insertSeparator(); | ||
1734 | m.insertItem( tr( "Set Permissions" ), this, SLOT( filePerms() )); | ||
1735 | if( QFile(QPEApplication::qpeDir()+"lib/libopie.so").exists() ) //bad hack for Sharp zaurus failings | ||
1736 | m.insertItem( tr( "Properties" ), this, SLOT( doProperties() )); | ||
1737 | m.setCheckable(TRUE); | ||
1738 | if (!b) | ||
1739 | m.setItemChecked(m.idAt(0),TRUE); | ||
1740 | else | ||
1741 | m.setItemChecked(m.idAt(0),FALSE); | ||
1742 | if(Ir::supported()) | ||
1743 | m.insertItem( tr( "Beam File" ), this, SLOT( doBeam() )); | ||
1744 | m.exec( QCursor::pos() ); | ||
1745 | } | ||
1746 | |||
1747 | |||
1748 | void AdvancedFm::cancelMenuTimer() | ||
1749 | { | ||
1750 | qDebug("cancel menu timer"); | ||
1751 | if( menuTimer.isActive() ) | ||
1752 | menuTimer.stop(); | ||
1753 | } | ||
diff --git a/noncore/apps/advancedfm/advancedfm.h b/noncore/apps/advancedfm/advancedfm.h index 5817fca..0cf94c6 100644 --- a/noncore/apps/advancedfm/advancedfm.h +++ b/noncore/apps/advancedfm/advancedfm.h | |||
@@ -12,14 +12,16 @@ | |||
12 | #ifndef ADVANCEDFM_H | 12 | #ifndef ADVANCEDFM_H |
13 | #define ADVANCEDFM_H | 13 | #define ADVANCEDFM_H |
14 | 14 | ||
15 | #include <qpe/ir.h> | ||
16 | |||
15 | #include <qvariant.h> | 17 | #include <qvariant.h> |
16 | #include <qdialog.h> | 18 | #include <qdialog.h> |
17 | #include <qmainwindow.h> | 19 | #include <qmainwindow.h> |
20 | #include <qstringlist.h> | ||
18 | #include <qdir.h> | 21 | #include <qdir.h> |
19 | #include <qstring.h> | 22 | #include <qstring.h> |
20 | #include <qpoint.h> | 23 | #include <qpoint.h> |
21 | #include <qstringlist.h> | 24 | #include <qtimer.h> |
22 | #include <qpe/ir.h> | ||
23 | 25 | ||
24 | class QVBoxLayout; | 26 | class QVBoxLayout; |
25 | class QHBoxLayout; | 27 | class QHBoxLayout; |
@@ -39,6 +41,7 @@ class QFile; | |||
39 | class QListViewItem; | 41 | class QListViewItem; |
40 | class QLineEdit; | 42 | class QLineEdit; |
41 | class QPushButton; | 43 | class QPushButton; |
44 | class Ir; | ||
42 | 45 | ||
43 | class AdvancedFm : public QMainWindow | 46 | class AdvancedFm : public QMainWindow |
44 | { | 47 | { |
@@ -62,8 +65,6 @@ public: | |||
62 | QStringList fileSystemTypeList, fsList; | 65 | QStringList fileSystemTypeList, fsList; |
63 | int currentServerConfig; | 66 | int currentServerConfig; |
64 | protected slots: | 67 | protected slots: |
65 | void showLocalMenu( QListViewItem *); | ||
66 | void showRemoteMenu( QListViewItem *); | ||
67 | void doLocalCd(); | 68 | void doLocalCd(); |
68 | void doRemoteCd(); | 69 | void doRemoteCd(); |
69 | // void copy(); | 70 | // void copy(); |
@@ -104,11 +105,14 @@ protected slots: | |||
104 | protected: | 105 | protected: |
105 | QGridLayout *tabLayout, *tabLayout_2, *tabLayout_3; | 106 | QGridLayout *tabLayout, *tabLayout_2, *tabLayout_3; |
106 | QStringList remoteDirPathStringList, localDirPathStringList; | 107 | QStringList remoteDirPathStringList, localDirPathStringList; |
108 | |||
107 | void keyReleaseEvent( QKeyEvent *); | 109 | void keyReleaseEvent( QKeyEvent *); |
108 | QString getFileSystemType(const QString &); | 110 | QString getFileSystemType(const QString &); |
109 | void parsetab(const QString &fileName); | 111 | void parsetab(const QString &fileName); |
110 | 112 | ||
111 | protected slots: | 113 | protected slots: |
114 | void showFileMenu(); | ||
115 | void cancelMenuTimer(); | ||
112 | void homeButtonPushed(); | 116 | void homeButtonPushed(); |
113 | void docButtonPushed(); | 117 | void docButtonPushed(); |
114 | void SDButtonPushed(); | 118 | void SDButtonPushed(); |
@@ -125,7 +129,9 @@ protected slots: | |||
125 | void fileStatus(); | 129 | void fileStatus(); |
126 | void doAbout(); | 130 | void doAbout(); |
127 | void doBeam(); | 131 | void doBeam(); |
128 | void fileBeamFinished( Ir *ir); | 132 | void fileBeamFinished( Ir *); |
133 | private: | ||
134 | QTimer menuTimer; | ||
129 | }; | 135 | }; |
130 | 136 | ||
131 | #endif // ADVANCEDFM_H | 137 | #endif // ADVANCEDFM_H |