/* This file is part of the KDE project Copyright (C) 1998, 1999 Reginald Stadlbauer Copyright (C) 2005 Thomas Zander 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 #include // for KoBorderPreview #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include /******************************************************************/ /* Class KWBrushStylePreview - only used by kwframestylemanager */ /******************************************************************/ KWBrushStylePreview::KWBrushStylePreview( TQWidget* tqparent ) : TQFrame(tqparent) { } void KWBrushStylePreview::drawContents( TQPainter* painter ) { painter->save(); painter->translate( contentsRect().x(), contentsRect().y() ); painter->fillRect( contentsRect(), tqcolorGroup().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* tqparent, KWFrame *frame) : KDialogBase( Tabbed, TQString(), Ok | Apply| Cancel, Ok, tqparent, "framedialog", true) { m_noSignal=false; m_frame = frame; m_mainFrame = 0; if(m_frame==0) { kdDebug() << "ERROR: KWFrameDia::constructor no 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* tqparent, KWFrame *frame, KWDocument *doc, FrameSetType ft ) : KDialogBase( Tabbed, i18n("Frame Properties for New Frame"), Ok | Cancel, Ok, tqparent, "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.."< listOfFrames) : KDialogBase( Tabbed, i18n("Frames Properties"), Ok | Apply | Cancel, Ok, tqparent, "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.."<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.."<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"<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( m_frame->frameSet() )->keepAspectRatio(); } else { KWFrame *f=m_allFrames.first(); KWPictureFrameSet *fs = dynamic_cast (f->frameSet()); if(fs) on=fs->keepAspectRatio(); f=m_allFrames.next(); while(f) { KWPictureFrameSet *fs = dynamic_cast (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, "Create a new page:
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, "Resize last frame:
" "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, "Don't show the extra text:
" "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("Reconnect frame to current flow:
" "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 tqlayouts.")); 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("Do not create a followup frame:
" "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("Place a copy of this frame:
" "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):").tqarg(m_doc->unitName()),m_sideHeads); sideTitle1->resize(sideTitle1->tqsizeHint()); 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):").tqarg(m_doc->unitName()),m_sideHeads); sideTitle2->resize(sideTitle2->tqsizeHint()); 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->tqsizeHint()); 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("Protect content:
" "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(m_frame->frameSet() )->textObject()->protectContent(); } else { KWFrame *f=m_allFrames.first(); KWTextFrameSet *fs = dynamic_cast (f->frameSet()); if(fs) on=fs->textObject()->protectContent(); f=m_allFrames.next(); while(f) { KWTextFrameSet *fs = dynamic_cast (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->tqlayout()->setSpacing( KDialog::spacingHint() ); TQGridLayout *groupBox1Layout = new TQGridLayout( m_runGroup->tqlayout() ); groupBox1Layout->tqsetAlignment( 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 ¬ 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->tqlayout()->setSpacing( KDialog::spacingHint() ); m_runSideGroup->tqlayout()->setMargin( KDialog::marginHint() ); TQGridLayout *runSideLayout = new TQGridLayout( m_runSideGroup->tqlayout() ); runSideLayout->tqsetAlignment( 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"<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 *tqlayout2 = new TQHBoxLayout( 0, 0, 6); TQSpacerItem* spacer = new TQSpacerItem( 20, 20, TQSizePolicy::Minimum, TQSizePolicy::Expanding ); tqlayout2->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())); tqlayout2->addWidget( m_lFrameSList ); tabLayout->addLayout( tqlayout2 ); 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 *tqlayout1 = new TQHBoxLayout( 0, 0, 6 ); TQLabel *textLabel1 = new TQLabel( m_tab3 ); textLabel1->setText( i18n( "Name of frameset:" ) ); tqlayout1->addWidget( textLabel1 ); m_eFrameSetName = new TQLineEdit( m_tab3 ); tqlayout1->addWidget( m_eFrameSetName ); tabLayout->addLayout( tqlayout1 ); 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" ).tqarg( 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->tqsizeHint() ); 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->tqsizeHint() ); pGrid->addWidget( m_sx, 1, 1 ); m_ly = new TQLabel( i18n( "Top:" ), m_grp1 ); m_ly->resize( m_ly->tqsizeHint() ); 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->tqsizeHint() ); pGrid->addWidget( m_sy, 1, 3 ); m_lw = new TQLabel( i18n( "Width:" ), m_grp1 ); m_lw->resize( m_lw->tqsizeHint() ); 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->tqsizeHint() ); 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->tqsizeHint() ); 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->tqsizeHint() ); 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->tqlayout()->setSpacing(KDialog::spacingHint()); grp->tqlayout()->setMargin(KDialog::marginHint()); m_prev3 = new KoBorderPreview( grp ); TQVBoxLayout *lay1 = new TQVBoxLayout( grp->tqlayout() ); 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.tqcontains(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.tqcontains(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.tqcontains(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.tqcontains(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->tqrepaint(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"<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(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(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 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(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(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 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.").tqarg(name)); else KMessageBox::sorry( this, i18n( "A frameset with the name '%1' " "already exists. Please enter another name." ).tqarg(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( 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( 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 FramesetSetKeepAspectRatioCommand; if(m_frame) { KWPictureFrameSet * frm=static_cast( 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 (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 :"<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().tqcontains(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 * tqparentFs = fs->groupmanager() ? fs->groupmanager() : fs; // Floating if ( m_floating->isChecked() && m_floating->state() != TQButton::NoChange && !tqparentFs->isFloating() ) { if(!macroCmd) macroCmd = new KMacroCommand( i18n("Make Frameset Inline") ); TQValueList frameindexList; TQValueList frameindexMove; KoPoint oldPos = f->topLeft(); // turn non-floating frame into floating frame KWFrameSetInlineCommand *cmd = new KWFrameSetInlineCommand( TQString(), tqparentFs, 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 && tqparentFs->isFloating() ) { if(!macroCmd) macroCmd = new KMacroCommand( i18n("Make Frameset Non-Inline") ); // turn floating-frame into non-floating frame KWFrameSetInlineCommand *cmd = new KWFrameSetInlineCommand( TQString(), tqparentFs, 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 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().tqcontains(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 tmpBorderList; TQPtrList 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 tmpBorderList; TQPtrList 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 tmpBorderList; TQPtrList 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 tmpBorderList; TQPtrList 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->tqlayout(); m_doc->tqrepaintAllViews(); } 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?").tqarg(fs->name()), i18n("Reconnect Frame"), i18n("&Reconnect")); if (result != KMessageBox::Continue) return false; } return true; } KWFourSideConfigWidget::KWFourSideConfigWidget( KWDocument* doc, const TQString& title, TQWidget* tqparent, const char* name ) : TQGroupBox( title, tqparent, 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("Synchronize changes:
" "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->tqsizeHint() ); 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->tqsizeHint() ); mGrid->addWidget( lmt, 2, 2 ); m_inputTop = new KoUnitDoubleSpinBox( grp2, 0, 9999, 1, 0.0, m_doc->unit() ); //m_inputTop->resize( m_inputTop->tqsizeHint() ); mGrid->addWidget( m_inputTop, 2, 3 ); TQLabel* lmr = new TQLabel( i18n( "Right:" ), grp2 ); //lmr->resize( lmr->tqsizeHint() ); mGrid->addWidget( lmr, 3, 0 ); m_inputRight = new KoUnitDoubleSpinBox( grp2, 0, 9999, 1, 0.0, m_doc->unit() ); //m_inputRight->resize( m_inputRight->tqsizeHint() ); mGrid->addWidget( m_inputRight, 3, 1 ); TQLabel* lmb = new TQLabel( i18n( "Bottom:" ), grp2 ); //lmb->resize( lmb->tqsizeHint() ); mGrid->addWidget( lmb, 3, 2 ); m_inputBottom = new KoUnitDoubleSpinBox( grp2, 0, 9999, 1, 0.0, m_doc->unit() ); //m_inputBottom->resize( m_inputBottom->tqsizeHint() ); 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. */