You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
koffice/kword/KWFrameDia.cpp

2491 lines
94 KiB

/* This file is part of the KDE project
Copyright (C) 1998, 1999 Reginald Stadlbauer <reggie@kde.org>
Copyright (C) 2005 Thomas Zander <zander@kde.org>
This library is free software; you can redistribute it and/or
modify it under the terms of the GNU Library General Public
License as published by the Free Software Foundation; either
version 2 of the License, or (at your option) any later version.
This library 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
Library General Public License for more details.
You should have received a copy of the GNU Library General Public License
along with this library; see the file COPYING.LIB. If not, write to
the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
* Boston, MA 02110-1301, USA.
*/
#include "KWFrameDia.h"
#include "KWTextFrameSet.h"
#include "KWDocument.h"
#include "KWFrameDia.moc"
#include "KWCommand.h"
#include "KWTableFrameSet.h"
#include "KWPageManager.h"
#include "KWPage.h"
#include "KWPictureFrameSet.h"
#include <KoSetPropCommand.h>
#include <KoParagDia_p.h> // for KoBorderPreview
#include <knuminput.h>
#include <tdelocale.h>
#include <kiconloader.h>
#include <tdemessagebox.h>
#include <knumvalidator.h>
#include <kcolorbutton.h>
#include <kdebug.h>
#include <tqwhatsthis.h>
#include <tqlineedit.h>
#include <tqcheckbox.h>
#include <tqcombobox.h>
#include <tqhbuttongroup.h>
#include <tqlabel.h>
#include <tqradiobutton.h>
#include <tqlistview.h>
#include <tqbuttongroup.h>
#include <tqhbox.h>
#include <tqheader.h>
#include <tqlayout.h>
#include <stdlib.h>
#include <limits.h>
/******************************************************************/
/* Class KWBrushStylePreview - only used by kwframestylemanager */
/******************************************************************/
KWBrushStylePreview::KWBrushStylePreview( TQWidget* parent )
: TQFrame(parent)
{
}
void KWBrushStylePreview::drawContents( TQPainter* painter )
{
painter->save();
painter->translate( contentsRect().x(), contentsRect().y() );
painter->fillRect( contentsRect(), colorGroup().base() ); // in case of a transparent brush
painter->fillRect( contentsRect(), brush );
painter->restore();
}
/******************************************************************/
/* Class: KWFrameDia *
*
* TAB Frame Options
* Set options dependent of frametype
* TAB Text Runaround
* Set the text behaviour of this frame
* TAB Frameset
* here the user can select from the current TEXT framesets, a new one is
* included in the list.
* Afterwards (on ok) the frame should be checked if it is already owned by a
* frameset, if so that connection must be disconnected (if different) and
* framebehaviour will be copied from the frameset
* then the new connection should be made.
*
* TAB Geometry
* position/size
******************************************************************/
KWFrameDia::KWFrameDia( TQWidget* parent, KWFrame *frame)
: KDialogBase( Tabbed, TQString(), Ok | Apply| Cancel, Ok, parent, "framedialog", true)
{
m_noSignal=false;
m_frame = frame;
m_mainFrame = 0;
if(m_frame==0) {
kdDebug() << "ERROR: KWFrameDia::constructor no frame.."<<endl;
return;
}
setCaption( i18n( "Frame Properties for %1" ).arg( m_frame->frameSet()->name() ) );
KWFrameSet *fs = m_frame->frameSet()->groupmanager();
if(fs==0L) fs=m_frame->frameSet();
m_frameType = fs->type();
m_frameSetFloating = fs->isFloating();
m_frameSetProtectedSize = fs->isProtectSize();
m_mainFrameSetIncluded = fs->isMainFrameset();
m_defaultFrameSetIncluded = fs->isMainFrameset() || fs->isHeaderOrFooter() || fs->isFootEndNote();
if ( m_mainFrameSetIncluded )
m_mainFrame = m_frame;
m_doc = 0;
init();
}
/* Contructor when the dialog is used on creation of frame */
KWFrameDia::KWFrameDia( TQWidget* parent, KWFrame *frame, KWDocument *doc, FrameSetType ft )
: KDialogBase( Tabbed, i18n("Frame Properties for New Frame"), Ok | Cancel, Ok, parent, "framedialog", true)
{
m_noSignal=false;
m_frameType=ft;
m_doc = doc;
m_frame= frame;
m_frameSetFloating = false;
m_frameSetProtectedSize = false;
m_mainFrameSetIncluded = false;
m_defaultFrameSetIncluded = false;
if(m_frame==0) {
kdDebug() << "ERROR: KWFrameDia::constructor no m_frame.."<<endl;
return;
}
m_mainFrame = 0;
init();
}
KWFrameDia::KWFrameDia( TQWidget *parent, TQPtrList<KWFrame> listOfFrames) : KDialogBase( Tabbed, i18n("Frames Properties"), Ok | Apply | Cancel, Ok, parent, "framedialog", true) , m_allFrames() {
m_noSignal=false;
m_mainFrame = m_frame = 0L;
m_tab1 = m_tab2 = m_tab3 = m_tab4 = m_tab5 = m_tab6 = 0;
KWFrame *f=listOfFrames.first();
if(f==0) {
kdDebug() << "ERROR: KWFrameDia::constructor no frames.."<<endl;
return;
}
if ( listOfFrames.count() == 1 )
setCaption( i18n( "Frame Settings for %1" ).arg( f->frameSet()->name() ) );
KWFrameSet *fs = f->frameSet()->groupmanager();
if(fs==0L) fs=f->frameSet();
m_frameType = fs->type();
bool frameTypeUnset=true;
m_doc = fs->kWordDocument();
if( !fs->isMainFrameset() ) { // don't include the main fs.
m_allFrames.append(f);
frameTypeUnset=false;
}
else
m_mainFrame = f;
f=listOfFrames.next();
while(f) {
fs = f->frameSet()->groupmanager();
if(fs==0L) fs=f->frameSet();
if(m_doc->processingType() != KWDocument::WP || m_doc->frameSet(0) != fs) { // don't include the main fs.
if(!frameTypeUnset && m_frameType != fs->type()) m_frameType= FT_TEXT;
if(frameTypeUnset) {
m_frameType = fs->type();
frameTypeUnset = false;
} else if(m_frameType != fs->type()) m_frameType= FT_TEXT;
m_allFrames.append(f);
}
f=listOfFrames.next();
}
if(m_allFrames.count()==0)
m_allFrames.append(listOfFrames.first());
// Now that m_allFrames is set, calculate m_mainFrameSetIncluded and m_defaultFrameSetIncluded
m_mainFrameSetIncluded = false;
m_defaultFrameSetIncluded = false;
for ( f = m_allFrames.first(); f; f = m_allFrames.next() ) {
fs = f->frameSet();
if ( !m_mainFrameSetIncluded )
{
m_mainFrameSetIncluded = fs->isMainFrameset();
if ( m_mainFrameSetIncluded )
m_mainFrame = f;
}
if ( !m_defaultFrameSetIncluded )
m_defaultFrameSetIncluded = fs->isMainFrameset() || fs->isHeaderOrFooter() || fs->isFootEndNote();
}
init();
}
void KWFrameDia::init() {
m_tab1 = m_tab2 = m_tab3 = m_tab4 = m_tab5 = m_tab6 = 0;
m_sw = m_sh = 0L;
m_cbAspectRatio=0L;
KWFrameSet *fs=0;
if(m_frame) {
fs = m_frame->frameSet(); // 0 when creating a frame
KoRect r = m_frame->normalize();
m_frame->setRect( r.x(), r.y(), r.width(), r.height() );
}
if(!m_doc && fs)
{
m_doc = fs->kWordDocument();
}
if(!m_doc)
{
kdDebug() << "ERROR: KWFrameDia::init frame has no reference to m_doc.."<<endl;
return;
}
if( fs && fs->isMainFrameset() )
{
setupTab6();
setupTab5();
setupTab4();
}
else if ( fs && (fs->isHeaderOrFooter() || fs->isFootEndNote()) )
{
setupTab1();
if ( !fs->isMainFrameset() && !fs->isHeaderOrFooter() && !fs->isFootEndNote())
setupTab2();
setupTab4();
setupTab5();
setupTab6();
}
else if(m_frameType == FT_TEXT)
{
setupTab1();
if ( fs && !fs->isMainFrameset() && !fs->isHeaderOrFooter() && !fs->isFootEndNote())
setupTab2();
else if ( !fs )
setupTab2();
setupTab3();
setupTab4();
setupTab5();
setupTab6();
if(! fs) // first creation
showPage(2);
}
else if(m_frameType == FT_PICTURE)
{
setupTab1();
if ( m_frameType == FT_PICTURE )
setupTab2();
if(m_frame) // not for multiframe dia
setupTab4();
setupTab6();
showPage(1); // while options are not implemented..
}
else if(m_frameType == FT_PART)
{
setupTab2();
if(m_frame) // not for multiframe dia
setupTab4();
setupTab6();
}
else if(m_frameType == FT_FORMULA)
{
setupTab1();
setupTab2();
if(m_frame) // not for multiframe dia
setupTab4();
setupTab6();
showPage(1); // while options are not implemented..
}
else if(m_frameType == FT_TABLE)
{
setupTab4();
setupTab5();
setupTab6();
}
setInitialSize( TQSize(550, 400) );
}
void KWFrameDia::setupTab1(){ // TAB Frame Options
//kdDebug() << "setup tab 1 Frame options"<<endl;
m_tab1 = addPage( i18n("Options") );
int columns = 0;
if(m_frameType == FT_FORMULA || m_frameType == FT_PICTURE)
columns = 1;
else if(m_frameType == FT_TEXT)
columns = 2;
m_grid1 = new TQGridLayout( m_tab1, 0 /*auto create*/, columns, 0, KDialog::spacingHint() );
// Options for all types of frames
m_cbCopy = new TQCheckBox( i18n("Frame is a copy of the previous frame"),m_tab1 );
m_grid1->addWidget(m_cbCopy,1,0);
if(m_frame) {
m_cbCopy->setChecked( m_frame->isCopy() );
m_cbCopy->setEnabled( m_frame->frameSet() && m_frame->frameSet()->frame( 0 ) != m_frame ); // First one can't be a copy
} else { // list of frames as input.
KWFrame *f=m_allFrames.first();
bool show=true;
bool enabled=f->frameSet() && f->frameSet()->frame( 0 ) != f; // First one can't be a copy
bool checked=f->isCopy();
f=m_allFrames.next();
while(f) {
enabled=enabled || (f->frameSet() && f->frameSet()->frame( 0 ) != f);
if(checked != f->isCopy()) show=false;
f=m_allFrames.next();
}
if(! show) {
m_cbCopy->setTristate();
m_cbCopy->setNoChange();
}
else m_cbCopy->setChecked(checked);
m_cbCopy->setEnabled( enabled );
}
// Well, for images, formulas etc. it doesn't make sense to activate 'is copy'. What else would it show ?
if(m_frameType!=FT_TEXT)
m_cbCopy->setEnabled( false );
int row = 2;
int column = 0;
// Picture m_frame
if(m_frameType==FT_PICTURE)
{
m_cbAspectRatio = new TQCheckBox (i18n("Retain original aspect ratio"),m_tab1);
connect( m_cbAspectRatio, TQT_SIGNAL(toggled(bool)),
this, TQT_SLOT(slotKeepRatioToggled(bool)));
bool show=true;
bool on=true;
if(m_frame) {
if ( m_frame->frameSet() )
on= static_cast<KWPictureFrameSet *>( m_frame->frameSet() )->keepAspectRatio();
} else {
KWFrame *f=m_allFrames.first();
KWPictureFrameSet *fs = dynamic_cast<KWPictureFrameSet *> (f->frameSet());
if(fs)
on=fs->keepAspectRatio();
f=m_allFrames.next();
while(f) {
KWPictureFrameSet *fs = dynamic_cast<KWPictureFrameSet *> (f->frameSet());
if(fs)
if(on != fs->keepAspectRatio()) {
show=false;
break;
}
f=m_allFrames.next();
}
}
m_cbAspectRatio->setChecked( on );
if(! show) {
m_cbAspectRatio->setTristate();
m_cbAspectRatio->setNoChange();
}
m_grid1->addWidget(m_cbAspectRatio, row, 0);
++row;
}
else
m_cbAspectRatio = 0L;
// Text m_frame
if(m_frameType==FT_TEXT)
{
// AutoCreateNewFrame policy.
m_endOfFrame = new TQGroupBox(i18n("If Text is Too Long for Frame"), m_tab1 );
m_grid1->addWidget( m_endOfFrame, row, 0 );
m_eofGrid= new TQGridLayout (m_endOfFrame, 4, 1, KDialog::marginHint(), KDialog::spacingHint());
m_rAppendFrame = new TQRadioButton( i18n( "Create a new page" ), m_endOfFrame );
TQWhatsThis::add( m_rAppendFrame, "<b>Create a new page:</b><br/> if there is too "
"much text for this text frame, a new page will be created and, "
"since \"Reconnect frame to current flow\" is the only possible "
"option together with this one, "
"the new page will have a frame for showing the additional text." );
m_eofGrid->addWidget( m_rAppendFrame, 1, 0 );
m_rResizeFrame = new TQRadioButton( i18n( "Resize last frame" ), m_endOfFrame );
TQWhatsThis::add( m_rResizeFrame, "<b>Resize last frame:</b><br/> "
"if there is too much text for this text frame, "
"the frame will resize itself (increasing its height) as much as it needs, "
"to be able to contain all the text. More precisely, when the frameset has "
"multiple chained frames, it's always the last one which will be resized." );
m_eofGrid->addWidget( m_rResizeFrame, 2, 0 );
m_rNoShow = new TQRadioButton( i18n( "Don't show the extra text" ), m_endOfFrame );
TQWhatsThis::add( m_rNoShow, "<b>Don't show the extra text:</b><br/> "
"if there is too much text for this text frame, nothing happens "
"automatically. Initially the extra text won't appear. One possibility "
"then is to resize the frame manually. The other possibility is, with the option "
"\"Reconnect frame to current flow\" selected, to create a new page "
"which will then have a followup frame with the extra text." );
m_eofGrid->addWidget( m_rNoShow, 3, 0 );
TQButtonGroup *grp = new TQButtonGroup( m_endOfFrame );
grp->hide();
grp->setExclusive( true );
grp->insert( m_rAppendFrame );
grp->insert( m_rResizeFrame );
grp->insert( m_rNoShow );
m_eofGrid->addRowSpacing( 0, KDialog::marginHint() + 5 );
KWFrame::FrameBehavior fb;
bool show=true;
if(m_frame) {
fb = m_frame->frameBehavior();
} else {
KWFrame *f=m_allFrames.first();
fb = f->frameBehavior();
f=m_allFrames.next();
while(f) {
if(fb != f->frameBehavior()) {
show=false;
break;
}
f=m_allFrames.next();
}
}
if(show) {
if(fb == KWFrame::AutoExtendFrame) {
m_rResizeFrame->setChecked(true);
} else if (fb == KWFrame::AutoCreateNewFrame) {
m_rAppendFrame->setChecked(true);
} else {
m_rNoShow->setChecked(true);
}
}
column++;
} else {
m_rResizeFrame = 0L;
m_rAppendFrame = 0L;
m_rNoShow = 0L;
}
// NewFrameBehavior - now for all type of frames
m_onNewPage = new TQGroupBox(i18n("On New Page Creation"),m_tab1);
m_grid1->addWidget( m_onNewPage, row, column );
m_onpGrid = new TQGridLayout( m_onNewPage, 4, 1, KDialog::marginHint(), KDialog::spacingHint() );
m_reconnect = new TQRadioButton (i18n ("Reconnect frame to current flow"), m_onNewPage);
TQWhatsThis::add(m_reconnect, i18n("<b>Reconnect frame to current flow:</b><br/>"
"When a new page is created, a new frame will be created for this "
"frameset, so that the text can flow from one page to the next if necessary. "
"This is what happens for the \"main text frameset\", but this option makes it possible "
"to choose the same behavior for other framesets, for instance in magazine layouts."));
if ( m_rResizeFrame )
connect( m_reconnect, TQT_SIGNAL( clicked() ), this, TQT_SLOT( setFrameBehaviorInputOn() ) );
m_onpGrid->addRowSpacing( 0, KDialog::marginHint() + 5 );
m_onpGrid->addWidget( m_reconnect, 1, 0 );
m_noFollowup = new TQRadioButton (i18n ("Do not create a followup frame"), m_onNewPage);
TQWhatsThis::add(m_noFollowup, i18n("<b>Do not create a followup frame:</b><br/>"
"When a new page is created, no frame will be created for this frameset."));
if ( m_rResizeFrame )
connect( m_noFollowup, TQT_SIGNAL( clicked() ), this, TQT_SLOT( setFrameBehaviorInputOn() ) );
m_onpGrid->addWidget( m_noFollowup, 2, 0 );
m_copyRadio= new TQRadioButton (i18n ("Place a copy of this frame"), m_onNewPage);
TQWhatsThis::add(m_copyRadio, i18n("<b>Place a copy of this frame:</b><br/>"
"When a new page is created, a frame will be created for this frameset, "
"which will always show the exact same thing as the frame on the previous "
"page. This is what happens for headers and footers, but this option "
"makes it possible to choose the same behavior for other framesets, for "
"instance a company logo and/or title that should appear exactly the same on every page."));
if ( m_rResizeFrame )
connect( m_copyRadio, TQT_SIGNAL( clicked() ), this, TQT_SLOT( setFrameBehaviorInputOff() ) );
m_onpGrid->addWidget( m_copyRadio, 3, 0);
enableOnNewPageOptions();
TQButtonGroup *grp2 = new TQButtonGroup( m_onNewPage );
grp2->hide();
grp2->setExclusive( true );
grp2->insert( m_reconnect );
grp2->insert( m_noFollowup );
grp2->insert( m_copyRadio );
m_grid1->addRowSpacing( row, m_onNewPage->height());
KWFrame::NewFrameBehavior nfb;
bool show=true;
if(m_frame) {
nfb = m_frame->newFrameBehavior();
} else {
KWFrame *f=m_allFrames.first();
nfb = f->newFrameBehavior();
f=m_allFrames.next();
while(f) {
if(nfb != f->newFrameBehavior()) {
show=false;
break;
}
f=m_allFrames.next();
}
}
if(show) {
if(nfb == KWFrame::Reconnect) {
m_reconnect->setChecked(true);
} else if(nfb == KWFrame::NoFollowup) {
m_noFollowup->setChecked(true);
} else {
m_copyRadio->setChecked(true);
setFrameBehaviorInputOff();
}
}
// SideHeads definition - for text frames only
if( false && m_frameType == FT_TEXT ) // disabled in the GUI for now! (TZ June 2002)
{
row++;
m_sideHeads = new TQGroupBox(i18n("SideHead Definition"),m_tab1);
m_sideHeads->setEnabled(false); //###
m_grid1->addWidget(m_sideHeads, row, 0);
m_sideGrid = new TQGridLayout( m_sideHeads, 4, 2, KDialog::marginHint(), KDialog::spacingHint() );
sideTitle1 = new TQLabel ( i18n("Size (%1):").arg(m_doc->unitName()),m_sideHeads);
sideTitle1->resize(sideTitle1->sizeHint());
m_sideGrid->addWidget(sideTitle1,1,0);
m_sideWidth= new TQLineEdit(m_sideHeads,"");
m_sideWidth->setMaxLength(6);
m_sideGrid->addWidget(m_sideWidth,1,1);
sideTitle2 = new TQLabel( i18n("Gap size (%1):").arg(m_doc->unitName()),m_sideHeads);
sideTitle2->resize(sideTitle2->sizeHint());
m_sideGrid->addWidget(sideTitle2,2,0);
m_sideGap = new TQLineEdit(m_sideHeads,"");
m_sideGap->setMaxLength(6);
m_sideGrid->addWidget(m_sideGap,2,1);
m_sideAlign = new TQComboBox (false,m_sideHeads);
m_sideAlign->setAutoResize(false);
m_sideAlign->insertItem ( i18n("Left"));
m_sideAlign->insertItem ( i18n("Right"));
m_sideAlign->insertItem ( i18n("Closest to Binding"));
m_sideAlign->insertItem ( i18n("Closest to Page Edge"));
m_sideAlign->resize(m_sideAlign->sizeHint());
m_sideGrid->addMultiCellWidget(m_sideAlign,3,3,0,1);
m_sideGrid->addRowSpacing( 0, KDialog::marginHint() + 5 );
// init for sideheads.
m_sideWidth->setText("0");
m_sideWidth->setValidator( new KFloatValidator(0,9999,true, m_sideWidth) );
m_sideGap->setText("0");
m_sideGap->setValidator( new KFloatValidator(0,9999,true, m_sideGap) );
// add rest of sidehead init..
}
m_cbAllFrames = new TQCheckBox (i18n("Changes will be applied to all frames in frameset"),m_tab1);
m_cbAllFrames->setChecked(m_frame!=0L);
row++;
m_grid1->addMultiCellWidget(m_cbAllFrames,row,row, 0, 1);
m_cbProtectContent = new TQCheckBox( i18n("Protect content"), m_tab1);
TQWhatsThis::add(m_cbProtectContent, i18n("<b>Protect content:</b><br/>"
"Disallow changes to be made to the contents of the frame(s)."));
connect( m_cbProtectContent, TQT_SIGNAL(toggled ( bool ) ), this, TQT_SLOT(slotProtectContentChanged( bool )));
row++;
m_grid1->addMultiCellWidget(m_cbProtectContent,row,row, 0, 1);
if( m_frameType != FT_TEXT || m_frame!=0 && m_frame->frameSet()==0) {
m_cbAllFrames->setChecked(false);
m_cbAllFrames->hide();
m_cbProtectContent->setChecked( false );
m_cbProtectContent->hide();
}
else if ( m_frameType == FT_TEXT /*&& m_frame!=0 && m_frame->frameSet()*/ )
{
bool show=true;
bool on=true;
if(m_frame)
{
if ( m_frame->frameSet() )
on= static_cast<KWTextFrameSet *>(m_frame->frameSet() )->textObject()->protectContent();
}
else
{
KWFrame *f=m_allFrames.first();
KWTextFrameSet *fs = dynamic_cast<KWTextFrameSet *> (f->frameSet());
if(fs)
on=fs->textObject()->protectContent();
f=m_allFrames.next();
while(f) {
KWTextFrameSet *fs = dynamic_cast<KWTextFrameSet *> (f->frameSet());
if(fs)
{
if(on != fs->textObject()->protectContent())
{
show=false;
break;
}
}
f=m_allFrames.next();
}
}
m_cbProtectContent->setChecked( on );
if(! show) {
m_cbProtectContent->setTristate();
m_cbProtectContent->setNoChange();
}
}
for(int i=0;i < row;i++)
m_grid1->setRowStretch( i, 0 );
m_grid1->setRowStretch( row + 1, 1 );
}
void KWFrameDia::setupTab2() { // TAB Text Runaround
m_tab2 = addPage( i18n( "Text Run Around" ) );
TQVBoxLayout *tabLayout = new TQVBoxLayout( m_tab2, 0, KDialog::spacingHint(), "tabLayout");
// First groupbox
m_runGroup = new TQButtonGroup( i18n( "Layout of Text in Other Frames" ), m_tab2);
m_runGroup->setColumnLayout( 0, Qt::Vertical );
m_runGroup->layout()->setSpacing( KDialog::spacingHint() );
TQGridLayout *groupBox1Layout = new TQGridLayout( m_runGroup->layout() );
groupBox1Layout->setAlignment( TQt::AlignTop );
m_rRunNo = new TQRadioButton( i18n( "Text will run &through this frame" ), m_runGroup );
groupBox1Layout->addWidget( m_rRunNo, 0, 1 );
m_rRunBounding = new TQRadioButton( i18n( "Text will run &around the frame" ), m_runGroup );
groupBox1Layout->addWidget( m_rRunBounding, 1, 1 );
m_rRunSkip = new TQRadioButton( i18n( "Text will &not run around this frame" ), m_runGroup );
groupBox1Layout->addWidget( m_rRunSkip, 2, 1 );
TQPixmap pixmap = KWBarIcon( "run_not" );
TQLabel *lRunNo = new TQLabel( m_runGroup );
lRunNo->setBackgroundPixmap( pixmap );
lRunNo->setFixedSize( pixmap.size() );
groupBox1Layout->addWidget( lRunNo, 0, 0 );
pixmap = KWBarIcon( "run_bounding" );
TQLabel *lRunBounding = new TQLabel( m_runGroup );
lRunBounding->setBackgroundPixmap( pixmap );
lRunBounding->setFixedSize( pixmap.size() );
groupBox1Layout->addWidget( lRunBounding, 1, 0 );
pixmap = KWBarIcon( "run_skip" );
TQLabel *lRunSkip = new TQLabel( m_runGroup );
lRunSkip->setBackgroundPixmap( pixmap );
lRunSkip->setFixedSize( pixmap.size() );
groupBox1Layout->addWidget( lRunSkip, 2, 0 );
tabLayout->addWidget( m_runGroup );
// Second groupbox
m_runSideGroup = new TQButtonGroup( i18n( "Run Around Side" ), m_tab2);
m_runSideGroup->setColumnLayout( 0, Qt::Vertical );
m_runSideGroup->layout()->setSpacing( KDialog::spacingHint() );
m_runSideGroup->layout()->setMargin( KDialog::marginHint() );
TQGridLayout *runSideLayout = new TQGridLayout( m_runSideGroup->layout() );
runSideLayout->setAlignment( TQt::AlignTop );
m_rRunLeft = new TQRadioButton( i18n( "Run Around", "&Left" ), m_runSideGroup );
runSideLayout->addWidget( m_rRunLeft, 0, 0 /*1*/ );
m_rRunRight = new TQRadioButton( i18n( "Run Around", "&Right" ), m_runSideGroup );
runSideLayout->addWidget( m_rRunRight, 1, 0 /*1*/ );
m_rRunBiggest = new TQRadioButton( i18n( "Run Around", "Lon&gest side" ), m_runSideGroup );
runSideLayout->addWidget( m_rRunBiggest, 2, 0 /*1*/ );
#if 0 // TODO icons!
TQPixmap pixmap = KWBarIcon( "run_left" );
TQLabel *label = new TQLabel( m_runSideGroup );
label->setBackgroundPixmap( pixmap );
label->setFixedSize( pixmap.size() );
runSideLayout->addWidget( label, 0, 0 );
pixmap = KWBarIcon( "run_right" );
label = new TQLabel( m_runSideGroup );
label->setBackgroundPixmap( pixmap );
label->setFixedSize( pixmap.size() );
runSideLayout->addWidget( label, 1, 0 );
pixmap = KWBarIcon( "run_biggest" );
label = new TQLabel( m_runSideGroup );
label->setBackgroundPixmap( pixmap );
label->setFixedSize( pixmap.size() );
runSideLayout->addWidget( label, 2, 0 );
#endif
tabLayout->addWidget( m_runSideGroup );
m_raDistConfigWidget = new KWFourSideConfigWidget( m_doc, i18n("Distance Between Frame && Text"), m_tab2 );
if ( m_frame )
m_raDistConfigWidget->setValues( TQMAX(0.00, m_frame->runAroundLeft()),
TQMAX(0.00, m_frame->runAroundRight()),
TQMAX(0.00, m_frame->runAroundTop()),
TQMAX(0.00, m_frame->runAroundBottom()) );
tabLayout->addWidget( m_raDistConfigWidget );
// Show current settings
// Runaround
bool show=true;
KWFrame::RunAround ra = KWFrame::RA_NO;
if ( m_frame )
ra = m_frame->runAround();
else {
KWFrame *f=m_allFrames.first();
ra = f->runAround();
f=m_allFrames.next();
while(f) {
if(ra != f->runAround()) show=false;
f=m_allFrames.next();
}
}
if(show) {
switch ( ra ) {
case KWFrame::RA_NO: m_rRunNo->setChecked( true ); break;
case KWFrame::RA_BOUNDINGRECT: m_rRunBounding->setChecked( true ); break;
case KWFrame::RA_SKIP: m_rRunSkip->setChecked( true ); break;
}
}
// Runaround side
show = true;
KWFrame::RunAroundSide rs = KWFrame::RA_BIGGEST;
if ( m_frame )
rs = m_frame->runAroundSide();
else {
KWFrame *f=m_allFrames.first();
rs = f->runAroundSide();
f = m_allFrames.next();
while(f) {
if(rs != f->runAroundSide()) show=false;
f=m_allFrames.next();
}
}
if(show) {
switch ( rs ) {
case KWFrame::RA_LEFT: m_rRunLeft->setChecked( true ); break;
case KWFrame::RA_RIGHT: m_rRunRight->setChecked( true ); break;
case KWFrame::RA_BIGGEST: m_rRunBiggest->setChecked( true ); break;
}
}
// Runaround gap
show=true;
double ragapLeft = 0;
double ragapRight = 0;
double ragapTop = 0;
double ragapBottom = 0;
if ( m_frame ) {
ragapLeft = m_frame->runAroundLeft();
ragapRight = m_frame->runAroundRight();
ragapTop = m_frame->runAroundTop();
ragapBottom = m_frame->runAroundBottom();
}
else {
KWFrame *f = m_allFrames.first();
ragapLeft = f->runAroundLeft();
ragapRight = f->runAroundRight();
ragapTop = f->runAroundTop();
ragapBottom = f->runAroundBottom();
for( f = m_allFrames.next() ; f ; f = m_allFrames.next() ) {
if( ragapLeft != f->runAroundLeft() ||
ragapRight != f->runAroundRight() ||
ragapTop != f->runAroundTop() ||
ragapBottom != f->runAroundBottom() )
show = false; // TODO special value in the spinbox
f = m_allFrames.next();
}
}
if(show)
m_raDistConfigWidget->setValues( ragapLeft, ragapRight, ragapTop, ragapBottom );
enableRunAround();
// Changing the type of runaround needs to enable/disable the runaround-side options
connect( m_runGroup, TQT_SIGNAL( clicked(int) ), this, TQT_SLOT( enableRunAround() ) );
}
void KWFrameDia::setupTab3(){ // TAB Frameset
/*
* here the user can select from the current TEXT framesets
* Afterwards (on ok) the frame should be checked if it is already owned by a
* frameset, if so that connection must be disconnected (if different) and
* framebehaviour will be copied from the frameset
* then the new connection should be made.
*/
//kdDebug() << "setup tab 3 frameSet"<<endl;
m_tab3 = addPage( i18n( "Connect Text Frames" ) );
TQVBoxLayout *tabLayout = new TQVBoxLayout( m_tab3, 0, KDialog::spacingHint());
TQButtonGroup *myGroup = new TQButtonGroup(this);
myGroup->hide();
m_rExistingFrameset = new TQRadioButton( m_tab3, "m_rExistingFrameset" );
m_rExistingFrameset->setText( i18n("Select existing frameset to connect frame to:") );
tabLayout->addWidget( m_rExistingFrameset );
myGroup->insert(m_rExistingFrameset,1);
connect (m_rExistingFrameset, TQT_SIGNAL( toggled(bool)), this, TQT_SLOT(ensureValidFramesetSelected()));
TQHBoxLayout *layout2 = new TQHBoxLayout( 0, 0, 6);
TQSpacerItem* spacer = new TQSpacerItem( 20, 20, TQSizePolicy::Minimum, TQSizePolicy::Expanding );
layout2->addItem( spacer );
m_lFrameSList = new TQListView( m_tab3, "m_lFrameSList" );
m_lFrameSList->addColumn( i18n("No.") );
m_lFrameSList->addColumn( i18n("Frameset Name") );
m_lFrameSList->setAllColumnsShowFocus( true );
m_lFrameSList->header()->setMovingEnabled( false );
connect( m_lFrameSList, TQT_SIGNAL(selectionChanged ()),this,TQT_SLOT(selectExistingFrameset ()) );
connect (m_lFrameSList, TQT_SIGNAL( selectionChanged()), this, TQT_SLOT(ensureValidFramesetSelected()));
layout2->addWidget( m_lFrameSList );
tabLayout->addLayout( layout2 );
m_rNewFrameset = new TQRadioButton( m_tab3);
m_rNewFrameset->setText( i18n( "Create a new frameset" ) );
tabLayout->addWidget( m_rNewFrameset );
myGroup->insert(m_rNewFrameset,2);
TQFrame *line1 = new TQFrame( m_tab3 );
line1->setProperty( "frameShape", (int)TQFrame::HLine );
line1->setFrameShadow( TQFrame::Plain );
line1->setFrameShape( TQFrame::HLine );
tabLayout->addWidget( line1 );
TQHBoxLayout *layout1 = new TQHBoxLayout( 0, 0, 6 );
TQLabel *textLabel1 = new TQLabel( m_tab3 );
textLabel1->setText( i18n( "Name of frameset:" ) );
layout1->addWidget( textLabel1 );
m_eFrameSetName = new TQLineEdit( m_tab3 );
layout1->addWidget( m_eFrameSetName );
tabLayout->addLayout( layout1 );
int amount=0;
// now fill the gui.
for ( unsigned int i = 0; i < m_doc->frameSetCount(); i++ ) {
KWFrameSet * fs = m_doc->frameSet( i );
if ( i == 0 && m_doc->processingType() == KWDocument::WP )
continue;
if ( fs->type() != FT_TEXT || fs->isHeaderOrFooter() )
continue;
if ( fs->frameSetInfo() == KWFrameSet::FI_FOOTNOTE )
continue;
if ( fs->groupmanager() )
continue;
if ( fs->isDeleted() )
continue;
TQListViewItem *item = new TQListViewItem( m_lFrameSList );
item->setText( 0, TQString( "%1" ).arg( i + 1 ) );
item->setText( 1, fs->name() );
amount++;
if( m_frame && m_frame->frameSet() == fs ) {
m_lFrameSList->setSelected(item, TRUE );
m_oldFrameSetName = fs->name();
m_rExistingFrameset->setChecked(true);
}
}
if(amount==0) {
m_rNewFrameset->setChecked(/*true*/false);
m_rNewFrameset->setEnabled(false);
m_rExistingFrameset->setEnabled(false);
m_lFrameSList->setEnabled(false);
}
//we can't create a new frame when we select
//multi frame!!!!
if ( m_allFrames.count() > 1 ) {
m_rNewFrameset->setChecked(false);
m_rNewFrameset->setEnabled(false);
myGroup->setRadioButtonExclusive( false );
}
if(m_frame && m_frame->frameSet() == 0) {
m_oldFrameSetName = m_doc->generateFramesetName( i18n( "Text Frameset %1" ) );
m_rNewFrameset->setChecked(true);
}
m_eFrameSetName->setText( m_oldFrameSetName );
connect( m_lFrameSList, TQT_SIGNAL( currentChanged( TQListViewItem * ) ),
this, TQT_SLOT( connectListSelected( TQListViewItem * ) ) );
connect(m_eFrameSetName, TQT_SIGNAL(textChanged ( const TQString & ) ),
this,TQT_SLOT(textNameFrameChanged ( const TQString & ) ) );
connect(m_eFrameSetName, TQT_SIGNAL(textChanged ( const TQString & )),
this,TQT_SLOT(textNameFrameChanged ( const TQString & ) ));
connect( m_rNewFrameset, TQT_SIGNAL(toggled (bool)),
this,TQT_SLOT(selectNewFrameset (bool)) );
}
void KWFrameDia::selectExistingFrameset() {
m_rExistingFrameset->setChecked(true);
}
void KWFrameDia::selectNewFrameset(bool on) {
if(!on) return;
TQListViewItem *frameSetItem = m_lFrameSList->selectedItem();
if ( !frameSetItem)
return;
TQString str = frameSetItem->text( 0 );
KWFrameSet *fs = m_doc->frameSet(str.toInt() - 1);
frameSetItem->setText(1, fs->name() );
}
void KWFrameDia::textNameFrameChanged ( const TQString &text )
{
if(m_rExistingFrameset->isChecked()) {
TQListViewItem *item = m_lFrameSList->selectedItem();
if ( !item )
return;
item->setText(1, text );
}
if(m_rNewFrameset->isChecked() || m_rExistingFrameset->isChecked()) //when one of both is clicked.
enableButtonOK( !text.isEmpty() );
else
enableButtonOK( true );
}
void KWFrameDia::setupTab4() { // TAB Geometry
m_noSignal = true;
m_tab4 = addPage( i18n( "Geometry" ) );
TQGridLayout* grid4 = new TQGridLayout( m_tab4, 5, 1, 0, KDialog::spacingHint() );
m_floating = new TQCheckBox( i18n("Frame is inline"), m_tab4 );
connect( m_floating, TQT_SIGNAL( toggled(bool) ), this, TQT_SLOT( slotFloatingToggled(bool) ) );
int row = 0;
grid4->addMultiCellWidget( m_floating, row, row, 0, 1 );
row++;
m_protectSize = new TQCheckBox( i18n("Protect size and position"), m_tab4);
grid4->addMultiCellWidget( m_protectSize, row, row, 0, 1 );
connect( m_protectSize, TQT_SIGNAL( toggled(bool) ), this, TQT_SLOT( slotProtectSizeToggled(bool) ) );
/* ideally the following properties could be given to any floating frame:
Position: (y)
Top of frame
Top of paragraph
Above current line
At insertion point
Below current line
Bottom of paragraph
Bottom of frame
Absolute
Alignment: (x)
Left
Right
Center
Closest to binding
Further from binding
Absolute
*/
m_grp1 = new TQGroupBox( i18n("Position"), m_tab4 );
TQGridLayout* pGrid = new TQGridLayout( m_grp1, 3, 4, KDialog::marginHint(), KDialog::spacingHint() );
m_lx = new TQLabel( i18n( "Left:" ), m_grp1 );
m_lx->resize( m_lx->sizeHint() );
pGrid->addWidget( m_lx, 1, 0 );
m_sx = new KoUnitDoubleSpinBox( m_grp1, 0, 9999, 1, 0.0, m_doc->unit() );
m_sx->resize( m_sx->sizeHint() );
pGrid->addWidget( m_sx, 1, 1 );
m_ly = new TQLabel( i18n( "Top:" ), m_grp1 );
m_ly->resize( m_ly->sizeHint() );
pGrid->addWidget( m_ly, 1, 2 );
m_sy = new KoUnitDoubleSpinBox( m_grp1, 0, 9999, 1, 0.0, m_doc->unit() );
m_sy->resize( m_sy->sizeHint() );
pGrid->addWidget( m_sy, 1, 3 );
m_lw = new TQLabel( i18n( "Width:" ), m_grp1 );
m_lw->resize( m_lw->sizeHint() );
pGrid->addWidget( m_lw, 2, 0 );
m_sw = new KoUnitDoubleSpinBox( m_grp1, 0, 9999, 1, 0.0, m_doc->unit() );
m_sw->resize( m_sw->sizeHint() );
connect( m_sw, TQT_SIGNAL(valueChanged(double)),
this, TQT_SLOT(slotUpdateHeightForWidth(double)) );
pGrid->addWidget( m_sw, 2, 1 );
m_lh = new TQLabel( i18n( "Height:" ), m_grp1 );
m_lh->resize( m_lh->sizeHint() );
pGrid->addWidget( m_lh, 2, 2 );
m_sh = new KoUnitDoubleSpinBox( m_grp1, 0, 9999, 1, 0.0, m_doc->unit() );
connect( m_sh, TQT_SIGNAL(valueChanged(double)),
this, TQT_SLOT(slotUpdateWidthForHeight(double)) );
m_sh->resize( m_sh->sizeHint() );
pGrid->addWidget( m_sh, 2, 3 );
pGrid->setRowSpacing( 0, KDialog::spacingHint() + 5 );
row++;
grid4->addMultiCellWidget( m_grp1, row, row, 0,1 );
if(m_frame) {
m_paddingConfigWidget = new KWFourSideConfigWidget( m_doc, i18n("Margins"), m_tab4 );
m_paddingConfigWidget->setValues( TQMAX(0.00, m_frame->paddingLeft()),
TQMAX(0.00, m_frame->paddingRight()),
TQMAX(0.00, m_frame->paddingTop()),
TQMAX(0.00, m_frame->paddingBottom()) );
row++;
grid4->addMultiCellWidget( m_paddingConfigWidget, row, row, 0, 1 );
if ( m_tab1 && m_cbProtectContent )
{
m_paddingConfigWidget->setEnabled( !m_cbProtectContent->isChecked() );
}
}
else
{
m_paddingConfigWidget = 0;
}
initGeometrySettings();
if ( !m_frame || m_defaultFrameSetIncluded ) {
// is multi frame, positions don't work for that..
// also not for default frames.
m_sx->setEnabled( false );
m_sy->setEnabled( false );
m_lx->setEnabled( false );
m_ly->setEnabled( false );
m_lw->setEnabled( false );
m_lh->setEnabled( false );
m_floating->setEnabled( false );
}
if ( m_defaultFrameSetIncluded || m_mainFrameSetIncluded)
{
m_sw->setEnabled( false );
m_sh->setEnabled( false );
m_grp1->setEnabled( false );
}
if ( m_mainFrameSetIncluded )
{
m_grp1->hide();
m_floating->hide( );
m_protectSize->hide();
}
m_noSignal=false;
++row;
grid4->setRowStretch( row, 1 );
}
void KWFrameDia::initGeometrySettings()
{
if ( m_frame ) {
// is single frame dia. Fill position strings and checkboxes now.
// Can't use frame->pageNum() here since frameset might be 0
int pageNum = m_doc->pageManager()->pageNumber(m_frame);
m_sx->setValue( KoUnit::toUserValue( m_frame->x(), m_doc->unit() ) );
m_sy->setValue( KoUnit::toUserValue( m_frame->y() - m_doc->pageManager()->topOfPage(pageNum), m_doc->unit() ) );
m_sw->setValue( KoUnit::toUserValue( m_frame->width(), m_doc->unit() ) );
m_sh->setValue( KoUnit::toUserValue( m_frame->height(), m_doc->unit() ) );
calcRatio();
// userValue leads to some rounding -> store old values from the ones
// displayed, so that the "change detection" in apply() works.
m_oldX = m_sx->value();
m_oldY = m_sy->value();
m_oldW = m_sw->value();
m_oldH = m_sh->value();
#ifdef ALLOW_NON_INLINE_TABLES
KWFrameSet * fs = m_frame->frameSet();
if ( fs && fs->groupmanager() )
m_floating->setText( i18n( "Table is inline" ) );
#else
m_floating->hide();
#endif
m_floating->setChecked( m_frameSetFloating );
m_protectSize->setChecked( m_frameSetProtectedSize);
} else {
// multi frame. Fill inline and protect checkbox, leave away the position strings.
KWFrame *f=m_allFrames.first();
KWFrameSet *fs=f->frameSet();
bool ps=fs->isProtectSize();
m_protectSize->setChecked( ps );
bool table=fs->groupmanager();
if(table)
fs=fs->groupmanager();
bool inlineframe =fs->isFloating();
m_floating->setChecked( inlineframe );
double commonWidth = f->width();
double commonHeight = f->height();
m_sw->setEnabled( true );
m_sh->setEnabled( true );
f=m_allFrames.next();
while(f) {
KWFrameSet *fs=f->frameSet();
if(ps != fs->isProtectSize()) {
m_protectSize->setTristate();
m_protectSize->setNoChange();
}
if(fs->groupmanager()) //table
fs=fs->groupmanager();
else
table=false;
if(inlineframe != fs->isFloating()) {
m_floating->setTristate();
m_floating->setNoChange();
}
if ( kAbs( f->width() - commonWidth ) > 1E-6 ) {
kdDebug() << k_funcinfo << "width differs:" << f->width() << " " << commonWidth << endl;
m_sw->setEnabled( false );
}
if ( kAbs( f->height() - commonHeight ) > 1E-6 ) {
kdDebug() << k_funcinfo << "height differs:" << f->height() << " " << commonHeight << endl;
m_sh->setEnabled( false );
}
f=m_allFrames.next();
}
// TODO show a special value when frames have a different width/height
if ( m_sw->isEnabled() )
m_sw->setValue( KoUnit::toUserValue( commonWidth, m_doc->unit() ) );
if ( m_sh->isEnabled() )
m_sh->setValue( KoUnit::toUserValue( commonHeight, m_doc->unit() ) );
if(table)
{
#ifdef ALLOW_NON_INLINE_TABLES
m_floating->setText( i18n( "Table is inline" ) );
#else
m_floating->hide();
#endif
}
}
}
void KWFrameDia::setupTab5() { // Tab Background fill/color
m_tab5 = addPage( i18n("Background") );
TQGridLayout* grid5 = new TQGridLayout( m_tab5, 0 /*auto*/, 2, 0, KDialog::spacingHint() );
int row = 0;
if (!m_frame ) {
m_overwriteColor = new TQCheckBox (i18n("Set new color on all selected frames"), m_tab5);
grid5->addMultiCellWidget(m_overwriteColor,row,row,0,1);
row++;
}
//brushPreview=new KWBrushStylePreview(m_tab5);
//grid5->addMultiCellWidget(brushPreview,row,5,1,1);
m_transparentCB = new TQCheckBox( i18n( "Transparent background" ), m_tab5 );
grid5->addWidget(m_transparentCB,row++,0);
m_transparentCB->setEnabled( !m_mainFrameSetIncluded );
TQLabel *labelBgColor = new TQLabel( i18n( "Background color:" ), m_tab5 );
grid5->addWidget(labelBgColor,row++,0);
m_brushColor = new KColorButton( TQt::white, KWDocument::defaultBgColor(0), m_tab5 );
grid5->addWidget(m_brushColor,row++,0);
// connect( m_brushColor, TQT_SIGNAL( changed( const TQColor & ) ),
// this, TQT_SLOT( updateBrushPreview() ) );
// ###########################
// Fill styles are ugly and not WYSIWYG (due to being pixel-based)
// Feature not in OOo either (they have a configurable level of transparency instead, much nicer)
#if 0
l = new TQLabel( i18n( "Background style:" ), m_tab5 );
grid5->addWidget(l,row++,0);
brushStyle = new TQComboBox( false,m_tab5, "BStyle" );
grid5->addWidget(brushStyle,row++,0);
brushStyle->insertItem( i18n( "No Background Fill" ) );
// xgettext:no-c-format
brushStyle->insertItem( i18n( "100% Fill Pattern" ) );
// xgettext:no-c-format
brushStyle->insertItem( i18n( "94% Fill Pattern" ) );
// xgettext:no-c-format
brushStyle->insertItem( i18n( "88% Fill Pattern" ) );
// xgettext:no-c-format
brushStyle->insertItem( i18n( "63% Fill Pattern" ) );
// xgettext:no-c-format
brushStyle->insertItem( i18n( "50% Fill Pattern" ) );
// xgettext:no-c-format
brushStyle->insertItem( i18n( "37% Fill Pattern" ) );
// xgettext:no-c-format
brushStyle->insertItem( i18n( "12% Fill Pattern" ) );
// xgettext:no-c-format
brushStyle->insertItem( i18n( "6% Fill Pattern" ) );
brushStyle->insertItem( i18n( "Horizontal Lines" ) );
brushStyle->insertItem( i18n( "Vertical Lines" ) );
brushStyle->insertItem( i18n( "Crossing Lines" ) );
brushStyle->insertItem( i18n( "Diagonal Lines ( / )" ) );
brushStyle->insertItem( i18n( "Diagonal Lines ( \\ )" ) );
brushStyle->insertItem( i18n( "Diagonal Crossing Lines" ) );
connect( brushStyle, TQT_SIGNAL( activated( int ) ),
this, TQT_SLOT( updateBrushPreview() ) );
updateBrushPreview();
#endif
connect( m_transparentCB, TQT_SIGNAL( toggled( bool ) ), labelBgColor, TQT_SLOT( setDisabled( bool ) ) );
connect( m_transparentCB, TQT_SIGNAL( toggled( bool ) ), m_brushColor, TQT_SLOT( setDisabled( bool ) ) );
initBrush();
TQSpacerItem* spacer = new TQSpacerItem( 10, 10, TQSizePolicy::Minimum, TQSizePolicy::Expanding);
grid5->addItem( spacer,row,0 );
}
void KWFrameDia::setupTab6() // Border style
{
m_tab6 = addPage( i18n("&Borders") );
TQGridLayout *grid = new TQGridLayout( m_tab6, 8, 2, 0, KDialog::spacingHint() );
TQLabel * lStyle = new TQLabel( i18n( "St&yle:" ), m_tab6 );
grid->addWidget( lStyle, 0, 0 );
m_cStyle = new TQComboBox( false, m_tab6 );
m_cStyle->insertItem( KoBorder::getStyle( KoBorder::SOLID ) );
m_cStyle->insertItem( KoBorder::getStyle( KoBorder::DASH ) );
m_cStyle->insertItem( KoBorder::getStyle( KoBorder::DOT ) );
m_cStyle->insertItem( KoBorder::getStyle( KoBorder::DASH_DOT ) );
m_cStyle->insertItem( KoBorder::getStyle( KoBorder::DASH_DOT_DOT ) );
m_cStyle->insertItem( KoBorder::getStyle( KoBorder::DOUBLE_LINE ) );
lStyle->setBuddy( m_cStyle );
grid->addWidget( m_cStyle, 1, 0 );
TQLabel * lWidth = new TQLabel( i18n( "&Width:" ), m_tab6 );
grid->addWidget( lWidth, 2, 0 );
m_cWidth = new TQComboBox( false, m_tab6 );
for( unsigned int i = 1; i <= 10; i++ )
m_cWidth->insertItem(TQString::number(i));
lWidth->setBuddy( m_cWidth );
grid->addWidget( m_cWidth, 3, 0 );
TQLabel * lColor = new TQLabel( i18n( "Co&lor:" ), m_tab6 );
grid->addWidget( lColor, 4, 0 );
m_bColor = new KColorButton( black,
black,
m_tab6 );
lColor->setBuddy( m_bColor );
grid->addWidget( m_bColor, 5, 0 );
TQButtonGroup * bb = new TQHButtonGroup( m_tab6 );
bb->setFrameStyle(TQFrame::NoFrame);
m_bLeft = new TQPushButton(bb);
m_bLeft->setPixmap( BarIcon( "borderleft" ) );
m_bLeft->setToggleButton( true );
m_bRight = new TQPushButton(bb);
m_bRight->setPixmap( BarIcon( "borderright" ) );
m_bRight->setToggleButton( true );
m_bTop = new TQPushButton(bb);
m_bTop->setPixmap( BarIcon( "bordertop" ) );
m_bTop->setToggleButton( true );
m_bBottom = new TQPushButton(bb);
m_bBottom->setPixmap( BarIcon( "borderbottom" ) );
m_bBottom->setToggleButton( true );
grid->addWidget( bb, 6, 0 );
connect( m_bLeft, TQT_SIGNAL( toggled( bool ) ), this, TQT_SLOT( brdLeftToggled( bool ) ) );
connect( m_bRight, TQT_SIGNAL( toggled( bool ) ), this, TQT_SLOT( brdRightToggled( bool ) ) );
connect( m_bTop, TQT_SIGNAL( toggled( bool ) ), this, TQT_SLOT( brdTopToggled( bool ) ) );
connect( m_bBottom, TQT_SIGNAL( toggled( bool ) ), this, TQT_SLOT( brdBottomToggled( bool ) ) );
initBorderSettings();
TQGroupBox *grp=new TQGroupBox( 0, Qt::Vertical, i18n( "Preview" ), m_tab6, "previewgrp" );
grid->addMultiCellWidget( grp , 0, 7, 1, 1 );
grp->layout()->setSpacing(KDialog::spacingHint());
grp->layout()->setMargin(KDialog::marginHint());
m_prev3 = new KoBorderPreview( grp );
TQVBoxLayout *lay1 = new TQVBoxLayout( grp->layout() );
lay1->addWidget(m_prev3);
connect( m_prev3, TQT_SIGNAL( choosearea(TQMouseEvent * ) ),
this, TQT_SLOT( slotPressEvent(TQMouseEvent *) ) );
// update the bordet preview widget
m_prev3->setLeftBorder( m_leftBorder );
m_prev3->setRightBorder( m_rightBorder );
m_prev3->setTopBorder( m_topBorder );
m_prev3->setBottomBorder( m_bottomBorder );
grid->setRowStretch( 7, 1 );
grid->setColStretch( 1, 1 );
}
void KWFrameDia::initBorderSettings()
{
KWFrame *f = m_mainFrame ? m_mainFrame : ( m_frame ? m_frame : m_allFrames.first() );
m_leftBorder = f->leftBorder();
m_rightBorder = f->rightBorder();
m_topBorder = f->topBorder();
m_bottomBorder = f->bottomBorder();
}
#define OFFSETX 15
#define OFFSETY 7
#define Ko_SPACE 30
void KWFrameDia::slotPressEvent(TQMouseEvent *ev)
{
TQRect r = m_prev3->contentsRect();
TQRect rect(r.x()+OFFSETX,r.y()+OFFSETY,r.width()-OFFSETX,r.y()+OFFSETY+Ko_SPACE);
if(rect.contains(TQPoint(ev->x(),ev->y())))
{
if( ( ((int)m_topBorder.penWidth() != m_cWidth->currentText().toInt()) ||(m_topBorder.color != m_bColor->color() )
||(m_topBorder.getStyle()!=KoBorder::getStyle(m_cStyle->currentText()) )) && m_bTop->isOn() )
{
m_topBorder.setPenWidth( m_cWidth->currentText().toInt() );
m_topBorder.color = TQColor( m_bColor->color() );
m_topBorder.setStyle(KoBorder::getStyle(m_cStyle->currentText()));
m_prev3->setTopBorder( m_topBorder );
}
else
m_bTop->setOn(!m_bTop->isOn());
}
rect.setCoords(r.x()+OFFSETX,r.height()-OFFSETY-Ko_SPACE,r.width()-OFFSETX,r.height()-OFFSETY);
if(rect.contains(TQPoint(ev->x(),ev->y())))
{
if( ( ((int)m_bottomBorder.penWidth() != m_cWidth->currentText().toInt()) ||(m_bottomBorder.color != m_bColor->color() )
||(m_bottomBorder.getStyle()!=KoBorder::getStyle(m_cStyle->currentText()) )) && m_bBottom->isOn() )
{
m_bottomBorder.setPenWidth(m_cWidth->currentText().toInt());
m_bottomBorder.color = TQColor( m_bColor->color() );
m_bottomBorder.setStyle(KoBorder::getStyle(m_cStyle->currentText()));
m_prev3->setBottomBorder( m_bottomBorder );
}
else
m_bBottom->setOn(!m_bBottom->isOn());
}
rect.setCoords(r.x()+OFFSETX,r.y()+OFFSETY,r.x()+Ko_SPACE+OFFSETX,r.height()-OFFSETY);
if(rect.contains(TQPoint(ev->x(),ev->y())))
{
if( ( ((int)m_leftBorder.penWidth() != m_cWidth->currentText().toInt()) ||(m_leftBorder.color != m_bColor->color() )
||(m_leftBorder.getStyle()!=KoBorder::getStyle(m_cStyle->currentText()) )) && m_bLeft->isOn() )
{
m_leftBorder.setPenWidth( m_cWidth->currentText().toInt());
m_leftBorder.color = TQColor( m_bColor->color() );
m_leftBorder.setStyle(KoBorder::getStyle(m_cStyle->currentText()));
m_prev3->setLeftBorder( m_leftBorder );
}
else
m_bLeft->setOn(!m_bLeft->isOn());
}
rect.setCoords(r.width()-OFFSETX-Ko_SPACE,r.y()+OFFSETY,r.width()-OFFSETX,r.height()-OFFSETY);
if(rect.contains(TQPoint(ev->x(),ev->y())))
{
if( ( ((int)m_rightBorder.penWidth() != m_cWidth->currentText().toInt()) ||(m_rightBorder.color != m_bColor->color() )
||(m_rightBorder.getStyle()!=KoBorder::getStyle(m_cStyle->currentText()) )) && m_bRight->isOn() )
{
m_rightBorder.setPenWidth( m_cWidth->currentText().toInt());
m_rightBorder.color = m_bColor->color();
m_rightBorder.setStyle(KoBorder::getStyle(m_cStyle->currentText()));
m_prev3->setRightBorder( m_rightBorder );
}
else
m_bRight->setOn(!m_bRight->isOn());
}
}
#undef OFFSETX
#undef OFFSETY
#undef Ko_SPACE
void KWFrameDia::brdLeftToggled( bool on )
{
if ( !on )
m_leftBorder.setPenWidth(0);
else {
m_leftBorder.setPenWidth(m_cWidth->currentText().toInt());
m_leftBorder.color = m_bColor->color();
m_leftBorder.setStyle(KoBorder::getStyle( m_cStyle->currentText() ));
}
m_prev3->setLeftBorder( m_leftBorder );
}
void KWFrameDia::brdRightToggled( bool on )
{
if ( !on )
m_rightBorder.setPenWidth(0);
else {
m_rightBorder.setPenWidth(m_cWidth->currentText().toInt());
m_rightBorder.color = m_bColor->color();
m_rightBorder.setStyle( KoBorder::getStyle( m_cStyle->currentText() ));
}
m_prev3->setRightBorder( m_rightBorder );
}
void KWFrameDia::brdTopToggled( bool on )
{
if ( !on )
m_topBorder.setPenWidth(0);
else {
m_topBorder.setPenWidth(m_cWidth->currentText().toInt());
m_topBorder.color = m_bColor->color();
m_topBorder.setStyle(KoBorder::getStyle( m_cStyle->currentText() ));
}
m_prev3->setTopBorder( m_topBorder );
}
void KWFrameDia::brdBottomToggled( bool on )
{
if ( !on )
m_bottomBorder.setPenWidth ( 0 );
else {
m_bottomBorder.setPenWidth( m_cWidth->currentText().toInt());
m_bottomBorder.color = m_bColor->color();
m_bottomBorder.setStyle(KoBorder::getStyle(m_cStyle->currentText()));
}
m_prev3->setBottomBorder( m_bottomBorder );
}
void KWFrameDia::slotProtectContentChanged( bool b )
{
if (m_tab4 && !m_noSignal && m_paddingConfigWidget) {
m_paddingConfigWidget->setEnabled( !b );
}
}
void KWFrameDia::slotUpdateWidthForHeight(double height)
{
if ( !m_cbAspectRatio || m_cbAspectRatio->state() != TQButton::NoChange)
return;
if ( m_heightByWidthRatio == 0 )
return; // avoid DBZ
m_sw->setValue( height / m_heightByWidthRatio );
}
void KWFrameDia::slotUpdateHeightForWidth( double width )
{
if ( !m_cbAspectRatio || m_cbAspectRatio->state() != TQButton::NoChange)
return;
m_sh->setValue( width * m_heightByWidthRatio );
}
void KWFrameDia::slotKeepRatioToggled(bool on)
{
if ( !on || !m_sw || !m_sh) return;
calcRatio();
}
void KWFrameDia::ensureValidFramesetSelected()
{
enableButtonOK( m_rNewFrameset->isChecked() || m_rExistingFrameset->isChecked() && m_lFrameSList->selectedItem() != NULL);
}
void KWFrameDia::calcRatio()
{
if ( m_sw->value() == 0 )
m_heightByWidthRatio = 1.0; // arbitrary
else
m_heightByWidthRatio = m_sh->value() / m_sw->value();
}
void KWFrameDia::initBrush()
{
bool allFramesSame=true;
if ( m_frame )
m_newBrushStyle = m_frame->backgroundColor();
else {
KWFrame *f=m_allFrames.first();
m_newBrushStyle = f->backgroundColor();
f=m_allFrames.next();
while(f) {
if(m_newBrushStyle != f->backgroundColor()) {
allFramesSame=false;
break;
}
f=m_allFrames.next();
}
m_overwriteColor->setChecked(allFramesSame);
}
m_transparentCB->setChecked( m_newBrushStyle.style() == NoBrush );
#if 0
switch ( m_newBrushStyle.style() )
{
case NoBrush:
brushStyle->setCurrentItem( 0 );
break;
case SolidPattern:
brushStyle->setCurrentItem( 1 );
break;
case Dense1Pattern:
brushStyle->setCurrentItem( 2 );
break;
case Dense2Pattern:
brushStyle->setCurrentItem( 3 );
break;
case Dense3Pattern:
brushStyle->setCurrentItem( 4 );
break;
case Dense4Pattern:
brushStyle->setCurrentItem( 5 );
break;
case Dense5Pattern:
brushStyle->setCurrentItem( 6 );
break;
case Dense6Pattern:
brushStyle->setCurrentItem( 7 );
break;
case Dense7Pattern:
brushStyle->setCurrentItem( 8 );
break;
case HorPattern:
brushStyle->setCurrentItem( 9 );
break;
case VerPattern:
brushStyle->setCurrentItem( 10 );
break;
case CrossPattern:
brushStyle->setCurrentItem( 11 );
break;
case BDiagPattern:
brushStyle->setCurrentItem( 12 );
break;
case FDiagPattern:
brushStyle->setCurrentItem( 13 );
break;
case DiagCrossPattern:
brushStyle->setCurrentItem( 14 );
break;
case CustomPattern:
break;
}
#endif
TQColor col = KWDocument::resolveBgColor( m_newBrushStyle.color(), 0 );
m_brushColor->setColor( col );
}
TQBrush KWFrameDia::frameBrushStyle() const
{
TQBrush brush;
brush.setStyle( m_transparentCB->isChecked() ? Qt::NoBrush : Qt::SolidPattern );
#if 0
switch ( brushStyle->currentItem() )
{
case 0:
brush.setStyle( NoBrush );
break;
case 1:
brush.setStyle( SolidPattern );
break;
case 2:
brush.setStyle( Dense1Pattern );
break;
case 3:
brush.setStyle( Dense2Pattern );
break;
case 4:
brush.setStyle( Dense3Pattern );
break;
case 5:
brush.setStyle( Dense4Pattern );
break;
case 6:
brush.setStyle( Dense5Pattern );
break;
case 7:
brush.setStyle( Dense6Pattern );
break;
case 8:
brush.setStyle( Dense7Pattern );
break;
case 9:
brush.setStyle( HorPattern );
break;
case 10:
brush.setStyle( VerPattern );
break;
case 11:
brush.setStyle( CrossPattern );
break;
case 12:
brush.setStyle( BDiagPattern );
break;
case 13:
brush.setStyle( FDiagPattern );
break;
case 14:
brush.setStyle( DiagCrossPattern );
break;
}
#endif
brush.setColor( m_brushColor->color() );
return brush;
}
#if 0
void KWFrameDia::updateBrushPreview()
{
if(brushStyle->currentItem()==0) {
brushPreview->hide();
} else {
brushPreview->show();
brushPreview->setBrush(frameBrushStyle());
brushPreview->repaint(true);
}
}
#endif
// Called when "m_reconnect" or "no followup" is checked
void KWFrameDia::setFrameBehaviorInputOn() {
if ( m_tab4 && m_floating->isChecked() )
return;
if( m_rAppendFrame && m_rResizeFrame && m_rNoShow /*&& !m_rAppendFrame->isEnabled()*/ ) {
if(m_frameBehavior== KWFrame::AutoExtendFrame) {
m_rResizeFrame->setChecked(true);
} else if (m_frameBehavior== KWFrame::AutoCreateNewFrame) {
m_rAppendFrame->setChecked(true);
} else {
m_rNoShow->setChecked(true);
}
m_rResizeFrame->setEnabled(true);
// Can't have "create a new page" if "no followup", that wouldn't work
kdDebug() << "setFrameBehaviorInputOn: m_reconnect->isChecked()==" << m_reconnect->isChecked() << endl;
m_rAppendFrame->setEnabled( m_reconnect->isChecked() );
m_rNoShow->setEnabled(true);
}
}
// Called when "place a copy" is checked
void KWFrameDia::setFrameBehaviorInputOff() {
if ( m_tab4 && m_floating->isChecked() )
return;
if( m_rAppendFrame && m_rResizeFrame && m_rNoShow && m_rAppendFrame->isEnabled() ) {
if(m_rResizeFrame->isChecked()) {
m_frameBehavior=KWFrame::AutoExtendFrame;
} else if ( m_rAppendFrame->isChecked()) {
m_frameBehavior=KWFrame::AutoCreateNewFrame;
} else {
m_frameBehavior=KWFrame::Ignore;
}
// In "Place a copy" mode, we can't have "create new page if text too long"
if ( m_rAppendFrame->isChecked() )
m_rNoShow->setChecked(true);
m_rAppendFrame->setEnabled(false);
m_rResizeFrame->setEnabled(true);
m_rNoShow->setEnabled(true);
}
}
void KWFrameDia::enableSizeAndPosition()
{
bool canMove = ( m_floating->state() == TQButton::Off ) // can move if no frame is floating
&& ( m_protectSize->state() == TQButton::Off ) // protects size too
&& !m_defaultFrameSetIncluded // those can't be moved
&& m_frame; // can't move if multiple frames selected
m_sx->setEnabled( canMove );
m_sy->setEnabled( canMove );
bool canResize = ( m_protectSize->state() == TQButton::Off ) // can resize if no frame is protect-size'd
&& !m_defaultFrameSetIncluded; // those can't be resized
m_sw->setEnabled( canResize );
m_sh->setEnabled( canResize );
}
void KWFrameDia::slotProtectSizeToggled(bool)
{
enableSizeAndPosition();
}
void KWFrameDia::slotFloatingToggled(bool b)
{
enableSizeAndPosition();
if (m_tab1 && m_rAppendFrame && m_rResizeFrame && m_rNoShow ) {
m_cbCopy->setEnabled( !b ); // 'copy' irrelevant for floating frames.
if ( m_rAppendFrame )
{
m_rAppendFrame->setEnabled( !b ); // 'create new page' irrelevant for floating frames.
if ( b && m_rAppendFrame->isChecked() )
m_rNoShow->setChecked( true );
}
enableOnNewPageOptions();
if ( b ) {
m_noFollowup->setChecked( true );
m_cbCopy->setChecked( false );
} else {
// Revert to non-inline frame stuff
m_rResizeFrame->setEnabled(true);
m_rAppendFrame->setEnabled(true);
m_rNoShow->setEnabled(true);
}
}
enableRunAround();
}
// Enable or disable the "on new page" options
void KWFrameDia::enableOnNewPageOptions()
{
if ( m_tab1 )
{
bool f = m_tab4 && m_floating->isChecked();
// 'what happens on new page' is irrelevant for floating frames
m_reconnect->setEnabled( !f );
m_noFollowup->setEnabled( !f );
m_copyRadio->setEnabled( !f );
if( m_frameType != FT_TEXT )
m_reconnect->setEnabled( false );
else if(m_frame) {
KWFrameSet *fs = m_frame->frameSet(); // 0 when creating a frame
if ( fs && (fs->isHeaderOrFooter() || fs->isFootEndNote() ))
{
m_reconnect->setEnabled( false );
m_noFollowup->setEnabled( false );
}
}
}
}
void KWFrameDia::enableRunAround()
{
if ( m_tab2 )
{
if ( m_tab4 && m_floating->isChecked() ) {
m_runGroup->setEnabled( false ); // Runaround options don't make sense for floating frames
} else
{
if ( m_frame && m_frame->frameSet() )
m_runGroup->setEnabled( !m_frameSetFloating && !m_frame->frameSet()->isMainFrameset() && !m_frame->frameSet()->isHeaderOrFooter() && !m_frame->frameSet()->isFootEndNote() );
else
m_runGroup->setEnabled( true );
}
m_runSideGroup->setEnabled( m_runGroup->isEnabled() && m_rRunBounding->isChecked() );
m_raDistConfigWidget->setEnabled( m_runGroup->isEnabled() &&
( m_rRunBounding->isChecked() || m_rRunSkip->isChecked() ) );
}
}
bool KWFrameDia::applyChanges()
{
kdDebug() << "KWFrameDia::applyChanges"<<endl;
KWFrame *frameCopy = 0L;
bool isNewFrame=false;
if(m_frame) { // only do undo/redo when we have 1 frame to change for now..
frameCopy = m_frame->getCopy(); // keep a copy of the original (for undo/redo)
isNewFrame = m_frame->frameSet() == 0L; // true if we are creating a newframe
}
TQString name=TQString();
KMacroCommand * macroCmd=0L;
if ( m_tab3 ) { // TAB Frameset
// Frame/Frameset belonging, and frameset naming
// We basically have three cases:
// * Creating a new frame (fs==0), and creating a frameset (m_rNewFrameset selected)
// * Creating a frame (fs==0), and attaching to an existing frameset (other)
// * Editing a frame (fs!=0), possibly changing the frameset attachment (maybe creating a new one)
name = m_eFrameSetName->text();
if ( name.isEmpty() ) // Don't allow empty names
name = m_doc->generateFramesetName( i18n( "Text Frameset %1" ) );
KWFrameSet *fs = 0L;
TQListViewItem *frameSetItem = m_lFrameSList->selectedItem();
if(frameSetItem) {
TQString str = frameSetItem->text( 0 );
fs = m_doc->frameSet(str.toInt() - 1);
}
if(m_rNewFrameset->isChecked()) { // create a new FS.
if(m_frame && m_frame->frameSet()) {
// disconnect.
if(! mayDeleteFrameSet( static_cast<KWTextFrameSet*>(m_frame->frameSet())))
return false;
m_frame->frameSet()->deleteFrame( m_frame, false );
} else {
// first check all frames and ask the user if its ok to disconnect.
for(KWFrame *f=m_allFrames.first();f; f=m_allFrames.next()) {
if(! mayDeleteFrameSet( static_cast<KWTextFrameSet*>(f->frameSet())))
return false;
}
for(KWFrame *f=m_allFrames.first();f; f=m_allFrames.next())
f->frameSet()->deleteFrame( f, false );
}
} else if(m_rExistingFrameset->isChecked()) { // rename and/or m_reconnect a new frameset for this frame.
if(frameSetItem && (fs->name() != frameSetItem->text( 1 ))) { // rename FS.
if(!macroCmd)
macroCmd = new KMacroCommand( i18n("Rename Frameset") );
// Rename frameset
typedef KoSetPropCommand<TQString, KWFrameSet, &KWFrameSet::setName> FramesetNameCommand;
FramesetNameCommand* cmd = new FramesetNameCommand( fs, i18n( "Rename Frameset" ), fs->name(), frameSetItem->text( 1 ) );
macroCmd->addCommand(cmd);
cmd->execute();
}
if(m_frame && fs ) {
if(m_frame->frameSet() != fs) {
if(m_frame->frameSet()!=0) {
// m_reconnect.
if(! mayDeleteFrameSet( dynamic_cast<KWTextFrameSet*>(m_frame->frameSet())))
return false;
m_frame->frameSet()->deleteFrame( m_frame, false );
}
fs->addFrame(m_frame);
}
} else if ( fs ){
// first check all frames and ask the user if its ok to m_reconnect.
for(KWFrame *f=m_allFrames.first();f; f=m_allFrames.next()) {
if(f->frameSet() != fs) { // m_reconnect.
if(! mayDeleteFrameSet( dynamic_cast<KWTextFrameSet*>(f->frameSet())))
return false;
}
}
if ( fs )
{
// then do the reconnects.
for(KWFrame *f=m_allFrames.first();f; f=m_allFrames.next()) {
KWFrameSet *fs2=f->frameSet();
if(! (fs2->isHeaderOrFooter() || fs2->isMainFrameset()) ) {
if(fs2 != fs) { // m_reconnect.
f->frameSet()->deleteFrame( f, false );
fs->addFrame(f);
}
}
}
}
}
}
if(m_rNewFrameset->isChecked() || m_rExistingFrameset->isChecked()) {
// check if new name is unique
for (TQPtrListIterator<KWFrameSet> fit = m_doc->framesetsIterator(); fit.current() ; ++fit ) {
if ( !fit.current()->isDeleted() && // Allow to reuse a deleted frameset's name
fs != fit.current() && fit.current()->name() == name) {
if ( m_rNewFrameset->isChecked() )
KMessageBox::sorry( this,
i18n( "A new frameset with the name '%1' "
"can not be made because a frameset with that name "
"already exists. Please enter another name or select "
"an existing frameset from the list.").arg(name));
else
KMessageBox::sorry( this,
i18n( "A frameset with the name '%1' "
"already exists. Please enter another name." ).arg(name) );
m_eFrameSetName->setText(m_oldFrameSetName);
return false;
}
}
}
}
if ( m_tab1 ) { // TAB Frame Options
// Copy
if(m_frame)
m_frame->setCopy( m_cbCopy->isChecked() );
else if(m_cbCopy->state() != TQButton::NoChange) {
for(KWFrame *f=m_allFrames.first();f; f=m_allFrames.next()) {
if(f == f->frameSet()->frame(0)) continue; // skip first frame of any frameset.
f->setCopy( m_cbCopy->isChecked() );
}
}
// FrameBehavior
if ( m_frameType == FT_TEXT )
{
bool update=true;
KWFrame::FrameBehavior fb=KWFrame::AutoCreateNewFrame;
if(m_rResizeFrame->isChecked())
fb = KWFrame::AutoExtendFrame;
else if ( m_rAppendFrame->isChecked())
fb = KWFrame::AutoCreateNewFrame;
else if ( m_rNoShow->isChecked())
fb = KWFrame::Ignore;
else
update=false;
if(m_frame)
if(m_cbAllFrames->isChecked() && m_frame->frameSet())
m_frame->frameSet()->setFrameBehavior(fb);
else
m_frame->setFrameBehavior(fb);
else if(update) {
for(KWFrame *f=m_allFrames.first();f; f=m_allFrames.next())
if(m_cbAllFrames->isChecked())
f->frameSet()->setFrameBehavior(fb);
else
f->setFrameBehavior(fb);
}
if ( m_frame && m_frame->frameSet())
{
KWTextFrameSet * frm=static_cast<KWTextFrameSet *>( m_frame->frameSet() );
if(frm->textObject()->protectContent()!=m_cbProtectContent->isChecked())
{
if(!macroCmd)
macroCmd = new KMacroCommand( i18n("Protect Content") );
KWProtectContentCommand * cmd = new KWProtectContentCommand( i18n("Protect Content"), frm,m_cbProtectContent->isChecked() );
cmd->execute();
macroCmd->addCommand(cmd);
}
}
else
{
if ( m_cbProtectContent->state() != TQButton::NoChange)
{
for(KWFrame *f=m_allFrames.first();f; f=m_allFrames.next())
{
KWTextFrameSet * frm=dynamic_cast<KWTextFrameSet *>( f->frameSet() );
if ( frm )
{
if(frm->textObject()->protectContent()!=m_cbProtectContent->isChecked())
{
if(!macroCmd)
macroCmd = new KMacroCommand( i18n("Protect Content") );
KWProtectContentCommand * cmd = new KWProtectContentCommand( i18n("Protect Content"), frm,m_cbProtectContent->isChecked() );
cmd->execute();
macroCmd->addCommand(cmd);
}
}
}
}
}
}
// NewFrameBehavior
bool update=true;
KWFrame::NewFrameBehavior nfb=KWFrame::Reconnect;
if( m_reconnect && m_reconnect->isChecked() )
nfb = KWFrame::Reconnect;
else if ( m_noFollowup->isChecked() )
nfb = KWFrame::NoFollowup;
else if ( m_copyRadio->isChecked() )
nfb = KWFrame::Copy;
else
update=false;
if(m_frame)
if(m_cbAllFrames->isChecked() && m_frame->frameSet())
m_frame->frameSet()->setNewFrameBehavior(nfb);
else
m_frame->setNewFrameBehavior(nfb);
else if(update)
for(KWFrame *f=m_allFrames.first();f; f=m_allFrames.next())
if(m_cbAllFrames->isChecked())
f->frameSet()->setNewFrameBehavior(nfb);
else
f->setNewFrameBehavior(nfb);
// aspect ratio
if ( m_cbAspectRatio && (m_frameType==FT_PICTURE))
{
typedef KoSetBasicPropCommand<bool, KWPictureFrameSet, &KWPictureFrameSet::setKeepAspectRatio> FramesetSetKeepAspectRatioCommand;
if(m_frame) {
KWPictureFrameSet * frm=static_cast<KWPictureFrameSet *>( m_frame->frameSet() );
if ( frm->keepAspectRatio() != m_cbAspectRatio->isChecked() )
{
if(!macroCmd)
macroCmd = new KMacroCommand( i18n("Frame Properties") );
FramesetSetKeepAspectRatioCommand* cmd = new FramesetSetKeepAspectRatioCommand( frm, TQString(), frm->keepAspectRatio(), m_cbAspectRatio->isChecked() );
cmd->execute();
macroCmd->addCommand(cmd);
}
} else if(m_cbAspectRatio->state() != TQButton::NoChange) {
for(KWFrame *f=m_allFrames.first();f; f=m_allFrames.next()) {
KWPictureFrameSet *fs = dynamic_cast<KWPictureFrameSet *> (f->frameSet());
if(fs) {
if(fs->keepAspectRatio()!=m_cbAspectRatio->isChecked())
{
if(!macroCmd)
macroCmd = new KMacroCommand( i18n("Frame Properties") );
FramesetSetKeepAspectRatioCommand* cmd = new FramesetSetKeepAspectRatioCommand( fs, TQString(), fs->keepAspectRatio(), m_cbAspectRatio->isChecked() );
cmd->execute();
macroCmd->addCommand(cmd);
}
}
}
}
}
}
if ( m_tab2 ) { // TAB Text Runaround
// Run around
KWFrame::RunAround ra=KWFrame::RA_BOUNDINGRECT;
bool update=true;
if ( m_rRunNo->isChecked() )
ra = KWFrame::RA_NO;
else if ( m_rRunBounding->isChecked() )
ra = KWFrame::RA_BOUNDINGRECT;
else if ( m_rRunSkip->isChecked() )
ra = KWFrame::RA_SKIP;
else
update=false;
if(m_frame)
m_frame->setRunAround(ra);
else if (update) {
for(KWFrame *f=m_allFrames.first();f; f=m_allFrames.next())
f->setRunAround(ra);
}
// Run around side.
KWFrame::RunAroundSide rs=KWFrame::RA_BIGGEST;
update=true;
if ( m_rRunLeft->isChecked() )
rs = KWFrame::RA_LEFT;
else if ( m_rRunRight->isChecked() )
rs = KWFrame::RA_RIGHT;
else if ( m_rRunBiggest->isChecked() )
rs = KWFrame::RA_BIGGEST;
else
update=false;
if(m_frame)
m_frame->setRunAroundSide(rs);
else if (update) {
for(KWFrame *f=m_allFrames.first();f; f=m_allFrames.next())
f->setRunAroundSide(rs);
}
// Run around gap.
double runAroundLeft = m_raDistConfigWidget->leftValue();
double runAroundRight = m_raDistConfigWidget->rightValue();
double runAroundTop = m_raDistConfigWidget->topValue();
double runAroundBottom = m_raDistConfigWidget->bottomValue();
if(m_frame) {
m_frame->setRunAroundGap( runAroundLeft, runAroundRight, runAroundTop, runAroundBottom );
}
else
for(KWFrame *f=m_allFrames.first();f; f=m_allFrames.next())
f->setRunAroundGap( runAroundLeft, runAroundRight, runAroundTop, runAroundBottom );
}
if(m_tab5) { // Tab Background fill/color
TQBrush tmpBrush=frameBrushStyle();
if(m_frame) {
if ( tmpBrush != KWDocument::resolveBgBrush( m_frame->backgroundColor() ) ) {
m_frame->setBackgroundColor(tmpBrush);
}
} else if(m_overwriteColor->isChecked()) {
for(KWFrame *f=m_allFrames.first();f; f=m_allFrames.next())
f->setBackgroundColor(tmpBrush);
}
}
double px=0.0;
double py=0.0;
double pw=0.0;
double ph=0.0;
double uLeft = 0.0;
double uTop = 0.0;
double uBottom = 0.0;
double uRight = 0.0;
if(m_tab4) { // TAB Geometry
if ( m_frame ) {
px = TQMAX( 0, m_sx->value() );
int pageNum = m_doc->pageManager()->pageNumber(m_frame);
py = TQMAX( 0, m_sy->value() ) + m_doc->pageManager()->topOfPage(pageNum);
}
pw = TQMAX( m_sw->value(), 0 );
ph = TQMAX( m_sh->value(), 0 );
if ( m_paddingConfigWidget )
{
uLeft = m_paddingConfigWidget->leftValue();
uRight = m_paddingConfigWidget->rightValue();
uTop = m_paddingConfigWidget->topValue();
uBottom = m_paddingConfigWidget->bottomValue();
}
}
KoRect rect( px, py, pw, ph );
//kdDebug() << "New geom: " << m_sx->text().toDouble() << ", " << m_sy->text().toDouble()
//<< " " << m_sw->text().toDouble() << "x" << m_sh->text().toDouble() << endl;
//kdDebug()<<" rect :"<<px <<" py :"<<py<<" pw :"<<pw <<" ph "<<ph<<endl;
// Undo/redo for frame properties
if(m_frame) { // only do undo/redo when we edit 1 frame for now..
if(m_frame->frameSet() == 0L ) { // if there is no frameset (anymore)
KWTextFrameSet *frameSet = new KWTextFrameSet( m_doc, name );
frameSet->addFrame( m_frame );
KWPage *page = m_doc->pageManager()->page(m_frame);
if( page->rect().contains(rect) ) {
m_frame->setRect( px, py, pw, ph );
//don't change margins when frame is protected.
if ( m_paddingConfigWidget && ( !m_tab1 || (m_tab1 && m_cbProtectContent && !m_cbProtectContent->isChecked())) )
m_frame->setFramePadding( uLeft, uTop, uRight, uBottom );
m_doc->frameChanged( m_frame );
} else {
KMessageBox::sorry( this,i18n("The frame will not be resized because the new size would be greater than the size of the page."));
}
m_doc->addFrameSet( frameSet );
if(!macroCmd)
macroCmd = new KMacroCommand( i18n("Create Text Frame") );
KWCreateFrameCommand *cmd=new KWCreateFrameCommand( i18n("Create Text Frame"), m_frame) ;
macroCmd->addCommand(cmd);
}
if(!isNewFrame && (frameCopy->isCopy()!=m_frame->isCopy()
|| frameCopy->frameBehavior()!=m_frame->frameBehavior()
|| frameCopy->newFrameBehavior()!=m_frame->newFrameBehavior()
|| frameCopy->runAround()!=m_frame->runAround()
|| frameCopy->runAroundSide()!=m_frame->runAroundSide()
|| frameCopy->runAroundLeft()!=m_frame->runAroundLeft()
|| frameCopy->runAroundRight()!=m_frame->runAroundRight()
|| frameCopy->runAroundTop()!=m_frame->runAroundTop()
|| frameCopy->runAroundBottom()!=m_frame->runAroundBottom()
|| (m_tab5 && KWDocument::resolveBgBrush( frameCopy->backgroundColor() )!=frameBrushStyle())))
{
if(!macroCmd)
macroCmd = new KMacroCommand( i18n("Frame Properties") );
KWFramePropertiesCommand*cmd = new KWFramePropertiesCommand( TQString(), frameCopy, m_frame );
macroCmd->addCommand(cmd);
frameCopy = 0L;
} else
delete frameCopy;
}
if ( m_tab4 ) { // TAB Geometry
KWFrame *f=m_allFrames.first();
if(f==0L) f=m_frame;
while(f) {
// The floating attribute applies to the whole frameset...
KWFrameSet * fs = f->frameSet();
KWFrameSet * parentFs = fs->groupmanager() ? fs->groupmanager() : fs;
// Floating
if ( m_floating->isChecked() &&
m_floating->state() != TQButton::NoChange &&
!parentFs->isFloating() )
{
if(!macroCmd)
macroCmd = new KMacroCommand( i18n("Make Frameset Inline") );
TQValueList<FrameIndex> frameindexList;
TQValueList<FrameMoveStruct> frameindexMove;
KoPoint oldPos = f->topLeft();
// turn non-floating frame into floating frame
KWFrameSetInlineCommand *cmd = new KWFrameSetInlineCommand( TQString(), parentFs, true );
cmd->execute();
frameindexList.append( FrameIndex( f ) );
frameindexMove.append( FrameMoveStruct( oldPos, f->topLeft() ) );
KWFrameMoveCommand *cmdMoveFrame = new KWFrameMoveCommand( TQString(), frameindexList, frameindexMove );
macroCmd->addCommand(cmdMoveFrame);
macroCmd->addCommand(cmd);
}
else if ( !m_floating->isChecked() &&
m_floating->state() != TQButton::NoChange &&
parentFs->isFloating() )
{
if(!macroCmd)
macroCmd = new KMacroCommand( i18n("Make Frameset Non-Inline") );
// turn floating-frame into non-floating frame
KWFrameSetInlineCommand *cmd = new KWFrameSetInlineCommand( TQString(), parentFs, false );
macroCmd->addCommand(cmd);
cmd->execute();
}
if ( fs->isProtectSize() != m_protectSize->isChecked()
&& m_protectSize->state() != TQButton::NoChange )
{
if(!macroCmd)
macroCmd = new KMacroCommand( i18n("Protect Size") );
typedef KoSetBasicPropCommand<bool, KWFrameSet, &KWFrameSet::setProtectSize> FramesetSetProtectSizeCommand;
FramesetSetProtectSizeCommand* cmd = new FramesetSetProtectSizeCommand( fs, TQString(), fs->isProtectSize(), m_protectSize->isChecked() );
macroCmd->addCommand(cmd);
cmd->execute();
m_frameSetProtectedSize = m_protectSize->isChecked();
}
if ( !fs->isMainFrameset() &&
( ( m_oldX != m_sx->value() && m_sx->isEnabled() )|| ( m_oldY != m_sy->value() && m_sy->isEnabled() ) || ( m_oldW != m_sw->value() && m_sw->isEnabled() ) || ( m_oldH != m_sh->value() && m_sh->isEnabled() ) ) )
{
//kdDebug() << "Old geom: " << m_oldX << ", " << m_oldY<< " " << m_oldW << "x" << m_oldH << endl;
//kdDebug() << "New geom: " << m_sx->text().toDouble() << ", " << m_sy->text().toDouble()
// << " " << m_sw->text().toDouble() << "x" << m_sh->text().toDouble() << endl;
if( m_doc->pageManager()->page(f)->rect().contains(rect) )
{
FrameIndex index( f );
KoRect initialRect = f->normalize();
double initialMinFrameHeight = f->minimumFrameHeight();
if ( m_frame ) // single frame: can be moved and resized
f->setRect( px, py, pw, ph );
else { // multiple frames: can only be resized
f->setWidth( pw );
f->setHeight( ph );
}
FrameResizeStruct tmpResize( initialRect, initialMinFrameHeight, f->normalize() );
if(!macroCmd)
macroCmd = new KMacroCommand( i18n("Resize Frame") );
KWFrameResizeCommand *cmd = new KWFrameResizeCommand( i18n("Resize Frame"), index, tmpResize ) ;
macroCmd->addCommand(cmd);
m_doc->frameChanged( f );
}
else
{
KMessageBox::sorry( this,i18n("The frame will not be resized because the new size would be greater than the size of the page."));
}
}
if ( m_paddingConfigWidget &&
(!m_tab1 || (m_tab1 && m_cbProtectContent && !m_cbProtectContent->isChecked())) &&
m_paddingConfigWidget->changed() )
{
FrameIndex index( f );
FramePaddingStruct tmpMargBegin(f);
FramePaddingStruct tmpMargEnd(uLeft, uTop, uRight, uBottom);
if(!macroCmd)
macroCmd = new KMacroCommand( i18n("Change Margin Frame") );
KWFrameChangeFramePaddingCommand *cmd = new KWFrameChangeFramePaddingCommand( i18n("Change Margin Frame"), index, tmpMargBegin, tmpMargEnd) ;
cmd->execute();
macroCmd->addCommand(cmd);
}
f=m_allFrames.next();
}
}
if ( m_tab6 ) // Border style
{
if ( m_mainFrame )
m_allFrames.append( m_mainFrame );
KWFrame *f = m_allFrames.first();
if(f==0L) f=m_frame;
for ( ; f ; f = m_allFrames.next() )
{
// TODO can't this become shorter??
if ( f->leftBorder() != m_leftBorder )
{
kdDebug() << "Changing borders!" << endl;
TQPtrList<KWFrameBorderCommand::FrameBorderTypeStruct> tmpBorderList;
TQPtrList<FrameIndex> frameindexList;
f = KWFrameSet::settingsFrame( f );
FrameIndex *index = new FrameIndex( f );
KWFrameBorderCommand::FrameBorderTypeStruct *tmp =new KWFrameBorderCommand::FrameBorderTypeStruct;
tmp->m_OldBorder = f->leftBorder();
tmp->m_EFrameType = KoBorder::LeftBorder;
tmpBorderList.append( tmp );
frameindexList.append( index );
if ( !macroCmd )
macroCmd = new KMacroCommand( i18n("Change Border"));
KWFrameBorderCommand *cmd = new KWFrameBorderCommand(i18n("Change Left Border Frame"), frameindexList, tmpBorderList, m_leftBorder);
cmd->execute();
macroCmd->addCommand( cmd);
}
if ( f->rightBorder() != m_rightBorder )
{
TQPtrList<KWFrameBorderCommand::FrameBorderTypeStruct> tmpBorderList;
TQPtrList<FrameIndex> frameindexList;
f = KWFrameSet::settingsFrame( f );
FrameIndex *index = new FrameIndex( f );
KWFrameBorderCommand::FrameBorderTypeStruct *tmp =new KWFrameBorderCommand::FrameBorderTypeStruct;
tmp->m_OldBorder = f->rightBorder();
tmp->m_EFrameType = KoBorder::RightBorder;
tmpBorderList.append( tmp );
frameindexList.append( index );
if ( !macroCmd )
macroCmd = new KMacroCommand( i18n("Change Border"));
KWFrameBorderCommand *cmd = new KWFrameBorderCommand(i18n("Change Right Border Frame"), frameindexList, tmpBorderList, m_rightBorder);
cmd->execute();
macroCmd->addCommand( cmd);
}
if ( f->topBorder() != m_topBorder )
{
TQPtrList<KWFrameBorderCommand::FrameBorderTypeStruct> tmpBorderList;
TQPtrList<FrameIndex> frameindexList;
f = KWFrameSet::settingsFrame( f );
FrameIndex *index = new FrameIndex( f );
KWFrameBorderCommand::FrameBorderTypeStruct *tmp =new KWFrameBorderCommand::FrameBorderTypeStruct;
tmp->m_OldBorder = f->topBorder();
tmp->m_EFrameType = KoBorder::TopBorder;
tmpBorderList.append( tmp );
frameindexList.append( index );
if ( !macroCmd )
macroCmd = new KMacroCommand( i18n("Change Border"));
KWFrameBorderCommand *cmd = new KWFrameBorderCommand(i18n("Change Top Border Frame"), frameindexList, tmpBorderList, m_topBorder);
cmd->execute();
macroCmd->addCommand( cmd);
}
if ( f->bottomBorder() != m_bottomBorder )
{
TQPtrList<KWFrameBorderCommand::FrameBorderTypeStruct> tmpBorderList;
TQPtrList<FrameIndex> frameindexList;
f = KWFrameSet::settingsFrame( f );
FrameIndex *index = new FrameIndex( f );
KWFrameBorderCommand::FrameBorderTypeStruct *tmp =new KWFrameBorderCommand::FrameBorderTypeStruct;
tmp->m_OldBorder = f->bottomBorder();
tmp->m_EFrameType = KoBorder::BottomBorder;
tmpBorderList.append( tmp );
frameindexList.append( index );
if ( !macroCmd )
macroCmd = new KMacroCommand( i18n("Change Border"));
KWFrameBorderCommand *cmd = new KWFrameBorderCommand(i18n("Change Bottom Border Frame"), frameindexList, tmpBorderList, m_bottomBorder);
cmd->execute();
macroCmd->addCommand( cmd);
}
}
}
if(macroCmd)
m_doc->addCommand(macroCmd);
updateFrames();
return true;
}
void KWFrameDia::updateFrames()
{
m_doc->updateAllFrames();
m_doc->layout();
m_doc->repaintAllViews();
}
void KWFrameDia::slotApply()
{
applyChanges();
if ( m_tab4 )
initGeometrySettings();
if ( m_tab6 )
initBorderSettings();
}
void KWFrameDia::slotOk()
{
if (applyChanges())
{
KDialogBase::slotOk();
}
}
void KWFrameDia::connectListSelected( TQListViewItem *item )
{
/* belongs to TAB3, is activated when the user selects another frameset from the list */
if ( !item )
item = m_lFrameSList->selectedItem();
if ( !item ) return; // assertion
m_rExistingFrameset->setChecked(true);
m_eFrameSetName->setText( item->text(1) );
}
bool KWFrameDia::mayDeleteFrameSet(KWTextFrameSet *fs) {
if(fs==0) return true;
if(fs->frameCount() > 1) return true;
KoTextParag * parag = fs->textDocument()->firstParag();
if(parag==0) return true;
bool isEmpty = parag->next() == 0L && parag->length() == 1;
if ( !isEmpty ) {
int result = KMessageBox::warningContinueCancel(this,
i18n( "You are about to reconnect the last frame of the "
"frameset '%1'. "
"The contents of this frameset will be deleted.\n"
"Are you sure you want to do that?").arg(fs->name()),
i18n("Reconnect Frame"), i18n("&Reconnect"));
if (result != KMessageBox::Continue)
return false;
}
return true;
}
KWFourSideConfigWidget::KWFourSideConfigWidget( KWDocument* doc, const TQString& title,
TQWidget* parent, const char* name )
: TQGroupBox( title, parent, name ),
m_doc( doc ),
m_changed( false ), m_noSignal( false )
{
TQGroupBox *grp2 = this;
TQGridLayout* mGrid = new TQGridLayout( grp2, 4, 4, KDialog::marginHint(), KDialog::spacingHint() );
m_synchronize=new TQCheckBox( i18n("Synchronize changes"), grp2 );
TQWhatsThis::add(m_synchronize, i18n("<b>Synchronize changes:</b><br/>"
"When this is checked any change in margins will be used for all directions."));
mGrid->addMultiCellWidget( m_synchronize, 1, 1, 0, 1 );
TQLabel* lml = new TQLabel( i18n( "Left:" ), grp2 );
//lml->resize( lml->sizeHint() );
mGrid->addWidget( lml, 2, 0 );
m_inputLeft = new KoUnitDoubleSpinBox( grp2, 0, 9999, 1, 0.0, m_doc->unit() );
mGrid->addWidget( m_inputLeft, 2, 1 );
TQLabel* lmt = new TQLabel( i18n( "Top:" ), grp2 );
//lmt->resize( lmt->sizeHint() );
mGrid->addWidget( lmt, 2, 2 );
m_inputTop = new KoUnitDoubleSpinBox( grp2, 0, 9999, 1, 0.0, m_doc->unit() );
//m_inputTop->resize( m_inputTop->sizeHint() );
mGrid->addWidget( m_inputTop, 2, 3 );
TQLabel* lmr = new TQLabel( i18n( "Right:" ), grp2 );
//lmr->resize( lmr->sizeHint() );
mGrid->addWidget( lmr, 3, 0 );
m_inputRight = new KoUnitDoubleSpinBox( grp2, 0, 9999, 1, 0.0, m_doc->unit() );
//m_inputRight->resize( m_inputRight->sizeHint() );
mGrid->addWidget( m_inputRight, 3, 1 );
TQLabel* lmb = new TQLabel( i18n( "Bottom:" ), grp2 );
//lmb->resize( lmb->sizeHint() );
mGrid->addWidget( lmb, 3, 2 );
m_inputBottom = new KoUnitDoubleSpinBox( grp2, 0, 9999, 1, 0.0, m_doc->unit() );
//m_inputBottom->resize( m_inputBottom->sizeHint() );
mGrid->addWidget( m_inputBottom, 3, 3 );
mGrid->setRowSpacing( 0, KDialog::spacingHint() + 5 );
connect( m_inputLeft, TQT_SIGNAL( valueChanged(double)), this, TQT_SLOT( slotValueChanged( double )));
connect( m_inputRight, TQT_SIGNAL( valueChanged(double)), this, TQT_SLOT( slotValueChanged( double )));
connect( m_inputTop, TQT_SIGNAL( valueChanged(double)), this, TQT_SLOT( slotValueChanged( double )));
connect( m_inputBottom, TQT_SIGNAL( valueChanged(double)), this, TQT_SLOT( slotValueChanged( double )));
}
// Called right after the ctor, so m_synchronize can't be checked
void KWFourSideConfigWidget::setValues( double left, double right, double top, double bottom )
{
m_inputLeft->setValue( KoUnit::toUserValue( left, m_doc->unit() ) );
m_inputRight->setValue( KoUnit::toUserValue( right, m_doc->unit() ) );
m_inputTop->setValue( KoUnit::toUserValue( top, m_doc->unit() ) );
m_inputBottom->setValue( KoUnit::toUserValue( bottom, m_doc->unit() ) );
}
void KWFourSideConfigWidget::slotValueChanged( double val )
{
m_changed = true;
if ( m_synchronize->isChecked() && !m_noSignal )
{
m_noSignal = true;
m_inputLeft->setValue( val );
m_inputBottom->setValue( val );
m_inputRight->setValue( val );
m_inputTop->setValue( val );
m_noSignal = false;
}
}
double KWFourSideConfigWidget::leftValue() const
{
return m_inputLeft->value();
}
double KWFourSideConfigWidget::rightValue() const
{
return m_inputRight->value();
}
double KWFourSideConfigWidget::topValue() const
{
return m_inputTop->value();
}
double KWFourSideConfigWidget::bottomValue() const
{
return m_inputBottom->value();
}
/*
TODO;
features that are present in the frames but not shown (yet)
- frames with 'copy' should have a radiogroup showing that its only going to be copied to
the even/odd side or to both sides.
*/