summaryrefslogtreecommitdiff
path: root/core/apps/textedit
authorllornkcor <llornkcor>2003-02-18 19:09:14 (UTC)
committer llornkcor <llornkcor>2003-02-18 19:09:14 (UTC)
commit4dd3080c36c96c58564a29f1b3d2cf21bfb1eae2 (patch) (side-by-side diff)
treefbc89396011e0e9a0dc04fcd1454ee670d6fcae3 /core/apps/textedit
parent50f0a50a14f87960cf9492d01aeed5a56a6dca06 (diff)
downloadopie-4dd3080c36c96c58564a29f1b3d2cf21bfb1eae2.zip
opie-4dd3080c36c96c58564a29f1b3d2cf21bfb1eae2.tar.gz
opie-4dd3080c36c96c58564a29f1b3d2cf21bfb1eae2.tar.bz2
autosave feature. will save to ~/textedit.tmp is no filename has been set. moved stuff from public methods
Diffstat (limited to 'core/apps/textedit') (more/less context) (show whitespace changes)
-rw-r--r--core/apps/textedit/textedit.cpp127
-rw-r--r--core/apps/textedit/textedit.h16
2 files changed, 136 insertions, 7 deletions
diff --git a/core/apps/textedit/textedit.cpp b/core/apps/textedit/textedit.cpp
index e931f01..1e8ce7f 100644
--- a/core/apps/textedit/textedit.cpp
+++ b/core/apps/textedit/textedit.cpp
@@ -40,24 +40,26 @@
#include <qfileinfo.h>
#include <qlineedit.h>
#include <qmessagebox.h>
#include <qobjectlist.h>
#include <qpopupmenu.h>
#include <qspinbox.h>
#include <qtoolbutton.h>
#include <qwidgetstack.h>
#include <qcheckbox.h>
#include <qcombo.h>
#include <qlayout.h>
#include <qapplication.h>
+#include <qtimer.h>
+#include <qdir.h>
#include <unistd.h>
#include <sys/stat.h>
#include <stdlib.h> //getenv
/* XPM */
static char * filesave_xpm[] = {
"16 16 78 1",
" c None",
". c #343434",
"+ c #A0A0A0",
"@ c #565656",
@@ -401,24 +403,31 @@ TextEdit::TextEdit( QWidget *parent, const char *name, WFlags f )
connect( filePermAction, SIGNAL( toggled(bool) ),
this, SLOT( doFilePerms(bool) ) );
filePermAction->setToggleAction(true);
filePermAction->addTo( advancedMenu);
searchBarAction = new QAction( tr("Search Bar Open"),
QString::null, 0, this, 0 );
connect( searchBarAction, SIGNAL( toggled(bool) ),
this, SLOT( setSearchBar(bool) ) );
searchBarAction->setToggleAction(true);
searchBarAction->addTo( advancedMenu);
+ nAutoSave = new QAction( tr("Auto Save 5 min."),
+ QString::null, 0, this, 0 );
+ connect( nAutoSave, SIGNAL( toggled(bool) ),
+ this, SLOT( doTimer(bool) ) );
+ nAutoSave->setToggleAction(true);
+ nAutoSave->addTo( advancedMenu);
+
font->insertSeparator();
font->insertItem(tr("About"), this, SLOT( doAbout()) );
mb->insertItem( tr( "File" ), file );
mb->insertItem( tr( "Edit" ), edit );
mb->insertItem( tr( "View" ), font );
searchBar = new QPEToolBar(this);
addToolBar( searchBar, "Search", QMainWindow::Top, true );
@@ -469,35 +478,42 @@ TextEdit::TextEdit( QWidget *parent, const char *name, WFlags f )
defaultFont = QFont ( family, size, weight, italic );
editor-> setFont ( defaultFont );
// updateCaption();
cfg.setGroup ( "View" );
promptExit = cfg.readBoolEntry ( "PromptExit", false );
openDesktop = cfg.readBoolEntry ( "OpenDesktop", true );
filePerms = cfg.readBoolEntry ( "FilePermissions", false );
useSearchBar = cfg.readBoolEntry ( "SearchBar", false );
startWithNew = cfg.readBoolEntry ( "startNew", true);
+ featureAutoSave = cfg.readBoolEntry( "autosave", false);
if(useSearchBar) searchBarAction->setOn(true);
if(promptExit ) nAdvanced->setOn( true );
if(openDesktop) desktopAction->setOn( true );
if(filePerms) filePermAction->setOn( true );
if(startWithNew) nStart->setOn( true );
+ if(featureAutoSave) nAutoSave->setOn(true);
+
+// {
+// doTimer(true);
+// }
bool wrap = cfg. readBoolEntry ( "Wrap", true );
wa-> setOn ( wrap );
setWordWrap ( wrap );
+/////////////////
if( qApp->argc() > 1) {
currentFileName=qApp->argv()[1];
QFileInfo fi(currentFileName);
if(fi.baseName().left(1) == "") {
openDotFile(currentFileName);
} else {
openFile(currentFileName);
}
} else {
edited1=false;
@@ -505,27 +521,48 @@ TextEdit::TextEdit( QWidget *parent, const char *name, WFlags f )
}
viewSelection = cfg.readNumEntry( "FileView", 0 );
}
TextEdit::~TextEdit() {
qWarning("textedit d'tor");
delete editor;
}
void TextEdit::closeEvent(QCloseEvent *) {
if( edited1 && promptExit)
+ {
+ switch( savePrompt() )
+ {
+ case 1:
+ {
saveAs();
qApp->quit();
}
+ break;
+
+ case 2:
+ {
+ qApp->quit();
+ }
+ break;
+
+ case -1:
+ break;
+ };
+ }
+ else
+ qApp->quit();
+
+}
void TextEdit::cleanUp() {
Config cfg ( "TextEdit" );
cfg. setGroup ( "Font" );
QFont f = editor->font();
cfg.writeEntry ( "Family", f. family ( ));
cfg.writeEntry ( "Size", f. pointSize ( ));
cfg.writeEntry ( "Weight", f. weight ( ));
cfg.writeEntry ( "Italic", f. italic ( ));
cfg.setGroup ( "View" );
@@ -805,44 +842,46 @@ void TextEdit::openFile( const DocLnk &f ) {
}
// fileNew();
if ( doc )
delete doc;
doc = new DocLnk(f);
editor->setText(txt);
editor->setEdited( false);
edited1=false;
edited=false;
doc->setName(currentFileName);
updateCaption();
+ setTimer();
}
void TextEdit::showEditTools() {
menu->show();
editBar->show();
if(!useSearchBar)
searchBar->hide();
else
searchBar->show();
setWState (WState_Reserved1 );
}
/*!
unprompted save */
bool TextEdit::save() {
qDebug("saveAsFile " + currentFileName);
if(currentFileName.isEmpty()) {
saveAs();
return false;
}
+
QString file = doc->file();
qDebug("saver file "+file);
QString name= doc->name();
qDebug("File named "+name);
QString rt = editor->text();
if( !rt.isEmpty() ) {
if(name.isEmpty()) {
saveAs();
} else {
currentFileName= name ;
qDebug("saveFile "+currentFileName);
@@ -877,24 +916,25 @@ bool TextEdit::save() {
chmod( file.latin1(), mode);
}
return true;
}
return false;
}
/*!
prompted save */
bool TextEdit::saveAs() {
+
if(caption() == tr("Text Editor"))
return false;
qDebug("saveAsFile " + currentFileName);
// case of nothing to save...
// if ( !doc && !currentFileName.isEmpty()) {
// //|| !bFromDocView)
// qDebug("no doc");
// return true;
// }
// if ( !editor->edited() ) {
// delete doc;
// doc = 0;
@@ -936,28 +976,33 @@ bool TextEdit::saveAs() {
map.insert(tr("All"), QStringList() );
QStringList text;
text << "text/*";
map.insert(tr("Text"), text );
text << "*";
map.insert(tr("All"), text );
QFileInfo cuFi( currentFileName);
QString filee = cuFi.fileName();
QString dire = cuFi.dirPath();
if(dire==".")
dire = QPEApplication::documentDir();
- QString str = OFileDialog::getSaveFileName( 2,
+ QString str;
+ if( !featureAutoSave)
+ {
+ str = OFileDialog::getSaveFileName( 2,
dire,
filee, map);
-
+ }
+ else
+ str=currentFileName;
if(!str.isEmpty()) {
QString fileNm=str;
qDebug("saving filename "+fileNm);
QFileInfo fi(fileNm);
currentFileName=fi.fileName();
if(doc)
// QString file = doc->file();
// doc->removeFiles();
delete doc;
DocLnk nf;
nf.setType("text/plain");
@@ -1131,12 +1176,90 @@ void TextEdit::doFilePerms(bool b) {
cfg.setGroup ( "View" );
cfg.writeEntry ( "FilePermissions", b);
}
void TextEdit::editPasteTimeDate() {
#ifndef QT_NO_CLIPBOARD
QClipboard *cb = QApplication::clipboard();
QDateTime dt = QDateTime::currentDateTime();
cb->setText( dt.toString());
editor->paste();
#endif
}
+
+int TextEdit::savePrompt()
+{
+ switch( QMessageBox::information( 0, (tr("Textedit")),
+ (tr("Textedit detected\n"
+ "you have unsaved changes\n"
+ "Go ahead and save?\n")),
+ (tr("Save")), (tr("Don't Save")), (tr("&Cancel")), 2, 2 ) )
+ {
+ case 0:
+ {
+ return 1;
+ }
+ break;
+
+ case 1:
+ {
+ return 2;
+ }
+ break;
+
+ case 2:
+ {
+ return -1;
+ }
+ break;
+ };
+
+ return 0;
+}
+
+void TextEdit::timerCrank()
+{
+ if(featureAutoSave)
+ {
+ if( edited1 )
+ {
+ if(currentFileName.isEmpty())
+ {
+ currentFileName = QDir::homeDirPath()+"/textedit.tmp";
+ saveAs();
+ }
+ else
+ {
+ qDebug("autosave");
+ save();
+ }
+ setTimer();
+ }
+ }
+}
+
+void TextEdit::doTimer(bool b)
+{
+ Config cfg("TextEdit");
+ cfg.setGroup ( "View" );
+ cfg.writeEntry ( "autosave", b);
+ featureAutoSave = b;
+ nAutoSave->setOn(b);
+ if(b)
+ {
+ qDebug("doTimer true");
+ setTimer();
+ }
+ else
+ qDebug("doTimer false");
+}
+
+void TextEdit::setTimer()
+{
+if(featureAutoSave)
+ {
+ qDebug("setting autosave");
+ QTimer *timer = new QTimer(this );
+ connect( timer, SIGNAL(timeout()), this, SLOT(timerCrank()) );
+ timer->start( 30000/*0*/, true); //5 minutes
+ }
+}
diff --git a/core/apps/textedit/textedit.h b/core/apps/textedit/textedit.h
index 9f16ebf..643ea68 100644
--- a/core/apps/textedit/textedit.h
+++ b/core/apps/textedit/textedit.h
@@ -38,45 +38,51 @@
#include <qmap.h>
class QAction;
class QWidgetStack;
class QToolButton;
class QPopupMenu;
class QToolBar;
class QLineEdit;
class QAction;
class FileSelector;
class QpeEditor;
class QPopupMenu;
+class QTimer;
class TextEdit : public QMainWindow
{
Q_OBJECT
public:
TextEdit( QWidget *parent = 0, const char *name = 0, WFlags f = 0 );
~TextEdit();
+protected:
QPopupMenu *font;
- QAction *nStart, *nFileDlgOpt, *nAdvanced, *desktopAction, *filePermAction, *searchBarAction;
+ QAction *nStart, *nFileDlgOpt, *nAdvanced, *desktopAction, *filePermAction, *searchBarAction, *nAutoSave;
bool edited, edited1;
void openFile( const QString & );
QCopChannel * channel;
-public slots:
- void editorChanged();
-void receive(const QCString&, const QByteArray&);
-protected:
+
+ bool featureAutoSave;
void closeEvent( QCloseEvent *e );
void doSearchBar();
+ int savePrompt();
+ void setTimer();
private slots:
+ void editorChanged();
+ void receive(const QCString&, const QByteArray&);
+ void timerCrank();
+ void doTimer(bool);
void editPasteTimeDate();
void doPrompt(bool);
void doDesktop(bool);
void doFilePerms(bool);
void doAbout();
void setDocument(const QString&);
void changeFont();
void fileNew();
void fileRevert();
void fileOpen();
void changeStartConfig(bool);
bool save();