summaryrefslogtreecommitdiffabout
Unidiff
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--korganizer/journalentry.cpp9
1 files changed, 2 insertions, 7 deletions
diff --git a/korganizer/journalentry.cpp b/korganizer/journalentry.cpp
index 902e96f..b8a4cf2 100644
--- a/korganizer/journalentry.cpp
+++ b/korganizer/journalentry.cpp
@@ -61,98 +61,98 @@ JournalEntry::JournalEntry(Calendar *calendar,QWidget *parent) :
61{ 61{
62 62
63 int fac = 5; 63 int fac = 5;
64 heiHint = QApplication::desktop()->height(); 64 heiHint = QApplication::desktop()->height();
65 if ( heiHint > 800 ) 65 if ( heiHint > 800 )
66 fac += 2; 66 fac += 2;
67 heiHint = heiHint / fac; 67 heiHint = heiHint / fac;
68 68
69 showOnlyMode = false; 69 showOnlyMode = false;
70 mCalendar = calendar; 70 mCalendar = calendar;
71 mJournal = 0; 71 mJournal = 0;
72 visibleMode = true; 72 visibleMode = true;
73 QHBox * vb = new QHBox ( this ); 73 QHBox * vb = new QHBox ( this );
74 QPixmap iconp; 74 QPixmap iconp;
75 vb->setMargin ( KDialog::marginHint()-1 ); 75 vb->setMargin ( KDialog::marginHint()-1 );
76 QPushButton * toggleJournal = new QPushButton( vb ); 76 QPushButton * toggleJournal = new QPushButton( vb );
77 iconp = SmallIcon("1updownarrow"); 77 iconp = SmallIcon("1updownarrow");
78 toggleJournal->setPixmap (iconp ) ; 78 toggleJournal->setPixmap (iconp ) ;
79 vb->setStretchFactor (new QLabel(" "+i18n("Title: "),vb),1); 79 vb->setStretchFactor (new QLabel(" "+i18n("Title: "),vb),1);
80 vb->setStretchFactor( toggleJournal, 1 ); 80 vb->setStretchFactor( toggleJournal, 1 );
81 mTitle = new KOLocationBox(TRUE, vb, 30); 81 mTitle = new KOLocationBox(TRUE, vb, 30);
82 mTitle->setSizePolicy( QSizePolicy( QSizePolicy::MinimumExpanding ,QSizePolicy::Fixed ,FALSE) ); 82 mTitle->setSizePolicy( QSizePolicy( QSizePolicy::MinimumExpanding ,QSizePolicy::Fixed ,FALSE) );
83 mCalendarBox = new QComboBox(vb); 83 mCalendarBox = new QComboBox(vb);
84 mCalendarBox->setSizePolicy( QSizePolicy( QSizePolicy::MinimumExpanding ,QSizePolicy::Fixed ,FALSE) ); 84 mCalendarBox->setSizePolicy( QSizePolicy( QSizePolicy::MinimumExpanding ,QSizePolicy::Fixed ,FALSE) );
85#ifndef DESKTOP_VERSION 85#ifndef DESKTOP_VERSION
86 mTitle->setSizeLimit( 8 ); 86 mTitle->setSizeLimit( 8 );
87 mCalendarBox->setSizeLimit( 8 ); 87 mCalendarBox->setSizeLimit( 8 );
88#endif 88#endif
89 vb->setStretchFactor ( mTitle, 8 ); 89 vb->setStretchFactor ( mTitle, 8 );
90 vb->setStretchFactor ( mCalendarBox, 3 ); 90 vb->setStretchFactor ( mCalendarBox, 3 );
91 //mTitleLabel->setMargin(0); 91 //mTitleLabel->setMargin(0);
92 //mTitleLabel->setAlignment(AlignCenter); 92 //mTitleLabel->setAlignment(AlignCenter);
93 QPushButton * loadTemplate = new QPushButton( vb ); 93 QPushButton * loadTemplate = new QPushButton( vb );
94 QPushButton * saveTemplate = new QPushButton( vb ); 94 QPushButton * saveTemplate = new QPushButton( vb );
95 if ( QApplication::desktop()->width() < 321 ) 95 if ( QApplication::desktop()->width() < 321 )
96 iconp = SmallIcon("fileexport16"); 96 iconp = SmallIcon("fileexport16");
97 else 97 else
98 iconp = SmallIcon("fileexport"); 98 iconp = SmallIcon("fileexport");
99 saveTemplate->setPixmap (iconp ) ; 99 saveTemplate->setPixmap (iconp ) ;
100 int size = saveTemplate->sizeHint().height(); 100 int size = saveTemplate->sizeHint().height();
101 if ( QApplication::desktop()->width() < 321 ) 101 if ( QApplication::desktop()->width() < 321 )
102 iconp = SmallIcon("fileimport16"); 102 iconp = SmallIcon("fileimport16");
103 else 103 else
104 iconp = SmallIcon("fileimport"); 104 iconp = SmallIcon("fileimport");
105 loadTemplate->setPixmap (iconp ) ; 105 loadTemplate->setPixmap (iconp ) ;
106 loadTemplate->setFixedSize( size, size ); 106 loadTemplate->setFixedSize( size, size );
107 saveTemplate->setFixedSize( size, size ); 107 saveTemplate->setFixedSize( size, size );
108 toggleJournal->setFixedSize( size , size ); 108 toggleJournal->setFixedSize( size , size );
109 mTitle->setMaximumHeight( size+4); 109 mTitle->setFixedHeight( size+4);
110 mCalendarBox->setMaximumHeight( size+4); 110 mCalendarBox->setFixedHeight( size+4);
111 mEditor = new KTextEdit(this); 111 mEditor = new KTextEdit(this);
112#ifndef DESKTOP_VERSION 112#ifndef DESKTOP_VERSION
113 QPEApplication::setStylusOperation( mEditor, QPEApplication::RightOnHold ); 113 QPEApplication::setStylusOperation( mEditor, QPEApplication::RightOnHold );
114#endif 114#endif
115 mEditor->setWordWrap( KTextEdit::WidgetWidth ); 115 mEditor->setWordWrap( KTextEdit::WidgetWidth );
116 QBoxLayout *topLayout = new QVBoxLayout(this); 116 QBoxLayout *topLayout = new QVBoxLayout(this);
117 topLayout->addWidget(vb); 117 topLayout->addWidget(vb);
118 topLayout->addWidget(mEditor); 118 topLayout->addWidget(mEditor);
119 mEditor->installEventFilter(this); 119 mEditor->installEventFilter(this);
120 connect( saveTemplate, SIGNAL( clicked() ), this , SLOT( slotSaveTemplate() ) ); 120 connect( saveTemplate, SIGNAL( clicked() ), this , SLOT( slotSaveTemplate() ) );
121 connect( loadTemplate, SIGNAL( clicked() ), this , SLOT( slotLoadTemplate() ) ); 121 connect( loadTemplate, SIGNAL( clicked() ), this , SLOT( slotLoadTemplate() ) );
122 connect( toggleJournal, SIGNAL( clicked() ), this , SLOT( toggleShowJournal() ) ); 122 connect( toggleJournal, SIGNAL( clicked() ), this , SLOT( toggleShowJournal() ) );
123 mTitle->load( KOLocationBox::SUMMARYJOURNAL ); 123 mTitle->load( KOLocationBox::SUMMARYJOURNAL );
124 mTitle->lineEdit ()->setText(""); 124 mTitle->lineEdit ()->setText("");
125} 125}
126 126
127JournalEntry::~JournalEntry() 127JournalEntry::~JournalEntry()
128{ 128{
129 //qDebug("JournalEntry::~JournalEntry() "); 129 //qDebug("JournalEntry::~JournalEntry() ");
130} 130}
131QSize JournalEntry::sizeHint() const 131QSize JournalEntry::sizeHint() const
132{ 132{
133 return QSize ( 240, heiHint ); 133 return QSize ( 240, heiHint );
134} 134}
135void JournalEntry::slotSaveTemplate() 135void JournalEntry::slotSaveTemplate()
136{ 136{
137 QString fileName =locateLocal( "templates", "journals" ); 137 QString fileName =locateLocal( "templates", "journals" );
138 QDir t_dir; 138 QDir t_dir;
139 if ( !t_dir.exists(fileName) ) 139 if ( !t_dir.exists(fileName) )
140 t_dir.mkdir ( fileName ); 140 t_dir.mkdir ( fileName );
141 fileName += "/journal"; 141 fileName += "/journal";
142 fileName = KFileDialog::getSaveFileName( fileName , i18n("Save as Journal template"), this ); 142 fileName = KFileDialog::getSaveFileName( fileName , i18n("Save as Journal template"), this );
143 if ( fileName.length() == 0 ) 143 if ( fileName.length() == 0 )
144 return; 144 return;
145 145
146 QFile fileIn( fileName ); 146 QFile fileIn( fileName );
147 if (!fileIn.open( IO_WriteOnly ) ) { 147 if (!fileIn.open( IO_WriteOnly ) ) {
148 KMessageBox::error( this, i18n("Error saving template file\n '%1'.") 148 KMessageBox::error( this, i18n("Error saving template file\n '%1'.")
149 .arg( fileName ) ); 149 .arg( fileName ) );
150 return; 150 return;
151 } 151 }
152 // QString text; 152 // QString text;
153 QTextStream tsIn( &fileIn ); 153 QTextStream tsIn( &fileIn );
154 tsIn.setCodec( QTextCodec::codecForName("utf8") ); 154 tsIn.setCodec( QTextCodec::codecForName("utf8") );
155 tsIn << mEditor->text(); 155 tsIn << mEditor->text();
156 fileIn.close(); 156 fileIn.close();
157} 157}
158void JournalEntry::slotLoadTemplate() 158void JournalEntry::slotLoadTemplate()
@@ -164,101 +164,96 @@ void JournalEntry::slotLoadTemplate()
164 fileName += "/journal"; 164 fileName += "/journal";
165 fileName = KFileDialog::getOpenFileName( fileName , i18n("Insert Journal template"), this ); 165 fileName = KFileDialog::getOpenFileName( fileName , i18n("Insert Journal template"), this );
166 if ( fileName.length() == 0 ) 166 if ( fileName.length() == 0 )
167 return; 167 return;
168 QFile fileIn( fileName ); 168 QFile fileIn( fileName );
169 if (!fileIn.open( IO_ReadOnly ) ) { 169 if (!fileIn.open( IO_ReadOnly ) ) {
170 KMessageBox::error( this, i18n("Error loading template file\n '%1'.") 170 KMessageBox::error( this, i18n("Error loading template file\n '%1'.")
171 .arg( fileName ) ); 171 .arg( fileName ) );
172 return; 172 return;
173 } 173 }
174 QTextStream tsIn( &fileIn ); 174 QTextStream tsIn( &fileIn );
175 tsIn.setCodec( QTextCodec::codecForName("utf8") ); 175 tsIn.setCodec( QTextCodec::codecForName("utf8") );
176 QString text = tsIn.read(); 176 QString text = tsIn.read();
177 fileIn.close(); 177 fileIn.close();
178 int line, col; 178 int line, col;
179 mEditor->getCursorPosition (& line, & col ); 179 mEditor->getCursorPosition (& line, & col );
180 mEditor-> insertAt ( text, line, col, true ); 180 mEditor-> insertAt ( text, line, col, true );
181 //mEditor->setIgnoreMark( true ); 181 //mEditor->setIgnoreMark( true );
182} 182}
183void JournalEntry::setDate(const QDate &date) 183void JournalEntry::setDate(const QDate &date)
184{ 184{
185 showOnlyMode = false; 185 showOnlyMode = false;
186 writeJournal(); 186 writeJournal();
187 mDate = date; 187 mDate = date;
188 fillCalendar( mCalendar->defaultCalendar() ); 188 fillCalendar( mCalendar->defaultCalendar() );
189} 189}
190void JournalEntry::fillCalendar( int setToID ) 190void JournalEntry::fillCalendar( int setToID )
191{ 191{
192 mCalendarBox->clear(); 192 mCalendarBox->clear();
193 KopiCalendarFile * kkf = KOPrefs::instance()->mCalendars.first(); 193 KopiCalendarFile * kkf = KOPrefs::instance()->mCalendars.first();
194 int std = 0; 194 int std = 0;
195 int count = 0; 195 int count = 0;
196 while ( kkf ) { 196 while ( kkf ) {
197 if ( (!kkf->mErrorOnLoad &&! kkf->isReadOnly) || setToID == kkf->mCalNumber ) { 197 if ( (!kkf->mErrorOnLoad &&! kkf->isReadOnly) || setToID == kkf->mCalNumber ) {
198 if ( setToID ) { 198 if ( setToID ) {
199 if ( kkf->mCalNumber == setToID ) 199 if ( kkf->mCalNumber == setToID )
200 std = count; 200 std = count;
201 } else { 201 } else {
202 if ( kkf->isStandard ) { 202 if ( kkf->isStandard ) {
203 std = count; 203 std = count;
204 } 204 }
205 } 205 }
206 ++count; 206 ++count;
207 mCalendarBox->insertItem( kkf->mName ); 207 mCalendarBox->insertItem( kkf->mName );
208 } 208 }
209 kkf = KOPrefs::instance()->mCalendars.next(); 209 kkf = KOPrefs::instance()->mCalendars.next();
210 } 210 }
211 mCalendarBox->setCurrentItem( std ); 211 mCalendarBox->setCurrentItem( std );
212 if ( KOPrefs::instance()->mCalendars.count() == 1 )
213 mCalendarBox->hide();
214 else {
215 mCalendarBox->show();
216 }
217} 212}
218 213
219void JournalEntry::toggleShowJournal() 214void JournalEntry::toggleShowJournal()
220{ 215{
221 if (!mEditor->text().isEmpty() || !mTitle->currentText ().isEmpty()) 216 if (!mEditor->text().isEmpty() || !mTitle->currentText ().isEmpty())
222 flushEntry(); 217 flushEntry();
223 if ( showOnlyMode ) 218 if ( showOnlyMode )
224 emit showJournalOnly( 0 ); 219 emit showJournalOnly( 0 );
225 else { 220 else {
226 // we have to protect mJournal from deleting if mJournal has empty text 221 // we have to protect mJournal from deleting if mJournal has empty text
227 visibleMode = false; // set to true via :setShowOnly() 222 visibleMode = false; // set to true via :setShowOnly()
228 emit showJournalOnly( mJournal ); 223 emit showJournalOnly( mJournal );
229 //QTimer::singleShot( 0, this, SLOT( setVisibleOn() ) ); 224 //QTimer::singleShot( 0, this, SLOT( setVisibleOn() ) );
230 } 225 }
231} 226}
232void JournalEntry::setVisibleOn() 227void JournalEntry::setVisibleOn()
233{ 228{
234 visibleMode = true; 229 visibleMode = true;
235} 230}
236void JournalEntry::setShowOnly() 231void JournalEntry::setShowOnly()
237{ 232{
238 showOnlyMode = true; 233 showOnlyMode = true;
239 if ( mTitle->currentText().isEmpty() ) 234 if ( mTitle->currentText().isEmpty() )
240 mTitle->setFocus(); 235 mTitle->setFocus();
241 else 236 else
242 mEditor->setFocus(); 237 mEditor->setFocus();
243} 238}
244void JournalEntry::setJournal(Journal *journal, bool saveJournal ) 239void JournalEntry::setJournal(Journal *journal, bool saveJournal )
245{ 240{
246 if ( saveJournal ) 241 if ( saveJournal )
247 writeJournal(); 242 writeJournal();
248 mTitle->load( KOLocationBox::SUMMARYJOURNAL ); 243 mTitle->load( KOLocationBox::SUMMARYJOURNAL );
249 244
250 mJournal = journal; 245 mJournal = journal;
251 if ( journal->isReadOnly() ) 246 if ( journal->isReadOnly() )
252 mTitle->lineEdit ()->setText(mJournal->summary()+" ("+i18n("readonly")+")"); 247 mTitle->lineEdit ()->setText(mJournal->summary()+" ("+i18n("readonly")+")");
253 else 248 else
254 mTitle->lineEdit ()->setText(mJournal->summary()); 249 mTitle->lineEdit ()->setText(mJournal->summary());
255 mEditor->setText(mJournal->description()); 250 mEditor->setText(mJournal->description());
256 mTitle->setEnabled (!journal->isReadOnly() ); 251 mTitle->setEnabled (!journal->isReadOnly() );
257 mEditor->setReadOnly ( journal->isReadOnly() ); 252 mEditor->setReadOnly ( journal->isReadOnly() );
258 mCalendarBox->setEnabled (!journal->isReadOnly() ); 253 mCalendarBox->setEnabled (!journal->isReadOnly() );
259 fillCalendar( mJournal->calID() ); 254 fillCalendar( mJournal->calID() );
260} 255}
261 256
262Journal *JournalEntry::journal() const 257Journal *JournalEntry::journal() const
263{ 258{
264 return mJournal; 259 return mJournal;